Vehicle Lock - Enable for planes (#6646)

* enable vehicle lock module for planes

* Add actions to planes

* improved lazy eval

* remove superfluous parent class check

* IS_KIND_OF_ANY macro

* Update addons/vehiclelock/functions/fnc_moduleSync.sqf

* Improve handleVehicleInitPost XEH
This commit is contained in:
commy2 2018-10-21 23:37:16 +02:00 committed by PabstMirror
parent 6f6b0d15f8
commit 001942b2ed
6 changed files with 31 additions and 46 deletions

View File

@ -16,21 +16,3 @@ class Extended_PostInit_EventHandlers {
init = QUOTE(call COMPILE_FILE(XEH_postInit)); init = QUOTE(call COMPILE_FILE(XEH_postInit));
}; };
}; };
class Extended_InitPost_EventHandlers {
class Car {
class ADDON {
serverInit = QUOTE(_this call FUNC(handleVehicleInitPost));
};
};
class Tank {
class ADDON {
serverInit = QUOTE(_this call FUNC(handleVehicleInitPost));
};
};
class Helicopter {
class ADDON {
serverInit = QUOTE(_this call FUNC(handleVehicleInitPost));
};
};
};

View File

@ -58,6 +58,9 @@ class CfgVehicles {
class Helicopter: Air { class Helicopter: Air {
MACRO_LOCK_ACTIONS MACRO_LOCK_ACTIONS
}; };
class Plane: Air {
MACRO_LOCK_ACTIONS
};
class Motorcycle: LandVehicle { class Motorcycle: LandVehicle {
MACRO_LOCK_ACTIONS MACRO_LOCK_ACTIONS
}; };

View File

@ -4,12 +4,18 @@
[QGVAR(setupCustomKey), {_this call FUNC(serverSetupCustomKeyEH)}] call CBA_fnc_addEventHandler; [QGVAR(setupCustomKey), {_this call FUNC(serverSetupCustomKeyEH)}] call CBA_fnc_addEventHandler;
[QGVAR(setVehicleLock), {_this call FUNC(setVehicleLockEH)}] call CBA_fnc_addEventHandler; [QGVAR(setVehicleLock), {_this call FUNC(setVehicleLockEH)}] call CBA_fnc_addEventHandler;
if (!hasInterface) exitwith {};
["ace_settingsInitialized", { ["ace_settingsInitialized", {
TRACE_1("SettingsInitialized eh",GVAR(LockVehicleInventory)); TRACE_2("SettingsInitialized eh",GVAR(LockVehicleInventory),GVAR(VehicleStartingLockState));
if (GVAR(LockVehicleInventory)) then { if (hasInterface && {GVAR(LockVehicleInventory)}) then {
["CAManBase", "InventoryOpened", {_this call FUNC(onOpenInventory)}] call CBA_fnc_addClassEventHandler; ["CAManBase", "InventoryOpened", {_this call FUNC(onOpenInventory)}] call CBA_fnc_addClassEventHandler;
}; };
if (isServer && {GVAR(VehicleStartingLockState) != -1}) then {
[{
TRACE_1("adding lock handler",GVAR(VehicleStartingLockState));
{
[_x, "initpost", LINKFUNC(handleVehicleInitPost), true, [], true] call CBA_fnc_addClassEventHandler;
} forEach ["Car", "Tank", "Air"];
}, [], 0.25] call CBA_fnc_waitAndExecute;
};
}] call CBA_fnc_addEventHandler; }] call CBA_fnc_addEventHandler;

View File

@ -2,7 +2,7 @@
/* /*
* Author: PabstMirror * Author: PabstMirror
* For every lockable vehicle, sets the starting lock state to a sane value. * For every lockable vehicle, sets the starting lock state to a sane value.
* Only run if the InitModule is placed. * Only run if the enabled via settings
* *
* Arguments: * Arguments:
* 0: Vehicle <OBJECT> * 0: Vehicle <OBJECT>
@ -16,28 +16,18 @@
* Public: No * Public: No
*/ */
if (!isServer) exitWith {};
params ["_vehicle"]; params ["_vehicle"];
TRACE_1("params",_vehicle); TRACE_1("handleVehicleInitPost",_vehicle);
[{ if (alive _vehicle) then {
//If the module wasn't placed, just exit (needs to be in wait because objectInitEH is before moduleInit)
if (GVAR(VehicleStartingLockState) == -1) exitWith {};
params ["_vehicle"];
if ((_vehicle isKindOf "Car") || {_vehicle isKindOf "Tank"} || {_vehicle isKindOf "Helicopter"}) then {
//set lock state (eliminates the ambigious 1-"Default" and 3-"Locked for Player" states) //set lock state (eliminates the ambigious 1-"Default" and 3-"Locked for Player" states)
private _lock = switch (GVAR(VehicleStartingLockState)) do { private _lock = switch (GVAR(VehicleStartingLockState)) do {
case (0): { (locked _vehicle) in [2, 3] }; case 0: {locked _vehicle in [2, 3]};
case (1): { true }; case 1: {true};
case (2): { false }; case 2: {false};
}; };
if ((_lock && {(locked _vehicle) != 2}) || {!_lock && {(locked _vehicle) != 0}}) then { if ((_lock && {locked _vehicle != 2}) || {!_lock && {locked _vehicle != 0}}) then {
TRACE_3("Setting Lock State",_lock,(typeOf _vehicle),_vehicle); TRACE_3("Setting Lock State",_lock,typeOf _vehicle,_vehicle);
[QGVAR(SetVehicleLock), [_vehicle, _lock], [_vehicle]] call CBA_fnc_targetEvent; [QGVAR(SetVehicleLock), [_vehicle, _lock], [_vehicle]] call CBA_fnc_targetEvent;
}; };
}; };
//Delay call until mission start (so everyone has the eventHandler's installed)
}, [_vehicle], 0.25] call CBA_fnc_waitAndExecute;

View File

@ -28,7 +28,9 @@ if !(_activated) exitWith {WARNING("Vehicle Lock Sync Module - placed but not ac
params ["_syncedObjects"]; params ["_syncedObjects"];
private _listOfVehicles = _syncedObjects select { private _listOfVehicles = _syncedObjects select {
(_x isKindOf "Car") || {(_x isKindOf "Tank") || {_x isKindOf "Helicopter"}} private _object = _x;
#define CLASSNAMES ["Car", "Tank", "Air"]
IS_KIND_OF_ANY(_object,CLASSNAMES)
}; };
if (_listOfVehicles isEqualTo []) exitWith { //Verbose error for mission makers (only shows on server) if (_listOfVehicles isEqualTo []) exitWith { //Verbose error for mission makers (only shows on server)

View File

@ -15,3 +15,5 @@
#endif #endif
#include "\z\ace\addons\main\script_macros.hpp" #include "\z\ace\addons\main\script_macros.hpp"
#define IS_KIND_OF_ANY(object,classnames) ((classnames) findIf {(object) isKindOf _x} > -1)