Track spectators for each SourceTV instance seperately

This commit is contained in:
Peace-Maker 2016-03-06 12:50:07 +01:00
parent 10910e8b8e
commit 61f59c5b9b
6 changed files with 54 additions and 49 deletions

View File

@ -136,8 +136,9 @@ void CForwardManager::UnhookRecorder(IDemoRecorder *recorder)
SH_REMOVE_HOOK(IDemoRecorder, StopRecording, recorder, SH_MEMBER(this, &CForwardManager::OnStopRecording_Post), true);
}
void CForwardManager::HookServer(IServer *server)
void CForwardManager::HookServer(HLTVServerWrapper *wrapper)
{
IServer *server = wrapper->GetBaseServer();
if (m_bHasClientConnectOffset)
SH_ADD_MANUALHOOK(CHLTVServer_ConnectClient, server, SH_MEMBER(this, &CForwardManager::OnSpectatorConnect), false);
@ -153,13 +154,14 @@ void CForwardManager::HookServer(IServer *server)
HookClient(client);
// Ip and password unknown :(
// Could add more gamedata to fetch it if people really lateload the extension and expect it to work :B
g_HLTVClientManager.GetClient(i + 1)->Initialize("", "", client);
wrapper->GetClient(i + 1)->Initialize("", "", client);
}
}
}
void CForwardManager::UnhookServer(IServer *server)
void CForwardManager::UnhookServer(HLTVServerWrapper *wrapper)
{
IServer *server = wrapper->GetBaseServer();
if (m_bHasClientConnectOffset)
SH_REMOVE_MANUALHOOK(CHLTVServer_ConnectClient, server, SH_MEMBER(this, &CForwardManager::OnSpectatorConnect), false);
@ -297,8 +299,12 @@ IClient *CForwardManager::OnSpectatorConnect(netadr_t & address, int nProtocol,
HookClient(client);
HLTVClientWrapper *wrapper = g_HLTVClientManager.GetClient(client->GetPlayerSlot() + 1);
wrapper->Initialize(ipString, pchPassword, client);
HLTVServerWrapper *wrapper = g_HLTVServers.GetWrapper(server);
if (wrapper)
{
HLTVClientWrapper *clientWrapper = wrapper->GetClient(client->GetPlayerSlot() + 1);
clientWrapper->Initialize(ipString, pchPassword, client);
}
m_SpectatorConnectedFwd->PushCell(client->GetPlayerSlot() + 1);
m_SpectatorConnectedFwd->Execute();

View File

@ -42,28 +42,3 @@ void HLTVClientWrapper::Kick(const char *reason)
// Go this route due to different IClient::Disconnect signatures in games..
m_Client->GetServer()->DisconnectClient(m_Client, reason);
}
HLTVClientWrapper *HLTVClientManager::GetClient(int index)
{
// Grow the vector with null pointers
// There might have been clients with lower indexes before we were loaded.
if (m_Clients.length() < (size_t)index)
{
int start = m_Clients.length();
m_Clients.resize(index);
for (int i = start; i < index; i++)
{
m_Clients[i] = nullptr;
}
}
if (!m_Clients[index - 1])
{
m_Clients[index - 1] = new HLTVClientWrapper();
}
return m_Clients[index - 1];
}
// FIXME: ClientManager instance for each hltvserver instance in csgo!
HLTVClientManager g_HLTVClientManager;

View File

@ -56,16 +56,4 @@ private:
ke::AString m_Password;
IClient *m_Client;
};
class HLTVClientManager {
public:
HLTVClientWrapper *GetClient(int index);
private:
ke::Vector<ke::AutoPtr<HLTVClientWrapper>> m_Clients;
};
extern HLTVClientManager g_HLTVClientManager;
#endif // _INCLUDE_SOURCEMOD_EXTENSION_HLTVCLIENT_H_

View File

