Skip to content

Commit

Permalink
Common - Optimize arithmeticGetResult function (#7232)
Browse files Browse the repository at this point in the history
* Optimize arithmeticGetResult

* Add element to default array, safer function

Co-Authored-By: PabstMirror <[email protected]>
  • Loading branch information
mharis001 and PabstMirror committed Oct 8, 2019
1 parent c1f3e82 commit 13ffc07
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 39 deletions.
67 changes: 30 additions & 37 deletions addons/common/functions/fnc_arithmeticGetResult.sqf
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
#include "script_component.hpp"
/*
* Author: PabstMirror
* Gets arithmetic result from a set.
* Returns the arithmetic result of performing the given operation on a set.
*
* Arguments:
* 0: Namespace <OBJECT><LOCATION><MISSIONNAMESPACE>
* 0: Namespace <OBJECT|LOCATION|NAMESPACE>
* 1: Number Set ID <STRING>
* 2: Operation (sum, product, min, max, avg) (Case Sensitive) <STRING>
* 2: Operation (max, min, sum, product, avg) (Case Sensitive) <STRING>
*
* Return Value:
* Value <NUMBER>
Expand All @@ -18,51 +18,44 @@
* Public: Yes
*/

params ["_namespace", "_setID", "_op"];
TRACE_3("arithmeticGetResult",_namespace,_setID,_op);
params ["_namespace", "_setID", "_operation"];
TRACE_3("arithmeticGetResult",_namespace,_setID,_operation);

private _data = (_namespace getVariable _setID) param [2, []];
private _data = (_namespace getVariable _setID) param [2, [{0}]];

switch (_op) do {
case ("max"): {
private _result = -1e99;
{
_result = _result max (call _x);
nil
} count _data;
_result // return
switch (_operation) do {
case "max": {
selectMax (_data apply {call _x})
};
case "min": {
selectMin (_data apply {call _x})
};
case ("sum"): {
case "sum": {
private _result = 0;

{
_result = _result + (call _x);
nil
} count _data;
_result // return
_result = _result + call _x;
} forEach _data;

_result
};
case ("product"): {
case "product": {
private _result = 1;

{
_result = _result * (call _x);
nil
} count _data;
_result // return
};
case ("min"): {
private _result = 1e99;
{
_result = _result min (call _x);
nil
} count _data;
_result // return
_result = _result * call _x;
} forEach _data;

_result
};
case ("avg"): {
case "avg": {
private _result = 0;

{
_result = _result + (call _x);
nil
} count _data;
_result / (count _data); // return
_result = _result + call _x;
} forEach _data;

_result / count _data
};
default {3735928559};
};
6 changes: 4 additions & 2 deletions addons/common/functions/fnc_arithmeticSetSource.sqf
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
* Adds or removes a source to an arithmetic set.
*
* Arguments:
* 0: Namespace <OBJECT><LOCATION><MISSIONNAMESPACE>
* 0: Namespace <OBJECT|LOCATION|NAMESPACE>
* 1: Number Set ID <STRING>
* 2: Source <STRING>
* 3: Code that returns a number (can access var _namespace) [use {} to remove] <CODE>
Expand All @@ -20,13 +20,15 @@
*/

params ["_namespace", "_setID", "_source", "_variable"];
TRACE_4("params",_namespace,_setID,_source,_variable);
TRACE_4("arithmeticSetSource",_namespace,_setID,_source,_variable);

private _hash = _namespace getVariable _setID;

if (isNil "_hash") then {
_hash = [] call CBA_fnc_hashCreate;
_namespace setVariable [_setID, _hash];
};

if (_variable isEqualTo {}) then {
TRACE_1("removing",_source);
[_hash, _source] call CBA_fnc_hashRem;
Expand Down

0 comments on commit 13ffc07

Please sign in to comment.