I have REXX code that can be called directly by TSO (in DD SYSTSIN data) or else by another REXX function. I want it to behave differently in each case:
- If called directly from TSO I want it to print something.
- If called from another function I want it to return some values to the calling function.
So I thought about how to do this. The answer’s quite simple: Use the parse source command and examine the second word returned.
Here’s a simple example, the function
/* REXX myfunc */
parse source . envt .
if envt="COMMAND" then do
/* Called from top level command */
say x y
/* Called from procedure or function */
return x y
interpret command is a fancy way of assigning two variables (and really a leftover from another test). It works but you would normally code
parse source command returns a number of words but it’s the second one that is of interest - and is saved in the variable
The following lines test whether
envt has the value “COMMAND” or not. If so the function’s been called directly from TSO. If not it hasn’t.
In the one case the variable values are printed. In the other they’re returned to the calling routine.
The calling routine might call have a line similar to
parse value myfunc() with x y
Which would unpack the two variables.
interpret "x=1;y=2" might look silly but
interpret "x='1 first';y='2 second'" doesn’t - as a way of passing strings with arbitrary spaces in them back from a routine.)
This is a simplified version of something I want to do in my own code. There might be a few people who will find this useful so why keep it to myself?
(It’s probably a standard technique nobody taught me.)