@ -65,12 +65,34 @@ int HLTVServerWrapper::GetInstanceNumber()
return g_HLTVServers.GetInstanceNumber(m_HLTVServer);
}
HLTVClientWrapper *HLTVServerWrapper::GetClient(int index)
{
// Grow the vector with null pointers
// There might have been clients with lower indexes before we were loaded.
if (m_Clients.length() < (size_t)index)
{
int start = m_Clients.length();
m_Clients.resize(index);
for (int i = start; i < index; i++)
{
m_Clients[i] = nullptr;
}
}
if (!m_Clients[index - 1])
{
m_Clients[index - 1] = new HLTVClientWrapper();
}
return m_Clients[index - 1];
}
void HLTVServerWrapper::Hook()
{
if (!m_Connected)
return;
g_pSTVForwards.HookServer(m_HLTVServer->GetBaseServer());
g_pSTVForwards.HookServer(this);
g_pSTVForwards.HookRecorder(m_DemoRecorder);
if (g_HLTVServers.HasShutdownOffset())
@ -95,7 +117,7 @@ void HLTVServerWrapper::Unhook()
if (!m_Connected)
return;
g_pSTVForwards.UnhookServer(m_HLTVServer->GetBaseServer());
g_pSTVForwards.UnhookServer(this);
g_pSTVForwards.UnhookRecorder(m_DemoRecorder);
if (g_HLTVServers.HasShutdownOffset())
@ -277,6 +299,17 @@ HLTVServerWrapper *HLTVServerWrapperManager::GetWrapper(IHLTVServer *hltvserver)
return nullptr;
}
HLTVServerWrapper *HLTVServerWrapperManager::GetWrapper(IServer *server)
{
for (unsigned int i = 0; i < m_HLTVServers.length(); i++)
{
HLTVServerWrapper *wrapper = m_HLTVServers[i];
if (wrapper->GetBaseServer() == server)
return wrapper;
}
return nullptr;
}
HLTVServerWrapper *HLTVServerWrapperManager::GetWrapper(IDemoRecorder *demorecorder)
{
for (unsigned int i = 0; i < m_HLTVServers.length(); i++)

View File

@ -44,6 +44,7 @@ public:
IHLTVServer *GetHLTVServer();
IServer *GetBaseServer();
IDemoRecorder *GetDemoRecorder();
HLTVClientWrapper *GetClient(int index);
int GetInstanceNumber();
private:
@ -63,6 +64,7 @@ private:
bool m_Connected = false;
IHLTVServer *m_HLTVServer = nullptr;
IDemoRecorder *m_DemoRecorder = nullptr;
ke::Vector<ke::AutoPtr<HLTVClientWrapper>> m_Clients;
};
class HLTVServerWrapperManager
@ -73,6 +75,7 @@ public:
void AddServer(IHLTVServer *hltvserver);
void RemoveServer(IHLTVServer *hltvserver, bool bInformPlugins);
HLTVServerWrapper *GetWrapper(IHLTVServer *hltvserver);
HLTVServerWrapper *GetWrapper(IServer *server);
HLTVServerWrapper *GetWrapper(IDemoRecorder *demorecorder);
int GetInstanceNumber(IHLTVServer *hltvserver);

View File

@ -619,7 +619,7 @@ static cell_t Native_IsClientConnected(IPluginContext *pContext, const cell_t *p
return 0;
}
HLTVClientWrapper *pClient = g_HLTVClientManager.GetClient(client);
HLTVClientWrapper *pClient = hltvserver->GetClient(client);
return pClient->IsConnected();
}
@ -636,7 +636,7 @@ static cell_t Native_GetSpectatorName(IPluginContext *pContext, const cell_t *pa
return 0;
}
HLTVClientWrapper *pClient = g_HLTVClientManager.GetClient(client);
HLTVClientWrapper *pClient = hltvserver->GetClient(client);
if (!pClient->IsConnected())
{
pContext->ReportError("Client %d is not connected.", client);
@ -660,7 +660,7 @@ static cell_t Native_GetSpectatorIP(IPluginContext *pContext, const cell_t *para
return 0;
}
HLTVClientWrapper *pClient = g_HLTVClientManager.GetClient(client);
HLTVClientWrapper *pClient = hltvserver->GetClient(client);
if (!pClient->IsConnected())
{
pContext->ReportError("Client %d is not connected.", client);
@ -684,7 +684,7 @@ static cell_t Native_GetSpectatorPassword(IPluginContext *pContext, const cell_t
return 0;
}
HLTVClientWrapper *pClient = g_HLTVClientManager.GetClient(client);
HLTVClientWrapper *pClient = hltvserver->GetClient(client);
if (!pClient->IsConnected())
{
pContext->ReportError("Client %d is not connected.", client);
@ -708,7 +708,7 @@ static cell_t Native_KickClient(IPluginContext *pContext, const cell_t *params)
return 0;
}
HLTVClientWrapper *pClient = g_HLTVClientManager.GetClient(client);
HLTVClientWrapper *pClient = hltvserver->GetClient(client);
if (!pClient->IsConnected())
{
pContext->ReportError("Client %d is not connected.", client);