2015-06-30 15:46:07 +06:00
|
|
|
#include "precompiled.h"
|
|
|
|
|
2017-10-12 21:50:56 +07:00
|
|
|
DebugOutputLevel outputLevel[] =
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2017-10-12 21:50:56 +07:00
|
|
|
{ "bot", DEBUG_BOT },
|
|
|
|
{ "career", DEBUG_CAREER },
|
|
|
|
{ "tutor", DEBUG_TUTOR },
|
|
|
|
{ "stats", DEBUG_STATS },
|
2017-01-29 05:56:29 +06:00
|
|
|
{ "hostage", DEBUG_HOSTAGE },
|
2017-10-12 21:50:56 +07:00
|
|
|
{ "all", DEBUG_ALL },
|
2015-06-30 15:46:07 +06:00
|
|
|
};
|
|
|
|
|
|
|
|
unsigned int theDebugOutputTypes;
|
2017-10-20 00:12:02 +07:00
|
|
|
char theDebugBuffer[MAX_DEBUG_BUFF_SIZE];
|
2015-06-30 15:46:07 +06:00
|
|
|
|
2016-02-04 06:18:26 +06:00
|
|
|
bool IsDeveloper()
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
|
|
|
return (CVAR_GET_FLOAT("developer") > 0.0);
|
|
|
|
}
|
|
|
|
|
|
|
|
NOXREF void UTIL_DPrintf(DebugOutputType outputType, char *pszMsg, ...)
|
|
|
|
{
|
2015-08-20 16:35:01 +06:00
|
|
|
if (!IsDeveloper())
|
|
|
|
return;
|
2015-06-30 15:46:07 +06:00
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
if (theDebugOutputTypes & outputType)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-08-20 16:35:01 +06:00
|
|
|
va_list argptr;
|
|
|
|
va_start(argptr, pszMsg);
|
|
|
|
vsprintf(theDebugBuffer, pszMsg, argptr);
|
|
|
|
va_end(argptr);
|
|
|
|
|
|
|
|
SERVER_PRINT(theDebugBuffer);
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void UTIL_DPrintf(char *pszMsg, ...)
|
|
|
|
{
|
2015-08-20 16:35:01 +06:00
|
|
|
if (!IsDeveloper())
|
|
|
|
return;
|
|
|
|
|
2015-06-30 15:46:07 +06:00
|
|
|
va_list argptr;
|
|
|
|
va_start(argptr, pszMsg);
|
2015-08-20 16:35:01 +06:00
|
|
|
vsprintf(theDebugBuffer, pszMsg, argptr);
|
|
|
|
va_end(argptr);
|
2015-06-30 15:46:07 +06:00
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
SERVER_PRINT(theDebugBuffer);
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
2016-02-04 06:18:26 +06:00
|
|
|
void PrintDebugFlags()
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
|
|
|
char *tmp;
|
2017-10-12 21:50:56 +07:00
|
|
|
int remainder = MAX_DEBUG_BUFF_SIZE;
|
2015-06-30 15:46:07 +06:00
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
theDebugBuffer[0] = '\0';
|
2015-06-30 15:46:07 +06:00
|
|
|
tmp = BufPrintf(theDebugBuffer, remainder, "mp_debug:\n");
|
|
|
|
|
2017-01-29 05:56:29 +06:00
|
|
|
for (auto level : outputLevel) {
|
2015-08-20 16:35:01 +06:00
|
|
|
tmp = BufPrintf(tmp, remainder, " %s: %s\n", level.name, (theDebugOutputTypes & level.value) ? "on" : "off");
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
2017-01-29 05:56:29 +06:00
|
|
|
|
2015-06-30 15:46:07 +06:00
|
|
|
SERVER_PRINT(theDebugBuffer);
|
|
|
|
}
|
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
void SetDebugFlag(const char *flagStr, bool state)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2017-01-29 05:56:29 +06:00
|
|
|
if (flagStr)
|
2015-12-09 04:39:54 +06:00
|
|
|
{
|
2017-01-29 05:56:29 +06:00
|
|
|
for (auto level : outputLevel)
|
2015-12-09 04:39:54 +06:00
|
|
|
{
|
|
|
|
if (FStrEq(level.name, flagStr))
|
|
|
|
{
|
2017-01-29 05:56:29 +06:00
|
|
|
DebugOutputType flag = level.value;
|
2015-12-09 04:39:54 +06:00
|
|
|
if (state)
|
|
|
|
theDebugOutputTypes |= flag;
|
|
|
|
else
|
|
|
|
theDebugOutputTypes &= ~flag;
|
|
|
|
|
|
|
|
SERVER_PRINT(SharedVarArgs("mp_debug: %s is now %s\n", flagStr, state ? "on" : "off"));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
SERVER_PRINT(SharedVarArgs("mp_debug: unknown variable '%s'\n", flagStr));
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
void PrintDebugFlag(const char *flagStr)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2017-01-29 05:56:29 +06:00
|
|
|
if (flagStr)
|
2015-12-09 04:39:54 +06:00
|
|
|
{
|
2017-01-29 05:56:29 +06:00
|
|
|
for (auto level : outputLevel)
|
2015-12-09 04:39:54 +06:00
|
|
|
{
|
|
|
|
if (FStrEq(level.name, flagStr))
|
|
|
|
{
|
2017-01-29 05:56:29 +06:00
|
|
|
SERVER_PRINT(SharedVarArgs("mp_debug: %s is %s\n", flagStr, (level.value & theDebugOutputTypes) ? "on" : "off"));
|
2015-12-09 04:39:54 +06:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
SERVER_PRINT(SharedVarArgs("mp_debug: unknown variable '%s'\n", flagStr));
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
void UTIL_SetDprintfFlags(const char *flagStr)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-08-20 16:35:01 +06:00
|
|
|
if (!IsDeveloper())
|
|
|
|
return;
|
|
|
|
|
2017-01-29 05:56:29 +06:00
|
|
|
if (!flagStr || !flagStr[0]) {
|
|
|
|
PrintDebugFlags();
|
|
|
|
return;
|
2015-08-20 16:35:01 +06:00
|
|
|
}
|
2017-01-29 05:56:29 +06:00
|
|
|
|
|
|
|
if (flagStr[0] == '+')
|
|
|
|
SetDebugFlag(&flagStr[1], true);
|
|
|
|
|
|
|
|
else if (flagStr[0] == '-')
|
|
|
|
SetDebugFlag(&flagStr[1], false);
|
2015-08-20 16:35:01 +06:00
|
|
|
else
|
2017-01-29 05:56:29 +06:00
|
|
|
PrintDebugFlag(flagStr);
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
NOXREF void UTIL_BotDPrintf(char *pszMsg, ...)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-08-20 16:35:01 +06:00
|
|
|
if (!IsDeveloper())
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (theDebugOutputTypes & DEBUG_BOT)
|
|
|
|
{
|
|
|
|
va_list argptr;
|
|
|
|
va_start(argptr, pszMsg);
|
|
|
|
vsprintf(theDebugBuffer, pszMsg, argptr);
|
|
|
|
va_end(argptr);
|
|
|
|
|
|
|
|
SERVER_PRINT(theDebugBuffer);
|
|
|
|
}
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
void UTIL_CareerDPrintf(char *pszMsg, ...)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-08-20 16:35:01 +06:00
|
|
|
if (!IsDeveloper())
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (theDebugOutputTypes & DEBUG_CAREER)
|
|
|
|
{
|
|
|
|
va_list argptr;
|
|
|
|
va_start(argptr, pszMsg);
|
|
|
|
vsprintf(theDebugBuffer, pszMsg, argptr);
|
|
|
|
va_end(argptr);
|
|
|
|
|
|
|
|
SERVER_PRINT(theDebugBuffer);
|
|
|
|
}
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
NOXREF void UTIL_TutorDPrintf(char *pszMsg, ...)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-08-20 16:35:01 +06:00
|
|
|
if (!IsDeveloper())
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (theDebugOutputTypes & DEBUG_TUTOR)
|
|
|
|
{
|
|
|
|
va_list argptr;
|
|
|
|
va_start(argptr, pszMsg);
|
|
|
|
vsprintf(theDebugBuffer, pszMsg, argptr);
|
|
|
|
va_end(argptr);
|
|
|
|
|
|
|
|
SERVER_PRINT(theDebugBuffer);
|
|
|
|
}
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
NOXREF void UTIL_StatsDPrintf(char *pszMsg, ...)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-08-20 16:35:01 +06:00
|
|
|
if (!IsDeveloper())
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (theDebugOutputTypes & DEBUG_STATS)
|
|
|
|
{
|
|
|
|
va_list argptr;
|
|
|
|
va_start(argptr, pszMsg);
|
|
|
|
vsprintf(theDebugBuffer, pszMsg, argptr);
|
|
|
|
va_end(argptr);
|
|
|
|
|
|
|
|
SERVER_PRINT(theDebugBuffer);
|
|
|
|
}
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
2015-08-20 16:35:01 +06:00
|
|
|
NOXREF void UTIL_HostageDPrintf(char *pszMsg, ...)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-08-20 16:35:01 +06:00
|
|
|
if (!IsDeveloper())
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (theDebugOutputTypes & DEBUG_HOSTAGE)
|
|
|
|
{
|
|
|
|
va_list argptr;
|
|
|
|
va_start(argptr, pszMsg);
|
|
|
|
vsprintf(theDebugBuffer, pszMsg, argptr);
|
|
|
|
va_end(argptr);
|
|
|
|
|
|
|
|
SERVER_PRINT(theDebugBuffer);
|
|
|
|
}
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|