mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
742626ff1a
Co-authored-by: PabstMirror <pabstmirror@gmail.com>
129 lines
4.7 KiB
Plaintext
129 lines
4.7 KiB
Plaintext
#include "..\script_component.hpp"
|
|
/*
|
|
* Author: PabstMirror
|
|
* Called at pre-init: Loads all ace_settings and converts them to CBA Settings.
|
|
*
|
|
* Arguments:
|
|
* None
|
|
*
|
|
* Return Value:
|
|
* None
|
|
*
|
|
* Example:
|
|
* [] call ace_common_fnc_cbaSettings;
|
|
*
|
|
* Public: No
|
|
*/
|
|
|
|
LOG("Adding ACE_Settings to CBA_settings");
|
|
|
|
// Init Vars:
|
|
GVAR(cbaSettings_forcedSettings) = [];
|
|
GVAR(cbaSettings_missionSettings) = [];
|
|
GVAR(settings) = []; // will stay empty - for BWC?
|
|
#ifdef DEBUG_MODE_FULL
|
|
GVAR(settingsMovedToSQF) = [];
|
|
#endif
|
|
|
|
// Add Event Handlers:
|
|
[QGVAR(setSetting), {
|
|
params ["_settingName", "_value"];
|
|
TRACE_2("setSettingMission from setSetting",_settingName,_value);
|
|
["CBA_settings_setSettingMission", [_settingName, _value, true]] call CBA_fnc_localEvent;
|
|
["CBA_settings_refreshSetting", [_settingName]] call CBA_fnc_localEvent;
|
|
}] call CBA_fnc_addEventHandler;
|
|
|
|
["CBA_beforeSettingsInitialized", {
|
|
TRACE_1("CBA_beforeSettingsInitialized EH",_this);
|
|
|
|
// First: Process missionConfig settings:
|
|
{
|
|
_x params ["_settingName", "_value"];
|
|
TRACE_2("setSettingMission from missionConfig",_settingName,_value);
|
|
["CBA_settings_setSettingMission", [_settingName, _value, true]] call CBA_fnc_localEvent;
|
|
} forEach GVAR(cbaSettings_missionSettings);
|
|
GVAR(cbaSettings_missionSettings) = nil;
|
|
|
|
// Second: Read settings from mission params
|
|
[] call FUNC(readSettingsFromParamsArray);
|
|
|
|
// Third: Event so that ACE_Modules have their settings loaded:
|
|
[QGVAR(initSettingsFromModules), []] call CBA_fnc_localEvent;
|
|
|
|
TRACE_1("Finished mission settings",_this);
|
|
}] call CBA_fnc_addEventHandler;
|
|
|
|
["CBA_settingsInitialized", {
|
|
TRACE_1("CBA_settingsInitialized EH",_this);
|
|
if !(SLX_XEH_MACHINE select 8) then {WARNING("PostInit not finished");};
|
|
INFO("Settings initialized.");
|
|
|
|
//Event that settings are safe to use:
|
|
["ace_settingsInitialized", []] call CBA_fnc_localEvent;
|
|
|
|
//Set init finished and run all delayed functions:
|
|
GVAR(settingsInitFinished) = true;
|
|
INFO_1("%1 delayed functions running.",count GVAR(runAtSettingsInitialized));
|
|
{
|
|
(_x select 1) call (_x select 0);
|
|
false
|
|
} count GVAR(runAtSettingsInitialized);
|
|
GVAR(runAtSettingsInitialized) = nil; //cleanup
|
|
|
|
#ifdef DEBUG_MODE_FULL
|
|
INFO_1("checking settingsMovedToSQF [%1]",count GVAR(settingsMovedToSQF));
|
|
{
|
|
if (isNil _x) then { WARNING_1("setting [%1] NOT moved to sqf",_x); };
|
|
} forEach GVAR(settingsMovedToSQF);
|
|
#endif
|
|
}] call CBA_fnc_addEventHandler;
|
|
|
|
private _start = diag_tickTime;
|
|
|
|
private _settingsConfig = configFile >> "ACE_Settings";
|
|
private _countOptions = count _settingsConfig;
|
|
TRACE_1("Reading settings from configFile",_countOptions);
|
|
for "_index" from 0 to (_countOptions - 1) do {
|
|
private _optionEntry = _settingsConfig select _index;
|
|
if ((getNumber (_optionEntry >> "movedToSQF")) == 0) then {
|
|
if (isNil (configName _optionEntry)) then {
|
|
[_optionEntry] call FUNC(cbaSettings_loadFromConfig);
|
|
} else {
|
|
WARNING_1("Setting [%1] - Already defined from somewhere else??",_varName);
|
|
};
|
|
#ifdef DEBUG_MODE_FULL
|
|
} else {
|
|
GVAR(settingsMovedToSQF) pushBack configName _optionEntry;
|
|
#endif
|
|
};
|
|
};
|
|
|
|
private _missionSettingsConfig = missionConfigFile >> "ACE_Settings";
|
|
_countOptions = count _missionSettingsConfig;
|
|
TRACE_1("Reading settings from missionConfigFile",_countOptions);
|
|
for "_index" from 0 to (_countOptions - 1) do {
|
|
private _optionEntry = _missionSettingsConfig select _index;
|
|
private _settingName = configName _optionEntry;
|
|
if ((toLower _settingName) in GVAR(cbaSettings_forcedSettings)) then {
|
|
WARNING_1("Setting [%1] - Already Forced - ignoring missionConfig",_varName);
|
|
} else {
|
|
if ((isNil _settingName) && {(getNumber (_settingsConfig >> _settingName >> "movedToSQF")) == 0}) then {
|
|
// New setting, that was first defined in missionConfigFile
|
|
INFO_1("Creating new CBA setting for ace_setting from mission config [%1]",_settingName);
|
|
[_optionEntry] call FUNC(cbaSettings_loadFromConfig);
|
|
} else {
|
|
private _value = (_optionEntry >> "value") call BIS_fnc_getCfgData;
|
|
if (isNil "_value") exitWith {ERROR_1("Setting [%1] - Has bad value",_settingName);};
|
|
TRACE_2("queuing missionConfig setting",_settingName,_value);
|
|
GVAR(cbaSettings_missionSettings) pushBack [_settingName, _value];
|
|
};
|
|
};
|
|
};
|
|
|
|
// Warning if using a custom ACE_ServerSettings config
|
|
if (isServer && {isClass (configFile >> "ACE_ServerSettings")}) then {
|
|
WARNING("ACE_ServerSettings is no longer supported and will be ignored");
|
|
};
|
|
|
|
INFO_1("Parsed Settings Configs [%1 ms]",(1000 * (diag_tickTime - _start)) toFixed 1);
|