configClasses: Difference between revisions

From Bohemia Interactive Community
m (Bot: Reverted to revision 102419 by IT07_bi_wiki on 2017-05-28T09:18:38Z)
No edit summary
 
(74 intermediate revisions by 4 users not shown)
Line 1: Line 1:
{{Command|= Comments
{{RV|type=command
____________________________________________________________________________________________


| arma3 |= Game name
|game1= arma3
|version1= 1.24


|1.24|= Game version
|gr1= Config


____________________________________________________________________________________________
|descr= Returns an array of config entries which meet criteria in condition code. Command iterates through all available config sub classes of the given config class. Current looked at config is stored in _x variable (similar to alternative [[count]] command implementation). Condition has to return [[true]] in order for the looked at config to be added to the resulting array. Slightly faster than [[configProperties]], but doesn't account for config properties or inherited entries.
{{Feature|important|
* The condition code passed to [[configClasses]] should only be used for '''simple filter expressions''' and nothing more
* Do not use {{hl|"[[isClass]] [[Magic Variables#x|_x]]"}} in the condition. The engine does this check already<br><br>
* {{arma3}} v2.02 brought specific engine optimisations for the following conditions:
** {{hl|"[[true]]"}}
** {{hl|"[[getNumber]] ([[Magic Variables#x|_x]] >> 'scope') > 0"}}}}


| Returns an array of config entries which meet criteria in condition code. Command iterates through all available config sub classes of the given config class. Current looked at config is stored in _x variable (similar to alternative [[count]] command implementation). Condition has to return [[true]] in order for the looked at config to be added to the resulting array. Slightly faster than [[configProperties]], but doesn't account for config properties or inherited entries.
|s1= condition [[configClasses]] config
<br><br>{{warning| The condition code passed to [[configClasses]] should only be used for '''simple filter expressions''' and nothing more}} |= Description
____________________________________________________________________________________________


| condition '''configClasses''' config |= Syntax
|p1= condition: [[String]]


|p1= condition: [[String]] |= Parameter 1
|p2= config: [[Config]]
|p2= config: [[Config]] |= Parameter 1


| [[Array]] - Array of [[Config]]s |= Return value
|r1= [[Array]] - array of [[Config]]s
____________________________________________________________________________________________
 
|x1= collect all CfgVehicles configs: <code>_configs = "[[true]]" [[configClasses]] ([[configFile]] >> "CfgVehicles");</code> |= Example 1


|x2= Return all classes that can transport 10 and more soldiers: <code>_transporters = "[[getNumber]] (_x >> 'transportSoldier') >= 10" [[configClasses]] ([[configFile]] >> "CfgVehicles");</code> |= Example 2
|s2= [[configClasses]] [config, depth, includeInherited, allSubclasses, classNames]
|s2since= arma3 2.22


|x3= Return all classes that inherit from 'RscText': <code>[[hint]] [[str]] ("[[inheritsFrom]] _x == ([[configFile]] >> 'RscText')" [[configClasses]] [[configFile]]);</code> |= Example 3
|p21= config: [[Config]] - target config
____________________________________________________________________________________________
|p22= depth: [[Number]] - how many levels of subclasses to go deep
|p23= includeInherited: [[Boolean]] - [[true]] to look through inherited classes
|p24= allSubclasses: [[Boolean]] - [[true]] to return all subclasses, [[false]] - to return only the last tier.
|p25= classnames: (Optional) [[Boolean]] - when [[true]] class names [[String]]s are retuned, when [[false]] - [[Config]]s are returned. Default: [[false]]  


| [[Config]], [[configFile]], [[missionConfigFile]], [[configProperties]], [[configHierarchy]] |= See also
|r2= [[Array]] - array of [[Config]]s or [[Strings]], which represent class names.


|x1= collect all CfgVehicles configs:
<sqf>_configs = "true" configClasses (configFile >> "CfgVehicles");</sqf>
|x2= Return all classes that can transport 10 and more soldiers:
<sqf>_transporters = "getNumber (_x >> 'transportSoldier') >= 10" configClasses (configFile >> "CfgVehicles");</sqf>
|x3= Return all classes that inherit from 'RscText':
<sqf>hint str ("inheritsFrom _x == (configFile >> 'RscText')" configClasses configFile);</sqf>
|x4= Return children:
<sqf>configClasses [configFile >> "CfgGroups", 0, true, true, true]
//Returns ["West","East","Indep","Empty"]</sqf>
|seealso= [[Config]] [[configFile]] [[missionConfigFile]] [[configProperties]] [[configHierarchy]] [[BIS_fnc_returnChildren]]
}}
}}


