Select
| Line 6: | Line 6: | ||
| <pre> | <pre> | ||
| − | Select  | + | Select | 
| + | { | ||
|      Case <expression> |      Case <expression> | ||
| + |     { | ||
|          statement1 |          statement1 | ||
|          ... |          ... | ||
| − | + |      } | |
| + |     Case <expression> | ||
| + |     { | ||
|          statement2 |          statement2 | ||
| − |          ... | + |          ... | 
| − | + |      } | |
| + |     Default | ||
| + |     { | ||
|          statementN |          statementN | ||
| − |          ... | + |          ... | 
| − | + |     } | |
| + | } | ||
| </pre> | </pre> | ||
| === Parameters === | === Parameters === | ||
| − | |||
| − | |||
| − | |||
| − | |||
| ==== Case <expression>  ==== | ==== Case <expression>  ==== | ||
| − | + | Optional; You can use none, one or more. | |
| + | |||
| + | If the case is true it will be executed. | ||
| Note - If a Case is lacking a Break then the code will fall through into the next case and execute that and fall through again if theres no break. | Note - If a Case is lacking a Break then the code will fall through into the next case and execute that and fall through again if theres no break. | ||
| + | |||
| + | ==== Default  ==== | ||
| + | |||
| + | Optional; You can use one or none. | ||
| + | |||
| + | If none of the cases are true the code in Default will be executed. | ||
| + | |||
| + | You dont need a Break in the Default. | ||
| === Remarks === | === Remarks === | ||
| Select statements may be nested. | Select statements may be nested. | ||
| + | |||
| + | Strings are case sensitive when used in a case. | ||
| + | |||
| + | A select acts very much like an If statement however it lets you fallthrough if thats useful to you. | ||
| + | |||
| + | The expression can contain the boolean operators of &&, ||, ! as well as the logical operators <, <=, >, >=, ==, !=, <>, eq, eqi, neq and neqi as needed grouped with parentheses as needed. | ||
| === Example === | === Example === | ||
| Line 40: | Line 59: | ||
| <syntaxhighlight lang="sputnik"> | <syntaxhighlight lang="sputnik"> | ||
| − | $var = 1 | + | $var = 1; | 
| − | + | Select | |
| − | Select  | + | { | 
| − |      Case 1 | + |      Case $var == 1: | 
| − |      Case 2 | + |      Case $var == 2: | 
| − | + | 	{ | |
| − | 	break | + |             println("Value is 1 or 2"); | 
| − |      Case 3 | + | 	} | 
| − | + | 	break; | |
| − | 	break | + |      Case $var == 3: | 
| − |      Case "test" | + | 	{ | 
| − | + |             println("Value is 3"); | |
| − | 	break | + | 	} | 
| − |      Default | + | 	break; | 
| − | + |      Case $var != 4: | |
| − | + | 	{ | |
| + |             println("Value is not 4"); | ||
| + | 	} | ||
| + | 	break; | ||
| + |     Case $var == "test": | ||
| + | 	{ | ||
| + |             println("Value is \"test\""); | ||
| + | 	} | ||
| + | 	break; | ||
| + |      Default: | ||
| + | 	{ | ||
| + |             println("No preceding case was true!"); | ||
| + | 	} | ||
| + | } | ||
| + | return 1; | ||
| </syntaxhighlight> | </syntaxhighlight> | ||
| Line 62: | Line 95: | ||
| if $var is 2 it will go into Case 2 run the code and break | if $var is 2 it will go into Case 2 run the code and break | ||
| if $var is 3 it will go into Case 3 run the code and break | if $var is 3 it will go into Case 3 run the code and break | ||
| + | if $var is not 4 it will go into Case 4 run the code and break | ||
| if $var is "test" it will go into Case "test" run the code and break | if $var is "test" it will go into Case "test" run the code and break | ||
| if $var does not match any case at all the code inside Default will be run | if $var does not match any case at all the code inside Default will be run | ||
Revision as of 16:48, 18 November 2011
| Contents | 
Select...Case...Default
Description
Conditionally run statements.
Select
{
    Case <expression>
    {
        statement1
        ...
    }
    Case <expression>
    {
        statement2
        ...
    }
    Default
    {
        statementN
        ...
    }
}
Parameters
Case <expression>
Optional; You can use none, one or more.
If the case is true it will be executed.
Note - If a Case is lacking a Break then the code will fall through into the next case and execute that and fall through again if theres no break.
Default
Optional; You can use one or none.
If none of the cases are true the code in Default will be executed.
You dont need a Break in the Default.
Remarks
Select statements may be nested.
Strings are case sensitive when used in a case.
A select acts very much like an If statement however it lets you fallthrough if thats useful to you.
The expression can contain the boolean operators of &&, ||, ! as well as the logical operators <, <=, >, >=, ==, !=, <>, eq, eqi, neq and neqi as needed grouped with parentheses as needed.
Example
Heres an example with all breaks in proper place (Break statement is needed to tell the code to stop or else it wil fall through into the next case that may be what you want though)
$var = 1; Select { Case $var == 1: Case $var == 2: { println("Value is 1 or 2"); } break; Case $var == 3: { println("Value is 3"); } break; Case $var != 4: { println("Value is not 4"); } break; Case $var == "test": { println("Value is \"test\""); } break; Default: { println("No preceding case was true!"); } } return 1;
In the above example: if $var is 1 it will go into Case 1 then fall through into case 2 run the code and break if $var is 2 it will go into Case 2 run the code and break if $var is 3 it will go into Case 3 run the code and break if $var is not 4 it will go into Case 4 run the code and break if $var is "test" it will go into Case "test" run the code and break if $var does not match any case at all the code inside Default will be run
This means you can in theory place loads of empty Case statements that you want to all fall through.
