canAdd: Difference between revisions

From Bohemia Interactive Community
m (Text replacement - "\{\{cc\|([^} ]*)\}\}" to "// $1")
m (Text replacement - "<code>([^<]*)\[\[([a-zA-Z][a-zA-Z0-9_]+)\]\]([^<]*) *<\/code>" to "<code>$1$2$3</code>")
Line 62: Line 62:
|r5= [[Boolean]]
|r5= [[Boolean]]


|x1= <code>[[if]] ([[player]] [[canAdd]] "FirstAidKit") [[then]]
|x1= <code>if ([[player]] [[canAdd]] "FirstAidKit") [[then]]
{
{
[[player]] [[addItem]] "FirstAidKit";
[[player]] [[addItem]] "FirstAidKit";
Line 69: Line 69:
{
{
[[hint]] "Not enough space";
[[hint]] "Not enough space";
};
};</code>
</code>


|x2= <code>[[if]] (_box [[canAdd]] "FirstAidKit") [[then]]
|x2= <code>if (_box [[canAdd]] "FirstAidKit") [[then]]
{
{
_box [[addWeaponCargo]] ["FirstAidKit", 1];
_box [[addWeaponCargo]] ["FirstAidKit", 1];
Line 79: Line 78:
{
{
[[hint]] "Not enough space";
[[hint]] "Not enough space";
};
};</code>
</code>


|x3= <code>car canAdd [<nowiki/>currentWeapon player, 50];</code>
|x3= <code>car canAdd [<nowiki/>currentWeapon player, 50];</code>
Line 108: Line 106:
Where '''_box''' is '''B_supplyCrate_F''':
Where '''_box''' is '''B_supplyCrate_F''':
<code>// empty
<code>// empty
_box [[canAdd]] "FirstAidKit"; // returns [[true]]
_box canAdd "FirstAidKit"; // returns [[true]]


// full
// full
_box [[canAdd]] "FirstAidKit"; // returns [[false]]
_box [[canAdd]] "FirstAidKit"; // returns [[false]]</code>
</code>
}}
}}



Revision as of 13:00, 12 May 2022

Hover & click on the images for description

Description

Description:
Checks if given object can be stored in inventory of given object or any inventory container (uniform, vest, backpack) of given unit. Since Arma 3 v2.09 this command will count unit storage space as whole, instead of as biggest container, when multiple items are queried.
Groups:
Unit Inventory

Syntax 1

Syntax:
object canAdd item
Parameters:
object: Object - unit or container
item: String - Config class
Return Value:
Boolean

Syntax 2

Syntax:
object canAdd [item, count]
Parameters:
object: Object - unit or container
item: String - Config class
count: Number - desired quantity
Return Value:
Boolean

Syntax 3

Syntax:
weapon canAdd item
Parameters:
weapon: String - Weapon class name
item: String - Config class of magazine or attachment
Return Value:
Boolean

Syntax 4

Syntax:
weapon canAdd [attachment, slot]
Parameters:
weapon: String - Weapon class name
attachment: String - Attachment class name
slot: String - Slot class name (defined under WeaponSlotsInfo class in weapon config)
Return Value:
Boolean

Syntax 5

Syntax:
weapon canAdd [magazine, muzzle]
Parameters:
weapon: String - Weapon class name
magazine: String - Magazine class name
muzzle: String - Muzzle class name
Return Value:
Boolean

Examples

Example 1:
if (player canAdd "FirstAidKit") then { player addItem "FirstAidKit"; } else { hint "Not enough space"; };
Example 2:
if (_box canAdd "FirstAidKit") then { _box addWeaponCargo ["FirstAidKit", 1]; } else { hint "Not enough space"; };
Example 3:
car canAdd [currentWeapon player, 50];
Example 4:
// check if attachment can be loaded "arifle_Katiba_GL_F" canAdd "acc_pointer_IR"; "arifle_Katiba_GL_F" canAdd ["acc_pointer_IR", "PointerSlot"];
Example 5:
// check if magazine can be loaded "arifle_Katiba_GL_F" canAdd "30Rnd_65x39_caseless_green"; "arifle_Katiba_GL_F" canAdd ["30Rnd_65x39_caseless_green", "this"]; "arifle_Katiba_GL_F" canAdd ["1Rnd_SmokeRed_Grenade_shell", "EGLM"];

Additional Information

See also:
canAddItemToBackpack canAddItemToUniform canAddItemToVest compatibleMagazines compatibleItems

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


Jonpas - c
Posted on Nov 29, 2015 - 00:02 (UTC)
Can also be used on any object that has inventory, not only player inventory containers.

Where _box is B_supplyCrate_F: // empty _box canAdd "FirstAidKit"; // returns true // full _box canAdd "FirstAidKit"; // returns false
Demellion - c
Posted on Feb 11, 2017 - 18:40 (UTC)
This can also be used as alternative to canAddItemToBackpack, canAddItemToUniform, canAddItemToVest where container might not be strictly defined. In some cases it might be a good optimisation for your code, where you also don't need to perform checks on which type of player container this is. Example:
private _container = selectRandom [uniformContainer player, vestContainer player, backpackContainer player]; if (_container canAdd "Rangefinder") then { _container addItemCargoGlobal ["Rangefinder", 1]; };