2023-09-12 18:58:10 +00:00
|
|
|
#include "..\script_component.hpp"
|
2023-02-17 02:06:11 +00:00
|
|
|
/*
|
|
|
|
* Author: QuantX
|
|
|
|
* Gets the capacity of a fuel source's tank.
|
|
|
|
*
|
|
|
|
* Arguments:
|
|
|
|
* 0: Fuel Source <OBJECT>
|
|
|
|
*
|
|
|
|
* Return Value:
|
|
|
|
* Fuel capacity <NUMBER> (-10 means infinte fuel, -1 means not a fuel source, >0 is a capacity in liters)
|
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
* [fuelTruck] call ace_refuel_fnc_getCapacity
|
|
|
|
*
|
|
|
|
* Public: Yes
|
|
|
|
*/
|
|
|
|
|
|
|
|
params [["_source", objNull, [objNull]]];
|
|
|
|
|
|
|
|
if (isNull _source) exitWith {REFUEL_DISABLED_FUEL};
|
|
|
|
|
|
|
|
private _capacity = _source getVariable QGVAR(capacity);
|
|
|
|
|
|
|
|
// Initialize fuel truck if needed
|
|
|
|
if (isNil "_capacity") then {
|
|
|
|
// Check if this object has a fuelCargo config entry
|
|
|
|
private _fuelCargo = configOf _source >> QGVAR(fuelCargo);
|
|
|
|
_capacity = if (isNumber _fuelCargo) then {getNumber _fuelCargo} else {REFUEL_DISABLED_FUEL};
|
|
|
|
|
|
|
|
// Set capacity even if this isn't a fuel source to save on config lookup time in the event this function is used in a loop
|
|
|
|
_source setVariable [QGVAR(capacity), _capacity, true];
|
2023-11-04 20:58:17 +00:00
|
|
|
// handle weird edge case when trying to run on "camera"/CfgNonAIVehicles which won't support setVariable and will inf-loop
|
2024-02-05 17:04:24 +00:00
|
|
|
if (isNil {_source getVariable QGVAR(capacity)}) exitWith { WARNING_1("trying to getCapacity from non-CfgVehicle %1",_this); };
|
2023-02-17 02:06:11 +00:00
|
|
|
[_source, _capacity] call FUNC(setFuel);
|
|
|
|
};
|
|
|
|
|
|
|
|
_capacity;
|