mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
Fix global behavior in add / remove virtual items funcs (#5887)
This commit is contained in:
parent
845f3656d4
commit
5fa0179d06
@ -5,6 +5,9 @@ GVAR(EH_ID) = 0;
|
|||||||
GVAR(lastSearchTextLeft) = "";
|
GVAR(lastSearchTextLeft) = "";
|
||||||
GVAR(lastSearchTextRight) = "";
|
GVAR(lastSearchTextRight) = "";
|
||||||
|
|
||||||
|
[QGVAR(addVirtualItems), {_this call FUNC(addVirtualItems)}] call CBA_fnc_addEventHandler;
|
||||||
|
[QGVAR(removeVirtualItems), {_this call FUNC(removeVirtualItems)}] call CBA_fnc_addEventHandler;
|
||||||
|
|
||||||
[QGVAR(initBox), {_this call FUNC(initBox)}] call CBA_fnc_addEventHandler;
|
[QGVAR(initBox), {_this call FUNC(initBox)}] call CBA_fnc_addEventHandler;
|
||||||
[QGVAR(removeBox), {_this call FUNC(removeBox)}] call CBA_fnc_addEventHandler;
|
[QGVAR(removeBox), {_this call FUNC(removeBox)}] call CBA_fnc_addEventHandler;
|
||||||
|
|
||||||
|
@ -24,7 +24,11 @@ params [["_object", objNull, [objNull]], ["_items", [], [true, []]], ["_global",
|
|||||||
if (_object == objNull) exitWith {};
|
if (_object == objNull) exitWith {};
|
||||||
if (_items isEqualType [] && {count _items == 0}) exitWith {};
|
if (_items isEqualType [] && {count _items == 0}) exitWith {};
|
||||||
|
|
||||||
private _cargo = _object getVariable [QGVAR(virtualItems), [
|
if (_global && {isMultiplayer}) then {
|
||||||
|
[QGVAR(addVirtualItems), [_object, _items, false]] call CBA_fnc_globalEvent;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
private _cargo = _object getVariable [QGVAR(virtualItems), [
|
||||||
[[], [], []], // Weapons 0, primary, secondary, handgun
|
[[], [], []], // Weapons 0, primary, secondary, handgun
|
||||||
[[], [], [], []], // WeaponAccessories 1, optic,side,muzzle,bipod
|
[[], [], [], []], // WeaponAccessories 1, optic,side,muzzle,bipod
|
||||||
[ ], // Magazines 2
|
[ ], // Magazines 2
|
||||||
@ -43,11 +47,12 @@ private _cargo = _object getVariable [QGVAR(virtualItems), [
|
|||||||
[ ], // WeaponThrow 15
|
[ ], // WeaponThrow 15
|
||||||
[ ], // WeaponPut 16
|
[ ], // WeaponPut 16
|
||||||
[ ] // InventoryItems 17
|
[ ] // InventoryItems 17
|
||||||
]];
|
]];
|
||||||
|
|
||||||
private _configCfgWeapons = configFile >> "CfgWeapons"; //Save this lookup in variable for perf improvement
|
private _configCfgWeapons = configFile >> "CfgWeapons"; //Save this lookup in variable for perf improvement
|
||||||
|
|
||||||
if (_items isEqualType true && {_items}) then {
|
if (_items isEqualType true) then {
|
||||||
|
if (_items) then {
|
||||||
private _configItems = uiNamespace getVariable QGVAR(configItems);
|
private _configItems = uiNamespace getVariable QGVAR(configItems);
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -67,8 +72,8 @@ if (_items isEqualType true && {_items}) then {
|
|||||||
(_cargo select _index) append (_configItems select _index);
|
(_cargo select _index) append (_configItems select _index);
|
||||||
_cargo set [_index, (_cargo select _index) arrayIntersect (_cargo select _index)];
|
_cargo set [_index, (_cargo select _index) arrayIntersect (_cargo select _index)];
|
||||||
};
|
};
|
||||||
|
};
|
||||||
} else {
|
} else {
|
||||||
{
|
{
|
||||||
if (_x isEqualType "") then {
|
if (_x isEqualType "") then {
|
||||||
private _configItemInfo = _configCfgWeapons >> _x >> "ItemInfo";
|
private _configItemInfo = _configCfgWeapons >> _x >> "ItemInfo";
|
||||||
@ -218,6 +223,7 @@ if (_items isEqualType true && {_items}) then {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
} foreach _items;
|
} foreach _items;
|
||||||
};
|
};
|
||||||
|
|
||||||
_object setVariable [QGVAR(virtualItems), _cargo, _global];
|
_object setVariable [QGVAR(virtualItems), _cargo];
|
||||||
|
};
|
||||||
|
@ -23,7 +23,11 @@ params [ ["_object", objNull, [objNull]], ["_items", [], [true, [""]]], ["_globa
|
|||||||
if (_object == objNull) exitWith {};
|
if (_object == objNull) exitWith {};
|
||||||
if (_items isEqualType [] && {count _items == 0}) exitWith {};
|
if (_items isEqualType [] && {count _items == 0}) exitWith {};
|
||||||
|
|
||||||
private _cargo = _object getVariable [QGVAR(virtualItems), [
|
if (_global && {isMultiplayer}) then {
|
||||||
|
[QGVAR(removeVirtualItems), [_object, _items, false]] call CBA_fnc_globalEvent;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
private _cargo = _object getVariable [QGVAR(virtualItems), [
|
||||||
[[], [], []], // Weapons 0, primary, handgun, secondary
|
[[], [], []], // Weapons 0, primary, handgun, secondary
|
||||||
[[], [], [], []], // WeaponAccessories 1, optic,side,muzzle,bipod
|
[[], [], [], []], // WeaponAccessories 1, optic,side,muzzle,bipod
|
||||||
[ ], // Magazines 2
|
[ ], // Magazines 2
|
||||||
@ -42,12 +46,14 @@ private _cargo = _object getVariable [QGVAR(virtualItems), [
|
|||||||
[ ], // WeaponThrow 15
|
[ ], // WeaponThrow 15
|
||||||
[ ], // WeaponPut 16
|
[ ], // WeaponPut 16
|
||||||
[ ] // InventoryItems 17
|
[ ] // InventoryItems 17
|
||||||
]];
|
]];
|
||||||
|
|
||||||
if (_items isEqualType true && {_items}) then {
|
if (_items isEqualType true) then {
|
||||||
|
if (_items) then {
|
||||||
[_object, _global] call FUNC(removeBox);
|
[_object, _global] call FUNC(removeBox);
|
||||||
_object setVariable [QGVAR(virtualItems), nil, _global];
|
_object setVariable [QGVAR(virtualItems), nil, _global];
|
||||||
} else {
|
};
|
||||||
|
} else {
|
||||||
|
|
||||||
// Make sure all items are in string form
|
// Make sure all items are in string form
|
||||||
_items = _items select {_x isEqualType "" && {_x != ""}};
|
_items = _items select {_x isEqualType "" && {_x != ""}};
|
||||||
@ -72,9 +78,10 @@ if (_items isEqualType true && {_items}) then {
|
|||||||
};
|
};
|
||||||
} count _cargo;
|
} count _cargo;
|
||||||
|
|
||||||
|
_object setVariable [QGVAR(virtualItems), _cargo];
|
||||||
|
|
||||||
if (_itemCount == 0) then {
|
if (_itemCount == 0) then {
|
||||||
[_object, _global] call FUNC(removeBox);
|
[_object, false] call FUNC(removeBox);
|
||||||
} else {
|
};
|
||||||
_object setVariable [QGVAR(virtualItems), _cargo, _global];
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user