aboutsummaryrefslogtreecommitdiff
path: root/mp/src/game/client/c_sprite_perfmonitor.cpp
diff options
context:
space:
mode:
authorJoe Ludwig <[email protected]>2013-06-26 15:22:04 -0700
committerJoe Ludwig <[email protected]>2013-06-26 15:22:04 -0700
commit39ed87570bdb2f86969d4be821c94b722dc71179 (patch)
treeabc53757f75f40c80278e87650ea92808274aa59 /mp/src/game/client/c_sprite_perfmonitor.cpp
downloadsource-sdk-2013-39ed87570bdb2f86969d4be821c94b722dc71179.tar.xz
source-sdk-2013-39ed87570bdb2f86969d4be821c94b722dc71179.zip
First version of the SOurce SDK 2013
Diffstat (limited to 'mp/src/game/client/c_sprite_perfmonitor.cpp')
-rw-r--r--mp/src/game/client/c_sprite_perfmonitor.cpp68
1 files changed, 68 insertions, 0 deletions
diff --git a/mp/src/game/client/c_sprite_perfmonitor.cpp b/mp/src/game/client/c_sprite_perfmonitor.cpp
new file mode 100644
index 00000000..3ff8b29b
--- /dev/null
+++ b/mp/src/game/client/c_sprite_perfmonitor.cpp
@@ -0,0 +1,68 @@
+//========= Copyright Valve Corporation, All rights reserved. ============//
+//
+// Purpose:
+//
+//=============================================================================
+#include "cbase.h"
+
+extern bool g_bMeasureParticlePerformance;
+extern bool g_bDisplayParticlePerformance;
+
+void ResetParticlePerformanceCounters( void );
+
+//-----------------------------------------------------------------------------
+// Purpose:
+//-----------------------------------------------------------------------------
+class C_ParticlePerformanceMonitor : public C_BaseEntity
+{
+ DECLARE_CLASS( C_ParticlePerformanceMonitor, C_BaseEntity );
+public:
+ DECLARE_CLIENTCLASS();
+
+ C_ParticlePerformanceMonitor();
+ ~C_ParticlePerformanceMonitor();
+ virtual void OnDataChanged( DataUpdateType_t updateType );
+
+private:
+ bool m_bDisplayPerf;
+ bool m_bMeasurePerf;
+private:
+ C_ParticlePerformanceMonitor( const C_ParticlePerformanceMonitor & );
+};
+
+IMPLEMENT_CLIENTCLASS_DT( C_ParticlePerformanceMonitor, DT_ParticlePerformanceMonitor, CParticlePerformanceMonitor )
+ RecvPropInt( RECVINFO(m_bMeasurePerf) ),
+ RecvPropInt( RECVINFO(m_bDisplayPerf) ),
+END_RECV_TABLE()
+
+//-----------------------------------------------------------------------------
+// Purpose:
+//-----------------------------------------------------------------------------
+C_ParticlePerformanceMonitor::C_ParticlePerformanceMonitor( void )
+{
+ m_bDisplayPerf = false;
+ m_bMeasurePerf = false;
+}
+
+//-----------------------------------------------------------------------------
+// Purpose:
+//-----------------------------------------------------------------------------
+C_ParticlePerformanceMonitor::~C_ParticlePerformanceMonitor( void )
+{
+ g_bMeasureParticlePerformance = false;
+ g_bDisplayParticlePerformance = false;
+}
+
+//-----------------------------------------------------------------------------
+// Purpose:
+//-----------------------------------------------------------------------------
+void C_ParticlePerformanceMonitor::OnDataChanged( DataUpdateType_t updateType )
+{
+ BaseClass::OnDataChanged(updateType);
+
+ if ( m_bMeasurePerf && ( ! g_bMeasureParticlePerformance ) )
+ ResetParticlePerformanceCounters();
+ g_bMeasureParticlePerformance = m_bMeasurePerf;
+ g_bDisplayParticlePerformance = m_bDisplayPerf;
+}
+