summaryrefslogtreecommitdiff
path: root/replay/thinkmanager.cpp
diff options
context:
space:
mode:
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;
+
+//----------------------------------------------------------------------------------------