☜ | FORDraft MDC Standard | ☞ |
For | │ │ │ |
[ SP ] SP lvn = forparameter |
│ │ │ |
forparameter | ::= | │ │ │ │ |
expr numexpr1 : numexpr2 : numexpr3 numexpr1 : numexpr2 |
│ │ │ │ |
The scope of the For command begins at the next command following the For on the same line and ends just prior to the eol on this line.
The For command with an argument specifies repeated execution of the commands within its scope for different values of the local variable lvn, under successive control of the forparameters, from left to right. Any expressions occurring in lvn, such as might occur in subscripts or indirection, are evaluated once per execution of the For command, prior to the first execution of any forparameter.
For each forparameter, control of the execution of the commands in the scope is specified as follows. (Note that A, B, and C are hidden temporary variables.)
If the For command has no argument:
Note that form d. and the argumentless form specify endless loops. Termination of these loops must occur by execution of a Quit or Goto command within the scope of the For command. These two termination methods are available within the scope of a For command independent of the form of forparameter currently in control of the execution of the scope of the For command; they are described below. Note also that no forparameter to the right of one of form d. can be executed.
Note that if the scope of a For command (the outer For command) contains an inner For command, one execution of the scope of commands of the outer For command encompasses all executions of the scope of commands of the inner For command, corresponding to one complete pass through the inner For command’s forparameter list.
Execution of a Quit command within the scope of a For command has two effects.
In other words, execution of a Quit command causes the immediate termination of the innermost For command whose scope contains that Quit command.
Execution of an argumented Quit command within the scope of a For command causes an error condition with an ecode = "M16".
Execution of a Goto command causes the immediate termination of all For commands in the line containing the Goto command, and it transfers execution control to the point specified. Note that the execution of an argumentless Quit command within the scope of a For command does not affect the local variable environment.
Copyright © Standard Documents; 1977-2024 MUMPS Development Committee;
Copyright © Examples: 1995-2024 Ed de Moel;
Copyright © Annotations: 2003-2008 Jacquard Systems Research
Copyright © Annotations: 2008-2024 Ed de Moel.
Some specifications are "approved for inclusion in a future standard". Note that the MUMPS Development Committee cannot guarantee that such future standards will indeed be published.
This page most recently updated on 09-Jan-2024, 15:14:56.
For comments, contact Ed de Moel (demoel@jacquardsystems.com)