mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
66 lines
1.6 KiB
Plaintext
66 lines
1.6 KiB
Plaintext
|
/**
|
||
|
* fn_debug.sqf
|
||
|
* @Descr: Print logging messages through the CSE framework.
|
||
|
* @Author: Glowbal
|
||
|
*
|
||
|
* @Arguments: [message ANY, level NUMBER (Optional)]
|
||
|
* @Return: BOOL True if message has been printed
|
||
|
* @PublicAPI: true
|
||
|
*/
|
||
|
|
||
|
#define ERROR 0
|
||
|
#define WARN 1
|
||
|
#define DEBUG 2
|
||
|
#define INFO 3
|
||
|
#define NONE 4
|
||
|
|
||
|
#define DEFAULTLOGLEVEL NONE
|
||
|
#define DEFAULTTEXTDISPLAY WARN
|
||
|
|
||
|
private ["_msg", "_level", "_prefix", "_defaultLoglevel","_defaultLogDisplayLevel", "_message", "_from"];
|
||
|
_msg = _this select 0;
|
||
|
_level = _this select 1;
|
||
|
|
||
|
if (isNil "CSE_LOGLEVEL") then {
|
||
|
_defaultLoglevel = DEFAULTLOGLEVEL;
|
||
|
} else {
|
||
|
_defaultLoglevel = CSE_LOGLEVEL;
|
||
|
};
|
||
|
|
||
|
if (isnil "CSE_LOGDISPLAY_LEVEL") then {
|
||
|
_defaultLogDisplayLevel = DEFAULTTEXTDISPLAY;
|
||
|
} else {
|
||
|
_defaultLogDisplayLevel = CSE_LOGDISPLAY_LEVEL;
|
||
|
};
|
||
|
|
||
|
if (isNil "_level") then {
|
||
|
_level = DEBUG;
|
||
|
};
|
||
|
if (_defaultLoglevel == 4) exitwith {false};
|
||
|
if (_level <= _defaultLoglevel) then {
|
||
|
switch (_level) do {
|
||
|
case ERROR: { _prefix = "CSE Error" };
|
||
|
case WARN: { _prefix = "CSE Warn" };
|
||
|
case DEBUG: { _prefix = "CSE Debug" };
|
||
|
case INFO: { _prefix = "CSE Info" };
|
||
|
default { _prefix = "CSE Unknown" };
|
||
|
};
|
||
|
_message = format["[%1] %2",_prefix,_msg];
|
||
|
|
||
|
if (isnil "CSE_LOGIC_OBJECT") then {
|
||
|
_group = createGroup sideLogic;
|
||
|
CSE_LOGIC_OBJECT = _group createUnit ["logic", [1,1,1], [], 0, "FORM"];
|
||
|
};
|
||
|
if (isNull CSE_LOGIC_OBJECT) then {
|
||
|
_group = createGroup sideLogic;
|
||
|
CSE_LOGIC_OBJECT = _group createUnit ["logic", [1,1,1], [], 0, "FORM"];
|
||
|
};
|
||
|
|
||
|
|
||
|
if (_level <= _defaultLogDisplayLevel) then {
|
||
|
showChat true;
|
||
|
CSE_LOGIC_OBJECT globalChat _message;
|
||
|
};
|
||
|
diag_log _message;
|
||
|
};
|
||
|
true
|