and: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "\[\[Category:[ _]?Scripting[ _]Commands[ _]Armed[ _]Assault(\|.*)]]" to "{{GameCategory|arma1|Scripting Commands}}")
m (Text replacement - "(\|[pr][0-9]+ *= *[^- ]*) *- *T([a-z ])" to "$1 - t$2")
 
(57 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{Command|Comments=
{{RV|type=command
____________________________________________________________________________________________


| ofp |Game name=
|game1= ofp
|version1= 1.00


|1.00|Game version=
|game2= ofpe
|version2= 1.00


|gr1= Variables |GROUP1=
|game3= arma1
|version3= 1.00


|gr2= Math |GROUP2=
|game4= arma2
____________________________________________________________________________________________
|version4= 1.00


| Returns [[true]] only if both conditions are [[true]]. In case of the alternative syntax, [http://en.wikipedia.org/wiki/Lazy_evaluation#Control_structures lazy evaluation] is used (if left operand is [[false]], evaluation of the right side is skipped completely). |DESCRIPTION=
|game5= arma2oa
____________________________________________________________________________________________
|version5= 1.50


| [[Boolean]] <nowiki>=</nowiki> a '''and''' b |SYNTAX=
|game6= tkoh
|p1= a: [[Boolean]] - Test condition or variable that returns [[Boolean]]. |PARAMETER1=
|version6= 1.00
|p2= b: [[Boolean]] - Test condition or variable that returns [[Boolean]]. |PARAMETER2=
| [[Boolean]] |RETURNVALUE=


|game7= arma3
|version7= 0.50


|gr1= Variables


|s2= [[Boolean]] <nowiki>=</nowiki> a '''and''' b (''Only available since Arma 2:OA v1.62.'') |SYNTAX2=
|gr2= Math


|p21= a: [[Boolean]] - Test condition or variable that returns [[Boolean]]. |PARAMETER21=
|descr= Returns [[true]] only if both conditions are [[true]].
|p22= b: [[Code]] - Code that returns [[Boolean]]. It is not evaluated if '''a''' returns as [[false]]. |PARAMETER22=
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.
|r2= [[Boolean]] |RETURNVALUE2=
____________________________________________________________________________________________
 
|x1= <code>[[if]] (([[alive]] [[player]]) and (_enemycount == 0)) then {[[hint]] "you win !"}</code> |EXAMPLE1=
|x2= <code>[[if]] (([[count]] _array > 0) and {(_array [[select]] 0) == [[player]]}) then {[[hint]] "It works! Without lazy evaluation it would throw an error if array was empty."}</code> |EXAMPLE2=


|mp= no special considerations|=
|alias= [[a && b]]
____________________________________________________________________________________________


| [[a && b]], [[or]], [[Operators]] |SEEALSO=
|s1= a [[and]] b


}}
|p1= a: [[Boolean]] - test condition or variable
 
|p2= b: [[Boolean]] - test condition or variable
 
|r1= [[Boolean]]
 
|s2= a [[and]] b
 
|s2since= arma2oa 1.62
 
|p21= a: [[Boolean]] - test condition or variable
 
|p22= b: [[Code]] - code that returns [[Boolean]]. It is '''not''' evaluated if ''a'' is [[false]]
 
|r2= [[Boolean]]


<h3 style="display:none">Notes</h3>
|x1= <sqf>
<dl class="command_description">
if ((not isNull player) and (alive player) and (_enemycount == 0)) then
<!-- Note Section BEGIN -->
{
<!-- Note Section END -->
hint "you win !";
</dl>
};
</sqf>


<h3 style="display:none">Bottom Section</h3>
|x2= <sqf>
if ((count _array > 0) and { (_array select 0) == player }) then // works as expected
{
hint "It works!";
};


[[Category:Scripting Commands|AND]]
if ((count _array > 0) and (_array select 0) == player) then // Error: _array select 0 is evaluated
[[Category:Scripting Commands OFP 1.99|AND]]
{
[[Category:Scripting Commands OFP 1.96|AND]]
hint "It... works?";
[[Category:Scripting Commands OFP 1.46|AND]]
};
{{GameCategory|arma1|Scripting Commands}}
</sqf>
[[Category:Scripting Commands Arma 2|{{uc:{{PAGENAME}}}}]]
[[Category:Scripting Commands Arma 3|{{uc:{{PAGENAME}}}}]]
[[Category:Scripting Commands Take On Helicopters|{{uc:{{PAGENAME}}}}]]


<!-- CONTINUE Notes -->
|seealso= [[a && b]] [[or]] [[Operators]]
<dl class="command_description">
}}
<dd class="notedate">Posted on April 12, 2015 - 10:45 (UTC)</dd>
<dt class="note">[[User:IT07|IT07]]</dt>
<dd class="note">
Just like the "or" command, the "and" command allows several conditions to be checked. Example: <br>
<code>if(alive player and speed player > 0 and _someOtherVar) then { hint"All three condtions are true" };</code>
The example above will check if the player is alive and if the player is moving and checks if _someOtherVar is true.
</dd>
</dl>
<!-- DISCONTINUE Notes -->

Latest revision as of 15:51, 8 November 2023

Hover & click on the images for description

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 && b
Groups:
VariablesMath

Syntax

Syntax:
a and b
Parameters:
a: Boolean - test condition or variable
b: Boolean - test condition or variable
Return Value:
Boolean

Alternative Syntax

Syntax:
a and b
Parameters:
a: Boolean - test condition or variable
b: Code - code that returns Boolean. It is not evaluated if a is false
Return Value:
Boolean

Examples

Example 1:
if ((not isNull player) and (alive player) and (_enemycount == 0)) then { hint "you win !"; };
Example 2:
if ((count _array > 0) and { (_array select 0) == player }) then // works as expected { hint "It works!"; }; if ((count _array > 0) and (_array select 0) == player) then // Error: _array select 0 is evaluated { hint "It... works?"; };

Additional Information

See also:
a && b or Operators

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