mirror of
https://github.com/rehlds/rehlds.git
synced 2025-01-01 01:25:38 +03:00
Merge pull request #412 from dreamstalker/fixes201703193
Add and use netsrc_s size.
This commit is contained in:
commit
a4d2cd722f
@ -16,12 +16,13 @@
|
|||||||
#ifndef ENUMS_H
|
#ifndef ENUMS_H
|
||||||
#define ENUMS_H
|
#define ENUMS_H
|
||||||
|
|
||||||
|
// Used as array indexer
|
||||||
typedef enum netsrc_s
|
typedef enum netsrc_s
|
||||||
{
|
{
|
||||||
NS_CLIENT,
|
NS_CLIENT = 0,
|
||||||
NS_SERVER,
|
NS_SERVER,
|
||||||
NS_MULTICAST // xxxMO
|
NS_MULTICAST, // xxxMO
|
||||||
|
NS_MAX
|
||||||
} netsrc_t;
|
} netsrc_t;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@ CRITICAL_SECTION net_cs;
|
|||||||
qboolean net_thread_initialized;
|
qboolean net_thread_initialized;
|
||||||
|
|
||||||
loopback_t loopbacks[2];
|
loopback_t loopbacks[2];
|
||||||
packetlag_t g_pLagData[3]; // List of lag structures, if fakelag is set.
|
packetlag_t g_pLagData[NS_MAX]; // List of lag structures, if fakelag is set.
|
||||||
float gFakeLag;
|
float gFakeLag;
|
||||||
int net_configured;
|
int net_configured;
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
@ -63,21 +63,21 @@ netadr_t in_from;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef HOOK_ENGINE
|
#ifndef HOOK_ENGINE
|
||||||
SOCKET ip_sockets[3] = { INV_SOCK, INV_SOCK, INV_SOCK };
|
SOCKET ip_sockets[NS_MAX] = { INV_SOCK, INV_SOCK, INV_SOCK };
|
||||||
#else
|
#else
|
||||||
SOCKET ip_sockets[3];
|
SOCKET ip_sockets[NS_MAX];
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#ifndef HOOK_ENGINE
|
#ifndef HOOK_ENGINE
|
||||||
SOCKET ipx_sockets[3] = { INV_SOCK, INV_SOCK, INV_SOCK };
|
SOCKET ipx_sockets[NS_MAX] = { INV_SOCK, INV_SOCK, INV_SOCK };
|
||||||
#else
|
#else
|
||||||
SOCKET ipx_sockets[3];
|
SOCKET ipx_sockets[NS_MAX];
|
||||||
#endif
|
#endif
|
||||||
#endif // _WIN32
|
#endif // _WIN32
|
||||||
|
|
||||||
LONGPACKET gNetSplit;
|
LONGPACKET gNetSplit;
|
||||||
net_messages_t *messages[3];
|
net_messages_t *messages[NS_MAX];
|
||||||
net_messages_t *normalqueue;
|
net_messages_t *normalqueue;
|
||||||
//void *hNetThread;
|
//void *hNetThread;
|
||||||
//int32 dwNetThreadId;
|
//int32 dwNetThreadId;
|
||||||
@ -775,7 +775,7 @@ qboolean NET_LagPacket(qboolean newdata, netsrc_t sock, netadr_t *from, sizebuf_
|
|||||||
packetlag_t *pPacket;
|
packetlag_t *pPacket;
|
||||||
float curtime;
|
float curtime;
|
||||||
int ninterval;
|
int ninterval;
|
||||||
static int losscount[3];
|
static int losscount[NS_MAX];
|
||||||
|
|
||||||
if (gFakeLag <= 0.0)
|
if (gFakeLag <= 0.0)
|
||||||
{
|
{
|
||||||
@ -1087,7 +1087,7 @@ DLL_EXPORT int NET_Sleep_Timeout(void)
|
|||||||
{
|
{
|
||||||
SOCKET number = 0;
|
SOCKET number = 0;
|
||||||
|
|
||||||
for (int sock = 0; sock < 3; sock++)
|
for (int sock = 0; sock < NS_MAX; sock++)
|
||||||
{
|
{
|
||||||
SOCKET net_socket = ip_sockets[sock];
|
SOCKET net_socket = ip_sockets[sock];
|
||||||
if (net_socket != INV_SOCK)
|
if (net_socket != INV_SOCK)
|
||||||
@ -1109,11 +1109,11 @@ DLL_EXPORT int NET_Sleep_Timeout(void)
|
|||||||
}
|
}
|
||||||
#endif // _WIN32
|
#endif // _WIN32
|
||||||
}
|
}
|
||||||
res = select((int)(number + 1), &fdset, 0, 0, &tv);
|
res = select((int)(number + 1), &fdset, NULL, NULL, &tv);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
res = select(0, 0, 0, 0, &tv);
|
res = select(0, NULL, NULL, NULL, &tv);
|
||||||
}
|
}
|
||||||
--numFrames;
|
--numFrames;
|
||||||
return res;
|
return res;
|
||||||
@ -1128,7 +1128,7 @@ int NET_Sleep(void)
|
|||||||
FD_ZERO(&fdset);
|
FD_ZERO(&fdset);
|
||||||
number = 0;
|
number = 0;
|
||||||
|
|
||||||
for (int sock = 0; sock < 3; sock++)
|
for (int sock = 0; sock < NS_MAX; sock++)
|
||||||
{
|
{
|
||||||
SOCKET net_socket = ip_sockets[sock];
|
SOCKET net_socket = ip_sockets[sock];
|
||||||
if (net_socket != INV_SOCK)
|
if (net_socket != INV_SOCK)
|
||||||
@ -1154,7 +1154,7 @@ int NET_Sleep(void)
|
|||||||
tv.tv_sec = 0;
|
tv.tv_sec = 0;
|
||||||
tv.tv_usec = 20 * 1000;
|
tv.tv_usec = 20 * 1000;
|
||||||
|
|
||||||
return select((int)(number + 1), &fdset, 0, 0, net_sleepforever == 0 ? &tv : NULL);
|
return select((int)(number + 1), &fdset, NULL, NULL, net_sleepforever == 0 ? &tv : NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void NET_StartThread(void)
|
void NET_StartThread(void)
|
||||||
@ -1306,7 +1306,7 @@ void NET_AllocateQueues(void)
|
|||||||
|
|
||||||
void NET_FlushQueues(void)
|
void NET_FlushQueues(void)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 3; i++)
|
for (int i = 0; i < NS_MAX; i++)
|
||||||
{
|
{
|
||||||
net_messages_t *p = messages[i];
|
net_messages_t *p = messages[i];
|
||||||
while (p)
|
while (p)
|
||||||
@ -1919,7 +1919,7 @@ void NET_Config(qboolean multiplayer)
|
|||||||
{
|
{
|
||||||
NET_ThreadLock();
|
NET_ThreadLock();
|
||||||
|
|
||||||
for (int sock = 0; sock < 3; sock++)
|
for (int sock = 0; sock < NS_MAX; sock++)
|
||||||
{
|
{
|
||||||
if (ip_sockets[sock] != INV_SOCK)
|
if (ip_sockets[sock] != INV_SOCK)
|
||||||
{
|
{
|
||||||
@ -2041,7 +2041,7 @@ void NET_Init(void)
|
|||||||
in_message.flags = 0;
|
in_message.flags = 0;
|
||||||
in_message.buffername = "in_message";
|
in_message.buffername = "in_message";
|
||||||
|
|
||||||
for (int i = 0; i < 3; i++)
|
for (int i = 0; i < NS_MAX; i++)
|
||||||
{
|
{
|
||||||
g_pLagData[i].pPrev = &g_pLagData[i];
|
g_pLagData[i].pPrev = &g_pLagData[i];
|
||||||
g_pLagData[i].pNext = &g_pLagData[i];
|
g_pLagData[i].pNext = &g_pLagData[i];
|
||||||
|
Loading…
Reference in New Issue
Block a user