2
0
mirror of https://github.com/rehlds/rehlds.git synced 2025-01-19 10:08:04 +03:00

Merge branch 'master' into launcher_refactoring

This commit is contained in:
Lev 2017-05-03 20:41:14 +05:00 committed by GitHub
commit a6ebcc747c
48 changed files with 231 additions and 191 deletions

View File

@ -65,7 +65,7 @@ There are several software requirements for building rehlds:
</ol> </ol>
### Checking requirements ### Checking requirements
####JDK version #### JDK version
Windows<pre>&gt; %JAVA_HOME%\bin\javac -version Windows<pre>&gt; %JAVA_HOME%\bin\javac -version
javac 1.8.0_25 javac 1.8.0_25
</pre> </pre>
@ -75,15 +75,15 @@ Linux
javac 1.7.0_65 javac 1.7.0_65
</pre> </pre>
####Visual Studio #### Visual Studio
Help -> About Help -> About
####ICC #### ICC
<pre>$ icc --version <pre>$ icc --version
icc (ICC) 15.0.1 20141023 icc (ICC) 15.0.1 20141023
</pre> </pre>
####GCC #### GCC
<pre>$ gcc --version <pre>$ gcc --version
gcc (Debian 4.9.2-10) 4.9.2 gcc (Debian 4.9.2-10) 4.9.2
</pre> </pre>

View File

@ -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

View File

@ -245,7 +245,7 @@ void CSys::Printf(char *fmt, ...)
ConsoleOutput(szText); ConsoleOutput(szText);
} }
#define MAX_LINUX_CMDLINE 2048 const int MAX_LINUX_CMDLINE = 2048;
static char linuxCmdline[MAX_LINUX_CMDLINE]; static char linuxCmdline[MAX_LINUX_CMDLINE];
char* BuildCmdLine(int argc, char **argv) char* BuildCmdLine(int argc, char **argv)

View File

