mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
9e133aa0a5
* carry item on unload * debug off * fix function header * ugly nested if blocks instead of superior switch statement Co-authored-by: jonpas <jonpas33@gmail.com> * Add delay for server event to finish Co-authored-by: jonpas <jonpas33@gmail.com> Co-authored-by: PabstMirror <pabstmirror@gmail.com>
40 lines
1.3 KiB
Plaintext
40 lines
1.3 KiB
Plaintext
#include "script_component.hpp"
|
|
/*
|
|
* Author: GhostIsSpooky
|
|
* Dragging integration. Unloader starts carrying unloaded object.
|
|
*
|
|
* Arguments:
|
|
* 0: Unloader <OBJECT>
|
|
* 1: Item <OBJECT>
|
|
*
|
|
* Return Value:
|
|
* None
|
|
*
|
|
* Example:
|
|
* [player, object] call ace_cargo_fnc_unloadCarryItem
|
|
*
|
|
* Public: No
|
|
*/
|
|
params ["_unloader", "_object"];
|
|
TRACE_2("unloadCarryItem-start",_unloader,_object);
|
|
|
|
if !(["ace_dragging"] call EFUNC(common,isModLoaded)) exitWith {};
|
|
|
|
// When unloading attached objects, this code will run before server has finished moving object to the safe position
|
|
[{
|
|
params ["_unloader", "_object"];
|
|
(_unloader distance _object) < 10
|
|
}, {
|
|
params ["_unloader", "_object"];
|
|
TRACE_2("unloadCarryItem-unloaded",_unloader,_object);
|
|
if ([_unloader, _object] call EFUNC(dragging,canCarry)) exitWith {
|
|
[_unloader, _object] call EFUNC(dragging,startCarry);
|
|
};
|
|
if ([_unloader, _object] call EFUNC(dragging,canDrag)) exitWith {
|
|
[_unloader, _object] call EFUNC(dragging,startDrag);
|
|
};
|
|
}, _this, 1.0, { // delay is based on how long it will take server event to trigger and take effect
|
|
// not a hard error if this fails, could have just unloaded to other side of vehicle because of findSafePos
|
|
TRACE_1("unloadCarryItem-failed to unload nearby player",_this);
|
|
}] call CBA_fnc_waitUntilAndExecute;
|