SUBMIT

Revised/reviewed January 2012

xcall SUBMIT, pid, stdin, stdout, stderr, executable, arg1, arg2 {,...argn}

(UNIX only) SUBMIT.SBR allows you to execute an arbitrary command (executable and arguments) as a child process of the current A-Shell process. It is similar to HOSTEX, but implemented using the lower level fork() / exec() sequence, rather than the higher level system() call used by HOSTEX. The lower level implementation provides some additional flexibility, which is mainly of use to SUBMIT.LIT, and thus is primarily of interest as an internal routine.

Parameters

Parameter

Type

I/O

Description

pid

Num

out

returns the process id number (pid) of the child process created to run the command. (Note that such pids can be larger than 64K in most modern UNIX implementation, thus B,2 is not a good choice.)

stdin

String

in

must specify the filespec (AMOS-style or native) of a file containing the input to be forced to the process (aka the "control file"). This is typically similar to a CMD file, but may contain raw keyboard characters as well as commands, and should start with a LOG command.

stdout,
 stderr

String

in

must specify the filespecs of files to which the standard and error output of the process will be sent. To mimic the AMOS log file behavior, set them both to the same name (typically with an extension of LOG and a base name either matching the control file or the job name).

executable

String

 

filespec of an executable which the child process will be forced to run. (In the case of SUBMIT.LIT, this is always "ashell", but could in theory be anything.) Normal operating system search path rules apply if the filespec doesn't specify a path.

arg1,
arg2, ...
argn

String

in

optional arguments to the executable. (Each parameter should contain just a single argument, with no embedded spaces unless the argument is quoted. For example, in the case of the ashell executable, the ini file name would actually occupy two arg parameters, one for "-i" and one for the miame.ini filespec.)

 

Example

xcall SUBMIT, RC, "CMD:TEST.CTL", "TEST.LOG", "TEST.LOG", "ashell", "-i", "/vm/miame/miame.ini"

Comments

Child processes launched this way are generally dependent on the parent process to continue running for the duration of the child process. To launch a child/background process independent of the current process, use SUBMIT.LIT with the /NEXT: or /AFTER: switch.

See Also

• The system parameter SBR option SUBMIT2 for related information.