From 9c440e1e6852f0a9c327b5ed086aa6b6ed54dbf2 Mon Sep 17 00:00:00 2001 From: Kawe Mazidjatari <48657826+Mauler125@users.noreply.github.com> Date: Wed, 26 Oct 2022 01:55:36 +0200 Subject: [PATCH] Overlay log system cleanup * Use single static buffer instead of each overlay having its own (its only used in the material system thread). * Improved readability by using ternary operators and c++ style casts. --- r5dev/engine/host.cpp | 2 +- r5dev/engine/sys_utils.cpp | 4 +- r5dev/squirrel/sqvm.cpp | 4 +- r5dev/tier0/dbg.cpp | 10 +- r5dev/vgui/vgui_baseui_interface.cpp | 2 +- r5dev/vgui/vgui_debugpanel.cpp | 184 ++++++++++++--------------- r5dev/vgui/vgui_debugpanel.h | 10 +- r5dev/vgui/vgui_fpspanel.cpp | 2 +- 8 files changed, 95 insertions(+), 123 deletions(-) diff --git a/r5dev/engine/host.cpp b/r5dev/engine/host.cpp index 84e597d1..663384b3 100644 --- a/r5dev/engine/host.cpp +++ b/r5dev/engine/host.cpp @@ -32,7 +32,7 @@ void _Host_RunFrame(void* unused, float time) }), g_FrameTasks.end()); #ifndef DEDICATED - g_pLogSystem.ShouldDraw(time); + g_pOverlay->ShouldDraw(time); #endif // !DEDICATED return v_Host_RunFrame(unused, time); diff --git a/r5dev/engine/sys_utils.cpp b/r5dev/engine/sys_utils.cpp index e217d661..228719cc 100644 --- a/r5dev/engine/sys_utils.cpp +++ b/r5dev/engine/sys_utils.cpp @@ -83,8 +83,8 @@ void HCon_NPrintf(int pos, const char* fmt, ...) va_end(args); }///////////////////////////// - snprintf(g_pLogSystem.m_pszCon_NPrintf_Buf, - sizeof(g_pLogSystem.m_pszCon_NPrintf_Buf), buf); + snprintf(g_pOverlay->m_pszCon_NPrintf_Buf, + sizeof(g_pOverlay->m_pszCon_NPrintf_Buf), buf); } } #endif // !DEDICATED diff --git a/r5dev/squirrel/sqvm.cpp b/r5dev/squirrel/sqvm.cpp index 8ff6fc08..dc7791ec 100644 --- a/r5dev/squirrel/sqvm.cpp +++ b/r5dev/squirrel/sqvm.cpp @@ -196,7 +196,7 @@ SQRESULT SQVM_PrintFunc(HSQUIRRELVM v, SQChar* fmt, ...) } g_pConsole->AddLog(ConLog_t(g_spd_sys_w_oss.str(), color)); - g_pLogSystem.AddLog(static_cast(nResponseId), g_spd_sys_w_oss.str()); + g_pOverlay->AddLog(static_cast(nResponseId), g_spd_sys_w_oss.str()); } #endif // !DEDICATED } @@ -289,7 +289,7 @@ SQRESULT SQVM_WarningFunc(HSQUIRRELVM v, SQInteger a2, SQInteger a3, SQInteger* iconsole->debug(vmStr); // Emit to in-game console. g_pConsole->AddLog(ConLog_t(g_spd_sys_w_oss.str(), ImVec4(1.00f, 1.00f, 0.00f, 0.80f))); - g_pLogSystem.AddLog(EGlobalContext_t::WARNING_C, g_spd_sys_w_oss.str()); + g_pOverlay->AddLog(EGlobalContext_t::WARNING_C, g_spd_sys_w_oss.str()); #endif // !DEDICATED } diff --git a/r5dev/tier0/dbg.cpp b/r5dev/tier0/dbg.cpp index 4d93d96b..55a793fd 100644 --- a/r5dev/tier0/dbg.cpp +++ b/r5dev/tier0/dbg.cpp @@ -172,7 +172,7 @@ void NetMsg(EGlobalContext_t context, const char* fmt, ...) iconsole->debug(svOut); g_pConsole->AddLog(ConLog_t(g_spd_sys_w_oss.str(), color)); - g_pLogSystem.AddLog(static_cast(context), g_spd_sys_w_oss.str()); + g_pOverlay->AddLog(static_cast(context), g_spd_sys_w_oss.str()); g_spd_sys_w_oss.str(""); g_spd_sys_w_oss.clear(); @@ -271,7 +271,7 @@ void NetMsg(EGlobalContext_t context, const char* fmt, ...) iconsole->info(svOut); g_pConsole->AddLog(ConLog_t(g_spd_sys_w_oss.str(), color)); - g_pLogSystem.AddLog(context, g_spd_sys_w_oss.str()); + g_pOverlay->AddLog(context, g_spd_sys_w_oss.str()); g_spd_sys_w_oss.str(""); g_spd_sys_w_oss.clear(); @@ -391,7 +391,7 @@ void DevMsg(eDLL_T context, const char* fmt, ...) if (g_bSpdLog_PostInit) { g_pConsole->AddLog(ConLog_t(g_spd_sys_w_oss.str(), color)); - g_pLogSystem.AddLog(tLog, g_spd_sys_w_oss.str()); + g_pOverlay->AddLog(tLog, g_spd_sys_w_oss.str()); } g_spd_sys_w_oss.str(""); @@ -472,7 +472,7 @@ void Warning(eDLL_T context, const char* fmt, ...) if (g_bSpdLog_PostInit) { g_pConsole->AddLog(ConLog_t(g_spd_sys_w_oss.str(), ImVec4(1.00f, 1.00f, 0.00f, 0.80f))); - g_pLogSystem.AddLog(EGlobalContext_t::WARNING_C, g_spd_sys_w_oss.str()); + g_pOverlay->AddLog(EGlobalContext_t::WARNING_C, g_spd_sys_w_oss.str()); } g_spd_sys_w_oss.str(""); @@ -555,7 +555,7 @@ void Error(eDLL_T context, UINT code, const char* fmt, ...) if (g_bSpdLog_PostInit) { g_pConsole->AddLog(ConLog_t(g_spd_sys_w_oss.str(), ImVec4(1.00f, 0.00f, 0.00f, 1.00f))); - g_pLogSystem.AddLog(EGlobalContext_t::ERROR_C, g_spd_sys_w_oss.str()); + g_pOverlay->AddLog(EGlobalContext_t::ERROR_C, g_spd_sys_w_oss.str()); } g_spd_sys_w_oss.str(""); diff --git a/r5dev/vgui/vgui_baseui_interface.cpp b/r5dev/vgui/vgui_baseui_interface.cpp index adbfb12c..715db9fb 100644 --- a/r5dev/vgui/vgui_baseui_interface.cpp +++ b/r5dev/vgui/vgui_baseui_interface.cpp @@ -22,7 +22,7 @@ int CEngineVGui::Paint(CEngineVGui* thisptr, PaintMode_t mode) if (/*mode == PaintMode_t::PAINT_UIPANELS ||*/ mode == PaintMode_t::PAINT_INGAMEPANELS) // Render in-main menu and in-game. { CEngineVGui_RenderStart(g_pMatSystemSurfaceReference); - g_pLogSystem.Update(); + g_pOverlay->Update(); CEngineVGui_RenderEnd(); } diff --git a/r5dev/vgui/vgui_debugpanel.cpp b/r5dev/vgui/vgui_debugpanel.cpp index fddb1291..18eaad10 100644 --- a/r5dev/vgui/vgui_debugpanel.cpp +++ b/r5dev/vgui/vgui_debugpanel.cpp @@ -10,24 +10,23 @@ #include #include #include +#include #include #include #include #include +#ifndef CLIENT_DLL +#include +#endif // !CLIENT_DLL +#include #include #include #include -#ifndef CLIENT_DLL -#include -#endif -#include -#include - //----------------------------------------------------------------------------- // Purpose: proceed a log update //----------------------------------------------------------------------------- -void CLogSystem::Update(void) +void CTextOverlay::Update(void) { if (!g_pMatSystemSurface) { @@ -62,50 +61,33 @@ void CLogSystem::Update(void) //----------------------------------------------------------------------------- // Purpose: add a log to the vector. //----------------------------------------------------------------------------- -void CLogSystem::AddLog(const EGlobalContext_t context, const string& svText) +void CTextOverlay::AddLog(const EGlobalContext_t context, const string& svText) { - if (con_drawnotify->GetBool()) + if (!con_drawnotify->GetBool() || svText.empty()) { - if (svText.length() > 0) - { - std::lock_guard l(m_Mutex); - m_vNotifyText.push_back(CNotifyText{ context, con_notifytime->GetFloat() , svText }); + return; + } - while (m_vNotifyText.size() > 0 && - (m_vNotifyText.size() > con_notifylines->GetInt())) - { - m_vNotifyText.erase(m_vNotifyText.begin()); - } - } + std::lock_guard l(m_Mutex); + m_vNotifyText.push_back(CNotifyText{ context, con_notifytime->GetFloat() , svText }); + + while (m_vNotifyText.size() > 0 && + (m_vNotifyText.size() > con_notifylines->GetInt())) + { + m_vNotifyText.erase(m_vNotifyText.begin()); } } //----------------------------------------------------------------------------- // Purpose: draw notify logs on screen. //----------------------------------------------------------------------------- -void CLogSystem::DrawNotify(void) +void CTextOverlay::DrawNotify(void) { - int x; - int y; - if (con_notify_invert_x->GetBool()) - { - x = g_nWindowWidth - con_notify_offset_x->GetInt(); - } - else - { - x = con_notify_offset_x->GetInt(); - } - if (con_notify_invert_y->GetBool()) - { - y = g_nWindowHeight - con_notify_offset_y->GetInt(); - } - else - { - y = con_notify_offset_y->GetInt(); - } + int x = con_notify_invert_x->GetBool() ? g_nWindowWidth - con_notify_offset_x->GetInt() : con_notify_offset_x->GetInt(); + int y = con_notify_invert_y->GetBool() ? g_nWindowHeight - con_notify_offset_y->GetInt() : con_notify_offset_y->GetInt(); std::lock_guard l(m_Mutex); - for (int i = 0, j = m_vNotifyText.size(); i < j; i++) + for (size_t i = 0, j = m_vNotifyText.size(); i < j; i++) { CNotifyText* pNotify = &m_vNotifyText[i]; Color c = GetLogColorForType(m_vNotifyText[i].m_type); @@ -115,7 +97,7 @@ void CLogSystem::DrawNotify(void) if (flTimeleft < 1.0f) { float f = clamp(flTimeleft, 0.0f, 1.0f) / 1.0f; - c[3] = (int)(f * 255.0f); + c[3] = static_cast(f * 255.0f); if (i == 0 && f < 0.2f) { @@ -140,11 +122,34 @@ void CLogSystem::DrawNotify(void) } } +//----------------------------------------------------------------------------- +// Purpose: draws formatted text over RUI +// Input : x - +// y - +// pszFormat - +// ... - +//----------------------------------------------------------------------------- +void CTextOverlay::DrawFormat(const int x, const int y, const Color c, const char* pszFormat, ...) const +{ + static char szLogbuf[4096]{}; + {///////////////////////////// + va_list args{}; + va_start(args, pszFormat); + + vsnprintf(szLogbuf, sizeof(szLogbuf), pszFormat, args); + + szLogbuf[sizeof(szLogbuf) - 1] = '\0'; + va_end(args); + }///////////////////////////// + + CMatSystemSurface_DrawColoredText(g_pMatSystemSurface, v_Rui_GetFontFace(), m_nFontHeight, x, y, c.r(), c.g(), c.b(), c.a(), szLogbuf); +} + //----------------------------------------------------------------------------- // Purpose: checks if the notify text is expired // Input : flFrameTime - //----------------------------------------------------------------------------- -void CLogSystem::ShouldDraw(const float flFrameTime) +void CTextOverlay::ShouldDraw(const float flFrameTime) { if (con_drawnotify->GetBool()) { @@ -166,119 +171,86 @@ void CLogSystem::ShouldDraw(const float flFrameTime) } else if (!m_vNotifyText.empty()) { + std::lock_guard l(m_Mutex); m_vNotifyText.clear(); } } //----------------------------------------------------------------------------- -// Purpose: draw current host stats on screen. +// Purpose: draws live host stats on screen. //----------------------------------------------------------------------------- -void CLogSystem::DrawHostStats(void) const +void CTextOverlay::DrawHostStats(void) const { - int nWidth = cl_hoststats_offset_x->GetInt(); - int nHeight = cl_hoststats_offset_y->GetInt(); const static Color c = { 255, 255, 255, 255 }; - - if (cl_hoststats_invert_x->GetBool()) - { - nWidth = g_nWindowWidth - nWidth; - } - if (cl_hoststats_invert_y->GetBool()) - { - nHeight = g_nWindowHeight - nHeight; - } + int nWidth = cl_hoststats_invert_x->GetBool() ? g_nWindowWidth - cl_hoststats_offset_x->GetInt() : cl_hoststats_offset_x->GetInt(); + int nHeight = cl_hoststats_invert_y->GetBool() ? g_nWindowHeight - cl_hoststats_offset_y->GetInt() : cl_hoststats_offset_y->GetInt(); CMatSystemSurface_DrawColoredText(g_pMatSystemSurface, v_Rui_GetFontFace(), m_nFontHeight, nWidth, nHeight, c.r(), c.g(), c.b(), c.a(), m_pszCon_NPrintf_Buf); } //----------------------------------------------------------------------------- -// Purpose: draw current simulation stats on screen. +// Purpose: draws live simulation stats on screen. //----------------------------------------------------------------------------- -void CLogSystem::DrawSimStats(void) const +void CTextOverlay::DrawSimStats(void) const { - int nWidth = cl_simstats_offset_x->GetInt(); - int nHeight = cl_simstats_offset_y->GetInt(); - static Color c = { 255, 255, 255, 255 }; - static const char* szLogbuf[4096]{}; + int nWidth = cl_simstats_invert_x->GetBool() ? g_nWindowWidth - cl_simstats_offset_x->GetInt() : cl_simstats_offset_x->GetInt(); + int nHeight = cl_simstats_invert_y->GetBool() ? g_nWindowHeight - cl_simstats_offset_y->GetInt() : cl_simstats_offset_y->GetInt(); - snprintf((char*)szLogbuf, 4096, "Server Frame: (%d) Client Frame: (%d) Render Frame: (%d)\n", + DrawFormat(nWidth, nHeight, c, "Server Frame: (%d) Client Frame: (%d) Render Frame: (%d)\n", g_pClientState->GetServerTickCount(), g_pClientState->GetClientTickCount(), *g_nRenderTickCount); - - if (cl_simstats_invert_x->GetBool()) - { - nWidth = g_nWindowWidth - nWidth; - } - if (cl_simstats_invert_y->GetBool()) - { - nHeight = g_nWindowHeight - nHeight; - } - - CMatSystemSurface_DrawColoredText(g_pMatSystemSurface, v_Rui_GetFontFace(), m_nFontHeight, nWidth, nHeight, c.r(), c.g(), c.b(), c.a(), (char*)szLogbuf); } //----------------------------------------------------------------------------- -// Purpose: draw current gpu stats on screen. +// Purpose: draws live gpu stats on screen. //----------------------------------------------------------------------------- -void CLogSystem::DrawGPUStats(void) const +void CTextOverlay::DrawGPUStats(void) const { - int nWidth = cl_gpustats_offset_x->GetInt(); - int nHeight = cl_gpustats_offset_y->GetInt(); - static Color c = { 255, 255, 255, 255 }; - static const char* szLogbuf[4096]{}; - snprintf((char*)szLogbuf, 4096, "%8d/%8d/%8dkiB unusable/unfree/total GPU Streaming Texture memory\n", - *g_nUnusableStreamingTextureMemory / 1024, *g_nUnfreeStreamingTextureMemory / 1024, *g_nUnusableStreamingTextureMemory / 1024); + int nWidth = cl_gpustats_invert_x->GetBool() ? g_nWindowWidth - cl_gpustats_offset_x->GetInt() : cl_gpustats_offset_x->GetInt(); + int nHeight = cl_gpustats_invert_y->GetBool() ? g_nWindowHeight - cl_gpustats_offset_y->GetInt() : cl_gpustats_offset_y->GetInt(); - if (cl_gpustats_invert_x->GetBool()) - { - nWidth = g_nWindowWidth - nWidth; - } - if (cl_gpustats_invert_y->GetBool()) - { - nHeight = g_nWindowHeight - nHeight; - } - - CMatSystemSurface_DrawColoredText(g_pMatSystemSurface, v_Rui_GetFontFace(), m_nFontHeight, nWidth, nHeight, c.r(), c.g(), c.b(), c.a(), (char*)szLogbuf); + DrawFormat(nWidth, nHeight, c, "%8d/%8d/%8dkiB unusable/unfree/total GPU Streaming Texture memory\n", + *g_nUnusableStreamingTextureMemory / 1024, *g_nUnfreeStreamingTextureMemory / 1024, *g_nUnusableStreamingTextureMemory / 1024); } //----------------------------------------------------------------------------- -// Purpose: draw currently traced material info on screen. +// Purpose: draws currently traced material info on screen. //----------------------------------------------------------------------------- -void CLogSystem::DrawCrosshairMaterial(void) const +void CTextOverlay::DrawCrosshairMaterial(void) const { CMaterialGlue* pMaterialGlue = GetMaterialAtCrossHair(); if (!pMaterialGlue) return; static Color c = { 255, 255, 255, 255 }; - static const char* szLogbuf[4096]{}; - snprintf((char*)szLogbuf, 4096, "name: %s\nguid: %llx\ndimensions: %d x %d\nsurface: %s/%s\nstc: %i\ntc: %i", + DrawFormat(cl_materialinfo_offset_x->GetInt(), cl_materialinfo_offset_y->GetInt(), c, "name: %s\nguid: %llx\ndimensions: %d x %d\nsurface: %s/%s\nstc: %i\ntc: %i", pMaterialGlue->m_pszName, pMaterialGlue->m_GUID, pMaterialGlue->m_iWidth, pMaterialGlue->m_iHeight, pMaterialGlue->m_pszSurfaceProp, pMaterialGlue->m_pszSurfaceProp2, pMaterialGlue->m_nStreamableTextureCount, pMaterialGlue->m_pShaderGlue->m_nTextureInputCount); - - CMatSystemSurface_DrawColoredText(g_pMatSystemSurface, v_Rui_GetFontFace(), m_nFontHeight, cl_materialinfo_offset_x->GetInt(), cl_materialinfo_offset_y->GetInt(), c.r(), c.g(), c.b(), c.a(), (char*)szLogbuf); } -void CLogSystem::DrawStreamOverlay(void) const +//----------------------------------------------------------------------------- +// Purpose: draws the stream overlay on screen. +//----------------------------------------------------------------------------- +void CTextOverlay::DrawStreamOverlay(void) const { - char buf[4096]; - - GetStreamOverlay(stream_overlay_mode->GetString(), buf, sizeof(buf)); - + static char szLogbuf[4096]; static Color c = { 255, 255, 255, 255 }; - - CMatSystemSurface_DrawColoredText(g_pMatSystemSurface, v_Rui_GetFontFace(), m_nFontHeight, 20, 300, c.r(), c.g(), c.b(), c.a(), buf); + + GetStreamOverlay(stream_overlay_mode->GetString(), szLogbuf, sizeof(szLogbuf)); + CMatSystemSurface_DrawColoredText(g_pMatSystemSurface, v_Rui_GetFontFace(), m_nFontHeight, 20, 300, c.r(), c.g(), c.b(), c.a(), szLogbuf); } //----------------------------------------------------------------------------- -// Purpose: get log color for passed type. +// Purpose: gets the log color for context. +// Input : context - +// Output : Color //----------------------------------------------------------------------------- -Color CLogSystem::GetLogColorForType(const EGlobalContext_t context) const +Color CTextOverlay::GetLogColorForType(const EGlobalContext_t context) const { switch (context) { @@ -316,4 +288,4 @@ Color CLogSystem::GetLogColorForType(const EGlobalContext_t context) const } /////////////////////////////////////////////////////////////////////////////// -CLogSystem g_pLogSystem; +CTextOverlay* g_pOverlay = new CTextOverlay(); diff --git a/r5dev/vgui/vgui_debugpanel.h b/r5dev/vgui/vgui_debugpanel.h index 5e002291..df51d8bf 100644 --- a/r5dev/vgui/vgui_debugpanel.h +++ b/r5dev/vgui/vgui_debugpanel.h @@ -15,10 +15,10 @@ struct CNotifyText string m_svMessage = ""; }; -class CLogSystem +class CTextOverlay { public: - CLogSystem() + CTextOverlay() { m_nFontHeight = 16; memset(m_pszCon_NPrintf_Buf, '\0', sizeof(m_pszCon_NPrintf_Buf)); @@ -26,8 +26,8 @@ public: void Update(void); void AddLog(const EGlobalContext_t context, const string& svText); - void DrawLog(void); - void DrawNotify(); + void DrawNotify(void); + void DrawFormat(const int x, const int y, const Color c, const char* pszFormat, ...) const; void ShouldDraw(const float flFrameTime); void DrawHostStats(void) const; void DrawSimStats(void) const; @@ -51,4 +51,4 @@ void CEngineVGui_Attach(); void CEngineVGui_Detach(); /////////////////////////////////////////////////////////////////////////////// -extern CLogSystem g_pLogSystem; +extern CTextOverlay* g_pOverlay; diff --git a/r5dev/vgui/vgui_fpspanel.cpp b/r5dev/vgui/vgui_fpspanel.cpp index 13b8c1a9..f4d7aa28 100644 --- a/r5dev/vgui/vgui_fpspanel.cpp +++ b/r5dev/vgui/vgui_fpspanel.cpp @@ -15,7 +15,7 @@ //----------------------------------------------------------------------------- ConVar* HCFPSPanel_Paint(void* thisptr) { - g_pLogSystem.Update(); + g_pOverlay->Update(); return CFPSPanel_Paint(thisptr); }