From befdcc2dffe3ff74a19f1aa5d3debddec40aa818 Mon Sep 17 00:00:00 2001 From: johnb432 <58661205+johnb432@users.noreply.github.com> Date: Sun, 12 Jan 2025 16:05:14 +0100 Subject: [PATCH] Unclaim, then claim --- addons/sitting/functions/fnc_sit.sqf | 12 +++++++++--- addons/sitting/functions/fnc_stand.sqf | 12 +++++++++--- 2 files changed, 18 insertions(+), 6 deletions(-) diff --git a/addons/sitting/functions/fnc_sit.sqf b/addons/sitting/functions/fnc_sit.sqf index 71ce49f6899..29da603c64f 100644 --- a/addons/sitting/functions/fnc_sit.sqf +++ b/addons/sitting/functions/fnc_sit.sqf @@ -94,9 +94,15 @@ private _seatDistOrig = (getPosASL _player) distance _seat; _seatsClaimed set [_seatPos, objNull]; _seat setVariable [QGVAR(seatsClaimed), _seatsClaimed, true]; - // Unclaim if no one else sitting on it, but pass ownership if someone remains - private _newOwner = _seatsClaimed param [_seatsClaimed findIf {!isNull _x}, objNull]; - [_newOwner, _seat] call EFUNC(common,claim); + // Unclaim... + [objNull, _seat] call EFUNC(common,claim); + + // ...but have a remaining unit reclaim ownership immediately + private _index = _seatsClaimed findIf {!isNull _x}; + + if (_index == -1) exitWith {}; + + [_seatsClaimed select _index, _seat] call EFUNC(common,claim); }; // Stand up if chair gets deleted or moved diff --git a/addons/sitting/functions/fnc_stand.sqf b/addons/sitting/functions/fnc_stand.sqf index eb4655c1b9e..26fb4fd6191 100644 --- a/addons/sitting/functions/fnc_stand.sqf +++ b/addons/sitting/functions/fnc_stand.sqf @@ -46,6 +46,12 @@ private _seatsClaimed = _seat getVariable [QGVAR(seatsClaimed), []]; _seatsClaimed set [_seatPos, objNull]; _seat setVariable [QGVAR(seatsClaimed), _seatsClaimed, true]; -// Unclaim if no one else sitting on it, but pass ownership if someone remains -private _newOwner = _seatsClaimed param [_seatsClaimed findIf {!isNull _x}, objNull]; -[_newOwner, _seat] call EFUNC(common,claim); +// Unclaim... +[objNull, _seat] call EFUNC(common,claim); + +// ...but have a remaining unit reclaim ownership immediately +private _index = _seatsClaimed findIf {!isNull _x}; + +if (_index == -1) exitWith {}; + +[_seatsClaimed select _index, _seat] call EFUNC(common,claim);