Difference between revisions of "If"
Jump to navigation
Jump to search
Search JIRA for related Issues
(Added caveat about short circuiting) |
(Added examples & cautionary notes.) |
||
Line 37: | Line 37: | ||
} | } | ||
</pre> | </pre> | ||
|examples | |examples=Simple inline if statement: | ||
<pre> | |||
if (a == 1) c = b; | |||
</pre> | |||
Simple block if statement: | |||
<pre> | |||
if (a == 1) | |||
{ | |||
// Do something here. | |||
} | |||
</pre> | |||
Compounded if statement: | |||
<pre> | |||
if (a == 1 && b == c) | |||
{ | |||
// more here. | |||
} | |||
</pre> | |||
Nested if statements: | |||
<pre> | |||
if (a == 1) | |||
{ | |||
if (b == c) | |||
{ | |||
// more here. | |||
} | |||
} | |||
</pre> | |||
|helpers | |helpers | ||
|also_header | |also_header | ||
Line 44: | Line 71: | ||
|also_articles | |also_articles | ||
|also_footer | |also_footer | ||
|notes | |notes=Watch out for misplaced semicolons. They can, and will, cause strange things to happen. | ||
For instance: If you place a semicolon between an if statement and a code block, the if statement will not control the execution of the block. | |||
<pre> | |||
if (a == "Loren"); | |||
{ | |||
llSay(0, "Lorem ipsum sic amet!"); | |||
} | |||
</pre> | |||
This code will execute in the following order: | |||
# The line <code>if (a == "Loren");</code> will execute; the semicolon will tell LSL that this is a simple inline if statement. | |||
# Next it meets the start of the code block and will execute the contents, in this case saying "Lorem ipsum sic amet!", no matter what the outcome of the above if statement. | |||
---- | |||
Another problem happens when someone forgets to use the curly braces. | |||
<pre> | |||
if (a == "Loren") | |||
llSay(0, "Lorem ipsum sic amet!"); | |||
llSay(0, "I don't know what it means either..."); | |||
</pre> | |||
The assumption is that because the indentation makes it "look" like both llSay commands are controlled by the if statement, that they are. In fact, if <code>a</code> was equal to "Joe" then all that would be said is "I don't know what it means either..." | |||
|mode | |mode | ||
|deprecated | |deprecated |
Revision as of 23:43, 5 March 2007
LSL Portal | Functions | Events | Types | Operators | Constants | Flow Control | Script Library | Categorized Library | Tutorials |
if( condition ) branch
• | condition | – | If this executes as true then branch is executed. | |
• | branch | – | Can be either a single statement, a block statement, or a null statement. |
Specification
Type | Condition |
---|---|
integer | True if it is not zero. |
float | True if it is not zero.[1] |
string | True if its length is not zero. |
key | True only if it is a valid key and not NULL_KEY. |
vector | True if the vector is not ZERO_VECTOR. |
rotation | True if the rotation is not ZERO_ROTATION. |
list | True if the length is not zero. Note that correct behavior is only seen with Mono-compiled scripts; LSO-compiled scripts incorrectly resolve to false if the list is non-empty: BUG-230728 |
Examples
Simple inline if statement:
if (a == 1) c = b;
Simple block if statement:
if (a == 1) { // Do something here. }
Compounded if statement:
if (a == 1 && b == c) { // more here. }
Nested if statements:
if (a == 1) { if (b == c) { // more here. } }
Notes
Watch out for misplaced semicolons. They can, and will, cause strange things to happen. For instance: If you place a semicolon between an if statement and a code block, the if statement will not control the execution of the block.
if (a == "Loren"); { llSay(0, "Lorem ipsum sic amet!"); }
This code will execute in the following order:
- The line
if (a == "Loren");
will execute; the semicolon will tell LSL that this is a simple inline if statement. - Next it meets the start of the code block and will execute the contents, in this case saying "Lorem ipsum sic amet!", no matter what the outcome of the above if statement.
Another problem happens when someone forgets to use the curly braces.
if (a == "Loren") llSay(0, "Lorem ipsum sic amet!"); llSay(0, "I don't know what it means either...");
The assumption is that because the indentation makes it "look" like both llSay commands are controlled by the if statement, that they are. In fact, if a
was equal to "Joe" then all that would be said is "I don't know what it means either..."
Deep Notes
Footnotes
- ^ The OpenSim LSL compiler will not do this implicitly. You will need to use an explicit check.