<h3 style="display:none">Notes</h3>
{{Note
<dl class="command_description">
|user= Iceman77
<dd class="notedate">Posted on oct 19, 2014 - 12:24</dd>
|timestamp= 20141019122400
<dt class="note">'''[[User:(Iceman77|Iceman77]]'''</dt>
|text= A fantastic way to filter stuff. eg:
<dd class="note"> A fantastic way to filter stuff. eg; Create an array of west vehicles and spawn then in front of the player in rows of 5
<sqf>
<code>
// create an array of west vehicles and spawn then in front of the player in rows of 5
private ["_cfgArray","_xPos","_yPos","_veh"];
 
private ["_cfgArray", "_xPos", "_yPos", "_veh"];
 
_cfgArray = "(  
_cfgArray = "(  
    (getNumber (_x >> 'scope') >= 2) &&  
(getNumber (_x >> 'scope') >= 2) &&  
    {getNumber (_x >> 'side') == 1 &&  
{
    {getText (_x >> 'vehicleClass') in ['Armored', 'Car', 'Air']  
getNumber (_x >> 'side') == 1 &&  
        }  
{ getText (_x >> 'vehicleClass') in ['Armored', 'Car', 'Air'] }
    }  
}
)" configClasses (configFile >> "CfgVehicles");
)" configClasses (configFile >> "CfgVehicles");


Line 51: Line 71:


{
{
    _yPos = _yPos + 20;
_yPos = _yPos + 20;
    _veh = createVehicle [ ( configName _x ), player modelToWorld [_xPos, _yPos, 0], [], 0, "None"];
_veh = createVehicle [(configName _x), player modelToWorld [_xPos, _yPos, 0], [], 0, "NONE"];
    if (_yPos >= 100) then {
if (_yPos >= 100) then
        _yPos = 0;
{
        _xPos = _xPos + 20;
_yPos = 0;
    };
_xPos = _xPos + 20;
};
} forEach _cfgArray;
} forEach _cfgArray;
</sqf>
</code>
}}


<!-- Note Section END -->
{{Note
</dd>
|user= Benargee
</dl>
|timestamp= 20160528202800
 
|text= [[configClasses]] does not account for inherited subclasses, use [[configProperties]] with [[isClass]] filter instead
<h3 style="display:none">Bottom Section</h3>
<sqf>configProperties [_config, "isClass _x", true];</sqf>
}}


 
{{Note
[[Category:Scripting Commands|{{uc:{{PAGENAME}}}}]]
|user= Nelis75733126
[[Category:Arma_3:_New_Scripting_Commands_List|{{uc:{{PAGENAME}}}}]]
|timestamp= 20170528091800
[[Category:Scripting Commands Arma 3|{{uc:{{PAGENAME}}}}]]
|text= this will get a list of ALL locations on the currently loaded world
 
<sqf>
<!-- CONTINUE Notes -->
( "true" configClasses (configFile >> "CfgWorlds" >> worldName >> "names" ) ) apply {
<dl class="command_description">
<dd class="notedate">Posted on May 28, 2016 - 20:28 (UTC)</dd>
<dt class="note">[[User:Benargee|Benargee]]</dt>
<dd class="note">
[[configClasses]] does not account for inherited subclasses, use [[configProperties]] with [[isClass]] filter instead
<code>[[configProperties]] [_config, "[[isClass]] _x", [[true]]];</code>
</dd>
</dl>
<!-- DISCONTINUE Notes -->
 
<!-- CONTINUE Notes -->
<dl class="command_description">
<dd class="notedate">Posted on May 28, 2017 - 09:18 (UTC)</dd>
<dt class="note">[[User:IT07|IT07]]</dt>
<dd class="note">
this will get a list of ALL locations on the currently loaded world
<code>( "true" configClasses ( configFile >> "CfgWorlds" >> worldName >> "names" ) ) apply {
// change each config entry into a location
// change each config entry into a location
nearestLocation [
nearestLocation [
Line 95: Line 100:
getText ( _x >> "type" )
getText ( _x >> "type" )
]
]
};</code>
};
</dd>
</sqf>
</dl>
}}
<!-- DISCONTINUE Notes -->

