mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
Fixes
This commit is contained in:
parent
3b181cb1b0
commit
05b8b5bd42
@ -20,7 +20,8 @@
|
|||||||
params ["_deviceId", "_otherDeviceId"];
|
params ["_deviceId", "_otherDeviceId"];
|
||||||
|
|
||||||
private _id = QGVAR(chatMessages);
|
private _id = QGVAR(chatMessages);
|
||||||
private _deviceIds = [_deviceId, _otherDeviceId] sort true;
|
private _deviceIds = [_deviceId, _otherDeviceId];
|
||||||
|
_deviceIds sort true;
|
||||||
|
|
||||||
{
|
{
|
||||||
_id = _id + _x;
|
_id = _id + _x;
|
||||||
|
@ -24,7 +24,7 @@ params ["_deviceId", "_otherDeviceId"];
|
|||||||
private _deviceDataOne = [_deviceId] call FUNC(getDeviceData);
|
private _deviceDataOne = [_deviceId] call FUNC(getDeviceData);
|
||||||
private _deviceDataTwo = [_otherDeviceId] call FUNC(getDeviceData);
|
private _deviceDataTwo = [_otherDeviceId] call FUNC(getDeviceData);
|
||||||
|
|
||||||
if (_deviceDataOne isEqualTo [] || _deviceDataTwo isEqualTo []) exitwith {[]}; // neither are valid devices
|
if (_deviceDataOne isEqualTo [] || {_deviceDataTwo isEqualTo []}) exitwith {[]}; // neither are valid devices
|
||||||
|
|
||||||
private _messagesId = [_deviceId, _otherDeviceId] call FUNC(chatMessage_getId);
|
private _messagesId = [_deviceId, _otherDeviceId] call FUNC(chatMessage_getId);
|
||||||
|
|
||||||
|
@ -18,9 +18,10 @@ params ["_unit", "_item"];
|
|||||||
|
|
||||||
if !(local _unit) exitwith {};
|
if !(local _unit) exitwith {};
|
||||||
|
|
||||||
if (isText (configFile >> "CfgWeapons" >> _item >> QGVAR(deviceType)) && {getText(configFile >> "CfgWeapons" >> _item >> QGVAR(deviceType)) != ""}) then {
|
private _configEntry = configFile >> "CfgWeapons" >> _item >> QGVAR(deviceType);
|
||||||
|
if (isText _configEntry && {(getText _configEntry) != ""}) then {
|
||||||
|
|
||||||
if !(isClass (configFile >> "ACE_BFT" >> "Devices" >> (getText(configFile >> "CfgWeapons" >> _item >> QGVAR(deviceType))))) exitwith {};
|
if !(isClass (configFile >> "ACE_BFT" >> "Devices" >> (getText _configEntry))) exitwith {};
|
||||||
|
|
||||||
systemChat format["%1 BFT enabled item %2", _unit, _item];
|
systemChat format["%1 BFT enabled item %2", _unit, _item];
|
||||||
diag_log format["%1 BFT enabled item %2", _unit, _item];
|
diag_log format["%1 BFT enabled item %2", _unit, _item];
|
||||||
@ -34,7 +35,7 @@ if (isText (configFile >> "CfgWeapons" >> _item >> QGVAR(deviceType)) && {getTex
|
|||||||
private _previousMags = magazinesDetail _unit;
|
private _previousMags = magazinesDetail _unit;
|
||||||
_unit addMagazine _magazine;
|
_unit addMagazine _magazine;
|
||||||
private _newMags = (magazinesDetail _unit) - _previousMags;
|
private _newMags = (magazinesDetail _unit) - _previousMags;
|
||||||
if ((count _newMags) == 0) exitWith {ERROR("failed to add magazine (inventory full?)");};
|
if (_newMags isEqualTo []) exitWith {ERROR("failed to add magazine (inventory full?)");};
|
||||||
private _newMagName = _newMags select 0;
|
private _newMagName = _newMags select 0;
|
||||||
|
|
||||||
private _magID = [_newMagName] call FUNC(getMagazineID);
|
private _magID = [_newMagName] call FUNC(getMagazineID);
|
||||||
|
@ -16,4 +16,4 @@
|
|||||||
|
|
||||||
params ["_keySetOne", "_keySetTwo"];
|
params ["_keySetOne", "_keySetTwo"];
|
||||||
|
|
||||||
count (_keySetOne arrayIntersect _keySetTwo) > 0
|
!((_keySetOne arrayIntersect _keySetTwo) isEqualTo [])
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
private _newKeyArray = [];
|
private _newKeyArray = [];
|
||||||
|
|
||||||
for "_i" from 1 to 15 /* step +1 */ do {
|
for "_i" from 1 to 15 /* step +1 */ do {
|
||||||
_newKeyArray pushback (48 + floor(random(74)));
|
_newKeyArray pushback (48 + floor (random 74));
|
||||||
};
|
};
|
||||||
|
|
||||||
(toString _newKeyArray)
|
toString _newKeyArray
|
||||||
|
@ -20,4 +20,4 @@ if (typeName _side == "OBJECT") then {
|
|||||||
_side = str side _side;
|
_side = str side _side;
|
||||||
};
|
};
|
||||||
|
|
||||||
(missionNamespace getvariable [format[QGVAR(%1_encryptionKey), _side], [""]])
|
missionNamespace getvariable [format[QGVAR(%1_encryptionKey), _side], [""]]
|
||||||
|
@ -29,8 +29,9 @@ private _interfaces = [];
|
|||||||
if (_deviceOwner isKindOf "ParachuteBase" || {_deviceOwner isKindOf "CAManBase"}) then {
|
if (_deviceOwner isKindOf "ParachuteBase" || {_deviceOwner isKindOf "CAManBase"}) then {
|
||||||
// personal device
|
// personal device
|
||||||
private _deviceType = D_GET_DEVICETYPE(_deviceData);
|
private _deviceType = D_GET_DEVICETYPE(_deviceData);
|
||||||
if (isText (configFile >> "ACE_BFT" >> "Devices" >> _deviceType >> "interface")) then {
|
private _config = configFile >> "ACE_BFT" >> "Devices" >> _deviceType >> "interface";
|
||||||
private _interface = getText (configFile >> "ACE_BFT" >> "Devices" >> _deviceType >> "interface");
|
if (isText _config) then {
|
||||||
|
private _interface = getText _config;
|
||||||
if (_interface != "") then {
|
if (_interface != "") then {
|
||||||
_interfaces pushBack _interface;
|
_interfaces pushBack _interface;
|
||||||
};
|
};
|
||||||
|
@ -16,8 +16,9 @@
|
|||||||
|
|
||||||
params ["_side", "_type"];
|
params ["_side", "_type"];
|
||||||
|
|
||||||
if (isClass (configFile >> "ACE_BFT" >> "Types" >> _type)) exitwith {
|
private _config = configFile >> "ACE_BFT" >> "Types" >> _type;
|
||||||
getText (configFile >> "ACE_BFT" >> "Types" >> _type >> "iconPath");
|
if (isClass _config) exitwith {
|
||||||
|
getText (_config >> "iconPath");
|
||||||
};
|
};
|
||||||
|
|
||||||
"\A3\ui_f\data\map\markers\nato\b_inf.paa"
|
"\A3\ui_f\data\map\markers\nato\b_inf.paa"
|
||||||
|
@ -41,7 +41,7 @@ if (_this select 1) then { // add new
|
|||||||
if (!(D_GET_OWNER(_data) isKindOf "CAManBAse") && {D_GET_DEVICE_STATE_VALUE(_data) isEqualTo STATE_NORMAL} && {!(isEngineOn D_GET_OWNER(_data)) && alive D_GET_OWNER(_data)}) exitwith {};
|
if (!(D_GET_OWNER(_data) isKindOf "CAManBAse") && {D_GET_DEVICE_STATE_VALUE(_data) isEqualTo STATE_NORMAL} && {!(isEngineOn D_GET_OWNER(_data)) && alive D_GET_OWNER(_data)}) exitwith {};
|
||||||
if (D_GET_DEVICE_STATE_VALUE(_data) in [STATE_OFFLINE, STATE_DESTROYED]) exitwith {};
|
if (D_GET_DEVICE_STATE_VALUE(_data) in [STATE_OFFLINE, STATE_DESTROYED]) exitwith {};
|
||||||
private _displayData = _data call FUNC(deviceDataToMapData);
|
private _displayData = _data call FUNC(deviceDataToMapData);
|
||||||
if (count _displayData > 0) then {
|
if !(_displayData isEqualTo []) then {
|
||||||
GVAR(availableDevices) pushback _displayData;
|
GVAR(availableDevices) pushback _displayData;
|
||||||
};
|
};
|
||||||
} else { // update existing
|
} else { // update existing
|
||||||
|
@ -28,7 +28,7 @@ if (_add) then {
|
|||||||
// Adding a new key isn't nice. Now we got to add new shit and loop through the massive data collection. yay?
|
// Adding a new key isn't nice. Now we got to add new shit and loop through the massive data collection. yay?
|
||||||
{
|
{
|
||||||
if !(isNull D_GET_OWNER(_x)) then {
|
if !(isNull D_GET_OWNER(_x)) then {
|
||||||
if (!(D_GET_OWNER(_x) isKindOf "CAManBAse") && {D_GET_DEVICE_STATE_VALUE(_x) isEqualTo STATE_NORMAL} && {!(isEngineOn D_GET_OWNER(_x)) && alive D_GET_OWNER(_data)}) exitwith {};
|
if (!(D_GET_OWNER(_x) isKindOf "CAManBAse") && {D_GET_DEVICE_STATE_VALUE(_x) isEqualTo STATE_NORMAL} && {!(isEngineOn D_GET_OWNER(_x)) && alive D_GET_OWNER(_x)}) exitwith {};
|
||||||
if (D_GET_DEVICE_STATE_VALUE(_x) in [STATE_OFFLINE, STATE_DESTROYED]) exitwith {};
|
if (D_GET_DEVICE_STATE_VALUE(_x) in [STATE_OFFLINE, STATE_DESTROYED]) exitwith {};
|
||||||
private _encryptionKeys = D_GET_ENCRYPTION(_x);
|
private _encryptionKeys = D_GET_ENCRYPTION(_x);
|
||||||
if !([_encryptionKeys, _newEncryptionKeys] call FUNC(encryptionKeyMatch)) exitWith {};
|
if !([_encryptionKeys, _newEncryptionKeys] call FUNC(encryptionKeyMatch)) exitWith {};
|
||||||
|
@ -27,7 +27,7 @@ if (count _viewModes == 0) exitWith {};
|
|||||||
if (_add) then {
|
if (_add) then {
|
||||||
{
|
{
|
||||||
if !(isNull D_GET_OWNER(_x)) then {
|
if !(isNull D_GET_OWNER(_x)) then {
|
||||||
if (!(D_GET_OWNER(_x) isKindOf "CAManBAse") && {D_GET_DEVICE_STATE_VALUE(_x) isEqualTo STATE_NORMAL} && {!(isEngineOn D_GET_OWNER(_x)) && alive D_GET_OWNER(_data)}) exitwith {};
|
if (!(D_GET_OWNER(_x) isKindOf "CAManBAse") && {D_GET_DEVICE_STATE_VALUE(_x) isEqualTo STATE_NORMAL} && {!(isEngineOn D_GET_OWNER(_x)) && alive D_GET_OWNER(_x)}) exitwith {};
|
||||||
if (D_GET_DEVICE_STATE_VALUE(_x) in [STATE_OFFLINE, STATE_DESTROYED]) exitwith {};
|
if (D_GET_DEVICE_STATE_VALUE(_x) in [STATE_OFFLINE, STATE_DESTROYED]) exitwith {};
|
||||||
private _deviceModes = D_GET_DEVICEMODES(_x);
|
private _deviceModes = D_GET_DEVICEMODES(_x);
|
||||||
if !([_deviceModes, _viewModes] call FUNC(encryptionKeyMatch)) exitWith {};
|
if !([_deviceModes, _viewModes] call FUNC(encryptionKeyMatch)) exitWith {};
|
||||||
@ -42,7 +42,7 @@ if (_add) then {
|
|||||||
};
|
};
|
||||||
} foreach GVAR(deviceData);
|
} foreach GVAR(deviceData);
|
||||||
} else { // if we remove one, we only have to check the already available devices
|
} else { // if we remove one, we only have to check the already available devices
|
||||||
private ["_device","_i"];
|
private ["_device"];
|
||||||
|
|
||||||
for "_i" from (count GVAR(availableDevices) - 1) to 0 step -1 do {
|
for "_i" from (count GVAR(availableDevices) - 1) to 0 step -1 do {
|
||||||
_device = GVAR(availableDevices) select _i;
|
_device = GVAR(availableDevices) select _i;
|
||||||
@ -52,6 +52,6 @@ if (_add) then {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
if (count GVAR(currentOpenedDevice) > 0) then {
|
if !(GVAR(currentOpenedDevice) isEqualTo []) then {
|
||||||
[GVAR(currentOpenedDevice)] call FUNC(removeDeviceByOwner);
|
[GVAR(currentOpenedDevice)] call FUNC(removeDeviceByOwner);
|
||||||
};
|
};
|
||||||
|
@ -26,7 +26,7 @@ private _variable = missionNamespace getvariable [_varName, []];
|
|||||||
{
|
{
|
||||||
private _compareID = if (typeName _x == "ARRAY") then {_x select 0} else {_x};
|
private _compareID = if (typeName _x == "ARRAY") then {_x select 0} else {_x};
|
||||||
if (_compareID isEqualTo _elementID) exitwith {
|
if (_compareID isEqualTo _elementID) exitwith {
|
||||||
_variable set[_forEachIndex, _data];
|
_variable set [_forEachIndex, _data];
|
||||||
["bft_syncedArrayChanged", [1, _data, _x]] call CBA_fnc_localEvent;
|
["bft_syncedArrayChanged", [1, _data, _x]] call CBA_fnc_localEvent;
|
||||||
};
|
};
|
||||||
} forEach _variable;
|
} forEach _variable;
|
||||||
|
@ -18,4 +18,4 @@ params ["_unit", "_deviceID"];
|
|||||||
|
|
||||||
private _ownedIDs = _unit getvariable [QGVAR(ownedDevices), []];
|
private _ownedIDs = _unit getvariable [QGVAR(ownedDevices), []];
|
||||||
|
|
||||||
(_deviceID in _ownedIDs)
|
_deviceID in _ownedIDs
|
||||||
|
@ -18,7 +18,7 @@ params ["_deviceID", "_deviceData"];
|
|||||||
|
|
||||||
private _data = [_deviceID] call FUNC(getDeviceData);
|
private _data = [_deviceID] call FUNC(getDeviceData);
|
||||||
|
|
||||||
if (count _data == 0) exitwith {};
|
if (_data isEqualTo []) exitwith {};
|
||||||
if (_deviceData isEqualTo (_data select 3)) exitwith {};
|
if (_deviceData isEqualTo (_data select 3)) exitwith {};
|
||||||
|
|
||||||
["bft_updateDeviceData", [_deviceID, _deviceData]] call CBA_fnc_globalEvent;
|
["bft_updateDeviceData", [_deviceID, _deviceData]] call CBA_fnc_globalEvent;
|
||||||
|
@ -18,7 +18,7 @@ params ["_varName"];
|
|||||||
private _variable = missionNamespace getvariable [_varName, []];
|
private _variable = missionNamespace getvariable [_varName, []];
|
||||||
private _nextID = 0;
|
private _nextID = 0;
|
||||||
|
|
||||||
if (count _variable > 0) then {
|
if !(_variable isEqualTo []) then {
|
||||||
_nextID = ((_variable select (count _variable - 1)) select 0) + 1;
|
_nextID = ((_variable select (count _variable - 1)) select 0) + 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -16,6 +16,6 @@
|
|||||||
|
|
||||||
params ["_varName", "_data"];
|
params ["_varName", "_data"];
|
||||||
|
|
||||||
if (typeName _data == "ARRAY" && {(count _data == 0)}) exitwith {};
|
if (typeName _data == "ARRAY" && {_data isEqualTo []}) exitwith {};
|
||||||
|
|
||||||
["bft_syncedArrayPushback", [_varName, _data]] call CBA_fnc_globalEvent;
|
["bft_syncedArrayPushback", [_varName, _data]] call CBA_fnc_globalEvent;
|
||||||
|
@ -16,6 +16,6 @@
|
|||||||
|
|
||||||
params ["_varName", "_data"];
|
params ["_varName", "_data"];
|
||||||
|
|
||||||
if (typeName _data == "ARRAY" && (count _data == 0)) exitwith {};
|
if (typeName _data == "ARRAY" && {_data isEqualTo []}) exitwith {};
|
||||||
|
|
||||||
["bft_syncedArrayUpdate", _this] call CBA_fnc_globalEvent;
|
["bft_syncedArrayUpdate", _this] call CBA_fnc_globalEvent;
|
||||||
|
@ -30,14 +30,14 @@ if (isNil "_add") then {
|
|||||||
if (_add) then {
|
if (_add) then {
|
||||||
// figure out the real difference
|
// figure out the real difference
|
||||||
_keys = _keys - GVAR(registeredEncyptionKeys);
|
_keys = _keys - GVAR(registeredEncyptionKeys);
|
||||||
if (count _keys > 0) then {
|
if !(_keys isEqualTo []) then {
|
||||||
GVAR(registeredEncyptionKeys) = GVAR(registeredEncyptionKeys) + _keys;
|
GVAR(registeredEncyptionKeys) = GVAR(registeredEncyptionKeys) + _keys;
|
||||||
_changed = true;
|
_changed = true;
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
// figure out the real difference
|
// figure out the real difference
|
||||||
_keys = GVAR(registeredEncyptionKeys) - (GVAR(registeredEncyptionKeys) - _keys);
|
_keys = GVAR(registeredEncyptionKeys) - (GVAR(registeredEncyptionKeys) - _keys);
|
||||||
if (count _keys > 0) then {
|
if !(_keys isEqualTo []) then {
|
||||||
GVAR(registeredEncyptionKeys) = GVAR(registeredEncyptionKeys) - _keys;
|
GVAR(registeredEncyptionKeys) = GVAR(registeredEncyptionKeys) - _keys;
|
||||||
_changed = true;
|
_changed = true;
|
||||||
};
|
};
|
||||||
|
@ -30,14 +30,14 @@ if (isNil "_add") then {
|
|||||||
if (_add) then {
|
if (_add) then {
|
||||||
// figure out the real difference
|
// figure out the real difference
|
||||||
_modes = _modes - GVAR(registeredViewModes);
|
_modes = _modes - GVAR(registeredViewModes);
|
||||||
if (count _modes > 0) then {
|
if !(_modes isEqualTo []) then {
|
||||||
GVAR(registeredViewModes) = GVAR(registeredViewModes) + _modes;
|
GVAR(registeredViewModes) = GVAR(registeredViewModes) + _modes;
|
||||||
_changed = true;
|
_changed = true;
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
// figure out the real difference
|
// figure out the real difference
|
||||||
_modes = GVAR(registeredViewModes) - (GVAR(registeredViewModes) - _modes);
|
_modes = GVAR(registeredViewModes) - (GVAR(registeredViewModes) - _modes);
|
||||||
if (count _modes > 0) then {
|
if !(_modes isEqualTo []) then {
|
||||||
GVAR(registeredViewModes) = GVAR(registeredViewModes) - _modes;
|
GVAR(registeredViewModes) = GVAR(registeredViewModes) - _modes;
|
||||||
_changed = true;
|
_changed = true;
|
||||||
};
|
};
|
||||||
|
@ -26,7 +26,7 @@ private _matchedIDs = [];
|
|||||||
{
|
{
|
||||||
private _magID = [_x] call FUNC(getMagazineID);
|
private _magID = [_x] call FUNC(getMagazineID);
|
||||||
private _data = [_magID] call FUNC(getDeviceData);
|
private _data = [_magID] call FUNC(getDeviceData);
|
||||||
if (count _data > 0) then {
|
if !(_data isEqualTo []) then {
|
||||||
if !(_magID in _ownedDevices) then {
|
if !(_magID in _ownedDevices) then {
|
||||||
systemChat format["validate - new picked up ID: %1 %2", _unit, _magID];
|
systemChat format["validate - new picked up ID: %1 %2", _unit, _magID];
|
||||||
diag_log format["validate - new picked up ID: %1 %2", _unit, _magID];
|
diag_log format["validate - new picked up ID: %1 %2", _unit, _magID];
|
||||||
@ -36,8 +36,9 @@ private _matchedIDs = [];
|
|||||||
} else {
|
} else {
|
||||||
if (!(_magId in GVAR(pendingIdAssignmentList))) then {
|
if (!(_magId in GVAR(pendingIdAssignmentList))) then {
|
||||||
private _magazine = (magazines _unit) select _forEachIndex;
|
private _magazine = (magazines _unit) select _forEachIndex;
|
||||||
if (getText (configFile >> "CfgMagazines" >> _magazine >> QGVAR(type)) != "") then {
|
private _configText = getText (configFile >> "CfgMagazines" >> _magazine >> QGVAR(type));
|
||||||
["bft_itemCreated", [_unit, getText (configFile >> "CfgMagazines" >> _magazine >> QGVAR(type)), _magazine, _magID]] call CBA_fnc_serverEvent;
|
if (_configText != "") then {
|
||||||
|
["bft_itemCreated", [_unit, _configText, _magazine, _magID]] call CBA_fnc_serverEvent;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
disableSerialization;
|
disableSerialization;
|
||||||
|
|
||||||
// make sure there is no PFH already, the interface is open and notifications are available
|
// make sure there is no PFH already, the interface is open and notifications are available
|
||||||
if (isNil QGVAR(processNotificationsPFH) && !(I_CLOSED) && count GVAR(notificationCache) != 0) then {
|
if (isNil QGVAR(processNotificationsPFH) && {!I_CLOSED} && {!(GVAR(notificationCache) isEqualTo [])}) then {
|
||||||
private _displayName = I_GET_NAME;
|
private _displayName = I_GET_NAME;
|
||||||
private _display = uiNamespace getVariable _displayName;
|
private _display = uiNamespace getVariable _displayName;
|
||||||
private _ctrl = _display displayCtrl IDC_NOTIFICATION;
|
private _ctrl = _display displayCtrl IDC_NOTIFICATION;
|
||||||
|
@ -74,10 +74,10 @@ private _combinedPropertiesUpdate = [] call CBA_fnc_hashCreate;
|
|||||||
if (!I_CLOSED) then {
|
if (!I_CLOSED) then {
|
||||||
call {
|
call {
|
||||||
if (!_updateInterface) exitWith {};
|
if (!_updateInterface) exitWith {};
|
||||||
if (count _combinedPropertiesUpdate > 0) exitWith {
|
if !(_combinedPropertiesUpdate isEqualTo []) exitWith {
|
||||||
[_combinedPropertiesUpdate] call FUNC(ifUpdate);
|
[_combinedPropertiesUpdate] call FUNC(ifUpdate);
|
||||||
};
|
};
|
||||||
if (count _commonPropertiesUpdate > 0) then {
|
if !(_commonPropertiesUpdate isEqualTo []) then {
|
||||||
[_commonPropertiesUpdate] call FUNC(ifUpdate);
|
[_commonPropertiesUpdate] call FUNC(ifUpdate);
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user