@ -8,7 +8,7 @@
#include "enums.h" #include "enums.h"
#endif #endif
#define MAX_ALIAS_NAME 32 const int MAX_ALIAS_NAME = 32;
typedef struct cmdalias_s typedef struct cmdalias_s
{ {

View File

@ -102,7 +102,7 @@ typedef struct module_s
#include "in_buttons.h" #include "in_buttons.h"
#endif #endif
#define CLDLL_INTERFACE_VERSION 7 const int CLDLL_INTERFACE_VERSION = 7;
extern void LoadSecurityModuleFromDisk(char * pszDllName); extern void LoadSecurityModuleFromDisk(char * pszDllName);
extern void LoadSecurityModuleFromMemory( unsigned char * pCode, int nSize ); extern void LoadSecurityModuleFromMemory( unsigned char * pCode, int nSize );

View File

@ -46,8 +46,8 @@
#include "model.h" #include "model.h"
#include "kbutton.h" #include "kbutton.h"
#define MAX_SCOREBOARDNAME 32 const int MAX_SCOREBOARDNAME = 32;
#define MAX_DEMOS 32 const int MAX_DEMOS = 32;
typedef enum cactive_e typedef enum cactive_e
{ {

View File

@ -36,9 +36,9 @@
All command/alias names are case insensitive! Arguments not. All command/alias names are case insensitive! Arguments not.
*/ */
#define MAX_CMD_BUFFER 16384 const int MAX_CMD_BUFFER = 16384;
#define MAX_CMD_TOKENS 80 const int MAX_CMD_TOKENS = 80;
#define MAX_CMD_LINE 1024 const int MAX_CMD_LINE = 1024;
/* /*

View File

@ -33,7 +33,7 @@
// Looks like no more than 8096 visibility leafs per world model // Looks like no more than 8096 visibility leafs per world model
#define MODEL_MAX_PVS 1024 const int MODEL_MAX_PVS = 1024;
#ifdef HOOK_ENGINE #ifdef HOOK_ENGINE

View File

@ -2798,7 +2798,7 @@ typedef struct
unsigned short wBitsPerSample; unsigned short wBitsPerSample;
} FormatChunk; } FormatChunk;
#define WAVE_HEADER_LENGTH 128 const int WAVE_HEADER_LENGTH = 128;
unsigned int EXT_FUNC COM_GetApproxWavePlayLength(const char *filepath) unsigned int EXT_FUNC COM_GetApproxWavePlayLength(const char *filepath)
{ {

View File

@ -28,7 +28,7 @@
#pragma once #pragma once
#define MAX_CONSISTENCY_LIST 512 const int MAX_CONSISTENCY_LIST = 512;
typedef struct consistency_s typedef struct consistency_s
{ {

View File

@ -32,8 +32,8 @@
#include "cvardef.h" #include "cvardef.h"
#include "FileSystem.h" #include "FileSystem.h"
#define MAX_CVAR_VALUE 1024 const int MAX_CVAR_VALUE = 1024;
#define MAX_CVARLIST_FILES 100 const int MAX_CVARLIST_FILES = 100;
#ifdef HOOK_ENGINE #ifdef HOOK_ENGINE
#define cvar_vars (*pcvar_vars) #define cvar_vars (*pcvar_vars)

View File

@ -32,7 +32,8 @@
#include "model.h" #include "model.h"
#include "wad.h" #include "wad.h"
#define MAX_DECALS 512 const int MAX_DECALS = 512;
#define DECAL_EXTRASIZE sizeof(texture_t) - sizeof(miptex_t) #define DECAL_EXTRASIZE sizeof(texture_t) - sizeof(miptex_t)
typedef struct decalname_s typedef struct decalname_s

View File

@ -30,7 +30,7 @@
#include "maintypes.h" #include "maintypes.h"
#define DELTA_MAX_FIELDS 56 // 7*8 const int DELTA_MAX_FIELDS = 56; // 7*8
enum enum
{ {
@ -46,7 +46,7 @@ enum
DT_SIGNED = BIT(31) // sign modificator DT_SIGNED = BIT(31) // sign modificator
}; };
#define FDT_MARK BIT(0) // Delta mark for sending const int FDT_MARK = BIT(0); // Delta mark for sending
typedef struct delta_s delta_t; typedef struct delta_s delta_t;
typedef void(*encoder_t)(delta_t *, const unsigned char *, const unsigned char *); typedef void(*encoder_t)(delta_t *, const unsigned char *, const unsigned char *);

View File

@ -30,8 +30,8 @@
#include "maintypes.h" #include "maintypes.h"
#define DELTAJIT_MAX_BLOCKS 32 const int DELTAJIT_MAX_BLOCKS = 32;
#define DELTAJIT_MAX_FIELDS 56 const int DELTAJIT_MAX_FIELDS = 56;
struct deltajit_field { struct deltajit_field {
unsigned int id; unsigned int id;

View File

@ -31,11 +31,11 @@
#include "userid.h" #include "userid.h"
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
#define MAX_IPFILTERS 4096 const int MAX_IPFILTERS = 4096;
#define MAX_USERFILTERS 4096 const int MAX_USERFILTERS = 4096;
#else #else
#define MAX_IPFILTERS 32768 const int MAX_IPFILTERS = 32768;
#define MAX_USERFILTERS 32768 const int MAX_USERFILTERS = 32768;
#endif // REHLDS_FIXES #endif // REHLDS_FIXES
typedef struct ipfilter_s typedef struct ipfilter_s

View File

@ -519,6 +519,16 @@ void SV_DropClient_internal(client_t *cl, qboolean crash, const char *string)
cl->connection_started = realtime; cl->connection_started = realtime;
cl->proxy = FALSE; cl->proxy = FALSE;
COM_ClearCustomizationList(&cl->customdata, FALSE); COM_ClearCustomizationList(&cl->customdata, FALSE);
#ifdef REHLDS_FIXES
if (cl->edict)
{
// Reset flags, leave FL_DORMANT used by CS
cl->edict->v.flags &= FL_DORMANT;
// Since the edict doesn't get deleted, fix it so it doesn't interfere.
cl->edict->v.takedamage = DAMAGE_NO; // don't attract autoaim
cl->edict->v.solid = SOLID_NOT;
}
#endif // REHLDS_FIXES
cl->edict = NULL; cl->edict = NULL;
Q_memset(cl->userinfo, 0, sizeof(cl->userinfo)); Q_memset(cl->userinfo, 0, sizeof(cl->userinfo));
Q_memset(cl->physinfo, 0, sizeof(cl->physinfo)); Q_memset(cl->physinfo, 0, sizeof(cl->physinfo));

View File

@ -34,7 +34,7 @@
#include "server.h" #include "server.h"
#include "rehlds_api.h" #include "rehlds_api.h"
#define MAX_COMMAND_LINE_PARAMS 50 const int MAX_COMMAND_LINE_PARAMS = 50;
typedef struct quakeparms_s typedef struct quakeparms_s
{ {

View File

@ -2929,8 +2929,9 @@ void Host_VoiceRecordStop_f(void)
} }
} }
void Host_Crash_f(void) NOXREF void Host_Crash_f(void)
{ {
NOXREFCHECK;
int *p = NULL; int *p = NULL;
*p = 0xffffffff; *p = 0xffffffff;
} }

View File

@ -31,17 +31,17 @@
#include "maintypes.h" #include "maintypes.h"
// Max key/value length (with a NULL char) // Max key/value length (with a NULL char)
#define MAX_KV_LEN 127 const int MAX_KV_LEN = 127;
// Key + value + 2 x slash + NULL // Key + value + 2 x slash + NULL
#define MAX_INFO_STRING 256 const int MAX_INFO_STRING = 256;
#define INFO_MAX_BUFFER_VALUES 4 const int INFO_MAX_BUFFER_VALUES = 4;
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
#define MAX_LOCALINFO 4096 const int MAX_LOCALINFO = 4096;
#else #else
#define MAX_LOCALINFO MAX_INFO_STRING * 128 const int MAX_LOCALINFO = MAX_INFO_STRING * 128;
#endif // REHLDS_FIXES #endif // REHLDS_FIXES
const char *Info_ValueForKey(const char *s, const char *key); const char *Info_ValueForKey(const char *s, const char *key);

View File

@ -30,7 +30,7 @@
#include "entity_state.h" #include "entity_state.h"
#define NUM_BASELINES 64 const int NUM_BASELINES = 64;
typedef struct extra_baselines_s typedef struct extra_baselines_s
{ {

View File

@ -33,7 +33,8 @@
#include "commonmacros.h" #include "commonmacros.h"
// header // header
#define STUDIO_VERSION 10 const int STUDIO_VERSION = 10;
#define IDSTUDIOHEADER MAKEID('I', 'D', 'S', 'T') // little-endian "IDST" #define IDSTUDIOHEADER MAKEID('I', 'D', 'S', 'T') // little-endian "IDST"
#define IDSEQGRPHEADER MAKEID('I', 'D', 'S', 'Q') // little-endian "IDSQ" #define IDSEQGRPHEADER MAKEID('I', 'D', 'S', 'Q') // little-endian "IDSQ"

View File

@ -33,53 +33,53 @@
#include "enums.h" #include "enums.h"
#include "netadr.h" #include "netadr.h"
#define PROTOCOL_VERSION 48 const int PROTOCOL_VERSION = 48;
// MAX_CHALLENGES is made large to prevent a denial // MAX_CHALLENGES is made large to prevent a denial
// of service attack that could cycle all of them // of service attack that could cycle all of them
// out before legitimate users connected // out before legitimate users connected
#ifdef REHLDS_OPT_PEDANTIC #ifdef REHLDS_OPT_PEDANTIC
#define MAX_CHALLENGES 64 const int MAX_CHALLENGES = 64;
#else #else
#define MAX_CHALLENGES 1024 const int MAX_CHALLENGES = 1024;
#endif // REHLDS_OPT_PEDANTIC #endif // REHLDS_OPT_PEDANTIC
// Client connection is initiated by requesting a challenge value // Client connection is initiated by requesting a challenge value
// the server sends this value back // the server sends this value back
#define S2C_CHALLENGE 'A' // + challenge value const char S2C_CHALLENGE = 'A'; // + challenge value
// Send a userid, client remote address, is this server secure and engine build number // Send a userid, client remote address, is this server secure and engine build number
#define S2C_CONNECTION 'B' const char S2C_CONNECTION = 'B';
// HLMaster rejected a server's connection because the server needs to be updated // HLMaster rejected a server's connection because the server needs to be updated
#define M2S_REQUESTRESTART 'O' const char M2S_REQUESTRESTART = 'O';
// send a log event as key value // send a log event as key value
#define S2A_LOGSTRING 'R' const char S2A_LOGSTRING = 'R';
// Send a log string // Send a log string
#define S2A_LOGKEY 'S' const char S2A_LOGKEY = 'S';
// Basic information about the server // Basic information about the server
#define A2S_INFO 'T' const char A2S_INFO = 'T';
// Details about each player on the server // Details about each player on the server
#define A2S_PLAYER 'U' const char A2S_PLAYER = 'U';
// The rules the server is using // The rules the server is using
#define A2S_RULES 'V' const char A2S_RULES = 'V';
// Another user is requesting a challenge value from this machine // Another user is requesting a challenge value from this machine
#define A2A_GETCHALLENGE 'W' // Request challenge # from another machine const char A2A_GETCHALLENGE = 'W'; // Request challenge # from another machine
// Generic Ping Request // Generic Ping Request
#define A2A_PING 'i' // respond with an A2A_ACK const char A2A_PING = 'i'; // respond with an A2A_ACK
// Generic Ack // Generic Ack
#define A2A_ACK 'j' // general acknowledgement without info const char A2A_ACK = 'j'; // general acknowledgement without info
// Challenge response from master // Challenge response from master
#define M2A_CHALLENGE 's' // + challenge value const char M2A_CHALLENGE = 's'; // + challenge value
// 0 == regular, 1 == file stream // 0 == regular, 1 == file stream
enum enum
@ -91,25 +91,25 @@ enum
}; };
// Flow control bytes per second limits // Flow control bytes per second limits
#define MAX_RATE 100000.0f const float MAX_RATE = 100000.0f;
#define MIN_RATE 1000.0f const float MIN_RATE = 1000.0f;
// Default data rate // Default data rate
#define DEFAULT_RATE (9999.0f) const float DEFAULT_RATE = (9999.0f);
// NETWORKING INFO // NETWORKING INFO
// Max size of udp packet payload // Max size of udp packet payload
#define MAX_UDP_PACKET 4010 // 9 bytes SPLITHEADER + 4000 payload? const int MAX_UDP_PACKET = 4010; // 9 bytes SPLITHEADER + 4000 payload?
// Max length of a reliable message // Max length of a reliable message
#define MAX_MSGLEN 3990 // 10 reserved for fragheader? const int MAX_MSGLEN = 3990; // 10 reserved for fragheader?
// Max length of unreliable message // Max length of unreliable message
#define MAX_DATAGRAM 4000 const int MAX_DATAGRAM = 4000;
// This is the packet payload without any header bytes (which are attached for actual sending) // This is the packet payload without any header bytes (which are attached for actual sending)
#define NET_MAX_PAYLOAD 65536 const int NET_MAX_PAYLOAD = 65536;
// This is the payload plus any header info (excluding UDP header) // This is the payload plus any header info (excluding UDP header)
@ -135,7 +135,7 @@ enum
// bytes will be stripped by the networking channel layer // bytes will be stripped by the networking channel layer
//#define NET_MAX_MESSAGE PAD_NUMBER( ( MAX_MSGLEN + HEADER_BYTES ), 16 ) //#define NET_MAX_MESSAGE PAD_NUMBER( ( MAX_MSGLEN + HEADER_BYTES ), 16 )
// This is currently used value in the engine. TODO: define above gives 4016, check it why. // This is currently used value in the engine. TODO: define above gives 4016, check it why.
#define NET_MAX_MESSAGE 4037 const int NET_MAX_MESSAGE = 4037;
typedef enum svc_commands_e typedef enum svc_commands_e
@ -237,7 +237,7 @@ typedef struct flowstats_s
double time; double time;
} flowstats_t; } flowstats_t;
#define MAX_LATENT 32 const int MAX_LATENT = 32;
typedef struct flow_s typedef struct flow_s
{ {
@ -252,19 +252,20 @@ typedef struct flow_s
float avgkbytespersec; float avgkbytespersec;
} flow_t; } flow_t;
#define FRAGMENT_C2S_MIN_SIZE 16 const int FRAGMENT_C2S_MIN_SIZE = 16;
#define FRAGMENT_S2C_MIN_SIZE 256 const int FRAGMENT_S2C_MIN_SIZE = 256;
#define FRAGMENT_S2C_MAX_SIZE 1024 const int FRAGMENT_S2C_MAX_SIZE = 1024;
#define CLIENT_FRAGMENT_SIZE_ONCONNECT 128
#define CUSTOMIZATION_MAX_SIZE 20480 const int CLIENT_FRAGMENT_SIZE_ONCONNECT = 128;
const int CUSTOMIZATION_MAX_SIZE = 20480;
#ifndef REHLDS_FIXES #ifndef REHLDS_FIXES
// Size of fragmentation buffer internal buffers // Size of fragmentation buffer internal buffers
#define FRAGMENT_MAX_SIZE 1400 const int FRAGMENT_MAX_SIZE = 1400;
#define MAX_FRAGMENTS 25000 const int MAX_FRAGMENTS = 25000;
#else #else
#define FRAGMENT_MAX_SIZE 1024 const int FRAGMENT_MAX_SIZE = 1024;
// Client sends normal fragments only while connecting // Client sends normal fragments only while connecting
#define MAX_NORMAL_FRAGMENTS (NET_MAX_PAYLOAD / CLIENT_FRAGMENT_SIZE_ONCONNECT) #define MAX_NORMAL_FRAGMENTS (NET_MAX_PAYLOAD / CLIENT_FRAGMENT_SIZE_ONCONNECT)
@ -274,8 +275,8 @@ typedef struct flow_s
#define MAX_FILE_FRAGMENTS (CUSTOMIZATION_MAX_SIZE / FRAGMENT_C2S_MIN_SIZE) #define MAX_FILE_FRAGMENTS (CUSTOMIZATION_MAX_SIZE / FRAGMENT_C2S_MIN_SIZE)
#endif #endif
#define UDP_HEADER_SIZE 28 const int UDP_HEADER_SIZE = 28;
#define MAX_RELIABLE_PAYLOAD 1200 const int MAX_RELIABLE_PAYLOAD = 1200;
#define MAKE_FRAGID(id,count) ( ( ( id & 0xffff ) << 16 ) | ( count & 0xffff ) ) #define MAKE_FRAGID(id,count) ( ( ( id & 0xffff ) << 16 ) | ( count & 0xffff ) )
#define FRAG_GETID(fragid) ( ( fragid >> 16 ) & 0xffff ) #define FRAG_GETID(fragid) ( ( fragid >> 16 ) & 0xffff )

View File

@ -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)
{ {
@ -784,7 +784,11 @@ qboolean NET_LagPacket(qboolean newdata, netsrc_t sock, netadr_t *from, sizebuf_
} }
curtime = realtime; curtime = realtime;
#ifdef REHLDS_FIXES
if (newdata && data)
#else
if (newdata) if (newdata)
#endif
{ {
if (fakeloss.value != 0.0) if (fakeloss.value != 0.0)
{ {
@ -1023,14 +1027,14 @@ qboolean NET_QueuePacket(netsrc_t sock)
if (ret == -1 || ret == MAX_UDP_PACKET) if (ret == -1 || ret == MAX_UDP_PACKET)
{ {
return NET_LagPacket(0, sock, 0, 0); return NET_LagPacket(FALSE, sock, NULL, NULL);
} }
NET_TransferRawData(&in_message, buf, ret); NET_TransferRawData(&in_message, buf, ret);
if (*(int32 *)in_message.data != NET_HEADER_FLAG_SPLITPACKET) if (*(int32 *)in_message.data != NET_HEADER_FLAG_SPLITPACKET)
{ {
return NET_LagPacket(1, sock, &in_from, &in_message); return NET_LagPacket(TRUE, sock, &in_from, &in_message);
} }
if (in_message.cursize < 9) if (in_message.cursize < 9)
@ -1087,7 +1091,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 +1113,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 +1132,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 +1158,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)
@ -1249,7 +1253,7 @@ qboolean NET_GetPacket(netsrc_t sock)
NET_ThreadLock(); NET_ThreadLock();
if (NET_GetLoopPacket(sock, &in_from, &in_message)) if (NET_GetLoopPacket(sock, &in_from, &in_message))
{ {
bret = NET_LagPacket(1, sock, &in_from, &in_message); bret = NET_LagPacket(TRUE, sock, &in_from, &in_message);
} }
else else
{ {
@ -1257,11 +1261,11 @@ qboolean NET_GetPacket(netsrc_t sock)
{ {
bret = NET_QueuePacket(sock); bret = NET_QueuePacket(sock);
if (!bret) if (!bret)
bret = NET_LagPacket(0, sock, 0, 0); bret = NET_LagPacket(FALSE, sock, NULL, NULL);
} }
else else
{ {
bret = NET_LagPacket(0, sock, 0, 0); bret = NET_LagPacket(FALSE, sock, NULL, NULL);
} }
} }
@ -1306,7 +1310,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 +1923,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 +2045,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];

View File

@ -46,15 +46,15 @@
#endif // _WIN32 #endif // _WIN32
#define MAX_ROUTEABLE_PACKET 1400 const int MAX_ROUTEABLE_PACKET = 1400;
#define SPLIT_SIZE (MAX_ROUTEABLE_PACKET - sizeof(SPLITPACKET)) #define SPLIT_SIZE (MAX_ROUTEABLE_PACKET - sizeof(SPLITPACKET))
// Create general message queues // Create general message queues
#define NUM_MSG_QUEUES 40 const int NUM_MSG_QUEUES = 40;
#define MSG_QUEUE_SIZE 1536 const int MSG_QUEUE_SIZE = 1536;
#define NET_HEADER_FLAG_SPLITPACKET -2 const int NET_HEADER_FLAG_SPLITPACKET = -2;
typedef struct loopmsg_s typedef struct loopmsg_s
{ {
@ -62,7 +62,7 @@ typedef struct loopmsg_s
int datalen; int datalen;
} loopmsg_t; } loopmsg_t;
#define MAX_LOOPBACK 4 const int MAX_LOOPBACK = 4;
typedef struct loopback_s typedef struct loopback_s
{ {
@ -110,7 +110,7 @@ typedef struct SPLITPACKET_t
} SPLITPACKET; } SPLITPACKET;
#pragma pack(pop) #pragma pack(pop)
#define NET_WS_MAX_FRAGMENTS 5 const int NET_WS_MAX_FRAGMENTS = 5;
#ifdef HOOK_ENGINE #ifdef HOOK_ENGINE
#define net_thread_initialized (*pnet_thread_initialized) #define net_thread_initialized (*pnet_thread_initialized)

View File

@ -828,7 +828,7 @@ void EXT_FUNC PF_stuffcmd_I(edict_t *pEdict, const char *szFmt, ...)
Q_vsnprintf(szOut, sizeof(szOut), szFmt, argptr); Q_vsnprintf(szOut, sizeof(szOut), szFmt, argptr);
va_end(argptr); va_end(argptr);
szOut[1023] = 0; szOut[sizeof(szOut) - 1] = 0;
if (entnum < 1 || entnum > g_psvs.maxclients) if (entnum < 1 || entnum > g_psvs.maxclients)
{ {
Con_Printf("\n!!!\n\nStuffCmd: Some entity tried to stuff '%s' to console " Con_Printf("\n!!!\n\nStuffCmd: Some entity tried to stuff '%s' to console "
@ -977,6 +977,8 @@ int EXT_FUNC iGetIndex(const char *pszField)
IGETINDEX_CHECK_FIELD(noise3); IGETINDEX_CHECK_FIELD(noise3);
IGETINDEX_CHECK_FIELD(globalname); IGETINDEX_CHECK_FIELD(globalname);
#undef IGETINDEX_CHECK_FIELD
return -1; return -1;
} }
@ -1017,8 +1019,6 @@ qboolean EXT_FUNC PR_IsEmptyString(const char *s)
int EXT_FUNC PF_precache_sound_I(const char *s) int EXT_FUNC PF_precache_sound_I(const char *s)
{ {
int i;
if (!s) if (!s)
Host_Error("%s: NULL pointer", __func__); Host_Error("%s: NULL pointer", __func__);
@ -1032,7 +1032,7 @@ int EXT_FUNC PF_precache_sound_I(const char *s)
{ {
g_psv.sound_precache_hashedlookup_built = 0; g_psv.sound_precache_hashedlookup_built = 0;
for (i = 0; i < MAX_SOUNDS; i++) for (int i = 0; i < MAX_SOUNDS; i++)
{ {
if (!g_psv.sound_precache[i]) if (!g_psv.sound_precache[i])
{ {
@ -1055,7 +1055,7 @@ int EXT_FUNC PF_precache_sound_I(const char *s)
} }
// precaching not enabled. check if already exists. // precaching not enabled. check if already exists.
for (i = 0; i < MAX_SOUNDS; i++) for (int i = 0; i < MAX_SOUNDS; i++)
{ {
if (g_psv.sound_precache[i] && !Q_stricmp(g_psv.sound_precache[i], s)) if (g_psv.sound_precache[i] && !Q_stricmp(g_psv.sound_precache[i], s))
return i; return i;
@ -1541,11 +1541,15 @@ int EXT_FUNC PF_precache_generic_I(const char *s)
int EXT_FUNC PF_IsMapValid_I(const char *mapname) int EXT_FUNC PF_IsMapValid_I(const char *mapname)
{ {
#ifdef REHLDS_FIXES
char cBuf[42];
if (!mapname || mapname[0] == '\0')
#else
char cBuf[260]; char cBuf[260];
if (!mapname || Q_strlen(mapname) == 0) if (!mapname || Q_strlen(mapname) == 0)
#endif
return 0; return 0;
Q_snprintf(cBuf, sizeof(cBuf), "maps/%.32s.bsp", mapname); Q_snprintf(cBuf, sizeof(cBuf), "maps/%.32s.bsp", mapname);
return FS_FileExists(cBuf); return FS_FileExists(cBuf);
} }
@ -1739,7 +1743,6 @@ void EXT_FUNC PF_aim_I(edict_t *ent, float speed, float *rgflReturn)
vec3_t dir; vec3_t dir;
vec3_t end; vec3_t end;
vec3_t bestdir; vec3_t bestdir;
int j;
trace_t tr; trace_t tr;
float dist; float dist;
float bestdist; float bestdist;
@ -1788,7 +1791,7 @@ void EXT_FUNC PF_aim_I(edict_t *ent, float speed, float *rgflReturn)
if (ent->v.team > 0 && ent->v.team == check->v.team) if (ent->v.team > 0 && ent->v.team == check->v.team)
continue; continue;
for (j = 0; j < 3; j++) for (int j = 0; j < 3; j++)
{ {
end[j] = (check->v.maxs[j] + check->v.mins[j]) * 0.75 + check->v.origin[j] + ent->v.view_ofs[j] * 0.0; end[j] = (check->v.maxs[j] + check->v.mins[j]) * 0.75 + check->v.origin[j] + ent->v.view_ofs[j] * 0.0;
} }
@ -2099,9 +2102,10 @@ void EXT_FUNC PF_MessageBegin_I(int msg_dest, int msg_type, const float *pOrigin
gMsgOrigin[1] = pOrigin[1]; gMsgOrigin[1] = pOrigin[1];
gMsgOrigin[2] = pOrigin[2]; gMsgOrigin[2] = pOrigin[2];
} }
#ifndef REHLDS_FIXES
//No idea why is it called here //No idea why is it called here
//Host_IsSinglePlayerGame(); Host_IsSinglePlayerGame();
#endif
} }
gMsgBuffer.flags = SIZEBUF_ALLOW_OVERFLOW; gMsgBuffer.flags = SIZEBUF_ALLOW_OVERFLOW;
@ -2357,11 +2361,13 @@ void SeedRandomNumberGenerator(void)
} }
} }
#define IA 16807 const int IA = 16807;
#define IM 2147483647 const int IM = 2147483647;
#define IQ 127773 const int IQ = 127773;
#define IR 2836 const int IR = 2836;
#define NTAB 32
const int NTAB = 32;
#define NDIV (1+(IM-1)/NTAB) #define NDIV (1+(IM-1)/NTAB)
int32 ran1(void) int32 ran1(void)
@ -2523,10 +2529,12 @@ const char* EXT_FUNC PF_GetPlayerAuthId(edict_t *e)
Q_strcpy(szAuthID[count], "BOT"); Q_strcpy(szAuthID[count], "BOT");
} }
// AUTH_IDTYPE_LOCAL is handled inside SV_GetIDString(), no need to do it here // AUTH_IDTYPE_LOCAL is handled inside SV_GetIDString(), no need to do it here
// else if (cl->network_userid.idtype == AUTH_IDTYPE_LOCAL) #ifndef REHLDS_FIXES
// { else if (cl->network_userid.idtype == AUTH_IDTYPE_LOCAL)
// Q_strcpy(szAuthID[count], "HLTV"); {
// } Q_strcpy(szAuthID[count], "HLTV");
}
#endif
else else
{ {
Q_snprintf(szAuthID[count], sizeof(szAuthID[count]) - 1, "%s", SV_GetClientIDString(cl)); Q_snprintf(szAuthID[count], sizeof(szAuthID[count]) - 1, "%s", SV_GetClientIDString(cl));
@ -2560,7 +2568,7 @@ const char* EXT_FUNC PF_GetPhysicsInfoString(const edict_t *pClient)
int entnum = NUM_FOR_EDICT(pClient); int entnum = NUM_FOR_EDICT(pClient);
if (entnum < 1 || entnum > g_psvs.maxclients) if (entnum < 1 || entnum > g_psvs.maxclients)
{ {
Con_Printf("tried to PF_GetPhysicsInfoString a non-client\n"); Con_Printf("tried to %s a non-client\n", __func__);
return ""; return "";
} }
@ -2573,7 +2581,7 @@ const char* EXT_FUNC PF_GetPhysicsKeyValue(const edict_t *pClient, const char *k
int entnum = NUM_FOR_EDICT(pClient); int entnum = NUM_FOR_EDICT(pClient);
if (entnum < 1 || entnum > g_psvs.maxclients) if (entnum < 1 || entnum > g_psvs.maxclients)
{ {
Con_Printf("tried to PF_GetPhysicsKeyValue a non-client\n"); Con_Printf("tried to %s a non-client\n", __func__);
return ""; return "";
} }
@ -2585,7 +2593,7 @@ void EXT_FUNC PF_SetPhysicsKeyValue(const edict_t *pClient, const char *key, con
{ {
int entnum = NUM_FOR_EDICT(pClient); int entnum = NUM_FOR_EDICT(pClient);
if (entnum < 1 || entnum > g_psvs.maxclients) if (entnum < 1 || entnum > g_psvs.maxclients)
Con_Printf("tried to PF_SetPhysicsKeyValue a non-client\n"); Con_Printf("tried to %s a non-client\n", __func__);
client_t* client = &g_psvs.clients[entnum - 1]; client_t* client = &g_psvs.clients[entnum - 1];
Info_SetValueForKey(client->physinfo, key, value, MAX_INFO_STRING); Info_SetValueForKey(client->physinfo, key, value, MAX_INFO_STRING);
@ -2605,7 +2613,7 @@ int EXT_FUNC PF_CanSkipPlayer(const edict_t *pClient)
int entnum = NUM_FOR_EDICT(pClient); int entnum = NUM_FOR_EDICT(pClient);
if (entnum < 1 || entnum > g_psvs.maxclients) if (entnum < 1 || entnum > g_psvs.maxclients)
{ {
Con_Printf("tried to PF_CanSkipPlayer a non-client\n"); Con_Printf("tried to %s a non-client\n", __func__);
return 0; return 0;
} }
@ -2698,7 +2706,7 @@ void EXT_FUNC PF_GetPlayerStats(const edict_t *pClient, int *ping, int *packet_l
int c = NUM_FOR_EDICT(pClient); int c = NUM_FOR_EDICT(pClient);
if (c < 1 || c > g_psvs.maxclients) if (c < 1 || c > g_psvs.maxclients)
{ {
Con_Printf("tried to PF_GetPlayerStats a non-client\n"); Con_Printf("tried to %s a non-client\n", __func__);
return; return;
} }
@ -2767,7 +2775,7 @@ void EXT_FUNC QueryClientCvarValue(const edict_t *player, const char *cvarName)
if (gNewDLLFunctions.pfnCvarValue) if (gNewDLLFunctions.pfnCvarValue)
gNewDLLFunctions.pfnCvarValue(player, "Bad Player"); gNewDLLFunctions.pfnCvarValue(player, "Bad Player");
Con_Printf("tried to QueryClientCvarValue a non-client\n"); Con_Printf("tried to %s a non-client\n", __func__);
return; return;
} }
client_t *client = &g_psvs.clients[entnum - 1]; client_t *client = &g_psvs.clients[entnum - 1];
@ -2783,7 +2791,11 @@ void EXT_FUNC QueryClientCvarValue2(const edict_t *player, const char *cvarName,
if (gNewDLLFunctions.pfnCvarValue2) if (gNewDLLFunctions.pfnCvarValue2)
gNewDLLFunctions.pfnCvarValue2(player, requestID, cvarName, "Bad Player"); gNewDLLFunctions.pfnCvarValue2(player, requestID, cvarName, "Bad Player");
#ifdef REHLDS_FIXES
Con_Printf("tried to %s a non-client\n", __func__);
#else
Con_Printf("tried to QueryClientCvarValue a non-client\n"); Con_Printf("tried to QueryClientCvarValue a non-client\n");
#endif
return; return;
} }
client_t *client = &g_psvs.clients[entnum - 1]; client_t *client = &g_psvs.clients[entnum - 1];

View File

@ -458,7 +458,11 @@ void R_StudioCalcBonePosition(int frame, float s, mstudiobone_t *pbone, mstudioa
} }
} }
} }
#ifdef REHLDS_FIXES
if (adj && pbone->bonecontroller[j] != -1)
#else
if (pbone->bonecontroller[j] != -1) if (pbone->bonecontroller[j] != -1)
#endif
{ {
pos[j] += adj[pbone->bonecontroller[j]]; pos[j] += adj[pbone->bonecontroller[j]];
} }
@ -1090,7 +1094,7 @@ int R_StudioComputeBounds(unsigned char *pBuffer, float *mins, float *maxs)
for (int f = 0; f < num_frames; ++f) for (int f = 0; f < num_frames; ++f)
{ {
vec3_t bonepos; vec3_t bonepos;
R_StudioCalcBonePosition(f, 0.0, &pbones[bone], panim, 0, bonepos); R_StudioCalcBonePosition(f, 0.0, &pbones[bone], panim, NULL, bonepos);
R_StudioBoundBone(bone_mins, bone_maxs, &bone_count, bonepos); R_StudioBoundBone(bone_mins, bone_maxs, &bone_count, bonepos);
} }
} }

View File

@ -31,8 +31,8 @@
#include "maintypes.h" #include "maintypes.h"
// TODO: I think this defines must be in /common/ // TODO: I think this defines must be in /common/
#define NUM_EDICTS 900 const int NUM_EDICTS = 900;
#define MAX_NAME 32 const int MAX_NAME = 32;
#include "custom_int.h" #include "custom_int.h"
#include "crc.h" #include "crc.h"
@ -54,9 +54,9 @@
#include "inst_baseline.h" #include "inst_baseline.h"
#include "net_ws.h" #include "net_ws.h"
#define DEFAULT_SOUND_PACKET_VOLUME 255 const int DEFAULT_SOUND_PACKET_VOLUME = 255;
#define DEFAULT_SOUND_PACKET_ATTENUATION 1.0f const float DEFAULT_SOUND_PACKET_ATTENUATION = 1.0f;
#define DEFAULT_SOUND_PACKET_PITCH 100 const int DEFAULT_SOUND_PACKET_PITCH = 100;
// Sound flags // Sound flags
enum enum
@ -82,10 +82,10 @@ enum
MSG_FL_ONE = BIT(7), // Send to single client MSG_FL_ONE = BIT(7), // Send to single client
}; };
#define RESOURCE_INDEX_BITS 12 const int RESOURCE_INDEX_BITS = 12;
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
#define RESOURCE_MAX_COUNT (1 << RESOURCE_INDEX_BITS) const int RESOURCE_MAX_COUNT = BIT(RESOURCE_INDEX_BITS);
#endif // REHLDS_FIXES #endif // REHLDS_FIXES
typedef enum redirect_e typedef enum redirect_e

View File

@ -31,7 +31,7 @@
#include "quakedef.h" #include "quakedef.h"
// max number of sentences in game. NOTE: this must match CVOXFILESENTENCEMAX in dlls\util.h!!! // max number of sentences in game. NOTE: this must match CVOXFILESENTENCEMAX in dlls\util.h!!!
#define CVOXFILESENTENCEMAX 1536 const int CVOXFILESENTENCEMAX = 1536;
typedef struct sfx_s typedef struct sfx_s
{ {

View File

@ -2011,7 +2011,7 @@ int EXT_FUNC SV_FinishCertificateCheck_internal(netadr_t *adr, int nAuthProtocol
const char *val = Info_ValueForKey(userinfo, "*hltv"); const char *val = Info_ValueForKey(userinfo, "*hltv");
if (val[0] == 0 || Q_atoi(val) != 1) if (val[0] == 0 || Q_atoi(val) != TYPE_PROXY)
{ {
SV_RejectConnection(adr, "Invalid CD Key.\n"); SV_RejectConnection(adr, "Invalid CD Key.\n");
return 0; return 0;
@ -2254,10 +2254,10 @@ int SV_CheckUserInfo(netadr_t *adr, char *userinfo, qboolean bIsReconnecting, in
switch (Q_atoi(s)) switch (Q_atoi(s))
{ {
case 0: case TYPE_CLIENT:
return 1; return 1;
case 1: case TYPE_PROXY:
SV_CountProxies(&proxies); SV_CountProxies(&proxies);
if (proxies >= sv_proxies.value && !bIsReconnecting) if (proxies >= sv_proxies.value && !bIsReconnecting)
{ {
@ -2266,7 +2266,7 @@ int SV_CheckUserInfo(netadr_t *adr, char *userinfo, qboolean bIsReconnecting, in
} }
return 1; return 1;
case 3: case TYPE_COMMENTATOR:
SV_RejectConnection(adr, "Please connect to HLTV master proxy.\n"); SV_RejectConnection(adr, "Please connect to HLTV master proxy.\n");
return 0; return 0;
@ -2470,7 +2470,7 @@ void EXT_FUNC SV_ConnectClient_internal(void)
SV_RejectConnection(&adr, "Invalid validation type\n"); SV_RejectConnection(&adr, "Invalid validation type\n");
return; return;
} }
if (Q_atoi(val) != 1) if (Q_atoi(val) != TYPE_PROXY)
{ {
SV_RejectConnection(&adr, "Invalid validation type\n"); SV_RejectConnection(&adr, "Invalid validation type\n");
return; return;
@ -3239,8 +3239,8 @@ void SV_BeginRedirect(redirect_t rd, netadr_t *addr)
outputbuf[0] = 0; outputbuf[0] = 0;
} }
#define MAX_RCON_FAILURES_STORAGE 32 const int MAX_RCON_FAILURES_STORAGE = 32;
#define MAX_RCON_FAILURES 20 const int MAX_RCON_FAILURES = 20;
typedef struct rcon_failure_s typedef struct rcon_failure_s
{ {
@ -4330,7 +4330,11 @@ int SV_CreatePacketEntities_internal(sv_delta_t type, client_t *client, packet_e
newindex = 9999; newindex = 9999;
} }
#ifdef REHLDS_FIXES
if (oldnum < oldmax && from)
#else
if (oldnum < oldmax) if (oldnum < oldmax)
#endif
oldindex = from->entities[oldnum].number; oldindex = from->entities[oldnum].number;
else else
oldindex = 9999; oldindex = 9999;
@ -5051,7 +5055,7 @@ void SV_ExtractFromUserinfo(client_t *cl)
cl->lc = val[0] != 0 ? Q_atoi(val) != 0 : 0; cl->lc = val[0] != 0 ? Q_atoi(val) != 0 : 0;
val = Info_ValueForKey(userinfo, "*hltv"); val = Info_ValueForKey(userinfo, "*hltv");
cl->proxy = val[0] != 0 ? Q_atoi(val) == 1 : 0; cl->proxy = val[0] != 0 ? Q_atoi(val) == TYPE_PROXY : 0;
SV_CheckUpdateRate(&cl->next_messageinterval); SV_CheckUpdateRate(&cl->next_messageinterval);
SV_CheckRate(cl); SV_CheckRate(cl);

View File

@ -31,7 +31,7 @@
#include "maintypes.h" #include "maintypes.h"
#include "server.h" #include "server.h"
#define DI_NODIR -1 const int DI_NODIR = -1;
#ifdef HOOK_ENGINE #ifdef HOOK_ENGINE

View File

@ -33,7 +33,7 @@
#include "world.h" #include "world.h"
#include "pm_defs.h" #include "pm_defs.h"
#define CMD_MAXBACKUP 64 const int CMD_MAXBACKUP = 64;
typedef struct command_s command_t; typedef struct command_s command_t;

View File

@ -619,15 +619,15 @@ double EXT_FUNC Sys_FloatTime(void)
double Sys_FloatTime(void) double Sys_FloatTime(void)
{ {
static struct timespec start_time; static struct timespec start_time;
static bool bInitialized; static bool bInitialized = false;
struct timespec now; struct timespec now;
if ( !bInitialized ) if ( !bInitialized )
{ {
bInitialized = 1; bInitialized = true;
clock_gettime(1, &start_time); clock_gettime(CLOCK_MONOTONIC, &start_time);
} }
clock_gettime(1, &now); clock_gettime(CLOCK_MONOTONIC, &now);
return (now.tv_sec - start_time.tv_sec) + now.tv_nsec * 0.000000001; return (now.tv_sec - start_time.tv_sec) + now.tv_nsec * 0.000000001;
} }

View File

@ -52,7 +52,7 @@
#endif #endif
#define MAX_DISCONNECT_REASON 256 const int MAX_DISCONNECT_REASON = 256;
#ifdef HOOK_ENGINE #ifdef HOOK_ENGINE

View File

@ -524,10 +524,7 @@ int Sys_InitGame(char *lpOrgCmdLine, char *pBaseDir, void *pwnd, int bIsDedicate
ClientDLL_ActivateMouse(); ClientDLL_ActivateMouse();
char MessageText[512]; char MessageText[512];
const char en_US[12]; const char en_US[] = "en_US.UTF-8";
Q_strcpy(en_US, "en_US.UTF-8");
en_US[16] = 0;
char *cat = setlocale(6, NULL); char *cat = setlocale(6, NULL);
if (!cat) if (!cat)

View File

@ -36,7 +36,8 @@
#include "engine_launcher_api.h" #include "engine_launcher_api.h"
#include "idedicatedexports.h" #include "idedicatedexports.h"
#define FIFTEEN_MB (15 * 1024 * 1024) const int FIFTEEN_MB = (15 * 1024 * 1024);
#define MINIMUM_WIN_MEMORY 0x0e00000 #define MINIMUM_WIN_MEMORY 0x0e00000
#define WARNING_MEMORY 0x0200000 #define WARNING_MEMORY 0x0200000
#define MAXIMUM_WIN_MEMORY 0x8000000 // Ask for 128 MB max #define MAXIMUM_WIN_MEMORY 0x8000000 // Ask for 128 MB max

View File

@ -31,7 +31,7 @@
#include "maintypes.h" #include "maintypes.h"
#include "wad.h" #include "wad.h"
#define MAX_MAP_TEXTURES 512 const int MAX_MAP_TEXTURES = 512;
typedef struct texlumpinfo_s typedef struct texlumpinfo_s
{ {

View File

@ -115,17 +115,19 @@ char* EXT_FUNC memfgets(unsigned char *pMemFile, int fileSize, int *pFilePos, ch
int IsComment(char *pText) int IsComment(char *pText)
{ {
int length;
if (!pText) if (!pText)
{
return TRUE; return TRUE;
}
length = Q_strlen(pText); #ifdef REHLDS_FIXES
if (length >= 2 && pText[0] == '/' && pText[1] == '/' || length <= 0) if ((pText[0] == '/' && pText[1] == '/') || !pText[0])
return TRUE;
#else
int length = Q_strlen(pText);
if ((length >= 2 && pText[0] == '/' && pText[1] == '/') || length <= 0)
{ {
return TRUE; return TRUE;
} }
#endif
return FALSE; return FALSE;
} }

View File

@ -30,19 +30,19 @@
#include "maintypes.h" #include "maintypes.h"
#define DEMO_MESSAGE "__DEMOMESSAGE__" static const char *DEMO_MESSAGE = "__DEMOMESSAGE__";
#define NETWORK_MESSAGE1 "__NETMESSAGE__1" static const char *NETWORK_MESSAGE1 = "__NETMESSAGE__1";
#define NETWORK_MESSAGE2 "__NETMESSAGE__2" static const char *NETWORK_MESSAGE2 = "__NETMESSAGE__2";
#define NETWORK_MESSAGE3 "__NETMESSAGE__3" static const char *NETWORK_MESSAGE3 = "__NETMESSAGE__3";
#define NETWORK_MESSAGE4 "__NETMESSAGE__4" static const char *NETWORK_MESSAGE4 = "__NETMESSAGE__4";
#define MAX_NETMESSAGE 4 const int MAX_NETMESSAGE = 4;
#define MSGFILE_NAME 0 const int MSGFILE_NAME = 0;
#define MSGFILE_TEXT 1 const int MSGFILE_TEXT = 1;
#define NAME_HEAP_SIZE 16384 const int NAME_HEAP_SIZE = 16384;
#define MAX_MESSAGES 1000 const int MAX_MESSAGES = 1000;
#ifdef HOOK_ENGINE #ifdef HOOK_ENGINE

View File

@ -68,7 +68,7 @@ typedef struct wadlist_s
typedef struct wadlist_s wadlist_t; typedef struct wadlist_s wadlist_t;
typedef struct lumpinfo_s lumpinfo_t; typedef struct lumpinfo_s lumpinfo_t;
#define NUM_WADS 2 const int NUM_WADS = 2;
#ifdef HOOK_ENGINE #ifdef HOOK_ENGINE
#define wads (*pwads) #define wads (*pwads)

View File

@ -46,7 +46,7 @@ all big things are allocated on the hunk.
*/ */
#define ZONEID 0x001d4a11 #define ZONEID 0x001d4a11
#define MINFRAGMENT 64 const int MINFRAGMENT = 64;
typedef struct memblock_s typedef struct memblock_s
{ {
@ -285,7 +285,7 @@ void Z_CheckHeap(void)
#ifndef Hunk_Functions_region #ifndef Hunk_Functions_region
#define HUNK_NAME_LEN 64 const int HUNK_NAME_LEN = 64;
#define HUNK_SENTINEL 0x1df001ed #define HUNK_SENTINEL 0x1df001ed
typedef struct hunk_s typedef struct hunk_s
@ -579,7 +579,7 @@ CACHE MEMORY
=============================================================================== ===============================================================================
*/ */
#define CACHE_NAME_LEN 64 const int CACHE_NAME_LEN = 64;
typedef struct cache_system_s typedef struct cache_system_s
{ {
@ -1118,7 +1118,7 @@ NOXREF void Cache_Print_Models_And_Totals(void)
FS_Close(file); FS_Close(file);
} }
#define MAX_SFX 1024 const int MAX_SFX = 1024;
NOXREF void Cache_Print_Sounds_And_Totals(void) NOXREF void Cache_Print_Sounds_And_Totals(void)
{ {

View File

@ -36,11 +36,11 @@ IBaseInterface* CreateFileSystemInterface(void);
InterfaceReg iface = InterfaceReg(CreateFileSystemInterface, "VFileSystem009"); InterfaceReg iface = InterfaceReg(CreateFileSystemInterface, "VFileSystem009");
#ifdef _WIN32 #ifdef _WIN32
#define ORIGINAL_ENGINE_DLL_NAME "swds.dll" const char *ORIGINAL_ENGINE_DLL_NAME = "swds.dll";
#define ORIGINAL_FILESYSTEM_DLL_NAME "filesystem_stdio2.dll" const char *ORIGINAL_FILESYSTEM_DLL_NAME = "filesystem_stdio2.dll";
#else #else
#define ORIGINAL_ENGINE_DLL_NAME "engine_i486.so" const char *ORIGINAL_ENGINE_DLL_NAME = "engine_i486.so";
#define ORIGINAL_FILESYSTEM_DLL_NAME "filesystem_stdio2.so" const char *ORIGINAL_FILESYSTEM_DLL_NAME = "filesystem_stdio2.so";
#endif #endif
CSysModule *g_pOriginalFileSystemModule = NULL; CSysModule *g_pOriginalFileSystemModule = NULL;

View File

@ -32,7 +32,7 @@
#include "osconfig.h" #include "osconfig.h"
#define MAX_PATTERN 128 const int MAX_PATTERN = 128;
struct Section; struct Section;

View File

@ -1,6 +1,6 @@
#include "precompiled.h" #include "precompiled.h"
#define REHLDS_DEBUG_MAX_EDICTS 2048 const int REHLDS_DEBUG_MAX_EDICTS = 2048;
uint32 calcFloatChecksum(uint32 crc, const float* pFloat) { uint32 calcFloatChecksum(uint32 crc, const float* pFloat) {
uint32 sVal = *reinterpret_cast<const uint32*>(pFloat); uint32 sVal = *reinterpret_cast<const uint32*>(pFloat);

View File

@ -28,7 +28,7 @@
#pragma once #pragma once
#include "hookchains.h" #include "hookchains.h"
#define MAX_HOOKS_IN_CHAIN 19 const int MAX_HOOKS_IN_CHAIN = 19;
// Implementation for chains in modules // Implementation for chains in modules
template<typename t_ret, typename ...t_args> template<typename t_ret, typename ...t_args>

View File

@ -59,3 +59,4 @@
#include "rehlds_security.h" #include "rehlds_security.h"
#include "dlls/cdll_dll.h" #include "dlls/cdll_dll.h"
#include "hltv.h"

View File

@ -10,8 +10,8 @@
#include <iostream> #include <iostream>
#include <fstream> #include <fstream>
#define HOSTENT_DATA_MAX_ALIASES 10 const int HOSTENT_DATA_MAX_ALIASES = 10;
#define HOSTENT_DATA_MAX_ADDRS 32 const int HOSTENT_DATA_MAX_ADDRS = 32;
struct hostent_data_t { struct hostent_data_t {
char hostName[256]; char hostName[256];

View File

@ -1,8 +1,8 @@
#pragma once #pragma once
#ifdef _WIN32 #ifdef _WIN32
#define TESTPLAYER_FUNCTREE_DEPTH 8 const int TESTPLAYER_FUNCTREE_DEPTH = 8;
#define TESTPLAYER_FUNCCALL_MAXSIZE 17000 const int TESTPLAYER_FUNCCALL_MAXSIZE = 17000;
#include "osconfig.h" #include "osconfig.h"
#include "funccalls.h" #include "funccalls.h"

View File

@ -10,8 +10,8 @@
#include <fstream> #include <fstream>
#include <unordered_map> #include <unordered_map>
#define TESTSUITE_PROTOCOL_VERSION_MINOR 5 const int TESTSUITE_PROTOCOL_VERSION_MINOR = 5;
#define TESTSUITE_PROTOCOL_VERSION_MAJOR 0 const int TESTSUITE_PROTOCOL_VERSION_MAJOR = 0;
void TestSuite_Init(const Module* engine, const Module* executable, const AddressRef* funcRefs); void TestSuite_Init(const Module* engine, const Module* executable, const AddressRef* funcRefs);