Latest revision as of 10:49, 13 October 2025

Hover & click on the images for description

Description

Description:
Returns an array of config entries which meet criteria in condition code. Command iterates through all available config sub classes of the given config class. Current looked at config is stored in _x variable (similar to alternative count command implementation). Condition has to return true in order for the looked at config to be added to the resulting array. Slightly faster than configProperties, but doesn't account for config properties or inherited entries.
  • The condition code passed to configClasses should only be used for simple filter expressions and nothing more
  • Do not use "isClass _x" in the condition. The engine does this check already

  • Arma 3 v2.02 brought specific engine optimisations for the following conditions:
Groups:
Config

Syntax

Syntax:
condition configClasses config
Parameters:
condition: String
config: Config
Return Value:
Array - array of Configs

Alternative Syntax

Syntax:
configClasses [config, depth, includeInherited, allSubclasses, classNames]
Parameters:
config: Config - target config
depth: Number - how many levels of subclasses to go deep
includeInherited: Boolean - true to look through inherited classes
allSubclasses: Boolean - true to return all subclasses, false - to return only the last tier.
classnames: (Optional) Boolean - when true class names Strings are retuned, when false - Configs are returned. Default: false
Return Value:
Array - array of Configs or Strings, which represent class names.

Examples

Example 1:
collect all CfgVehicles configs:
_configs = "true" configClasses (configFile >> "CfgVehicles");
Example 2:
Return all classes that can transport 10 and more soldiers:
_transporters = "getNumber (_x >> 'transportSoldier') >= 10" configClasses (configFile >> "CfgVehicles");
Example 3:
Return all classes that inherit from 'RscText':
hint str ("inheritsFrom _x == (configFile >> 'RscText')" configClasses configFile);
Example 4:
Return children:
configClasses [configFile >> "CfgGroups", 0, true, true, true] //Returns ["West","East","Indep","Empty"]

Additional Information

See also:
Config configFile missionConfigFile configProperties configHierarchy BIS_fnc_returnChildren

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
Iceman77 - c
Posted on Oct 19, 2014 - 12:24 (UTC)
A fantastic way to filter stuff. eg:
// create an array of west vehicles and spawn then in front of the player in rows of 5 private ["_cfgArray", "_xPos", "_yPos", "_veh"]; _cfgArray = "( (getNumber (_x >> 'scope') >= 2) && { getNumber (_x >> 'side') == 1 && { getText (_x >> 'vehicleClass') in ['Armored', 'Car', 'Air'] } } )" configClasses (configFile >> "CfgVehicles"); _xPos = 0; _yPos = 0; { _yPos = _yPos + 20; _veh = createVehicle [(configName _x), player modelToWorld [_xPos, _yPos, 0], [], 0, "NONE"]; if (_yPos >= 100) then { _yPos = 0; _xPos = _xPos + 20; }; } forEach _cfgArray;
Benargee - c
Posted on May 28, 2016 - 20:28 (UTC)
configClasses does not account for inherited subclasses, use configProperties with isClass filter instead
configProperties [_config, "isClass _x", true];
Nelis75733126 - c
Posted on May 28, 2017 - 09:18 (UTC)
this will get a list of ALL locations on the currently loaded world
( "true" configClasses (configFile >> "CfgWorlds" >> worldName >> "names" ) ) apply { // change each config entry into a location nearestLocation [ getArray ( _x >> "position" ), getText ( _x >> "type" ) ] };