ace_common: throttledPublicVariable function

This commit is contained in:
Nicolás Badano 2015-02-09 22:59:43 -03:00
parent a2b1cf1259
commit f163e307c8
2 changed files with 50 additions and 0 deletions

View File

@ -127,6 +127,7 @@ PREP(toBin);
PREP(toBitmask);
PREP(toHex);
PREP(toNumber);
PREP(throttledPublicVariable);
PREP(unmuteUnit);
PREP(waitAndExecute);

View File

@ -0,0 +1,49 @@
/*
* Author: CAA-Picard
* Schedules the publishment of an object variable to reduce network overhead
*
* Arguments:
* 0: Unit <OBJECT>.
* 1: Variable name <STRING>
* 2: Maximum delay <NUMBER>
*
* Return Value:
* None
*
* Example:
* None
*
* Public: No
*/
#include "script_component.hpp"
EXPLODE_3_PVT(_this,_unit,_varName,_maxDelay);
// Create the publish scheduler PFH the first time
if (isNil QGVAR(publishSchedId)) then {
GVAR(publishVarNames) = [];
GVAR(publishNextTime) = 1e7;
GVAR(publishSchedId) = [{
if (diag_tickTime > GVAR(publishNextTime)) then {
{
EXPLODE_2_PVT(_x,_unit,_varName);
_unit setVariable [_varName, (_unit getVariable _varName), true];
} forEach GVAR(publishVarNames);
GVAR(publishVarNames) = [];
GVAR(publishNextTime) = 1e7;
};
}, 0, []] call cba_fnc_addPerFrameHandler;
};
// If the variable is not on the list
if (GVAR(publishVarNames) find [_unit,_varName] == -1) exitWith {
GVAR(publishVarNames) pushBack [_unit,_varName];
GVAR(publishNextTime) = GVAR(publishNextTime) min (diag_tickTime + _maxDelay);
};
// If the variable is on the list
GVAR(publishNextTime) = GVAR(publishNextTime) min (diag_tickTime + _maxDelay);