getVariable: Difference between revisions
Jump to navigation
Jump to search
Lou Montana (talk | contribs) m (Text replacement - "<!-- Note Section [A-Z]+ --> " to "") |
(formatting, new table) |
||
Line 1: | Line 1: | ||
{{RV|type=command | {{RV|type=command | ||
| arma1 | |game1= arma1 | ||
|1.00 | |version1= 1.00 | ||
|game2= arma2 | |||
|version2= 1.00 | |||
|game3= arma2oa | |||
|version3= 1.51 | |||
|game4= tkoh | |||
|version4= 1.00 | |||
|game5= arma3 | |||
|version5= 0.50 | |||
|arg= global | |arg= global | ||
Line 11: | Line 27: | ||
|gr2= Variables | |gr2= Variables | ||
| Returns the value of variable in the variable space assigned to various data types. | |descr= Returns the value of variable in the variable space assigned to various data types. | ||
All available data types combinations: | All available data types combinations: | ||
{{{!}} class | {{{!}} class="wikitable" | ||
! Primary syntax ([[String]]) | !colspan="2"{{!}}Primary syntax ([[String]]) !! colspan="2"{{!}}Alternative syntax ([[Array]]) | ||
! Alternative syntax ([[Array]]) | |||
{{!}}- | {{!}}- | ||
{{!}} | {{!}}'''Code''' | ||
{{!}}'''Since''' | |||
{{!}}'''Code''' | |||
{{!}}'''Since''' | |||
{{!}}- | |||
{{!}} [[Namespace]] getVariable [[String]] {{!}}{{!}} - {{!}}{{!}} [[Namespace]] getVariable [[Array]] {{!}}{{!}} {{arma2oa}} v1.60 | |||
{{!}}- | |||
{{!}} [[Object]] getVariable [[String]] {{!}}{{!}} - {{!}}{{!}} [[Object]] getVariable [[Array]] {{!}}{{!}} - | |||
{{!}}- | |||
{{!}} | {{!}} [[Group]] getVariable [[String]] {{!}}{{!}} - {{!}}{{!}} [[Group]] getVariable [[Array]] {{!}}{{!}} - | ||
{{!}}- | |||
{{!}} [[Team_Member]] getVariable [[String]] {{!}}{{!}} - {{!}}{{!}} [[Team_Member]] getVariable [[Array]] {{!}}{{!}} - | |||
{{!}}- | |||
{{!}} [[Task]] getVariable [[String]] {{!}}{{!}} - {{!}}{{!}} [[Task]] getVariable [[Array]] {{!}}{{!}} {{arma3}} v1.68 | |||
{{!}}- | |||
{{!}} [[Location]] getVariable [[String]] {{!}}{{!}} - {{!}}{{!}} [[Location]] getVariable [[Array]] {{!}}{{!}} {{arma3}} v1.68 | |||
{{!}}- | |||
{{!}} [[Control]] getVariable [[String]] {{!}}{{!}} - {{!}}{{!}} [[Control]] getVariable [[Array]] {{!}}{{!}} {{arma3}} v1.56 | |||
{{!}}- | |||
{{!}} [[Display]] getVariable [[String]] {{!}}{{!}} {{arma3}} v1.56 {{!}}{{!}} [[Display]] getVariable [[Array]] {{!}}{{!}} {{arma3}} v1.56 | |||
{{!}}} | {{!}}} | ||
Line 43: | Line 60: | ||
* Variable namespace is null ([[objNull]], [[grpNull]], etc.)}} | * Variable namespace is null ([[objNull]], [[grpNull]], etc.)}} | ||
| varspace [[getVariable]] name | |s1= varspace [[getVariable]] name | ||
|p1= varspace: [[Namespace]], [[Object]], [[Display]], [[Control]], [[Group]], [[Location]], [[Task]], [[Team Member]], [[Display]], [[Control]] | |p1= varspace: [[Namespace]], [[Object]], [[Display]], [[Control]], [[Group]], [[Location]], [[Task]], [[Team Member]], [[Display]], [[Control]] | ||
|p2= name: [[String]] - | |p2= name: [[String]] - Variable name in given namespace | ||
| [[Anything]] or [[Nothing]] if the variable doesn't exist | |r1= [[Anything]] or [[Nothing]] if the variable doesn't exist | ||
|s2= varspace [[getVariable]] [name, defaultValue] | |s2= varspace [[getVariable]] [name, defaultValue] | ||
Line 55: | Line 72: | ||
|p21= varspace: [[Namespace]], [[Object]], [[Display]], [[Control]], [[Group]], [[Location]], [[Task]], [[Team Member]], [[Display]], [[Control]] | |p21= varspace: [[Namespace]], [[Object]], [[Display]], [[Control]], [[Group]], [[Location]], [[Task]], [[Team Member]], [[Display]], [[Control]] | ||
|p22= name: [[String]] - Variable name | |p22= name: [[String]] - Variable name in given namespace | ||
|p23= defaultValue: [[Anything]] - Value to return if variable doesn't exist | |p23= defaultValue: [[Anything]] - Value to return if variable doesn't exist {{Feature|warning|A dynamic ''defaultValue'' e.g. {{ic|[[random]] 500}} will always be executed, even if the variable is defined.}} | ||
|r2= [[Anything]] - | |r2= [[Anything]] - Current value of the variable or ''defaultValue'' if the variable doesn't exist. | ||
|x1= <code>[[private]] _variable = myTruck [[getVariable]] "myVariable"; {{cc|returns [[nil]] if "myVariable" is not set}}</code> | |x1= <code>[[private]] _variable = myTruck [[getVariable]] "myVariable"; {{cc|returns [[nil]] if "myVariable" is not set}}</code> | ||
Line 65: | Line 82: | ||
|x2= <code>[[private]] _variable = myTruck [[getVariable]] ["myVariable", 50]; {{cc|returns 50 if "myVariable" is not set}}</code> | |x2= <code>[[private]] _variable = myTruck [[getVariable]] ["myVariable", 50]; {{cc|returns 50 if "myVariable" is not set}}</code> | ||
|x3= | |x3= | ||
<code>[[for]] "_i" [[from]] 0 [[to]] 5 [[do]] { | <code>[[for]] "_i" [[from]] 0 [[to]] 5 [[do]] { | ||
_car = [[missionNamespace]] [[getVariable]] ("car" [[valuea_plus_valueb|+]] [[str]] _i); | _car = [[missionNamespace]] [[getVariable]] ("car" [[valuea_plus_valueb|+]] [[str]] _i); | ||
_car [[setDamage]] 0; | _car [[setDamage]] 0; | ||
};</code> | };{{cc|Set damage of car0..car5 to 0}}</code> | ||
|x4= <code>myMissionVar = 2015; | |x4= <code>myMissionVar = 2015; | ||
[[missionNamespace]] [[getVariable]] "myMissionVar"; {{cc| | [[missionNamespace]] [[getVariable]] "myMissionVar"; {{cc|Returns 2015}}</code> | ||
| | |x5= Get current value of a variable and if it is undefined, define it and get the defined value:<code>[[private]] _var = [[missionNamespace]] [[getVariable]] "varName"; | ||
[[if]] ([[isNil]] "_var") [[then]] | [[if]] ([[isNil]] "_var") [[then]] | ||
{ | { | ||
Line 94: | Line 107: | ||
<dt class="note">[[User:Ebay|Ebay]]</dt> | <dt class="note">[[User:Ebay|Ebay]]</dt> | ||
<dd class="note"> | <dd class="note"> | ||
'''NOTE: {{arma2}} | '''NOTE: {{arma2}} only! In {{arma3}} this will return default value:''' | ||
Warning: the alternative syntax returns undefined when the | Warning: the alternative syntax returns undefined when the namespace is an object and that object is null. Example:<br> | ||
<code>_test = [[objNull]] [[getVariable]] ["test", "0"]; | <code>_test = [[objNull]] [[getVariable]] ["test", "0"]; | ||
[[systemChat]] _test;</code> | [[systemChat]] _test;</code> | ||
Errors because _test is undefined. Tested in | Errors because _test is undefined. Tested in {{arma2oa}} 1.63.131129 | ||
</dd> | </dd> | ||
<dt><dt> | <dt><dt> | ||
Line 109: | Line 122: | ||
<code><nowiki>[</nowiki>[[player]] [[getVariable]] "myVar"] [[params]] [["_myVar", "", [""]]];</code> | <code><nowiki>[</nowiki>[[player]] [[getVariable]] "myVar"] [[params]] [["_myVar", "", [""]]];</code> | ||
</dd> | </dd> | ||
</dl> | </dl> | ||
Revision as of 11:51, 17 April 2021
Description
- Description:
- Returns the value of variable in the variable space assigned to various data types.
All available data types combinations:
Primary syntax (String) Alternative syntax (Array) Code Since Code Since Namespace getVariable String - Namespace getVariable Array Arma 2: Operation Arrowhead v1.60 Object getVariable String - Object getVariable Array - Group getVariable String - Group getVariable Array - Team_Member getVariable String - Team_Member getVariable Array - Task getVariable String - Task getVariable Array Arma 3 v1.68 Location getVariable String - Location getVariable Array Arma 3 v1.68 Control getVariable String - Control getVariable Array Arma 3 v1.56 Display getVariable String Arma 3 v1.56 Display getVariable Array Arma 3 v1.56 - Groups:
- MultiplayerVariables
Syntax
- Syntax:
- varspace getVariable name
- Parameters:
- varspace: Namespace, Object, Display, Control, Group, Location, Task, Team Member, Display, Control
- name: String - Variable name in given namespace
- Return Value:
- Anything or Nothing if the variable doesn't exist
Alternative Syntax
- Syntax:
- varspace getVariable [name, defaultValue]
- Parameters:
- varspace: Namespace, Object, Display, Control, Group, Location, Task, Team Member, Display, Control
- name: String - Variable name in given namespace
- defaultValue: Anything - Value to return if variable doesn't exist
- Return Value:
- Anything - Current value of the variable or defaultValue if the variable doesn't exist.
Examples
- Example 1:
private _variable = myTruck getVariable "myVariable"; // returns nil if "myVariable" is not set
- Example 2:
private _variable = myTruck getVariable ["myVariable", 50]; // returns 50 if "myVariable" is not set
- Example 3:
for "_i" from 0 to 5 do { _car = missionNamespace getVariable ("car" + str _i); _car setDamage 0; };// Set damage of car0..car5 to 0
- Example 4:
myMissionVar = 2015; missionNamespace getVariable "myMissionVar"; // Returns 2015
- Example 5:
- Get current value of a variable and if it is undefined, define it and get the defined value:
private _var = missionNamespace getVariable "varName"; if (isNil "_var") then { missionNamespace setVariable ["varName", 123]; _var = 123; }; // _var here will contain current value of the variable varName
Additional Information
- See also:
- setVariableallVariablesgetFSMVariable
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
- Posted on August 13, 2016 - 17:13 (UTC)
- Ebay
-
NOTE: Arma 2 only! In Arma 3 this will return default value:
Warning: the alternative syntax returns undefined when the namespace is an object and that object is null. Example:
_test = objNull getVariable ["test", "0"]; systemChat _test;
Errors because _test is undefined. Tested in Arma 2: Operation Arrowhead 1.63.131129 - Posted on August 31, 2017 - 03:29 (UTC)
- AgentRev
-
You can do typechecking using param:
private _myVar = [player getVariable "myVar"] param [0, "", [""]];
and params:[player getVariable "myVar"] params [["_myVar", "", [""]]];
Categories:
- Scripting Commands
- Introduced with Armed Assault version 1.00
- ArmA: Armed Assault: New 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: Multiplayer
- Command Group: Variables