summaryrefslogtreecommitdiff
path: root/replay/thinkmanager.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/thinkmanager.cpp
downloadarchived-source-engine-2018-hl2-src-3bf9df6b2785fa6d951086978a3e66f49427166a.tar.xz
archived-source-engine-2018-hl2-src-3bf9df6b2785fa6d951086978a3e66f49427166a.zip
Diffstat (limited to 'replay/thinkmanager.cpp')
-rw-r--r--replay/thinkmanager.cpp49
1 files changed, 49 insertions, 0 deletions
diff --git a/replay/thinkmanager.cpp b/replay/thinkmanager.cpp
new file mode 100644
index 0000000..696420c
--- /dev/null
+++ b/replay/thinkmanager.cpp
@@ -0,0 +1,49 @@
+//========= Copyright Valve Corporation, All rights reserved. ============//
+//
+//=======================================================================================//
+
+#include "thinkmanager.h"
+#include "ithinker.h"
+#include "replay/ienginereplay.h"
+#include "replay_dbg.h"
+
+// memdbgon must be the last include file in a .cpp file!!!
+#include "tier0/memdbgon.h"
+
+//----------------------------------------------------------------------------------------
+
+extern IEngineReplay *g_pEngine;
+
+//----------------------------------------------------------------------------------------
+
+void CThinkManager::AddThinker( IThinker *pThinker )
+{
+ Assert( m_lstManagers.Find( pThinker ) == m_lstManagers.InvalidIndex() );
+ m_lstManagers.AddToTail( pThinker );
+}
+
+void CThinkManager::RemoveThinker( IThinker *pThinker )
+{
+ int it = m_lstManagers.Find( pThinker ); Assert( it != m_lstManagers.InvalidIndex() );
+ m_lstManagers.Remove( it );
+}
+
+void CThinkManager::Think()
+{
+ FOR_EACH_LL( m_lstManagers, i )
+ {
+ IThinker *pCurThinker = m_lstManagers[ i ];
+ if ( !pCurThinker->ShouldThink() )
+ continue;
+
+ pCurThinker->Think();
+ pCurThinker->PostThink();
+ }
+}
+
+//----------------------------------------------------------------------------------------
+
+static CThinkManager s_ThinkManager;
+IThinkManager *g_pThinkManager = &s_ThinkManager;
+
+//----------------------------------------------------------------------------------------