2022-03-07 18:29:19 +00:00
|
|
|
#include "script_component.hpp"
|
|
|
|
/*
|
2023-06-19 13:31:17 +00:00
|
|
|
* Author: PabstMirror, modified by Grim
|
2022-03-07 18:29:19 +00:00
|
|
|
* Handles AI reloading
|
|
|
|
*
|
|
|
|
* Arguments:
|
|
|
|
* 0: Static Weapon <OBJECT>
|
|
|
|
* 1: Gunner <OBJECT>
|
|
|
|
* 2: Weapon <STRING>
|
|
|
|
*
|
|
|
|
* Return Value:
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
* Public: No
|
|
|
|
*/
|
2023-07-01 15:39:42 +00:00
|
|
|
params ["_staticWeapon", "_gunner", "_weapon"];
|
|
|
|
TRACE_4("AI reload",_staticWeapon,_gunner,_weapon);
|
2022-03-07 18:29:19 +00:00
|
|
|
|
|
|
|
private _turretPath = [_gunner] call EFUNC(common,getTurretIndex);
|
|
|
|
private _reloadSource = objNull;
|
|
|
|
private _reloadMag = "";
|
|
|
|
private _reloadNeededAmmo = -1;
|
|
|
|
|
|
|
|
private _cfgMagGroups = configFile >> QGVAR(groups);
|
|
|
|
|
2023-07-01 15:39:42 +00:00
|
|
|
// see fnc_reload_getLoadableMagazines, but AI doesn't get filtered out
|
|
|
|
private _nearSupplies = (_staticWeapon nearSupplies 5) select {
|
2022-03-07 18:29:19 +00:00
|
|
|
isNull (group _x) ||
|
|
|
|
{!([_x] call EFUNC(common,isPlayer)) && {[side group _gunner, side group _x] call BIS_fnc_sideIsFriendly}}
|
2023-07-01 15:39:42 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// add gunner since it won't show up in nearSupplies
|
|
|
|
_nearSupplies pushBack _gunner;
|
2022-03-07 18:29:19 +00:00
|
|
|
|
|
|
|
// Find if there is anything we can reload with
|
2023-07-01 15:39:42 +00:00
|
|
|
// see fnc_reload_getLoadableMagazines, though we don't care about AI pulling from the best ammo possible
|
2022-03-07 18:29:19 +00:00
|
|
|
{
|
|
|
|
scopeName "findSource";
|
2023-07-01 15:39:42 +00:00
|
|
|
if (_x isKindOf "CAManBase") then {
|
|
|
|
// unit inventory needs to be added manually
|
|
|
|
_nearSupplies append [uniformContainer _x, vestContainer _x, backpackContainer _x];
|
|
|
|
continue
|
|
|
|
};
|
2022-03-07 18:29:19 +00:00
|
|
|
private _xSource = _x;
|
|
|
|
|
2023-07-01 15:39:42 +00:00
|
|
|
private _cswMagazines = (magazineCargo _xSource) select {isClass (_cfgMagGroups >> _x)};
|
2022-03-07 18:29:19 +00:00
|
|
|
TRACE_2("",_xSource,_cswMagazines);
|
|
|
|
|
|
|
|
{
|
|
|
|
private _xWeaponMag = _x;
|
|
|
|
{
|
|
|
|
if ((getNumber (_cfgMagGroups >> _x >> _xWeaponMag)) == 1) then {
|
|
|
|
private _loadInfo = [_staticWeapon, _turretPath, _x, _xSource] call FUNC(reload_canLoadMagazine);
|
|
|
|
if (_loadInfo select 0) then {
|
|
|
|
_reloadMag = _x;
|
|
|
|
_reloadSource = _xSource;
|
|
|
|
_reloadNeededAmmo = _loadInfo select 2;
|
|
|
|
TRACE_3("found mag",_reloadMag,_reloadSource,_x);
|
|
|
|
breakOut "findSource";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
} forEach _cswMagazines;
|
2023-07-01 15:39:42 +00:00
|
|
|
} forEach (compatibleMagazines _weapon);
|
2022-03-07 18:29:19 +00:00
|
|
|
} forEach _nearSupplies;
|
|
|
|
if (_reloadMag == "") exitWith {TRACE_1("could not find mag",_reloadMag);};
|
|
|
|
|
|
|
|
// Figure out what we can add from the magazines we have
|
|
|
|
private _bestAmmoToSend = -1;
|
|
|
|
{
|
|
|
|
_x params ["_xMag", "_xAmmo"];
|
|
|
|
TRACE_2("",_xMag,_xAmmo);
|
|
|
|
if (_xMag == _reloadMag) then {
|
|
|
|
if ((_bestAmmoToSend == -1) || {(_xAmmo > _bestAmmoToSend) && {_xAmmo <= _reloadNeededAmmo}}) then {
|
|
|
|
_bestAmmoToSend = _xAmmo;
|
|
|
|
};
|
|
|
|
};
|
2022-08-14 16:09:01 +00:00
|
|
|
} forEach (if (_reloadSource isKindOf "CAManBase") then {magazinesAmmo _reloadSource} else {magazinesAmmoCargo _reloadSource});
|
2022-03-07 18:29:19 +00:00
|
|
|
TRACE_4("",_reloadSource,_reloadMag,_reloadNeededAmmo,_bestAmmoToSend);
|
|
|
|
if (_bestAmmoToSend == -1) exitWith {ERROR("No ammo");};
|
|
|
|
|
|
|
|
// Remove the mag from the source
|
|
|
|
[_reloadSource, _reloadMag, _bestAmmoToSend] call EFUNC(common,removeSpecificMagazine);
|
|
|
|
|
2023-07-01 15:39:42 +00:00
|
|
|
// see fnc_reload_loadMagazine #L54
|
|
|
|
// AI never returns ammo and removes the magazine before reloading, so we can skip distance and weaponHolder checks
|
|
|
|
private _eventParams = [_staticWeapon, _turretPath, objNull, _reloadMag, _bestAmmoToSend, _gunner];
|
|
|
|
|
2022-03-07 18:29:19 +00:00
|
|
|
private _timeToLoad = 1;
|
2023-07-01 15:39:42 +00:00
|
|
|
if !(isNull (configOf _staticWeapon >> QUOTE(ADDON) >> "ammoLoadTime")) then {
|
|
|
|
_timeToLoad = getNumber (configOf _staticWeapon >> QUOTE(ADDON) >> "ammoLoadTime");
|
2022-03-07 18:29:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
TRACE_1("Reloading in progress",_timeToLoad);
|
|
|
|
[{
|
2023-07-01 15:39:42 +00:00
|
|
|
params ["_staticWeapon", "", "", "", "", "_gunner"];
|
|
|
|
if !(alive _staticWeapon && {alive _gunner}) exitWith {TRACE_2("invalid state",alive _staticWeapon,alive _gunner);};
|
2022-03-07 18:29:19 +00:00
|
|
|
|
|
|
|
// Reload the static weapon
|
2023-07-01 15:39:42 +00:00
|
|
|
TRACE_5("calling addTurretMag event: AI reload",_staticWeapon,_turretPath,_gunner,_reloadMag,_bestAmmoToSend);
|
2022-03-07 18:29:19 +00:00
|
|
|
[QGVAR(addTurretMag), _this] call CBA_fnc_globalEvent;
|
2023-07-01 15:39:42 +00:00
|
|
|
}, _eventParams, _timeToLoad] call CBA_fnc_waitAndExecute;
|