mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-29 09:45:32 +00:00
[Browser] Optimize PingRakNetServer() function
This commit is contained in:
parent
93bd3207db
commit
42eaa7a8fd
1 changed files with 31 additions and 22 deletions
|
@ -7,7 +7,6 @@
|
||||||
#include <RakSleep.h>
|
#include <RakSleep.h>
|
||||||
#include <GetTime.h>
|
#include <GetTime.h>
|
||||||
|
|
||||||
#include <iostream>
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <components/openmw-mp/Version.hpp>
|
#include <components/openmw-mp/Version.hpp>
|
||||||
|
|
||||||
|
@ -19,32 +18,42 @@ unsigned int PingRakNetServer(const char *addr, unsigned short port)
|
||||||
{
|
{
|
||||||
RakNet::Packet *packet;
|
RakNet::Packet *packet;
|
||||||
bool done = false;
|
bool done = false;
|
||||||
int attempts = 0;
|
int attempt = 0;
|
||||||
|
static const int timeout = 5;
|
||||||
RakNet::TimeMS time = PING_UNREACHABLE;
|
RakNet::TimeMS time = PING_UNREACHABLE;
|
||||||
|
|
||||||
RakNet::SocketDescriptor socketDescriptor {0, ""};
|
RakNet::SocketDescriptor socketDescriptor{0, ""};
|
||||||
RakNet::RakPeerInterface *peer = RakNet::RakPeerInterface::GetInstance();
|
RakNet::RakPeerInterface *peer = RakNet::RakPeerInterface::GetInstance();
|
||||||
peer->Startup(1,&socketDescriptor, 1);
|
peer->Startup(1, &socketDescriptor, 1);
|
||||||
|
|
||||||
peer->Ping(addr, port, false);
|
peer->Ping(addr, port, false);
|
||||||
while (!done)
|
while (!done)
|
||||||
{
|
{
|
||||||
for (packet=peer->Receive(); packet; peer->DeallocatePacket(packet), packet=peer->Receive())
|
packet = peer->Receive();
|
||||||
|
if (!packet)
|
||||||
{
|
{
|
||||||
if(packet->data[0] == ID_UNCONNECTED_PONG)
|
if (attempt > 5)
|
||||||
{
|
done = true;
|
||||||
RakNet::BitStream bsIn(&packet->data[1], packet->length, false);
|
attempt++;
|
||||||
bsIn.Read(time);
|
RakSleep(timeout);
|
||||||
time = RakNet::GetTimeMS() - time - 5;
|
continue;
|
||||||
done = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (attempts >= 60) // wait 300 msec
|
switch (packet->data[0])
|
||||||
done = true;
|
{
|
||||||
attempts++;
|
case ID_DISCONNECTION_NOTIFICATION:
|
||||||
RakSleep(5);
|
case ID_CONNECTION_LOST:
|
||||||
|
done = true;
|
||||||
|
break;
|
||||||
|
case ID_CONNECTED_PING:
|
||||||
|
case ID_UNCONNECTED_PONG:
|
||||||
|
RakNet::BitStream bsIn(&packet->data[1], packet->length, false);
|
||||||
|
bsIn.Read(time);
|
||||||
|
time = RakNet::GetTimeMS() - time - timeout;
|
||||||
|
done = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
peer->DeallocatePacket(packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
peer->Shutdown(0);
|
peer->Shutdown(0);
|
||||||
|
@ -110,7 +119,7 @@ ServerExtendedData getExtendedData(const char *addr, unsigned short port)
|
||||||
}
|
}
|
||||||
puts(msg.c_str());
|
puts(msg.c_str());
|
||||||
|
|
||||||
if(queue == -1) // connection is failed
|
if (queue == -1) // connection is failed
|
||||||
return data;
|
return data;
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -125,20 +134,20 @@ ServerExtendedData getExtendedData(const char *addr, unsigned short port)
|
||||||
{
|
{
|
||||||
for (packet = peer->Receive(); packet; peer->DeallocatePacket(packet), packet = peer->Receive())
|
for (packet = peer->Receive(); packet; peer->DeallocatePacket(packet), packet = peer->Receive())
|
||||||
{
|
{
|
||||||
if(packet->data[0] == (ID_USER_PACKET_ENUM+1))
|
if (packet->data[0] == (ID_USER_PACKET_ENUM + 1))
|
||||||
{
|
{
|
||||||
RakNet::BitStream bs(packet->data, packet->length, false);
|
RakNet::BitStream bs(packet->data, packet->length, false);
|
||||||
bs.IgnoreBytes(1);
|
bs.IgnoreBytes(1);
|
||||||
size_t length = 0;
|
size_t length = 0;
|
||||||
bs.Read(length);
|
bs.Read(length);
|
||||||
for(size_t i = 0; i < length; i++)
|
for (size_t i = 0; i < length; i++)
|
||||||
{
|
{
|
||||||
RakNet::RakString str;
|
RakNet::RakString str;
|
||||||
bs.Read(str);
|
bs.Read(str);
|
||||||
data.players.push_back(str.C_String());
|
data.players.push_back(str.C_String());
|
||||||
}
|
}
|
||||||
bs.Read(length);
|
bs.Read(length);
|
||||||
for(size_t i = 0; i < length; i++)
|
for (size_t i = 0; i < length; i++)
|
||||||
{
|
{
|
||||||
RakNet::RakString str;
|
RakNet::RakString str;
|
||||||
bs.Read(str);
|
bs.Read(str);
|
||||||
|
|
Loading…
Reference in a new issue