breakTo: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "\| *(arg|eff|mp|serverExec|gr[0-9]) *= *(.*) * *\|([^=]{12})" to "|$1=$2 |descr=$3")
m (Text replacement - "Nelis.75733126" to "Nelis75733126")
 
(29 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{RV|type=command
{{RV|type=command


| arma1
|game1= arma1
|version1= 1.00
 
|game2= arma2
|version2= 1.00
 
|game3= arma2oa
|version3= 1.50
 
|game4= tkoh
|version4= 1.00
 
|game5= arma3
|version5= 0.50


|gr1= Program Flow
|gr1= Program Flow


|descr=1.00
|descr= Breaks block to scope named ''name''.
 
| Breaks block to scope named '''name'''. Nil is returned.


Scope name can be assigned using [[scopeName]] command.
Scope name can be assigned using the [[scopeName]] command.


|s1= '''breakTo''' name
|s1= [[breakTo]] name


|p1= name: [[String]]
|p1= name: [[String]]
Line 17: Line 28:
|r1= [[Nothing]]
|r1= [[Nothing]]


|x1= <code>[[scopeName]] "main";
|x1= <sqf>
while {[[true]]} do {
scopeName "main";
[[scopeName]] "loop1";
while { true } do
while {[[true]]} do {
{
[[scopeName]] "loop2";
scopeName "loop1";
if (condition1) then {[[breakTo]] "main"}; // Breaks all scopes and return to "main"
while { true } do
if (condition2) then {[[breakOut]] "loop2"}; // Breaks scope named "loop2"
{
[[sleep]] 1;
scopeName "loop2";
if (condition1) then { breakTo "main" }; // breaks all scopes and return to "main"
if (condition2) then { breakOut "loop2" }; // breaks scope named "loop2"
sleep 1;
};
};
[[sleep]] 1;
sleep 1;
};
};
</code>
</sqf>


|seealso= [[scopeName]], [[breakOut]], [[exitWith]]
|seealso= [[scopeName]] [[breakOut]] [[exitWith]]
}}
}}


{{GameCategory|arma2|Scripting Commands}}
{{Note
{{GameCategory|arma2|Scripting Commands}}
|user= Nelis75733126
{{GameCategory|arma3|Scripting Commands}}
|timestamp= 20170518181900
{{GameCategory|tkoh|Scripting Commands}}
|text= I wish to clarify the behaviour of this command by saying that the <sqf inline>breakTo</sqf> command will literally break the scope in which it has been placed, and continue reading whatever is after and outside of that scope.<br>
 
Example:
<dl class="command_description">
<sqf>
 
scopeName "something";
<dt></dt>
if true then
<dd class="notedate">Posted on May 18, 2017 - 18:19 (UTC)</dd>
{
<dt class="note">[[User:IT07|IT07]]</dt>
breakTo "something";
<dd class="note">
_v = 0; // this line will be skipped
This command can not be used to re-execute scopes in which command is inside of. Example:
<code>scopeName "whatever";
if true then {
  breakTo "whatever"
};
};
</code>
The example above will not make the engine jump back to line 1 and re-execute the 2nd line. Instead, it will just jump across line 2 to line 5 if it [ line 5 ] exists.
</dd>


</dl>
_a = 0; // this is where script execution will jump to.
</sqf>
}}

Latest revision as of 15:38, 29 June 2024

Hover & click on the images for description

Description

Description:
Breaks block to scope named name. Scope name can be assigned using the scopeName command.
Groups:
Program Flow

Syntax

Syntax:
breakTo name
Parameters:
name: String
Return Value:
Nothing

Examples

Example 1:
scopeName "main"; while { true } do { scopeName "loop1"; while { true } do { scopeName "loop2"; if (condition1) then { breakTo "main" }; // breaks all scopes and return to "main" if (condition2) then { breakOut "loop2" }; // breaks scope named "loop2" sleep 1; }; sleep 1; };

Additional Information

See also:
scopeName breakOut exitWith

Notes

Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
Only post proven facts here! Add Note
Nelis75733126 - c
Posted on May 18, 2017 - 18:19 (UTC)
I wish to clarify the behaviour of this command by saying that the breakTo command will literally break the scope in which it has been placed, and continue reading whatever is after and outside of that scope.
Example:
scopeName "something"; if true then { breakTo "something"; _v = 0; // this line will be skipped }; _a = 0; // this is where script execution will jump to.