2018-09-17 19:19:29 +00:00
|
|
|
#define DEBUG_MODE_FULL
|
2023-09-12 18:58:10 +00:00
|
|
|
#include "..\script_component.hpp"
|
2017-06-08 13:31:51 +00:00
|
|
|
/*
|
2024-01-11 23:58:47 +00:00
|
|
|
* Author: ACE-Team, Lambda.Tiger
|
2024-01-13 06:35:22 +00:00
|
|
|
* This function will dump every ammo config that would generate ace_frag
|
2024-01-15 19:55:01 +00:00
|
|
|
* fragments that could be fired from a weapon
|
2017-06-08 13:31:51 +00:00
|
|
|
*
|
|
|
|
* Arguments:
|
2024-01-15 19:55:01 +00:00
|
|
|
* 0: Log ammo types that wouldn't normally frag
|
2024-01-13 06:35:22 +00:00
|
|
|
* 1: Only export ammo classes of classes referenced in cfgAmmo
|
2024-01-15 19:37:12 +00:00
|
|
|
* and their submunitions. <BOOL>
|
|
|
|
* 2: Force a CSV format on debug print <BOOL>
|
2017-06-08 13:31:51 +00:00
|
|
|
*
|
|
|
|
* Return Value:
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
* Example:
|
2024-01-15 21:37:18 +00:00
|
|
|
* call ace_frag_fnc_dev_debugAmmo
|
2017-06-08 13:31:51 +00:00
|
|
|
*
|
|
|
|
* Public: No
|
|
|
|
*/
|
2016-10-26 22:16:31 +00:00
|
|
|
params [
|
2024-01-15 19:13:59 +00:00
|
|
|
["_logAll", false, [false]],
|
2024-01-12 07:50:01 +00:00
|
|
|
["_onlyShotAmmoTypes", false, [false]],
|
2024-01-11 23:58:47 +00:00
|
|
|
["_csvFormat", false, [false]]
|
2016-10-26 22:16:31 +00:00
|
|
|
];
|
2016-05-07 20:35:39 +00:00
|
|
|
|
|
|
|
diag_log text format ["~~~~~~~~~~~~~Start [%1]~~~~~~~~~~~~~", _this];
|
2024-01-12 07:50:01 +00:00
|
|
|
if (_csvFormat) then {
|
|
|
|
diag_log text format ["ammo,gurney_c,gurney_m,gurney_k,gurney_gC,fragTypes,fragCount,Inheritance"];
|
|
|
|
};
|
2016-05-07 20:35:39 +00:00
|
|
|
|
2024-01-13 06:35:22 +00:00
|
|
|
// Gather all configs, either those that could be created from firing or all classes
|
2024-01-12 07:50:01 +00:00
|
|
|
private _allAmmoConfigs = [];
|
|
|
|
if (_onlyShotAmmoTypes) then {
|
2024-01-15 19:13:59 +00:00
|
|
|
private _configSearchFunc = {
|
2024-01-12 07:50:01 +00:00
|
|
|
params [
|
|
|
|
["_ammo", "", [""]]
|
|
|
|
];
|
|
|
|
if (_ammo isEqualTo "" || {_ammo in _allAmmoConfigs}) exitWith {};
|
|
|
|
_allAmmoConfigs pushBack _ammo;
|
2024-01-15 19:55:15 +00:00
|
|
|
private _subMunit = toLowerANSI getText (configFile >> "cfgAmmo" >> _ammo >> "submunitionAmmo");
|
2024-01-12 07:50:01 +00:00
|
|
|
if (_subMunit isNotEqualTo "") then {
|
|
|
|
_subMunit = getArray (configFile >> "cfgAmmo" >> _ammo >> "submunitionAmmo");
|
|
|
|
for "_i" from 0 to count _subMunit - 1 do {
|
|
|
|
if (_i mod 2 == 0) then {
|
2024-01-15 19:55:15 +00:00
|
|
|
[toLowerANSI (_subMunit#_i)] call _configSearchFunc;
|
2024-01-12 07:50:01 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
} else {
|
2024-01-15 19:55:15 +00:00
|
|
|
[toLowerANSI _subMunit] call _configSearchFunc;
|
2024-01-12 07:50:01 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
private _allMagazineConfigs = configProperties [configFile >> "cfgMagazines", "isClass _x", true];
|
2016-05-07 20:35:39 +00:00
|
|
|
|
2024-01-12 07:50:01 +00:00
|
|
|
{
|
2024-01-15 19:55:15 +00:00
|
|
|
[toLowerANSI getText (_x >> "ammo")] call _configSearchFunc;
|
2024-01-12 07:50:01 +00:00
|
|
|
} forEach _allMagazineConfigs;
|
|
|
|
} else {
|
|
|
|
_allAmmoConfigs = configProperties [configFile >> "cfgAmmo", "isClass _x && !('ace_frag' in configName _x)", true] apply {configName _x};
|
2024-01-11 23:58:47 +00:00
|
|
|
};
|
|
|
|
|
2024-01-12 07:50:01 +00:00
|
|
|
private _processedCfgAmmos = [];
|
2024-01-11 23:58:47 +00:00
|
|
|
private _printCount = 0;
|
2024-01-13 06:35:22 +00:00
|
|
|
{ // Begin forEach to check each ammo type
|
2024-01-12 07:50:01 +00:00
|
|
|
private _ammo = _x;
|
2016-10-26 22:16:31 +00:00
|
|
|
if (_ammo != "" && {!(_ammo in _processedCfgAmmos)}) then {
|
2016-05-07 20:35:39 +00:00
|
|
|
_processedCfgAmmos pushBack _ammo;
|
|
|
|
|
2024-01-12 07:50:01 +00:00
|
|
|
private _ammoConfig = (configFile >> "cfgAmmo" >> _ammo);
|
2024-01-11 23:58:47 +00:00
|
|
|
private _shoulFrag = [_ammo] call FUNC(shouldFrag);
|
2016-05-07 20:35:39 +00:00
|
|
|
|
2024-01-15 19:13:59 +00:00
|
|
|
if (_shoulFrag || _logAll) then {
|
2016-10-26 22:16:31 +00:00
|
|
|
|
|
|
|
private _warn = false;
|
2024-01-11 23:58:47 +00:00
|
|
|
private _fragTypes = getArray (_ammoConfig >> QGVAR(CLASSES));
|
2016-10-26 22:16:31 +00:00
|
|
|
if (_fragTypes isEqualTo []) then {_warn = true;};
|
2024-01-11 23:58:47 +00:00
|
|
|
private _c = getNumber(_ammoConfig >> QGVAR(CHARGE));
|
2016-10-26 22:16:31 +00:00
|
|
|
if (_c == 0) then {_warn = true;};
|
2024-01-11 23:58:47 +00:00
|
|
|
private _m = getNumber(_ammoConfig >> QGVAR(METAL));
|
2016-10-26 22:16:31 +00:00
|
|
|
if (_m == 0) then {_warn = true;};
|
2024-01-11 23:58:47 +00:00
|
|
|
private _k = getNumber(_ammoConfig >> QGVAR(GURNEY_K));
|
2016-10-26 22:16:31 +00:00
|
|
|
if (_k == 0) then {_warn = true;};
|
2024-01-11 23:58:47 +00:00
|
|
|
private _gC = getNumber(_ammoConfig >> QGVAR(GURNEY_C));
|
2016-10-26 22:16:31 +00:00
|
|
|
if (_gC == 0) then {_warn = true;};
|
2024-01-11 23:58:47 +00:00
|
|
|
private _fragCount = getNumber (_ammoConfig >> QGVAR(fragCount));
|
|
|
|
if (_fragCount == 0) then {_fragCount = 200; _warn = true;};
|
2024-01-13 06:35:22 +00:00
|
|
|
|
2024-01-11 23:58:47 +00:00
|
|
|
if (_warn) then {
|
|
|
|
INC(_printCount);
|
|
|
|
if (_csvFormat) then {
|
2024-01-12 07:50:01 +00:00
|
|
|
diag_log text format ["%7,%1,%2,%3,%4,%5,%6,%8", _c, _m, _k, _gC, _fragTypes, _fragCount, _ammo, [_ammoConfig, true] call BIS_fnc_returnParents];
|
2024-01-11 23:58:47 +00:00
|
|
|
} else {
|
|
|
|
diag_log text format ["Ammo [%1] MISSING frag configs:", _ammo];
|
|
|
|
diag_log text format [" _c=%1,_m=%2,_k=%3,_gC=%4,_fragTypes=%5,_fragCount=%6", _c, _m, _k, _gC, _fragTypes, _fragCount];
|
|
|
|
};
|
2016-05-07 20:35:39 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2024-01-11 23:58:47 +00:00
|
|
|
} forEach _allAmmoConfigs;
|
2016-05-07 20:35:39 +00:00
|
|
|
|
2024-01-11 23:58:47 +00:00
|
|
|
diag_log text format ["~~~~~~~~~~~~~~End [%1-%2]~~~~~~~~~~~~~~", count _allAmmoConfigs, count _processedCfgAmmos];
|
2024-01-15 19:13:59 +00:00
|
|
|
diag_log text format ["~~~~~~~~~~~~~~Printed: %1~~~~~~~~~~~", _printCount];
|