CALL |
Transfer to Subprogram |
CALL subprog$[;entry$][,ERR=stmtref][,arglist...][WITH variable=expression, ...]
Where:
subprog$ |
Name of the subprogram to call. Maximum string size 8kb. |
;entry$ |
Name of starting statement label to use as entry point in the subprogram. Optional. Maximum string size 8kb. If included, use a leading ; (semi-colon) and add it to the subprog$ string expression. |
stmtref |
Program line number or statement label to which to transfer control. |
arglist... |
Comma-separated list of variables, literals or expressions. |
variable |
Can either be a numeric or string variable that will be initialized with the value from the expression prior execution of the called program. |
(The WITH clause was added in PxPlus 2021.)
Use the CALL directive to transfer control to a subprogram. The current program state is saved and the specified subprogram is loaded and executed. If you use arguments, they are received in the called subprogram for its use via the ENTER directive.
The called program should terminate with an EXIT, which may be replaced by an END or STOP.
Normally, the total number of arguments in the CALL and ENTER statements must match. Each argument in the CALL statement must correspond in relative position and in type (numeric or string) to a variable in the ENTER statement. If you use a shorter list of arguments in a CALL statement than in the ENTER statement, make sure to maintain relative position and type up to the point where you shorten the list (and include error handling options). Otherwise, the following error will occur: Error #36: ENTER parameters don't match those of the CALL.
You can protect a simple variable in a CALL or ENTER statement by placing it inside parentheses. This turns the variable into an expression, which has the effect of making it read only:
call "PROG",(A$)
IOLists can also be used as arguments for CALL statements:
call "PROG",iol=8000
Pass a complete array to a subprogram by specifying the array name followed by {ALL}. In this case, all values are passed to the subprogram and any changes made are returned to the calling program. See Called Procedures.
String templates cannot be passed if they are defined prior to the ENTER statement in the called program.
To pass an array as a read-only copy, surround the array specification with parentheses on either the CALL or ENTER directive:
call "someprog",(X${all}) ! Passes copy of the array
enter (X${all}) ! Loads copy of array regardless of CALL
(Support for passing an array as a read-only copy was added in PxPlus 2019.)
This directive also has an optional feature you will find useful for applications like subprogram "libraries" (with multiple stand-alone routines, each accessed by a statement label). To use this form of access, append a ; (semi-colon) plus the label name of the starting statement to the subprogram name:
call "PROG;STARTING_LABEL",err=1000,X$,A,CT$
After the called subprogram is loaded, the system internally issues a GOTO STARTING_LABEL (e.g.) directive and starts execution there. Use this to create a single subprogram with multiple entry points and ENTER directives.
In addition, PxPlus allows the specification of a line number instead of a label. To specify a line number, the entry point must consist of a # (pound sign) followed by the line number:
call "ProgABC;#1000" (would start execution at statement 1000 in ProgABC)
(Specification of a line number was added in PxPlus v7.10, build 9170.)
CALL and ENTER from ASCII Programs
When you run programs from ASCII text files, the CALL and ENTER with no arguments will always fail because the system thinks that the variables have already been assigned. To work around this, use the PERFORM directive or save the called program in a program file.
ENTER Specify Arguments
PERFORM Call Subprogram, Pass Variables
END Halt Execution of Program
EXIT Terminate Subprogram and Return
STOP Halt Program Execution
0020 call "ABCDEF",err=0050,A,4*F,Z$,X$(4,5),(Q)
In ABCDEF:
0030 enter Z,X,A$,B$,V$
Z will receive the value of A – A will reflect changes in Z.
X will receive the value of 4*F.
A$ will receive the value of Z$ – Z$ will reflect changes in A$.
B$ will receive the string from X$(4,5), which will not change.
V$ will receive Q$ but Q$ cannot be changed.