mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
Dev helper function to convert settings to code (#5752)
* Dev helper function to convert settings to code * fix double // * Add movedToSQF config * Fix paramArray settings * Add movedToSQF to moveMarkers * Add tabs
This commit is contained in:
parent
e24ed0fa92
commit
00ba133b21
@ -1,6 +1,7 @@
|
|||||||
TRACE_1("",QUOTE(ADDON));
|
TRACE_1("",QUOTE(ADDON));
|
||||||
|
|
||||||
PREP(cbaSettings);
|
PREP(cbaSettings);
|
||||||
|
PREP(cbaSettings_convertHelper);
|
||||||
PREP(cbaSettings_loadFromConfig);
|
PREP(cbaSettings_loadFromConfig);
|
||||||
PREP(cbaSettings_settingChanged);
|
PREP(cbaSettings_settingChanged);
|
||||||
PREP(cbaSettings_transferUserSettings);
|
PREP(cbaSettings_transferUserSettings);
|
||||||
|
@ -76,11 +76,13 @@ private _countOptions = count _settingsConfig;
|
|||||||
TRACE_1("Reading settings from configFile",_countOptions);
|
TRACE_1("Reading settings from configFile",_countOptions);
|
||||||
for "_index" from 0 to (_countOptions - 1) do {
|
for "_index" from 0 to (_countOptions - 1) do {
|
||||||
private _optionEntry = _settingsConfig select _index;
|
private _optionEntry = _settingsConfig select _index;
|
||||||
|
if ((getNumber (_optionEntry >> "movedToSQF")) == 0) then {
|
||||||
if (isNil (configName _optionEntry)) then {
|
if (isNil (configName _optionEntry)) then {
|
||||||
[_optionEntry] call FUNC(cbaSettings_loadFromConfig);
|
[_optionEntry] call FUNC(cbaSettings_loadFromConfig);
|
||||||
} else {
|
} else {
|
||||||
WARNING_1("Setting [%1] - Already defined from somewhere else??",_varName);
|
WARNING_1("Setting [%1] - Already defined from somewhere else??",_varName);
|
||||||
};
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
_settingsConfig = missionConfigFile >> "ACE_Settings";
|
_settingsConfig = missionConfigFile >> "ACE_Settings";
|
||||||
@ -92,7 +94,7 @@ for "_index" from 0 to (_countOptions - 1) do {
|
|||||||
if ((toLower _settingName) in GVAR(cbaSettings_forcedSettings)) then {
|
if ((toLower _settingName) in GVAR(cbaSettings_forcedSettings)) then {
|
||||||
WARNING_1("Setting [%1] - Already Forced - ignoring missionConfig",_varName);
|
WARNING_1("Setting [%1] - Already Forced - ignoring missionConfig",_varName);
|
||||||
} else {
|
} else {
|
||||||
if (isNil _settingName) then {
|
if ((isNil _settingName) && {(getNumber (_settingsConfig >> _settingName >> "movedToSQF")) == 0}) then {
|
||||||
// New setting, that was first defined in missionConfigFile
|
// New setting, that was first defined in missionConfigFile
|
||||||
[_optionEntry] call FUNC(cbaSettings_loadFromConfig);
|
[_optionEntry] call FUNC(cbaSettings_loadFromConfig);
|
||||||
} else {
|
} else {
|
||||||
|
128
addons/common/functions/fnc_cbaSettings_convertHelper.sqf
Normal file
128
addons/common/functions/fnc_cbaSettings_convertHelper.sqf
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
/*
|
||||||
|
* Author: PabstMirror
|
||||||
|
* Dev function: Converts ace_settings to code, outputs to clipboard
|
||||||
|
*
|
||||||
|
* Arguments:
|
||||||
|
* 0: Addon <STRING>
|
||||||
|
*
|
||||||
|
* Return Value:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
* ["ace_weaponselect"] call ace_common_fnc_cbaSettings_convertHelper
|
||||||
|
*
|
||||||
|
* Public: No
|
||||||
|
*/
|
||||||
|
#define DEBUG_MODE_FULL
|
||||||
|
#include "script_component.hpp"
|
||||||
|
|
||||||
|
params ["_addon"];
|
||||||
|
|
||||||
|
private _output = [format ["// CBA Settings [ADDON: %1]:", _addon]];
|
||||||
|
|
||||||
|
private _addonSearch = _addon + "_";
|
||||||
|
private _addonSearchCount = count _addonSearch;
|
||||||
|
TRACE_2("",_addonSearch, _addonSearchCount);
|
||||||
|
|
||||||
|
private _settings = configProperties [configFile >> "ACE_Settings", "(isClass _x) && {((configName _x) select [0, _addonSearchCount]) == _addonSearch}"];
|
||||||
|
|
||||||
|
{
|
||||||
|
private _config = _x;
|
||||||
|
private _varName = configName _config;
|
||||||
|
private _typeName = toUpper getText (_config >> "typeName");
|
||||||
|
if (_typeName == "") then {
|
||||||
|
WARNING_1("Setting [%1] Has no typeName",_varName);
|
||||||
|
_typeName = "SCALAR";
|
||||||
|
};
|
||||||
|
TRACE_2("loadFromConfig",_varName,_typeName);
|
||||||
|
|
||||||
|
private _isClientSettable = (getNumber (_config >> "isClientSettable")) > 0;
|
||||||
|
private _localizedName = getText (_config >> "displayName");
|
||||||
|
private _localizedDescription = getText (_config >> "description");
|
||||||
|
private _isForced = (getNumber (_config >> "force")) > 0;
|
||||||
|
private _category = getText (_config >> "category");
|
||||||
|
|
||||||
|
private _cbaIsGlobal = (!_isClientSettable) || _isForced;
|
||||||
|
if (_isForced) then {GVAR(cbaSettings_forcedSettings) pushBack (toLower _varName);};
|
||||||
|
|
||||||
|
// Basic handling of setting types CBA doesn't support:
|
||||||
|
if (_typeName == "ARRAY") exitWith {
|
||||||
|
WARNING_1("Setting [%1] is type ARRAY - limited support",_varName);
|
||||||
|
private _value = getArray (_config >> "value");
|
||||||
|
if (isServer) then {missionNamespace setVariable [_varName, _value, true];};
|
||||||
|
};
|
||||||
|
|
||||||
|
private _cbaSettingType = "";
|
||||||
|
private _cbaValueInfo = [];
|
||||||
|
_cbaValueInfoHint = "default value";
|
||||||
|
switch (_typeName) do {
|
||||||
|
case ("SCALAR"): { // ACE's Scalar can be a float or an index for a list
|
||||||
|
if (!isNumber (_config >> "value")) then {WARNING_2("Setting [%1] - value type [%2] is missing number",_varName,_typeName);};
|
||||||
|
if (isArray (_config >> "values")) then {
|
||||||
|
_cbaSettingType = "LIST"; // [_values, _valueTitles, _defaultIndex]
|
||||||
|
private _values = [];
|
||||||
|
private _valueTitles = [];
|
||||||
|
{
|
||||||
|
_values pushBack _forEachIndex;
|
||||||
|
_valueTitles pushBack (if ((_x select [0, 1]) == "$") then {localize (_x select [1]);} else {_x});
|
||||||
|
} forEach (getArray (_config >> "values"));
|
||||||
|
_cbaValueInfo = [_values, _valueTitles, getNumber (_config >> "value")];
|
||||||
|
} else {
|
||||||
|
_cbaSettingType = "SLIDER"; // [_min, _max, _default, _trailingDecimals]
|
||||||
|
_cbaValueInfo = if (isArray (_config >> "sliderSettings")) then {
|
||||||
|
getArray (_config >> "sliderSettings");
|
||||||
|
} else {
|
||||||
|
[-1, 5000, 0, 1]
|
||||||
|
};
|
||||||
|
_cbaValueInfo set [2, getNumber (_config >> "value")];
|
||||||
|
_cbaValueInfoHint = "[min, max, default value, trailing decimals (-1 for whole numbers only)]";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
case ("BOOL"): {
|
||||||
|
if (!isNumber (_config >> "value")) then {WARNING_2("Setting [%1] - value type [%2] is missing number",_varName,_typeName);};
|
||||||
|
_cbaSettingType = "CHECKBOX";
|
||||||
|
_cbaValueInfo = (getNumber (_config >> "value")) > 0;
|
||||||
|
};
|
||||||
|
case ("COLOR"): {
|
||||||
|
if (!isArray (_config >> "value")) then {WARNING_2("Setting [%1] - value type [%2] is missing array",_varName,_typeName);};
|
||||||
|
_cbaSettingType = "COLOR";
|
||||||
|
_cbaValueInfo = getArray (_config >> "value");
|
||||||
|
};
|
||||||
|
case ("STRING"): {
|
||||||
|
if (!isText (_config >> "value")) then {WARNING_2("Setting [%1] - value type [%2] is missing text",_varName,_typeName);};
|
||||||
|
_cbaSettingType = "EDITBOX";
|
||||||
|
_cbaValueInfo = getText (_config >> "value");
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
if (_cbaSettingType == "") exitWith {ERROR_3("Setting [%1] - value type [%2] is unknown - %3",_varName,_typeName,_cbaValueInfo);};
|
||||||
|
|
||||||
|
if (_localizedDescription == "") then {_localizedDescription = _varName};
|
||||||
|
if (_category == "") then {
|
||||||
|
WARNING_1("Setting [%1] - no category",_varName);
|
||||||
|
_category = "Uncategorized";
|
||||||
|
};
|
||||||
|
private _uncat = false;
|
||||||
|
if (((_varName select [0, 4]) == "ACE_") && {(_category select [0, 3]) != "ACE"}) then {_uncat = true; _category = format ["ACE %1", _category];};
|
||||||
|
if (((_varName select [0, 5]) == "ACEX_") && {(_category select [0, 4]) != "ACEX"}) then {_uncat = true; _category = format ["ACEX %1", _category];};
|
||||||
|
|
||||||
|
private _gvarName = _varName select [_addonSearchCount];
|
||||||
|
|
||||||
|
_output pushBack "";
|
||||||
|
_output pushBack format ["["];
|
||||||
|
_output pushBack format [" QGVAR(%1), ""%2"",", _gvarName, _cbaSettingType];
|
||||||
|
_output pushBack format [" [LSTRING(), LSTRING()], // %1, %2", _localizedName, _localizedDescription];
|
||||||
|
_output pushBack format [" ""%1"", // %2", ["localize LSTRING()", _category] select _uncat, _category];
|
||||||
|
_output pushBack format [" %1, // %2", _cbaValueInfo, _cbaValueInfoHint];
|
||||||
|
_output pushBack format [" %1, // isGlobal", _cbaIsGlobal];
|
||||||
|
if ((_varName select [0, 4]) == "ACE_") then {
|
||||||
|
_output pushBack format [" {[QGVAR(%1), _this] call EFUNC(common,cbaSettings_settingChanged)}] call CBA_settings_fnc_init;", _gvarName];
|
||||||
|
} else {
|
||||||
|
_output pushBack format [" {[""%1"", _this] call ace_common_fnc_cbaSettings_settingChanged}", _varName];
|
||||||
|
};
|
||||||
|
_output pushBack "] call CBA_settings_fnc_init;";
|
||||||
|
} forEach _settings;
|
||||||
|
|
||||||
|
copyToClipboard (_output joinString endl);
|
||||||
|
|
||||||
|
INFO_1("Settings sqf copied to clipboard for %1",_addon);
|
@ -38,18 +38,22 @@ TRACE_1("Reading missionConfigFile params",_paramsArray);
|
|||||||
|
|
||||||
// The setting is not forced, so update the value
|
// The setting is not forced, so update the value
|
||||||
// Read entry and cast it to the correct type from the existing variable
|
// Read entry and cast it to the correct type from the existing variable
|
||||||
|
(cba_settings_default getVariable [_settingName, []]) params ["", "", ["_settingType", ""]];
|
||||||
private _validValue = false;
|
private _validValue = false;
|
||||||
switch (true) do {
|
switch (true) do {
|
||||||
case (_typeName == "SCALAR"): {_validValue = true;};
|
case (_settingType == "LIST");
|
||||||
case (_typeName == "BOOL"): {
|
case (_settingType == "SCALAR"): {
|
||||||
_settingValue = _settingValue > 0;
|
_validValue = [_settingName, _settingValue] call CBA_settings_fnc_check;
|
||||||
_validValue = true;
|
|
||||||
};
|
};
|
||||||
//TODO: Handle ARRAY,COLOR,STRING??? (bool/scalar covers most important settings)
|
case (_settingType == "CHECKBOX"): {
|
||||||
|
_settingValue = _settingValue > 0;
|
||||||
|
_validValue = [_settingName, _settingValue] call CBA_settings_fnc_check;
|
||||||
|
};
|
||||||
|
// Will not Handle ARRAY,COLOR,STRING??? (bool/scalar covers most important settings)
|
||||||
};
|
};
|
||||||
|
|
||||||
if (!_validValue) exitWith {
|
if (!_validValue) exitWith {
|
||||||
WARNING_3("readSettingsFromParamsArray - param [%1] type not valid [%2] - expected type [%3]", _settingName,_settingValue,_typeName);
|
WARNING_3("readSettingsFromParamsArray - param [%1] type not valid [%2] - expected type [%3]", _settingName,_settingValue,_settingType);
|
||||||
};
|
};
|
||||||
|
|
||||||
if ([_settingName, "mission"] call CBA_settings_fnc_isForced) then {
|
if ([_settingName, "mission"] call CBA_settings_fnc_isForced) then {
|
||||||
@ -57,7 +61,7 @@ TRACE_1("Reading missionConfigFile params",_paramsArray);
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Set the setting as a mission setting and force it
|
// Set the setting as a mission setting and force it
|
||||||
TRACE_2("setSettingMission from module",_settingName,_value);
|
private _return = ["CBA_settings_setSettingMission", [_settingName, _settingValue, true]] call CBA_fnc_localEvent;
|
||||||
["CBA_settings_setSettingMission", [_settingName, _value, true]] call CBA_fnc_localEvent;
|
TRACE_3("setSettingMission from paramsArray",_settingName,_settingValue,_return);
|
||||||
};
|
};
|
||||||
} forEach _paramsArray;
|
} forEach _paramsArray;
|
||||||
|
8
addons/markers/ACE_Settings.hpp
Normal file
8
addons/markers/ACE_Settings.hpp
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
class ACE_Settings {
|
||||||
|
class GVAR(movableMarkersEnabled) {
|
||||||
|
movedToSQF = 1;
|
||||||
|
};
|
||||||
|
class GVAR(moveRestriction) {
|
||||||
|
movedToSQF = 1;
|
||||||
|
};
|
||||||
|
};
|
@ -15,6 +15,7 @@ class CfgPatches {
|
|||||||
};
|
};
|
||||||
|
|
||||||
#include "CfgEventHandlers.hpp"
|
#include "CfgEventHandlers.hpp"
|
||||||
|
#include "ACE_Settings.hpp"
|
||||||
#include "CfgVehicles.hpp"
|
#include "CfgVehicles.hpp"
|
||||||
|
|
||||||
#include "InsertMarker.hpp"
|
#include "InsertMarker.hpp"
|
||||||
|
Loading…
Reference in New Issue
Block a user