summaryrefslogtreecommitdiff
path: root/replay/basethinker.cpp
diff options
context:
space:
mode:
authorFluorescentCIAAfricanAmerican <[email protected]>2020-04-22 12:56:21 -0400
committerFluorescentCIAAfricanAmerican <[email protected]>2020-04-22 12:56:21 -0400
commit3bf9df6b2785fa6d951086978a3e66f49427166a (patch)
tree2c0f1f0c63c4832882bc93814ebd2c2b1c6224e5 /replay/basethinker.cpp
downloadarchived-source-engine-2018-hl2-src-3bf9df6b2785fa6d951086978a3e66f49427166a.tar.xz
archived-source-engine-2018-hl2-src-3bf9df6b2785fa6d951086978a3e66f49427166a.zip
Diffstat (limited to 'replay/basethinker.cpp')
-rw-r--r--replay/basethinker.cpp47
1 files changed, 47 insertions, 0 deletions
diff --git a/replay/basethinker.cpp b/replay/basethinker.cpp
new file mode 100644
index 0000000..108a345
--- /dev/null
+++ b/replay/basethinker.cpp
@@ -0,0 +1,47 @@
+//========= Copyright Valve Corporation, All rights reserved. ============//
+//
+//=======================================================================================//
+
+#include "basethinker.h"
+#include "ithinkmanager.h"
+#include "replay/ienginereplay.h"
+#include "dbg.h"
+
+// memdbgon must be the last include file in a .cpp file!!!
+#include "tier0/memdbgon.h"
+
+//----------------------------------------------------------------------------------------
+
+extern IThinkManager *g_pThinkManager;
+extern IEngineReplay *g_pEngine;
+
+//----------------------------------------------------------------------------------------
+
+CBaseThinker::CBaseThinker()
+: m_flNextThinkTime( 0.0f )
+{
+ g_pThinkManager->AddThinker( this );
+}
+
+CBaseThinker::~CBaseThinker()
+{
+ g_pThinkManager->RemoveThinker( this );
+}
+
+void CBaseThinker::Think()
+{
+ AssertMsg( ShouldThink(), "Thinking before ready - Think() being called explicitly? Let the think manager call Think()." );
+}
+
+bool CBaseThinker::ShouldThink() const
+{
+ const float flHostTime = g_pEngine->GetHostTime();
+ return m_flNextThinkTime >= 0.0f && flHostTime >= m_flNextThinkTime;
+}
+
+void CBaseThinker::PostThink()
+{
+ m_flNextThinkTime = GetNextThinkTime();
+}
+
+//----------------------------------------------------------------------------------------