Fix global behavior in add / remove virtual items funcs (#5887)

This commit is contained in:
Josuan Albin 2017-12-10 18:53:51 +01:00 committed by PabstMirror
parent 845f3656d4
commit 5fa0179d06
3 changed files with 254 additions and 238 deletions

View File

@ -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;

View File

@ -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];
};

View File

@ -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];
}; };
}; };