⍎ execute

Execute R←⍎Y

Warning

If the argument to execute could include user input, then there is a risk to data and systems. To reduce this risk, a system function might be more appropriate than the execute function. For example:

  • use ⎕VGET or [⎕VSET](../system-functions/vset.md to get or set the value of one or more variables named within one or more character vectors.
  • use ⎕VFI, ⎕JSON, or ⎕CSV to make numbers in text form into actual numbers.
  • use ⎕OR to call a function by name; exact usage depends on valency. For example:
  • niladic – (⎕OR fnName){⍺⍺}
  • monadic – (⎕OR fnName){⍺⍺ ⍵}YY
  • dyadic – X((⎕OR fnName){⍺ ⍺⍺ ⍵})Y

Y must be a simple character scalar or vector containing an APL expression to be executed. The expression may contain one or more sub-expressions separated by (Diamond) characters.

If the result of the expression is used or is assigned to a name, R is the result (if any) of the last-executed sub-expression and the non-shy results of all preceding expressions (that are not assigned within the expression) are displayed. Otherwise the unassigned non-shy results of all of the sub-expressions are displayed.

If the expression is an empty vector or a vector containing only blanks or one that does not produce a result, then ⍎Y has no value and using or assigning it to a name will generate VALUE ERROR.

If Y contains a branch expression, the branch is effected in the environment from which execute was invoked, and ⍎Y does not return.

Examples

      '2+2'
4
      '1+1 ⋄ 2+2'
2
4
      A '1+1 ⋄ 2+2'
2
      A
4
      4=⍎'1+1 ⋄ 2+2'
2
1
      'A←2|¯1↑⎕TS ⋄ →0⍴⍨A ⋄ A'
0
      A
0
      A''
VALUE ERROR: No result was provided when the context expected one
      A''