Difference between revisions of "For"
(Updated examples.) |
|||
(17 intermediate revisions by 9 users not shown) | |||
Line 1: | Line 1: | ||
{{ | {{LSL_Conditional | ||
| | |statement=for | ||
| | |statement_header | ||
| | |statement_desc=Only the condition is required. The initializer, increment, and loop body are optional and can be left empty. | ||
| | |statement_end=loop | ||
| | |statement_end_desc=Can be either a single statement, a block statement, or a null statement. | ||
|p1_name=initializer|p1_desc=Executed once just before checking '''condition'''. | |||
|p2_name=condition|p2_desc=If this executes as true then '''loop''' is executed. | |||
|p1_name=initializer|p1_desc=Executed before | |p3_name=increment|p3_desc=Executed after '''loop''', then '''condition''' is checked again. | ||
|p2_name=condition|p2_desc=If this executes as true then ''' | |||
|p3_name=increment|p3_desc= | |||
|constants | |constants | ||
|spec | |spec | ||
|caveats | |caveats | ||
|examples | |examples= | ||
The following is the most common way a for-loop is written, with each part properly specified. | |||
The loop will run or "iterate" 10 times, from 0 to 9. It will execute two statements each iteration. | |||
<source lang="lsl2"> | |||
integer a = 0; | |||
integer b = 10; | |||
for (a = 0; a < b; ++a) | |||
{ | |||
llOwnerSay( (string)a ); // first statement | |||
llOwnerSay( (string)b ); // second statement | |||
} | |||
</source> | |||
The following is less common, where the curly braces are left out. | |||
This can be used when only one statement needs to be executed during the loop. | |||
<source lang="lsl2"> | |||
integer a = 0; | |||
integer b = 10; | |||
for (a = 0; a < b; ++a) | |||
llOwnerSay( (string)a ); // single statement | |||
</source> | |||
Although the following is technically possible, it's not recommended because it's hard to read and maintain. | |||
The initialization is left out because the variable <code>a</code> already has the value zero. | |||
The loop body is left out because the increment statement includes a function call which does everything that's needed. | |||
<source lang="lsl2"> | |||
integer a = 0; | |||
integer b = 10; | |||
for ( ; a < b; llOwnerSay((string)(++a)) ) | |||
; // empty statement (could be at the end of the previous line) | |||
</source> | |||
|helpers | |helpers | ||
|also_header | |also_header | ||
|also_functions | |also_functions | ||
|also_tests | |||
|also_articles | |also_articles | ||
|also_footer | |also_footer | ||
|notes | |notes= | ||
A for-loop can also be written as a [[While]]-loop. | |||
<source lang="lsl2"> | |||
initializer; | |||
while(condition) | |||
{ | |||
loop; | |||
increment; | |||
} | |||
</source> | |||
|mode | |mode | ||
| | |deprecated | ||
|cat1=Flow Control/Loop | |||
|cat2=Conditional | |||
|cat3 | |||
|cat4 | |||
}} | }} |
Latest revision as of 17:31, 19 May 2023
LSL Portal | Functions | Events | Types | Operators | Constants | Flow Control | Script Library | Categorized Library | Tutorials |
for( initializer; condition; increment ) loop
• | initializer | – | Executed once just before checking condition. | |
• | condition | – | If this executes as true then loop is executed. | |
• | increment | – | Executed after loop, then condition is checked again. | |
• | loop | – | Can be either a single statement, a block statement, or a null statement. |
Only the condition is required. The initializer, increment, and loop body are optional and can be left empty.
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
The following is the most common way a for-loop is written, with each part properly specified.
The loop will run or "iterate" 10 times, from 0 to 9. It will execute two statements each iteration.
integer a = 0;
integer b = 10;
for (a = 0; a < b; ++a)
{
llOwnerSay( (string)a ); // first statement
llOwnerSay( (string)b ); // second statement
}
The following is less common, where the curly braces are left out.
This can be used when only one statement needs to be executed during the loop.
integer a = 0;
integer b = 10;
for (a = 0; a < b; ++a)
llOwnerSay( (string)a ); // single statement
Although the following is technically possible, it's not recommended because it's hard to read and maintain.
The initialization is left out because the variable a
already has the value zero.
The loop body is left out because the increment statement includes a function call which does everything that's needed.
integer a = 0;
integer b = 10;
for ( ; a < b; llOwnerSay((string)(++a)) )
; // empty statement (could be at the end of the previous line)
Notes
Deep Notes
Footnotes
- ^ The OpenSim LSL compiler will not do this implicitly. You will need to use an explicit check.