Skip to content

Commit

Permalink
Refuel - Fix fuel source disabling (#9995)
Browse files Browse the repository at this point in the history
* Add enable setting

* Exclude man class init

* Fix multiplayer terrain pump fuel sync

* Add terrain pumps positions

* Add vanilla fuel cargo restoring before destroying

* Add Livonia positions by bux

* Fix terrain pumps destruction

* Improve settings init

* Fix double settings category

* Check enabled var in public functions

* Fix fnc_makeSource

* Handle recent CUP Terrains changes

* Update includes

* Fix issues introduced in #9133

* Change warning

Co-authored-by: johnb432 <[email protected]>

* Optimisations and cleanup

- Use hashmaps wherever possible
- Reduced pump search radius by ~30%
- Sorted pumps alphabetically and sorted positions by "smallest" first, for consistency

* Add init debug trace

* compileScript in dev

* yoda conditions & DFUNC macro

* Wait until CBA settings are ready

* Update Chernarus 2020 and add more maps configs

* Remove vanilla fuel cargo restoring before destroying

* Update fnc_makeSource.sqf

---------

Co-authored-by: Dystopian <[email protected]>
Co-authored-by: Grim <[email protected]>
  • Loading branch information
3 people authored May 23, 2024
1 parent 7c65f85 commit c0d74ba
Showing 1 changed file with 16 additions and 1 deletion.
17 changes: 16 additions & 1 deletion addons/refuel/functions/fnc_makeSource.sqf
Original file line number Diff line number Diff line change
Expand Up @@ -40,9 +40,24 @@ TRACE_4("makeSource",_source,_fuelCargo,_hooks,_fuelCargoConfig);
if (
isNull _source
|| {_fuelCargo < 0 && {!(_fuelCargo in [REFUEL_INFINITE_FUEL, REFUEL_DISABLED_FUEL])}}
|| {_fuelCargo == REFUEL_DISABLED_FUEL && {_fuelCargoConfig == REFUEL_DISABLED_FUEL}}
) exitWith {};

// We might be removing fuel from an object that in config doesn't have fuel, but was given fuel via this function prior
if (_fuelCargo == REFUEL_DISABLED_FUEL && {_fuelCargoConfig == REFUEL_DISABLED_FUEL}) exitWith {
if (isNil {_source getVariable QGVAR(currentFuelCargo)}) exitWith {};

_source setVariable [QGVAR(currentFuelCargo), nil, true];
_source setVariable [QGVAR(capacity), REFUEL_DISABLED_FUEL, true];

private _jipID = _source getVariable QGVAR(initSource_jipID);

if (isNil "_jipID") exitWith {};

_jipID call CBA_fnc_removeGlobalEventJIP;

_source setVariable [QGVAR(initSource_jipID), nil];
};

private _capacity = if (_fuelCargo < 0) then {_fuelCargo} else {_fuelCargoConfig max _fuelCargo};

_source setVariable [QGVAR(capacity), _capacity, true];
Expand Down

0 comments on commit c0d74ba

Please sign in to comment.