a && b: Difference between revisions
| Lou Montana (talk | contribs) m (Text replacement - " \| *(game[0-9]|version[0-9]|gr[0-9]|serverExec|mp|pr|descr|s[0-9]|p[0-9]{1,3}|r[0-9]|x1?[0-9]|seealso) *=  +" to " |$1= ") | Lou Montana (talk | contribs)  m (Text replacement - "<sqf>([^↵][^<]*↵[^<]*)<\/sqf>" to "<sqf> $1 </sqf>") | ||
| (31 intermediate revisions by the same user not shown) | |||
| Line 1: | Line 1: | ||
| {{RV|type=command | {{RV|type=command | ||
| |sortKey= # | |||
| |game1= ofp | |game1= ofp | ||
| Line 27: | Line 29: | ||
| |descr= Returns [[true]] only if both conditions are [[true]]. | |descr= Returns [[true]] only if both conditions are [[true]]. | ||
| In case of the alternative syntax, {{ | In case of the alternative syntax, {{Link|https://en.wikipedia.org/wiki/Lazy_evaluation#Control_structures|lazy evaluation}} is used - if left operand is [[false]], evaluation of the right side is ignored. | ||
| |alias= [[a and b]] | |alias= [[a and b]] | ||
| Line 33: | Line 35: | ||
| |s1= booleanA [[a && b|&&]] booleanB | |s1= booleanA [[a && b|&&]] booleanB | ||
| |p1= booleanA: [[Boolean]] -  | |p1= booleanA: [[Boolean]] - test condition or variable | ||
| |p2= booleanB: [[Boolean]] -  | |p2= booleanB: [[Boolean]] - test condition or variable | ||
| |r1= [[Boolean]] | |r1= [[Boolean]] | ||
| |s2= boolean [[a && b|&&]] code  | |s2= boolean [[a && b|&&]] code | ||
| |s2since= arma2oa 1.62 | |||
| |p21= boolean: [[Boolean]] -  | |p21= boolean: [[Boolean]] - test condition or variable | ||
| |p22= code: [[Code]] -  | |p22= code: [[Code]] - code that once executed returns a [[Boolean]]. The code is not evaluated if '''boolean''' is [[false]]. | ||
| |r2= [[Boolean]] | |r2= [[Boolean]] | ||
| |x1= < | |x1= <sqf> | ||
| private _allEnemiesKilled = true; | |||
| if (alive player && _allEnemiesKilled) then | |||
| { | { | ||
| 	hint "you win !"; | |||
| };</ | }; | ||
| </sqf> | |||
| |x2= < | |x2= <sqf> | ||
| if ((count _array > 0) && { (_array select 0) == player }) then // an error would be thrown without lazy evaluation | |||
| { | { | ||
| 	hint "It works!"; | |||
| };</ | }; | ||
| </sqf> | |||
| |x3= < | |x3= <sqf> | ||
| if ((alive player) && { player setDamage 0.5; true }) then // valid AS LONG AS the code block returns a Boolean | |||
| { | { | ||
| 	hint "It works!"; | |||
| };</ | }; | ||
| </sqf> | |||
| |seealso= [[and]] | |seealso= [[and]] [[or]] [[Operators]] | ||
| }} | }} | ||
Latest revision as of 19:42, 3 September 2024
Description
- Description:
- Returns true only if both conditions are true. In case of the alternative syntax, lazy evaluation is used - if left operand is false, evaluation of the right side is ignored.
- Alias:
- a and b
- Groups:
- VariablesMath
Syntax
- Syntax:
- booleanA && booleanB
- Parameters:
- booleanA: Boolean - test condition or variable
- booleanB: Boolean - test condition or variable
- Return Value:
- Boolean
Alternative Syntax
- Syntax:
- boolean && code
- Parameters:
- boolean: Boolean - test condition or variable
- code: Code - code that once executed returns a Boolean. The code is not evaluated if boolean is false.
- Return Value:
- Boolean
Examples
- Example 1:
- Example 2:
- Example 3:
Additional Information
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
Categories: 
- Scripting Commands
- Introduced with Operation Flashpoint version 1.00
- Operation Flashpoint: New Scripting Commands
- Operation Flashpoint: Scripting Commands
- Operation Flashpoint: Elite: Scripting Commands
- ArmA: Armed Assault: Scripting Commands
- Arma 2: Scripting Commands
- Arma 2: Operation Arrowhead: Scripting Commands
- Take On Helicopters: Scripting Commands
- Arma 3: Scripting Commands
- Command Group: Variables
- Command Group: Math
 
	





