Button for 1977 Button for 1984 Button for 1990 Button for 1995 Button for MDC Button for notes Button for examples

FOR

1990 Version of ANSI Standard

2.6.5 For

For

[ SP ]
SP lvn = forparameter


See 2.2.2.1 for the definition of lvn. See section 1 for the definition of L.

    forparameter::=


expr
numexpr1 : numexpr2 : numexpr3
numexpr1 : numexpr2



See 2.3 for the definition of expr. See 2.2.4 for the definition of numexpr.

The scope of this For command begins at the next command following this For on the same line and ends just prior to the eol on this line.

The For with arguments 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, 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 temporaries.)

  1. If the forparameter is of the form expr1.
    1. Set lvn = expr.
    2. Execute the commands in the scope once.
    3. Processing of this forparameter is complete.
  2. If the forparameter is of the form numexpr1 : numexpr2 : numexpr3
    and numexpr2 is nonnegative.
    1. Set A = numexpr1.
    2. Set B = numexpr2.
    3. Set C = numexpr3.
    4. Set lvn = A.
    5. If lvn > C, processing of this forparameter is complete.
    6. Execute the commands in the scope once; an undefined value for lvn is erroneous.
    7. If lvn > C-B, processing of this forparameter is complete.
    8. Otherwise, set lvn = lvn + B.
    9. Go to 6.
  3. If the forparameter is of the form numexpr1 : numexpr2 : numexpr3
    and numexpr2 is negative.
    1. Set A = numexpr1.
    2. Set B = numexpr2.
    3. Set C = numexpr3.
    4. Set lvn = A.
    5. If lvn < C, processing of this forparameter is complete.
    6. Execute the commands in the scope once; an undefined value for lvn is erroneous.
    7. If lvn < C-B, processing of this forparameter is complete.
    8. Otherwise, set lvn = lvn + B.
    9. Go to 6.
  4. If the forparameter is of the form numexpr1 : numexpr2.
    1. Set A = numexpr1.
    2. Set B = numexpr2.
    3. Set lvn = A.
    4. Execute the commands in the scope once; an undefined value for lvn is erroneous.
    5. Set lvn = lvn + B.
    6. Go to 4.

If the For command has no argument.

  1. Execute the commands in the scope once; since no lvn has been specified, it cannot be referenced.
  2. Goto 1.

Note that form d. and the argumentless For, specify endless loops. Termination of these loops must occur by execution of a Quit or Goto within the scope of the For. These two termination methods are available within the scope of a For independent of the form of forparameter currently in control of the execution of the scope; 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 (the outer For) contains an inner For, one execution of the scope of commands of the outer For encompasses all executions of the scope of commands of the inner For corresponding to one complete pass through the inner For command’s forparameter list.

Execution of a Quit within the scope of a For has two effects.

  1. It terminates that particular execution of the scope at the Quit; commands to the right of the Quit are not executed.
  2. It causes any remaining values of the forparameter in control at the time of execution of the Quit, and the remainder of the forparameters in the same forparameter list, not to be calculated and the commands in the scope not to be executed under their control.

In other words, execution of Quit effects the immediate termination of the innermost For whose scope contains the Quit.

Execution of Goto effects the immediate termination of all For commands in the line containing the Goto, and it transfers execution control to the point specified. Note that the execution of a Quit within the scope of a For does not affect the variable environment, e.g., stacked New frames are not removed or processed.

Button for 1977 Button for 1984 Button for 1990 Button for 1995 Button for MDC Button for notes Button for examples

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.

This page most recently updated on 09-Jan-2024, 15:14:56.

For comments, contact Ed de Moel (demoel@jacquardsystems.com)