mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
Interaction Menu - Only compile self actions when needed (#6792)
* Interaction Menu - Only compile self actions when needed * Update XEH_clientInit.sqf * fix spellling * format/comments * Don't compile actions on headless servers * Update addons/zeus/XEH_postInit.sqf Co-Authored-By: PabstMirror <pabstmirror@gmail.com>
This commit is contained in:
parent
639d3fdfa1
commit
ff5eb34e10
@ -17,14 +17,6 @@ class Extended_PostInit_EventHandlers {
|
||||
};
|
||||
};
|
||||
|
||||
class Extended_InitPost_EventHandlers {
|
||||
class All {
|
||||
class GVAR(compileMenu) {
|
||||
init = QUOTE(_this call FUNC(compileMenu);_this call FUNC(compileMenuSelfAction));
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
class Extended_DisplayLoad_EventHandlers {
|
||||
class RscDiary {
|
||||
ADDON = QUOTE(call COMPILE_FILE(XEH_displayLoad));
|
||||
|
@ -2,6 +2,29 @@
|
||||
|
||||
if (!hasInterface) exitWith {};
|
||||
|
||||
// Wait until player controls (man,vehicle or uav) a thing before compiling the menu
|
||||
GVAR(controllableSelfActionsAdded) = [] call CBA_fnc_createNamespace;
|
||||
DFUNC(newControllableObject) = {
|
||||
params ["_object"];
|
||||
private _type = typeOf _object;
|
||||
TRACE_2("newControllableObject",_object,_type);
|
||||
if (_type == "") exitWith {};
|
||||
|
||||
if (!(GVAR(controllableSelfActionsAdded) getVariable [_type, false])) then {
|
||||
[_type] call FUNC(compileMenuSelfAction);
|
||||
GVAR(controllableSelfActionsAdded) setVariable [_type, true];
|
||||
[{
|
||||
TRACE_1("sending newControllableObject event",_this);
|
||||
// event for other systems to add self actions, running addActionToClass before this will cause compiling
|
||||
[QGVAR(newControllableObject), _this] call CBA_fnc_localEvent;
|
||||
}, [_type]] call CBA_fnc_execNextFrame; // delay event a frame to ensure postInit has run for all addons
|
||||
};
|
||||
};
|
||||
["unit", {[_this select 0] call FUNC(newControllableObject)}, true] call CBA_fnc_addPlayerEventHandler;
|
||||
["vehicle", {[_this select 1] call FUNC(newControllableObject)}, true] call CBA_fnc_addPlayerEventHandler;
|
||||
["ACE_controlledUAV", {[_this select 0] call FUNC(newControllableObject)}] call CBA_fnc_addEventHandler;
|
||||
|
||||
|
||||
GVAR(blockDefaultActions) = [];
|
||||
|
||||
GVAR(cachedBuildingTypes) = [];
|
||||
|
@ -8,6 +8,10 @@ PREP_RECOMPILE_END;
|
||||
|
||||
#include "initSettings.sqf"
|
||||
|
||||
if (!hasInterface) exitWith { ADDON = true; };
|
||||
|
||||
["All", "init", {_this call FUNC(compileMenu)}] call CBA_fnc_addClassEventHandler;
|
||||
|
||||
GVAR(ActNamespace) = [] call CBA_fnc_createNamespace;
|
||||
GVAR(ActSelfNamespace) = [] call CBA_fnc_createNamespace;
|
||||
|
||||
|
@ -20,6 +20,7 @@
|
||||
* Public: Yes
|
||||
*/
|
||||
|
||||
if (!hasInterface) exitWith { [] };
|
||||
if (!params [["_objectType", "", [""]], ["_typeNum", 0, [0]], ["_parentPath", [], [[]]], ["_action", [], [[]], 11]]) exitWith {
|
||||
ERROR("Bad Params");
|
||||
[]
|
||||
|
@ -19,6 +19,7 @@
|
||||
* Public: Yes
|
||||
*/
|
||||
|
||||
if (!hasInterface) exitWith { [] };
|
||||
if (!params [["_object", objNull, [objNull]], ["_typeNum", 0, [0]], ["_parentPath", [], [[]]], ["_action", [], [[]], 11]]) exitWith {
|
||||
ERROR("Bad Params");
|
||||
[]
|
||||
|
@ -17,6 +17,7 @@
|
||||
* Public: Yes
|
||||
*/
|
||||
|
||||
if (!hasInterface) exitWith { [] };
|
||||
if (!params [["_parentPath", [], [[]]], ["_action", [], [[]], 11]]) exitWith {ERROR("Bad Params"); []};
|
||||
if ((_parentPath param [0, ""]) != "ACE_ZeusActions") exitWith {ERROR_1("Bad path %1 - should have ACE_ZeusActions as base", _parentPath); []};
|
||||
TRACE_2("addActionToZeus",_parentPath,_action);
|
||||
|
@ -28,6 +28,7 @@
|
||||
|
||||
// IGNORE_PRIVATE_WARNING(_actionName,_displayName,_icon,_statement,_condition,_insertChildren,_customParams,_position,_distance,_params,_modifierFunction);
|
||||
|
||||
if (!hasInterface) exitWith { [] };
|
||||
params [
|
||||
"_actionName",
|
||||
"_displayName",
|
||||
|
@ -82,6 +82,11 @@ if (hasInterface) then {
|
||||
[localize "str_a3_cfgvehicles_moduletasksetstate_f_arguments_state_values_created_0"] call EFUNC(common,displayTextStructured);
|
||||
}] call CBA_fnc_addEventHandler;
|
||||
|
||||
[QEGVAR(interact_menu,newControllableObject), {
|
||||
params ["_type"];
|
||||
if (!(_type isKindOf "CAManBase")) exitWith {};
|
||||
TRACE_1("Adding zeus actions",_type);
|
||||
|
||||
private _action = [
|
||||
QGVAR(create),
|
||||
LLSTRING(CreateZeus),
|
||||
@ -100,7 +105,7 @@ if (hasInterface) then {
|
||||
&& {isNil QGVAR(zeus)}
|
||||
}
|
||||
] call EFUNC(interact_menu,createAction);
|
||||
["CAManBase", 1, ["ACE_SelfActions"], _action, true] call EFUNC(interact_menu,addActionToClass);
|
||||
[_type, 1, ["ACE_SelfActions"], _action] call EFUNC(interact_menu,addActionToClass);
|
||||
|
||||
_action = [
|
||||
QGVAR(delete),
|
||||
@ -112,5 +117,6 @@ if (hasInterface) then {
|
||||
},
|
||||
{!(isNil QGVAR(zeus) || {isNull GVAR(zeus)})}
|
||||
] call EFUNC(interact_menu,createAction);
|
||||
["CAManBase", 1, ["ACE_SelfActions"], _action, true] call EFUNC(interact_menu,addActionToClass);
|
||||
[_type, 1, ["ACE_SelfActions"], _action] call EFUNC(interact_menu,addActionToClass);
|
||||
}] call CBA_fnc_addEventHandler;
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user