ACE3/addons/medical_treatment/functions/fnc_onMedicationUsage.sqf

81 lines
2.9 KiB
Plaintext
Raw Normal View History

2015-02-22 09:27:57 +00:00
/*
* Author: Glowbal
* Handles the medication given to a patient.
*
* Arguments:
* 0: The patient <OBJECT>
* 1: Medication Treatment classname <STRING>
* 2: The medication treatment variablename <STRING>
* 3: Max dosage <NUMBER>
* 4: The time in the system <NUMBER>
2015-02-22 09:27:57 +00:00
* 5: Incompatable medication <ARRAY<STRING>>
*
* Return Value:
2015-08-22 14:25:10 +00:00
* None
2015-02-22 09:27:57 +00:00
*
* Public: No
*/
2015-02-28 17:59:37 +00:00
#include "script_component.hpp"
2015-08-22 14:25:10 +00:00
params ["_target", "_className", "_variable", "_maxDosage", "_timeInSystem", "_incompatabileMeds", "_viscosityChange", "_painReduce"];
TRACE_8("params",_target,_className,_variable,_maxDosage,_timeInSystem,_incompatabileMeds,_viscosityChange,_painReduce);
2015-02-22 09:27:57 +00:00
private _foundEntry = false;
private _allUsedMedication = _target getVariable [QEGVAR(medical,allUsedMedication), []];
2015-02-22 09:27:57 +00:00
{
2015-08-22 14:25:10 +00:00
_x params ["_variableX", "_allMedsFromClassname"];
2015-11-30 16:14:05 +00:00
if (_variableX== _variable) exitWith {
2015-02-22 09:27:57 +00:00
if !(_className in _allMedsFromClassname) then {
2015-11-30 16:21:28 +00:00
_allMedsFromClassname pushBack _className;
2015-02-22 09:27:57 +00:00
_x set [1, _allMedsFromClassname];
2015-11-30 16:23:48 +00:00
_allUsedMedication set [_forEachIndex, _x];
_target setVariable [QEGVAR(medical,allUsedMedication), _allUsedMedication];
2015-02-22 09:27:57 +00:00
};
_foundEntry = true;
};
2015-11-30 16:23:48 +00:00
} forEach _allUsedMedication;
2015-02-22 09:27:57 +00:00
if (!_foundEntry) then {
2015-11-30 16:21:28 +00:00
_allUsedMedication pushBack [_variable, [_className]];
_target setVariable [QEGVAR(medical,allUsedMedication), _allUsedMedication];
2015-02-22 09:27:57 +00:00
};
private _usedMeds = _target getVariable [_variable, 0];
if (_usedMeds >= floor (_maxDosage + round(random(2))) && _maxDosage >= 1 && GVAR(enableOverdosing)) then {
[_target] call EFUNC(medical,setDead);
2015-02-22 09:27:57 +00:00
};
private _hasOverDosed = 0;
2015-02-22 09:27:57 +00:00
{
2015-08-22 14:25:10 +00:00
_x params ["_med", "_limit"];
2015-02-22 09:27:57 +00:00
{
2015-08-22 14:25:10 +00:00
_x params ["", "_classNamesUsed"];
2015-02-28 19:46:36 +00:00
if ({_x == _med} count _classNamesUsed > _limit) then {
2015-02-22 09:27:57 +00:00
_hasOverDosed = _hasOverDosed + 1;
};
2015-11-30 16:23:48 +00:00
} forEach _allUsedMedication;
} forEach _incompatabileMeds;
2015-02-22 09:27:57 +00:00
if (_hasOverDosed > 0 && GVAR(enableOverdosing)) then {
private _medicationConfig = (configFile >> "ace_medical_treatment" >> "Medication");
private _onOverDose = getText (_medicationConfig >> "onOverDose");
if (isClass (_medicationConfig >> _className)) then {
_medicationConfig = (_medicationConfig >> _className);
if (isText (_medicationConfig >> "onOverDose")) then { _onOverDose = getText (_medicationConfig >> "onOverDose"); };
};
if (isNil _onOverDose) then {
_onOverDose = compile _onOverDose;
} else {
_onOverDose = missionNamespace getVariable _onOverDose;
};
[_target, _className] call _onOverDose;
};
private _decreaseAmount = 1 / _timeInSystem;
private _viscosityAdjustment = _viscosityChange / _timeInSystem;
// Run the loop that computes the effect of the medication over time
2016-02-29 01:58:09 +00:00
[_target, _variable, 0, _decreaseAmount, _viscosityAdjustment, _painReduce / _timeInSystem] call FUNC(medicationEffectLoop);