From e858abc57ca34bbdc4e424d7298566c1e8310352 Mon Sep 17 00:00:00 2001 From: Fredrik Falk Date: Sun, 15 May 2022 03:17:01 +0200 Subject: [PATCH] Allow stitching when wound reopening disabled --- .../ACE_Medical_Treatment_Actions.hpp | 2 +- addons/medical_treatment/XEH_PREP.hpp | 1 + .../functions/fnc_canStitch.sqf | 11 ++++++- .../functions/fnc_getStitchTime.sqf | 23 ++++++++++++++- .../functions/fnc_surgicalKitProgress.sqf | 5 ++-- .../functions/fnc_surgicalKitSuccess.sqf | 29 +++++++++++++++++++ 6 files changed, 66 insertions(+), 5 deletions(-) create mode 100644 addons/medical_treatment/functions/fnc_surgicalKitSuccess.sqf diff --git a/addons/medical_treatment/ACE_Medical_Treatment_Actions.hpp b/addons/medical_treatment/ACE_Medical_Treatment_Actions.hpp index 433e8a5a62a..1e4c8da75a2 100644 --- a/addons/medical_treatment/ACE_Medical_Treatment_Actions.hpp +++ b/addons/medical_treatment/ACE_Medical_Treatment_Actions.hpp @@ -285,7 +285,7 @@ class GVAR(actions) { medicRequired = QGVAR(medicSurgicalKit); treatmentTime = QFUNC(getStitchTime); condition = QFUNC(canStitch); - callbackSuccess = ""; + callbackSuccess = QFUNC(surgicalKitSuccess); callbackProgress = QFUNC(surgicalKitProgress); consumeItem = QGVAR(consumeSurgicalKit); animationMedic = "AinvPknlMstpSnonWnonDnon_medic1"; diff --git a/addons/medical_treatment/XEH_PREP.hpp b/addons/medical_treatment/XEH_PREP.hpp index 0c0f11742f7..1892f58eca5 100644 --- a/addons/medical_treatment/XEH_PREP.hpp +++ b/addons/medical_treatment/XEH_PREP.hpp @@ -53,6 +53,7 @@ PREP(setTriageStatus); PREP(splint); PREP(splintLocal); PREP(surgicalKitProgress); +PREP(surgicalKitSuccess); PREP(tourniquet); PREP(tourniquetLocal); PREP(tourniquetRemove); diff --git a/addons/medical_treatment/functions/fnc_canStitch.sqf b/addons/medical_treatment/functions/fnc_canStitch.sqf index a542de23f14..d6b0b09958e 100644 --- a/addons/medical_treatment/functions/fnc_canStitch.sqf +++ b/addons/medical_treatment/functions/fnc_canStitch.sqf @@ -18,4 +18,13 @@ params ["", "_patient"]; -(_patient call FUNC(getStitchableWounds) isNotEqualTo []) +(_patient call FUNC(getStitchableWounds) isNotEqualTo []) || +{ // Allow stitching if "Clear Trauma" is set to "After Stitch", + // but wound reopening is disabled + GVAR(clearTrauma) isEqualTo 1 && + {!IS_BLEEDING(_patient)} && + {(_patient getVariable [ + QEGVAR(medical,bodyPartDamage), + [0,0,0,0,0,0] + ]) isNotEqualTo [0,0,0,0,0,0]} +} diff --git a/addons/medical_treatment/functions/fnc_getStitchTime.sqf b/addons/medical_treatment/functions/fnc_getStitchTime.sqf index 12c770eb957..b64342658d6 100644 --- a/addons/medical_treatment/functions/fnc_getStitchTime.sqf +++ b/addons/medical_treatment/functions/fnc_getStitchTime.sqf @@ -17,5 +17,26 @@ */ params ["", "_patient"]; +private _time = 0; + +if (GVAR(advancedBandages) == 2) then { + _time = count (_patient call FUNC(getStitchableWounds)) * GVAR(woundStitchTime) +} else { + // Allow stitching if "Clear Trauma" is set to "After Stitch", + // but wound reopening is disabled + if (GVAR(clearTrauma) == 1) then { + private _bodyPartDamage = _patient getVariable [ + QEGVAR(medical,bodyPartDamage), + [0,0,0,0,0,0] + ]; + + { + ADD(_time, _x * GVAR(woundStitchTime)); + } forEach _bodyPartDamage; + + _time = _time max GVAR(woundStitchTime); + }; +}; + +_time -count (_patient call FUNC(getStitchableWounds)) * GVAR(woundStitchTime) diff --git a/addons/medical_treatment/functions/fnc_surgicalKitProgress.sqf b/addons/medical_treatment/functions/fnc_surgicalKitProgress.sqf index 9928936f30d..06ec177401c 100644 --- a/addons/medical_treatment/functions/fnc_surgicalKitProgress.sqf +++ b/addons/medical_treatment/functions/fnc_surgicalKitProgress.sqf @@ -24,8 +24,9 @@ _args params ["", "_patient"]; private _stitchableWounds = _patient call FUNC(getStitchableWounds); -// Stop treatment if there are no wounds that can be stitched remaining -if (_stitchableWounds isEqualTo []) exitWith {false}; +// Stop treatment if there are no wounds that can be stitched remaining, +// except when clear trauma on stitch is enabled +if (_stitchableWounds isEqualTo []) exitWith {GVAR(clearTrauma) == 1}; // Not enough time has elapsed to stitch a wound if (_totalTime - _elapsedTime > (count _stitchableWounds - 1) * GVAR(woundStitchTime)) exitWith {true}; diff --git a/addons/medical_treatment/functions/fnc_surgicalKitSuccess.sqf b/addons/medical_treatment/functions/fnc_surgicalKitSuccess.sqf new file mode 100644 index 00000000000..ec237c09dde --- /dev/null +++ b/addons/medical_treatment/functions/fnc_surgicalKitSuccess.sqf @@ -0,0 +1,29 @@ +#include "script_component.hpp" +/* + * Author: Freddo + * Handles the surgical kit treatment by resetting bodypart damage. + * + * Arguments: + * 0: Medic (not used) + * 1: Patient + * + * Return Value: + * None + * + * Example: + * [player, player] call ace_medical_treatment_fnc_surgicalKitSuccess + * + * Public: No + */ + +params ["_medic", "_patient"]; + +if (GVAR(clearTrauma) == 1 && {GVAR(advancedBandages) != 2}) then { + TRACE_2("clearTrauma - clearing trauma after stitching (no reopening)",_medic,_patient); + _patient setVariable [QEGVAR(medical,bodyPartDamage), [0,0,0,0,0,0], true]; + + [_patient, true, true, true, true] call EFUNC(medical_engine,updateBodyPartVisuals); +}; + + +nil