mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
4d71607e81
* Add macro for virtualItems index 0 (weapons) * Add macro for virtualItems index 1 (attachments) * Add macro for virtualItems index 2 (all items) * Add macro for virtualItems index 3 (headgear) * Add macro for virtualItems index 4 (uniform) * Add macro for virtualItems index 5 (vest) * Add macro for virtualItems index 6 (backpack) * Add macro for virtualItems index 7 (goggles)
240 lines
8.8 KiB
Plaintext
240 lines
8.8 KiB
Plaintext
#include "script_component.hpp"
|
|
#include "..\defines.hpp"
|
|
/*
|
|
* Author: Alganthe
|
|
* Verify the provided loadout.
|
|
*
|
|
* Arguments:
|
|
* 0: Loadout <ARRAY> (getUnitLoadout format)
|
|
*
|
|
* Return Value:
|
|
* Verified loadout and missing / unavailable items list and count <ARRAY>
|
|
*
|
|
* Public: No
|
|
*/
|
|
|
|
params ["_loadout"];
|
|
|
|
private _weaponCfg = configFile >> "CfgWeapons";
|
|
private _magCfg = configFile >> "CfgMagazines";
|
|
private _vehcCfg = configFile >> "CfgVehicles";
|
|
private _glassesCfg = configFile >> "CfgGlasses";
|
|
private _weaponsArray = GVAR(virtualItems) select IDX_VIRT_WEAPONS;
|
|
private _accsArray = GVAR(virtualItems) select IDX_VIRT_ATTACHEMENTS;
|
|
|
|
private _nullItemsAmount = 0;
|
|
private _unavailableItemsAmount = 0;
|
|
private _nullItemsList = [];
|
|
private _unavailableItemsList = [];
|
|
|
|
private _fnc_weaponCheck = {
|
|
params ["_dataPath"];
|
|
|
|
if (count _dataPath != 0) then {
|
|
{
|
|
if (_x isEqualType "") then {
|
|
|
|
private _item = _x;
|
|
|
|
if (_item != "") then {
|
|
if (isClass (_weaponCfg >> _item)) then {
|
|
if !(CHECK_WEAPON_OR_ACC) then {
|
|
|
|
_unavailableItemsList pushBackUnique _item;
|
|
_dataPath set [_forEachIndex, ""];
|
|
_unavailableItemsAmount = _unavailableItemsAmount + 1;
|
|
};
|
|
} else {
|
|
|
|
_nullItemsList pushBackUnique _item;
|
|
_dataPath set [_forEachIndex, ""];
|
|
_nullItemsAmount = _nullItemsAmount + 1;
|
|
};
|
|
};
|
|
|
|
} else {
|
|
|
|
if (count _x != 0) then {
|
|
private _mag = _x select 0;
|
|
|
|
if (isClass (_magCfg >> _mag)) then {
|
|
if !(_mag in (GVAR(virtualItems) select IDX_VIRT_ITEMS_ALL)) then {
|
|
|
|
_unavailableItemsList pushBackUnique _mag;
|
|
_dataPath set [_forEachIndex, []];
|
|
_unavailableItemsAmount = _unavailableItemsAmount + 1;
|
|
};
|
|
} else {
|
|
|
|
_nullItemsList pushBackUnique _mag;
|
|
_dataPath set [_forEachIndex, []];
|
|
_nullItemsAmount = _nullItemsAmount + 1;
|
|
};
|
|
};
|
|
};
|
|
} foreach _dataPath;
|
|
};
|
|
};
|
|
|
|
for "_dataIndex" from 0 to 9 do {
|
|
switch (_dataIndex) do {
|
|
case 0;
|
|
case 1;
|
|
case 2;
|
|
case 8: {
|
|
[_loadout select _dataIndex] call _fnc_weaponCheck;
|
|
};
|
|
|
|
case 3;
|
|
case 4;
|
|
case 5: {
|
|
private _containerArray = (_loadout select _dataIndex);
|
|
|
|
if (count _containerArray != 0) then {
|
|
|
|
_containerArray params ["_item", "_containerItems"];
|
|
|
|
if (isClass (_vehcCfg >> _item) || {isClass (_weaponCfg >> _item)}) then {
|
|
if !(CHECK_CONTAINER) then {
|
|
|
|
_unavailableItemsList pushBackUnique _item;
|
|
_loadout set [_dataIndex, []];
|
|
_unavailableItemsAmount = _unavailableItemsAmount + 1;
|
|
} else {
|
|
|
|
if (count _containerItems != 0) then {
|
|
{
|
|
private _currentIndex = _forEachIndex;
|
|
|
|
switch (count _x) do {
|
|
case 2: {
|
|
|
|
if ((_x select 0) isEqualType "") then {
|
|
|
|
private _item = _x select 0;
|
|
|
|
if (CLASS_CHECK_ITEM) then {
|
|
if !(CHECK_CONTAINER_ITEMS) then {
|
|
|
|
_unavailableItemsList pushBackUnique _item;
|
|
((_loadout select _dataIndex) select 1) set [_currentIndex, []];
|
|
_unavailableItemsAmount = _unavailableItemsAmount + 1;
|
|
};
|
|
} else {
|
|
|
|
_nullItemsList pushBackUnique _item;
|
|
((_loadout select _dataIndex) select 1) set [_currentIndex, []];
|
|
_nullItemsAmount = _nullItemsAmount + 1;
|
|
};
|
|
} else {
|
|
|
|
[(((_loadout select _dataIndex) select 1) select _currentIndex) select 0] call _fnc_weaponCheck;
|
|
};
|
|
};
|
|
|
|
case 3: {
|
|
private _item = _x select 0;
|
|
|
|
if (isClass (_magCfg >> _item)) then {
|
|
if !(
|
|
_item in (GVAR(virtualItems) select IDX_VIRT_ITEMS_ALL) ||
|
|
_item in (GVAR(virtualItems) select 15) ||
|
|
_item in (GVAR(virtualItems) select 16)
|
|
) then {
|
|
|
|
_unavailableItemsList pushBackUnique _item;
|
|
((_loadout select _dataIndex) select 1) set [_currentIndex, []];
|
|
_unavailableItemsAmount = _unavailableItemsAmount + 1;
|
|
};
|
|
} else {
|
|
|
|
_nullItemsList pushBackUnique _item;
|
|
((_loadout select _dataIndex) select 1) set [_currentIndex, []];
|
|
_nullItemsAmount = _nullItemsAmount + 1;
|
|
};
|
|
};
|
|
};
|
|
} foreach _containerItems;
|
|
};
|
|
};
|
|
} else {
|
|
|
|
_nullItemsList pushBackUnique _item;
|
|
_loadout set [_dataIndex, []];
|
|
_nullItemsAmount = _nullItemsAmount + 1;
|
|
};
|
|
};
|
|
};
|
|
|
|
case 6: {
|
|
private _item = _loadout select _dataIndex;
|
|
|
|
if (_item != "") then {
|
|
|
|
if (isClass (_weaponCfg >> _item)) then {
|
|
|
|
if !(_item in (GVAR(virtualItems) select IDX_VIRT_HEADGEAR)) then {
|
|
|
|
_unavailableItemsList pushBackUnique _item;
|
|
_loadout set [_dataIndex, ""];
|
|
_unavailableItemsAmount = _unavailableItemsAmount + 1;
|
|
};
|
|
} else {
|
|
|
|
_nullItemsList pushBackUnique _item;
|
|
_loadout set [_dataIndex, ""];
|
|
_nullItemsAmount = _nullItemsAmount + 1;
|
|
};
|
|
};
|
|
};
|
|
|
|
case 7: {
|
|
private _item = _loadout select _dataIndex;
|
|
|
|
if (_item != "") then {
|
|
|
|
if (isClass (_glassesCfg >> _item)) then {
|
|
|
|
if !(_item in (GVAR(virtualItems) select IDX_VIRT_GOGGLES)) then {
|
|
|
|
_unavailableItemsList pushBackUnique _item;
|
|
_loadout set [_dataIndex, ""];
|
|
_unavailableItemsAmount = _unavailableItemsAmount + 1;
|
|
};
|
|
} else {
|
|
|
|
_nullItemsList pushBackUnique _item;
|
|
_loadout set [_dataIndex, ""];
|
|
_nullItemsAmount = _nullItemsAmount + 1;
|
|
};
|
|
};
|
|
};
|
|
|
|
case 9: {
|
|
for "_subIndex" from 0 to 5 do {
|
|
private _item = (_loadout select _dataIndex) select _subIndex;
|
|
|
|
if (_item != "") then {
|
|
|
|
if (isClass (_weaponCfg >> _item)) then {
|
|
|
|
if !(CHECK_ASSIGNED_ITEMS) then {
|
|
|
|
_unavailableItemsList pushBackUnique _item;
|
|
(_loadout select _dataIndex) set [_subIndex, ""];
|
|
_unavailableItemsAmount = _unavailableItemsAmount + 1;
|
|
};
|
|
} else {
|
|
|
|
_nullItemsList pushBackUnique _item;
|
|
(_loadout select _dataIndex) set [_subIndex, ""];
|
|
_nullItemsAmount = _nullItemsAmount + 1;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
[_loadout, _nullItemsAmount, _unavailableItemsAmount, _nullItemsList, _unavailableItemsList]
|