BIS fnc bitflagsFlip: Difference between revisions
m (Text replacement - "|Game version=" to "|Game version=  |gr1= Bitwise |GROUP1=")  | 
				Lou Montana (talk | contribs)  m (Text replacement - "_{10,} " to "")  | 
				||
| Line 1: | Line 1: | ||
{{DISPLAYTITLE:BIS_fnc_bitflagsFlip}}{{Function|Comments=  | {{DISPLAYTITLE:BIS_fnc_bitflagsFlip}}{{Function|Comments=  | ||
| arma3 |Game=  | | arma3 |Game=  | ||
| Line 10: | Line 9: | ||
|eff= |MPEFFECTS=    | |eff= |MPEFFECTS=    | ||
| Flips one or more flags (set gets unset and vice versa) in the given flagset, represented with decimal or hexadecimal number<br>  | | Flips one or more flags (set gets unset and vice versa) in the given flagset, represented with decimal or hexadecimal number<br>  | ||
| Line 19: | Line 17: | ||
intended to work with unsigned 24 bit integers only. This means that the    | intended to work with unsigned 24 bit integers only. This means that the    | ||
supported range is 2^0...2^24 (1...16777216) |DESCRIPTION=  | supported range is 2^0...2^24 (1...16777216) |DESCRIPTION=  | ||
| [flagset, flag] call '''BIS_fnc_bitflagsFlip''' |SYNTAX=  | | [flagset, flag] call '''BIS_fnc_bitflagsFlip''' |SYNTAX=  | ||
| Line 32: | Line 29: | ||
[2 + 4 + 8, 2 + 8] [[call]] [[BIS_fnc_bitflagsFlip]]; // 4  | [2 + 4 + 8, 2 + 8] [[call]] [[BIS_fnc_bitflagsFlip]]; // 4  | ||
[4, 2 + 8] [[call]] [[BIS_fnc_bitflagsFlip]]; // 14 (which is 2 + 4 + 8)</code>|EXAMPLE1=    | [4, 2 + 8] [[call]] [[BIS_fnc_bitflagsFlip]]; // 14 (which is 2 + 4 + 8)</code>|EXAMPLE1=    | ||
| [[BIS fnc bitflagsSet]], [[BIS fnc bitflagsCheck]], [[BIS fnc bitflagsToArray]], [[BIS fnc bitflagsUnset]]|SEEALSO=    | | [[BIS fnc bitflagsSet]], [[BIS fnc bitflagsCheck]], [[BIS fnc bitflagsToArray]], [[BIS fnc bitflagsUnset]]|SEEALSO=    | ||
|  |MPBEHAVIOUR=    | |  |MPBEHAVIOUR=    | ||
}}  | }}  | ||
Revision as of 22:34, 16 January 2021
Description
- Description:
 - Flips one or more flags (set gets unset and vice versa) in the given flagset, represented with decimal or hexadecimal number
(Hexadecimal number representation is simply auto-converted into decimal by the engine)
To check which flags are present in given flagset use BIS_fnc_bitflagsToArray
Limitations:
Due to various limitations of the Real Virtuality engine this function is intended to work with unsigned 24 bit integers only. This means that the supported range is 2^0...2^24 (1...16777216) - Execution:
 - call
 - Groups:
 - Bitwise
 
Syntax
- Syntax:
 - [flagset, flag] call BIS_fnc_bitflagsFlip
 - Parameters:
 - flagset: Number - flagset
 - flag: Number - one or more flags to flip
 - Return Value:
 - Number - new flagset with given flag or flags flipped
 
Examples
- Example 1:
 [1 + 16, 8] call BIS_fnc_bitflagsFlip; // 25 (which is 1 + 8 + 16) [25, 8] call BIS_fnc_bitflagsFlip; // 17 (which is 1 + 16) [2 + 4 + 8, 2 + 8] call BIS_fnc_bitflagsFlip; // 4 [4, 2 + 8] call BIS_fnc_bitflagsFlip; // 14 (which is 2 + 4 + 8)
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