Control Structures: Difference between revisions
| mNo edit summary | mNo edit summary | ||
| Line 26: | Line 26: | ||
| * <tt>STATEMENT</tt> is a custom sequence of statements. That may be commands, assignments, control structures etc. | * <tt>STATEMENT</tt> is a custom sequence of statements. That may be commands, assignments, control structures etc. | ||
| Example: | '''Example:''' | ||
|   [[if]] (_temperature < 0) [[then]] |   [[if]] (_temperature < 0) [[then]] | ||
| Line 59: | Line 59: | ||
| Since the <tt>if</tt>-statement is itself a [[Statement|statement]], you can also create '''nested <tt>if</tt>-statements'''. | Since the <tt>if</tt>-statement is itself a [[Statement|statement]], you can also create '''nested <tt>if</tt>-statements'''. | ||
| Example: | '''Example:''' | ||
|   if ([[alive]] [[player]]) then |   if ([[alive]] [[player]]) then | ||
| Line 118: | Line 118: | ||
| The structure compares <tt>VARIABLE</tt> against all given values (<tt>VALUE1</tt>, <tt>VALUE2</tt>, ...). If any of the values matches, the corresponding block of statements is executed. | The structure compares <tt>VARIABLE</tt> against all given values (<tt>VALUE1</tt>, <tt>VALUE2</tt>, ...). If any of the values matches, the corresponding block of statements is executed. | ||
| Example: | '''Example:''' | ||
|   switch (_color) do |   switch (_color) do | ||
| Line 185: | Line 185: | ||
| If <tt>CONDITION</tt> is <tt>false</tt> from the beginning on, the statements within the block of the loop will never be executed. | If <tt>CONDITION</tt> is <tt>false</tt> from the beginning on, the statements within the block of the loop will never be executed. | ||
| Example: | '''Example:''' | ||
|   _counter = 0; |   _counter = 0; | ||
| Line 219: | Line 219: | ||
| If <tt>CONDITION</tt> is <tt>false</tt> from the beginning on, the code block will never be executed. | If <tt>CONDITION</tt> is <tt>false</tt> from the beginning on, the code block will never be executed. | ||
| Example: | '''Example:''' | ||
|   // a loop repeating 10 times |   // a loop repeating 10 times | ||
| Line 240: | Line 240: | ||
|   9 |   9 | ||
| Description: | '''Description:''' | ||
| # The variable <tt>_i</tt> is set to 0 | # The variable <tt>_i</tt> is set to 0 | ||
| Line 272: | Line 272: | ||
| The following example is semantically equal to the last example. | The following example is semantically equal to the last example. | ||
| Example: | '''Example:''' | ||
|   // a loop repeating 10 times |   // a loop repeating 10 times | ||
| Line 303: | Line 303: | ||
| You may use the [[Magic Variables|magic variable]] <tt>_x</tt> within the code block, which always references to the current item of the array. | You may use the [[Magic Variables|magic variable]] <tt>_x</tt> within the code block, which always references to the current item of the array. | ||
| Example: | '''Example:''' | ||
|   _array = [unit1, unit2, unit3]; |   _array = [unit1, unit2, unit3]; | ||
| Line 312: | Line 312: | ||
|   forEach _array; |   forEach _array; | ||
| Description: | '''Description:''' | ||
| # In the first loop, the statement <tt>unit1 setDamage 1;</tt> is executed | # In the first loop, the statement <tt>unit1 setDamage 1;</tt> is executed | ||
Revision as of 17:01, 22 December 2006
Control Structures are special statements. They are sequences of scripting code which help to control complex procedures. You can use control structures to define code which is only executed under certain conditions or repeated for a couple of times.
Requirements
To fully understand this article you should read the following articles:
Conditional Structures
Conditional structures help to define code which is only executed under certain circumstances. Often you will write code that depends on the game state, on other code or other conditions.
if-Statement
The if-statement defines code that is only executed if a certain condition is met. The syntax of it looks like that:
if (CONDITION) then
{
    STATEMENT;
    ...
}
- CONDITION is a Boolean statement or variable which returns either true or false. The code nested in the following block is only executed if the condition is true, else ignored.
- STATEMENT is a custom sequence of statements. That may be commands, assignments, control structures etc.
Example:
if (_temperature < 0) then { hint "Snow!"; }
In this example, first the value of _temperature is checked:
- If the value is greater than 0, the nested code is ignored.
- If the value is 0 or less than 0, the command hint "Snow!"; is executed.
Alternative Code
You can also define alternative code that is executed, when the condition is not true.
if (CONDITION) then
{
    STATEMENT;
    ...
}
else
{
    STATEMENT;
    ...
}
Here you have a second statement executed when CONDITION is false.
Nested if-Statements
Since the if-statement is itself a statement, you can also create nested if-statements.
Example:
if (alive player) then { if (someAmmo player) then { hint "The player is alive and has ammo!"; } else { hint "The player is out of ammo!"; } } else { hint "The player is dead!"; }
switch-Statement
(Armed Assault only)
In some cases you may want to check a variable for several values and execute different code depending on the value. With the above knowledge you could just write a sequence of if-statements.
if (_color == "blue") then
{
    hint "What a nice color";
}
else
{
    if (_color == "red") then
    {
        hint "Don't you get aggressive?";
    }
}
The more values you want to compare, the longer gets this sequence. That is why the simplified switch-statement was introduced.
The switch-statement compares a variable against different values:
switch (VARIABLE) do
{
    case VALUE1:
    {
        STATEMENT;
        ...
    };
    case VALUE2:
    {
        STATEMENT;
        ...
    };
    ...
}
The structure compares VARIABLE against all given values (VALUE1, VALUE2, ...). If any of the values matches, the corresponding block of statements is executed.
Example:
switch (_color) do
{
    case "blue":
    {
        hint "What a nice color";
    };
    case "red":
    {
        hint "Don't you get aggressive?";
    };
}
default-Block
In some cases you may want to define alternative code that is executed, when none of the values matches. You can write this code in a default-Block.
switch (VARIABLE) do
{
    case VALUE1:
    {
        STATEMENT;
        ...
    };
    case VALUE2:
    {
        STATEMENT;
        ...
    };
    ...
    default:
    {
        STATEMENT;
        ...
    };
}
Loops
Loops are used to execute the same code block for a specific or unspecific number of times.
Limitations
Any loop may repeat at maximum 10 000 times. Then it is aborted an an error message is drawn.
while-Loop
This loop repeats the same code block as long as a given Boolean condition is true.
while {CONDITION} do
{
    STATEMENT;
    ...
}
Note the curled braces for the condition. The loop processes as follow:
- CONDITION is evaluated. If it is true, go on to 2., else skip the block and go on with the code following the loop.
- Execution of all nested statements. Go back to 1.
If CONDITION is false from the beginning on, the statements within the block of the loop will never be executed.
Example:
_counter = 0;
while {_counter < 10} do
{
    _counter = _counter + 1;
}
for-Loop
(Armed Assault only)
The for-loop repeats the same code block for a specific number of times.
for [{BEGIN}, {CONDITION}, {STEP}] do
{
    STATEMENT;
    ...
}
- BEGIN is a number of statements executed before the loop starts
- CONDITION is a Boolean condition evaluated before each loop
- STEP is a number of statements executed after each loop
The loop processes as follows:
- BEGIN is executed
- CONDITION is evaluated. If it is true, go on to 3., else skip the block and go on with the code following the loop.
- The statements in the code block are executed
- STEP is executed, go on to 2.
If CONDITION is false from the beginning on, the code block will never be executed.
Example:
// a loop repeating 10 times
for [{_i=0}, {_i<10}, {_i=_i+1}] do
{
    player globalChat _i;
}
will display
0 1 2 3 4 5 6 7 8 9
Description:
- The variable _i is set to 0
- The condition _i<10 is evaluated, which is true until _i surpasses 9.
- The code player globalChat _i; is executed
- The variable _i is incremented by 1, back to step 2.
for-from-to-Loop
There exists an alternate syntax of the for-loop, which simplifies the last example a bit.
for "VARNAME" from STARTVALUE to ENDVALUE do
{
    STATEMENT;
    ...
}
- VARNAME is any name given to the variable used to count the loop
- STARTVALUE is a Number value given to the counter variable before the loop starts
- ENDVALUE is a Number value until which the counter is incremented/decremented
The loop processes as follows:
- A variable with the name VARNAME is initialized with STARTVALUE
- If VARNAME is not equal to ENDVALUE, the code block is executed
- 
- If ENDVALUE is greater than STARTVALUE, the variable VARNAME is incremented by 1
- If ENDVALUE is less than STARTVALUE, the variable VARNAME is decremented by 1
 
- Go back to step 2
The following example is semantically equal to the last example.
Example:
// a loop repeating 10 times
for "_i" from 0 to 9 do
{
    player globalChat _i;
}
forEach-Loop
You will often use the for-loop to increment over arrays.
_array = [unit1, unit2, unit3];
for [{_i=0}, {_i < count _array}, {_i=_i+1}] do
{
    (_array select _i) setDamage 1;
}
The forEach-loop does exactly that: It repeats the same code block for every item in an array.
{
    STATEMENT;
    ...
}
forEach ARRAY;
The code block is executed exactly (count ARRAY) times.
You may use the magic variable _x within the code block, which always references to the current item of the array.
Example:
_array = [unit1, unit2, unit3];
{
    _x setDamage 1;
}
forEach _array;
Description:
- In the first loop, the statement unit1 setDamage 1; is executed
- In the second loop, the statement unit2 setDamage 1; is executed
- In the third loop, the statement unit3 setDamage 1; is executed
Return Values
Control structures always return the last expression executed within the structure. Note that there must not be a semicolon (;) after this value, otherwise Nothing is returned.
Example:
if (myCondition) then {myValueA} else {myValueB}
=> returns myValueA or myValueB
