mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
56eae4060c
Code formatting changes from 9234
80 lines
2.6 KiB
Plaintext
80 lines
2.6 KiB
Plaintext
#include "..\script_component.hpp"
|
|
/*
|
|
* Author: PabstMirror
|
|
* Gets nearby magazines that can be loaded into the CSW.
|
|
*
|
|
* Arguments:
|
|
* 0: CSW <OBJECT>
|
|
* 1: Unit <OBJECT>
|
|
*
|
|
* Return Value:
|
|
* Mags <ARRAY>
|
|
* [Carry Magazine <STRING>, Turret Path <ARRAY>, Load Info <ARRAY>, Magazine Source <OBJECT>]
|
|
*
|
|
* Example:
|
|
* [cursorObject, player] call ace_csw_fnc_reload_getLoadableMagazines
|
|
*
|
|
* Public: No
|
|
*/
|
|
|
|
params ["_vehicle", "_player"];
|
|
|
|
private _magGroupsConfig = configFile >> QGVAR(groups); // so we don't solve in loop every time
|
|
private _availableMagazines = createHashMap; // slower than array, still needed for setting source of magazine
|
|
|
|
// filter enemy & player units while allowing pulling from friendly AI, crates, etc
|
|
private _nearSupplies = ((_vehicle nearSupplies 10) select {
|
|
isNull (group _x) ||
|
|
{!([_x] call EFUNC(common,isPlayer)) && {[side group _player, side group _x] call BIS_fnc_sideIsFriendly}}
|
|
});
|
|
|
|
// backpacks/uniforms/etc need to be added manually.
|
|
// array can't be modified while iterating, use copy
|
|
{
|
|
{
|
|
_x params ["_classname", "_container"];
|
|
_nearSupplies pushBack _container;
|
|
} forEach (everyContainer _x);
|
|
} forEach ((+_nearSupplies) select {(everyContainer _x) isNotEqualTo []});
|
|
|
|
// add caller to list of sources
|
|
_nearSupplies = [_player] + _nearSupplies;
|
|
|
|
{
|
|
private _xSource = _x;
|
|
private _mags = magazineCargo _xSource;
|
|
|
|
{
|
|
_availableMagazines set [_x, _xSource];
|
|
} forEach (_mags select {isClass (_magGroupsConfig >> _x)});
|
|
} forEach _nearSupplies;
|
|
|
|
if (_availableMagazines isEqualTo createHashMap) exitWith { [] }; // fast exit if no available mags
|
|
|
|
private _loadInfo = [];
|
|
private _return = [];
|
|
// Go through turrets and find weapons that we could reload
|
|
{
|
|
private _turretPath = _x;
|
|
{
|
|
private _weapon = _x;
|
|
{
|
|
//IGNORE_PRIVATE_WARNING ["_x", "_y"];
|
|
private _carryMag = _x;
|
|
private _magSource = _y;
|
|
private _carryGroup = _magGroupsConfig >> _carryMag;
|
|
{
|
|
if (
|
|
((getNumber (_carryGroup >> _x)) == 1) &&
|
|
{_loadInfo = [_vehicle, _turretPath, _carryMag, _magSource] call FUNC(reload_canLoadMagazine); _loadInfo select 0}
|
|
) exitWith {
|
|
_return pushBack [_carryMag, _turretPath, _loadInfo, _magSource];
|
|
};
|
|
} forEach (compatibleMagazines _weapon);
|
|
} forEach _availableMagazines;
|
|
} forEach (_vehicle weaponsTurret _turretPath);
|
|
} forEach (allTurrets _vehicle);
|
|
// Note: these nested forEach's looks terrible, but most only have one element
|
|
|
|
_return
|