Programmer Guide/Command Reference/SHELL: Difference between revisions

From STX Wiki
Jump to navigationJump to search
No edit summary
No edit summary
 
(11 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{DISPLAYTITLE:{{SUBPAGENAME}}}}
{{DISPLAYTITLE:{{SUBPAGENAME}}}}
  SHELL <var>macroname macroarguments</var>
{{Shell}}
  SHELL <var>macroname</var> <var>macroarguments</var>


The <code>SHELL</code> command starts a new {{STX}} shell (i.e., a new {{STX}} command interpreter) to run the macro <var>macroname</var>.
The <code>SHELL</code> command starts a new {{STX}} shell (i.e., a new {{STx}} command interpreter) to execute the subroutine <var>macroname</var>. Hence, your subroutine will start its existence in a clean execution environment, without any local variables set. It will, differently put, be unable to access the local and the shell variables of the caller. Much less will it be able to alter them (for a different behaviour, see below, or directly refer to the {{Stx}} statements <code>[[Programmer_Guide/Command_Reference/MACRO|MACRO]]</code>, and <code>[[Programmer_Guide/Command_Reference/MACROX|MACROX]]</code>).


The macro source code <var>macroname</var> must be loaded (see <code>[[User Guide/Workspace/Pre-configured profiles|LOAD]]</code>)The <var>macroarguments</var> passed to the macro are stored in the variable <code>#ARGV</code> of the called macro. Because of the special command-line processing in {{STX}}, all string replacements are applied to and all special parsing information (e.g. quotation marks) are removed from <var>macroarguments</var> before it is assigned to <code>#ARGV</code>.
The macro source code <var>macroname</var> must be loaded (see the <code>[[../LOAD/]]</code> command). The <var>macroarguments</var> passed to the macro are stored in the variable <code>#ARGV</code> of the called macro. Because of the special command-line processing in {{STX}}, all string replacements are applied to, and all special parsing information (e.g. quotation marks) are removed from, <var>macroarguments</var> before it is assigned to <code>#ARGV</code>. For more information on argument passing, and parsing, see [[Programmer_Guide/Concepts/Argument_Passing|Argument Passing]]. For a broader information on macro programming, see [[XXX|Script Programming in {{STx}}]]. And since this is a dead link, I have searched the {{STX}} documentation for any article that may fit this description, and found the following:
* [[Programmer_Guide/Programming|Programming:]]  It's only a stub, so don't bother with it.
* [[Programmer_Guide/Introduction|Introduction:]] This seems more helpful, though a bit outdated and fragmentary.
* [[Programmer_Guide/STx_Guru|Becoming an {{Stx}} guru:]] This is probably the way to go if you are ''really'' new to {{STX}}. It is a longish beginner's handbook on {{Stx}} programming.


For information about macro definitions (header) and argument parsing see the [[XXX|Script Programming in {{STX}}]]. Many macros use the call-format: name command arguments (e.g. <code>MSGBOX MSG text</code>). If you want to pass quoted arguments to such a macro, use the format <code>MSGBOX 'MSG text'</code> instead of <code>MSGBOX MSG 'text'</code>. This is necessary because the argument string <code>MSG 'text'</code> is passed (after command-line processing) as <code>MSGtext</code> to the macro.If a new shell is called to run a macro, the id (8 hex digits) is assigned to the variable <code>#SHELL</code> of the caller. In the new shell, the variable <code>SHELL</code> is set to '<code>this_shellid caller_shellid</code>'. The two variables can be used to identify the shells in communication messages.It is not necessary to use the command <code>MACRO</code> explicitly, because the interpreter tries to execute all 'non-shell' commands as a macro. This means the command line <code>MACRO macroname</code> is equivalent to command line <code>macroname</code>.
If you want your subroutine to be able to access the environment of the caller, there is the <code>[[Programmer_Guide/Command_Reference/MACRO|MACRO]]</code> command for executing the subroutine in a ''copy'' of the calling environment, and even the <code>[[Programmer_Guide/Command_Reference/MACROX|MACROX]]</code> command for dangerously executing the subroutine directly within the caller's environment.
 
==Example==
// Load a source file and start one of the macros
load sourcecode scripts\examples\shellexample.sts
shell shellexample

Latest revision as of 08:23, 15 March 2018

SHELL macroname macroarguments

The SHELL command starts a new STx shell (i.e., a new STx command interpreter) to execute the subroutine macroname. Hence, your subroutine will start its existence in a clean execution environment, without any local variables set. It will, differently put, be unable to access the local and the shell variables of the caller. Much less will it be able to alter them (for a different behaviour, see below, or directly refer to the STx statements MACRO, and MACROX).

The macro source code macroname must be loaded (see the LOAD command). The macroarguments passed to the macro are stored in the variable #ARGV of the called macro. Because of the special command-line processing in STx, all string replacements are applied to, and all special parsing information (e.g. quotation marks) are removed from, macroarguments before it is assigned to #ARGV. For more information on argument passing, and parsing, see Argument Passing. For a broader information on macro programming, see Script Programming in STx. And since this is a dead link, I have searched the STx documentation for any article that may fit this description, and found the following:

  • Programming: It's only a stub, so don't bother with it.
  • Introduction: This seems more helpful, though a bit outdated and fragmentary.
  • Becoming an STx guru: This is probably the way to go if you are really new to STx. It is a longish beginner's handbook on STx programming.

If you want your subroutine to be able to access the environment of the caller, there is the MACRO command for executing the subroutine in a copy of the calling environment, and even the MACROX command for dangerously executing the subroutine directly within the caller's environment.

Example

// Load a source file and start one of the macros
load sourcecode scripts\examples\shellexample.sts
shell shellexample

Navigation menu

Personal tools