engine(masterserver): fix servers duplication
This commit is contained in:
parent
7be935079d
commit
3b20e2404c
2 changed files with 21 additions and 17 deletions
|
@ -46,7 +46,7 @@ public:
|
||||||
// Master sent back a challenge value, read it and send the actual heartbeat
|
// Master sent back a challenge value, read it and send the actual heartbeat
|
||||||
virtual void RespondToHeartbeatChallenge( netadr_t &from, bf_read &msg ) = 0;
|
virtual void RespondToHeartbeatChallenge( netadr_t &from, bf_read &msg ) = 0;
|
||||||
// Console command to set/remove master server
|
// Console command to set/remove master server
|
||||||
virtual void SetMaster_f( const CCommand &args ) = 0;
|
virtual void AddMaster_f( const CCommand &args ) = 0;
|
||||||
// Force a heartbeat to be issued right away
|
// Force a heartbeat to be issued right away
|
||||||
virtual void Heartbeat_f( void ) = 0;
|
virtual void Heartbeat_f( void ) = 0;
|
||||||
|
|
||||||
|
|
|
@ -76,7 +76,7 @@ public:
|
||||||
|
|
||||||
void ProcessConnectionlessPacket( netpacket_t *packet );
|
void ProcessConnectionlessPacket( netpacket_t *packet );
|
||||||
|
|
||||||
void SetMaster_f( const CCommand &args );
|
void AddMaster_f( const CCommand &args );
|
||||||
void Heartbeat_f( void );
|
void Heartbeat_f( void );
|
||||||
|
|
||||||
void RunFrame();
|
void RunFrame();
|
||||||
|
@ -89,15 +89,15 @@ public:
|
||||||
void RequestInternetServerList( const char *gamedir, IServerListResponse *response );
|
void RequestInternetServerList( const char *gamedir, IServerListResponse *response );
|
||||||
void RequestLANServerList( const char *gamedir, IServerListResponse *response );
|
void RequestLANServerList( const char *gamedir, IServerListResponse *response );
|
||||||
void AddServerAddresses( netadr_t **adr, int count );
|
void AddServerAddresses( netadr_t **adr, int count );
|
||||||
void StopRefresh();
|
|
||||||
void RequestServerInfo( const netadr_t &adr );
|
void RequestServerInfo( const netadr_t &adr );
|
||||||
|
void StopRefresh();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// List of known master servers
|
// List of known master servers
|
||||||
adrlist_t *m_pMasterAddresses;
|
adrlist_t *m_pMasterAddresses;
|
||||||
|
|
||||||
bool m_bInitialized;
|
bool m_bInitialized;
|
||||||
bool m_bWaitingForReplys;
|
bool m_bRefreshing;
|
||||||
|
|
||||||
int m_iServersResponded;
|
int m_iServersResponded;
|
||||||
|
|
||||||
|
@ -139,7 +139,7 @@ CMaster::CMaster( void )
|
||||||
m_serverListResponse = NULL;
|
m_serverListResponse = NULL;
|
||||||
SetDefLessFunc( m_serverAddresses );
|
SetDefLessFunc( m_serverAddresses );
|
||||||
SetDefLessFunc( m_serversRequestTime );
|
SetDefLessFunc( m_serversRequestTime );
|
||||||
m_bWaitingForReplys = false;
|
m_bRefreshing = false;
|
||||||
m_iInfoSequence = 1;
|
m_iInfoSequence = 1;
|
||||||
|
|
||||||
Init();
|
Init();
|
||||||
|
@ -153,14 +153,14 @@ void CMaster::RunFrame()
|
||||||
{
|
{
|
||||||
CheckHeartbeat();
|
CheckHeartbeat();
|
||||||
|
|
||||||
if( !m_bWaitingForReplys )
|
if( !m_bRefreshing )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if( m_serverListResponse &&
|
if( m_serverListResponse &&
|
||||||
m_flStartRequestTime < Plat_FloatTime()-INFO_REQUEST_TIMEOUT )
|
m_flStartRequestTime < Plat_FloatTime()-INFO_REQUEST_TIMEOUT )
|
||||||
{
|
{
|
||||||
m_serverListResponse->RefreshComplete( NServerResponse::nServerFailedToRespond );
|
|
||||||
StopRefresh();
|
StopRefresh();
|
||||||
|
m_serverListResponse->RefreshComplete( NServerResponse::nServerFailedToRespond );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -190,11 +190,11 @@ void CMaster::RunFrame()
|
||||||
|
|
||||||
void CMaster::StopRefresh()
|
void CMaster::StopRefresh()
|
||||||
{
|
{
|
||||||
if( !m_bWaitingForReplys )
|
if( !m_bRefreshing )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
m_iServersResponded = 0;
|
m_iServersResponded = 0;
|
||||||
m_bWaitingForReplys = false;
|
m_bRefreshing = false;
|
||||||
m_serverAddresses.RemoveAll();
|
m_serverAddresses.RemoveAll();
|
||||||
m_serversRequestTime.RemoveAll();
|
m_serversRequestTime.RemoveAll();
|
||||||
}
|
}
|
||||||
|
@ -235,9 +235,7 @@ void CMaster::ReplyInfo( const netadr_t &adr, uint sequence )
|
||||||
buf.PutUnsignedInt( nFlags );
|
buf.PutUnsignedInt( nFlags );
|
||||||
|
|
||||||
if ( nFlags & S2A_EXTRA_DATA_HAS_GAMETAG_DATA )
|
if ( nFlags & S2A_EXTRA_DATA_HAS_GAMETAG_DATA )
|
||||||
{
|
|
||||||
buf.PutString( pchTags );
|
buf.PutString( pchTags );
|
||||||
}
|
|
||||||
|
|
||||||
NET_SendPacket( NULL, NS_SERVER, adr, (unsigned char *)buf.Base(), buf.TellPut() );
|
NET_SendPacket( NULL, NS_SERVER, adr, (unsigned char *)buf.Base(), buf.TellPut() );
|
||||||
}
|
}
|
||||||
|
@ -293,6 +291,9 @@ void CMaster::ProcessConnectionlessPacket( netpacket_t *packet )
|
||||||
}
|
}
|
||||||
case M2C_QUERY:
|
case M2C_QUERY:
|
||||||
{
|
{
|
||||||
|
if( !m_bRefreshing )
|
||||||
|
break;
|
||||||
|
|
||||||
ip = msg.ReadLong();
|
ip = msg.ReadLong();
|
||||||
port = msg.ReadShort();
|
port = msg.ReadShort();
|
||||||
|
|
||||||
|
@ -323,6 +324,9 @@ void CMaster::ProcessConnectionlessPacket( netpacket_t *packet )
|
||||||
}
|
}
|
||||||
case S2C_INFOREPLY:
|
case S2C_INFOREPLY:
|
||||||
{
|
{
|
||||||
|
if( !m_bRefreshing )
|
||||||
|
break;
|
||||||
|
|
||||||
uint sequence = msg.ReadLong();
|
uint sequence = msg.ReadLong();
|
||||||
newgameserver_t &s = ProcessInfo( msg );
|
newgameserver_t &s = ProcessInfo( msg );
|
||||||
|
|
||||||
|
@ -584,7 +588,7 @@ void CMaster::RespondToHeartbeatChallenge( netadr_t &from, bf_read &msg )
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose: Add/remove master servers
|
// Purpose: Add/remove master servers
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
void CMaster::SetMaster_f ( const CCommand &args )
|
void CMaster::AddMaster_f ( const CCommand &args )
|
||||||
{
|
{
|
||||||
CUtlString cmd( ( args.ArgC() > 1 ) ? args[ 1 ] : "" );
|
CUtlString cmd( ( args.ArgC() > 1 ) ? args[ 1 ] : "" );
|
||||||
|
|
||||||
|
@ -620,9 +624,9 @@ void CMaster::Heartbeat_f (void)
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose:
|
// Purpose:
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
void SetMaster_f( const CCommand &args )
|
void AddMaster_f( const CCommand &args )
|
||||||
{
|
{
|
||||||
master->SetMaster_f( args );
|
master->AddMaster_f( args );
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
@ -633,7 +637,7 @@ void Heartbeat1_f( void )
|
||||||
master->Heartbeat_f();
|
master->Heartbeat_f();
|
||||||
}
|
}
|
||||||
|
|
||||||
static ConCommand setmaster("setmaster", SetMaster_f );
|
static ConCommand setmaster("addmaster", AddMaster_f );
|
||||||
static ConCommand heartbeat("heartbeat", Heartbeat1_f, "Force heartbeat of master servers" );
|
static ConCommand heartbeat("heartbeat", Heartbeat1_f, "Force heartbeat of master servers" );
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
@ -679,7 +683,7 @@ void CMaster::RequestInternetServerList(const char *gamedir, IServerListResponse
|
||||||
if( response )
|
if( response )
|
||||||
{
|
{
|
||||||
StopRefresh();
|
StopRefresh();
|
||||||
m_bWaitingForReplys = true;
|
m_bRefreshing = true;
|
||||||
m_serverListResponse = response;
|
m_serverListResponse = response;
|
||||||
m_flRetryRequestTime = m_flStartRequestTime = m_flMasterRequestTime = Plat_FloatTime();
|
m_flRetryRequestTime = m_flStartRequestTime = m_flMasterRequestTime = Plat_FloatTime();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue