Programmer Guide/Command Reference/IF: Difference between revisions

From STX Wiki
Jump to navigationJump to search
No edit summary
No edit summary
 
(8 intermediate revisions by 2 users not shown)
Line 2: Line 2:
There are two forms of the <code>IF</code> syntax. The first allows the conditional execution of one command:
There are two forms of the <code>IF</code> syntax. The first allows the conditional execution of one command:


  IF <var>[[Programmer_Guide/Command_Reference_Intro/Conditional_Expressions|condition]]</var> singlecommand
  IF [[Programmer_Guide/Concepts/Conditional_Expressions|<var>condition</var>]] singlecommand
  IFNOT <var>condition</var> singlecommand
 
  IFNOT [[Programmer_Guide/Concepts/Conditional_Expressions|<var>condition</var>]] singlecommand
 
The second allows conditional execution of multiple commands within a block:
The second allows conditional execution of multiple commands within a block:
  IF <var>[[Programmer_Guide/Command_Reference_Intro/Conditional_Expressions|condition<sub>1</sub>]]</var> THEN
 
     ...
  IF <var>[[Programmer_Guide/Concepts/Conditional_Expressions|condition<sub>1</sub>]]</var> THEN
  ELSE IF <var>condition<sub>2</sub></var> THEN
     &hellip;
     ...
  ELSE IF <var>[[Programmer_Guide/Concepts/Conditional_Expressions|condition<sub>2</sub>]]</var> THEN
  ELSE IFNOT <var>condition<sub>n</sub></var> THEN
     &hellip;
     ...
  ELSE IFNOT <var>[[Programmer_Guide/Concepts/Conditional_Expressions|condition<sub>n</sub>]]</var> THEN
     &hellip;
  ELSE
  ELSE
     ...
     &hellip;
  END
  END
Note that only <code>IF</code> clause mandatory, all other clauses are optional. Both command forms <code>IF</code> and <code>IFNOT</code> can be used. Empty clauses (i.e., clauses without commands) are allowed. The last clause must be closed with an <code>[[Programmer Guide/Command Reference/END|END]]</code> statement. For more information on conditions see [[Programmer_Guide/Command_Reference_Intro/Conditional_Expressions|Conditional Expressions]].
 
Note that only the <code>IF</code> clause is mandatory, all other clauses are optional. Empty clauses (i.e., clauses without commands) are allowed. The last clause must be closed with an <code>[[Programmer Guide/Command Reference/END|END]]</code> statement. For more information on conditions see [[Programmer_Guide/Concepts/Conditional_Expressions|Conditional Expressions]].
 
Neither the [[Programmer_Guide/Concepts/Conditional_Expressions|<var>condition</var>]] nor the <code>singlecommand</code> should contain the string <code>THEN</code>. If either does, in most cases {{STx}} will amazingly mistake the whole command for an ill-formed <code>IF</code> &hellip; <code>THEN</code> &hellip; <code>END</code> block.

Latest revision as of 15:42, 25 April 2014

There are two forms of the IF syntax. The first allows the conditional execution of one command:

IF condition singlecommand
IFNOT condition singlecommand

The second allows conditional execution of multiple commands within a block:

IF condition1 THEN
   …
ELSE IF condition2 THEN
   …
ELSE IFNOT conditionn THEN
   …
ELSE
   …
END

Note that only the IF clause is mandatory, all other clauses are optional. Empty clauses (i.e., clauses without commands) are allowed. The last clause must be closed with an END statement. For more information on conditions see Conditional Expressions.

Neither the condition nor the singlecommand should contain the string THEN. If either does, in most cases STx will amazingly mistake the whole command for an ill-formed IFTHENEND block.

Navigation menu

Personal tools