findIf: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (released with stable now)
m (Fixed examples)
Line 24: Line 24:
|x1= <code>[unit1,unit2,unit3] [[findIf]] {[[!]][[alive]] [[_x]]}; //return index of first dead unit</code> |= Example 1
|x1= <code>[unit1,unit2,unit3] [[findIf]] {[[!]][[alive]] [[_x]]}; //return index of first dead unit</code> |= Example 1
|x2= <code>//two ways how to 'wait for all units to be dead':
|x2= <code>//two ways how to 'wait for all units to be dead':
[[waitUntil]]{[unit1,unit2,unit3] [[findIf]] {[[alive]] [[_x]]} [[==]] -1}; //fast, terminates as soon as it finds alive unit
[[waitUntil]] { [unit1,unit2,unit3] [[findIf]] {[[alive]] [[_x]]} [[==]] -1 }; //fast, terminates as soon as it finds alive unit
[[waitUntil]]{[unit1,unit2,unit3] [[count]] {[[alive]] [[_x]]} [[==]] 0}; //slow, always goes through all array elements</code> |= Example 2
[[waitUntil]] { {[[alive]] [[_x]]} [[count]] [unit1,unit2,unit3] [[==]] 0 }; //slow, always goes through all array elements</code> |= Example 2
___________________________________________________________________________________________
___________________________________________________________________________________________



Revision as of 05:44, 15 April 2018

Hover & click on the images for description

Description

Description:
Searches for an element within array for which the code evaluates to true. Returns the 0 based index on success or -1 if not found. Code on the right side of the command is evaluated for each element of the array, processed element can be referenced in code as _x.

NOTE: Because command findIf terminates as soon as it finds an element that fulfills the condition, it is more efficient then count in scenarios where you need to check for presence / absence of at least one element that evaluates to true.
Groups:
Uncategorised

Syntax

Syntax:
array findIf code
Parameters:
array: Array - array to search in
code: Code - code defining an element to find, processed element can be referenced within the code as _x
Return Value:
Number - 0 based position of the first array element for which the code evaluate to true, -1 if not found

Examples

Example 1:
[unit1,unit2,unit3] findIf {!alive _x}; //return index of first dead unit
Example 2:
//two ways how to 'wait for all units to be dead': waitUntil { [unit1,unit2,unit3] findIf {alive _x} == -1 }; //fast, terminates as soon as it finds alive unit waitUntil { {alive _x} count [unit1,unit2,unit3] == 0 }; //slow, always goes through all array elements

Additional Information

See also:
find count

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

Notes

Bottom Section