Select

From Sputnik Wiki
(Difference between revisions)
Jump to: navigation, search
Line 6: Line 6:
  
 
<pre>
 
<pre>
Select <expression>
+
Select
 +
{
 
     Case <expression>
 
     Case <expression>
 +
    {
 
         statement1
 
         statement1
 
         ...
 
         ...
     [Case <expression>
+
     }
 +
    Case <expression>
 +
    {
 
         statement2
 
         statement2
         ...]
+
         ...
     [Default
+
     }
 +
    Default
 +
    {
 
         statementN
 
         statementN
         ...]
+
         ...
EndSelect
+
    }
 +
}
 
</pre>
 
</pre>
  
 
=== Parameters ===
 
=== Parameters ===
 
==== Switch <expression>  ====
 
 
Any vaid expression to used and compared with the Case <expressions>
 
  
 
==== Case <expression>  ====
 
==== Case <expression>  ====
  
If the expression matches the Switch <expression> the following statements up to the next Case or EndSelect statement are executed. If more than one of the Case statements are true, only the first one is executed.
+
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 $var
+
{
     Case 1
+
     Case $var == 1:
     Case 2
+
     Case $var == 2:
        println("Value is 1 or 2")
+
{
break
+
            println("Value is 1 or 2");
     Case 3
+
}
        println("Value is 3")
+
break;
break
+
     Case $var == 3:
     Case "test"
+
{
        println("Value is \"test\"")
+
            println("Value is 3");
break
+
}
     Default
+
break;
        println("No preceding case was true!")
+
     Case $var != 4:
EndSelect
+
{
 +
            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.

Personal tools
Namespaces
Variants
Actions
Navigation
Toolbox