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

Refactoring

Fix crash on SV_SingleClipMoveToEntity, added safe check for pointer model
This commit is contained in:
s1lentq 2016-12-12 21:28:21 +07:00
parent 4094d8d633
commit 4fc947807f
27 changed files with 220 additions and 198 deletions

View File

@ -51,7 +51,7 @@ task publishPrepareFiles {
copy { copy {
from 'rehlds/public' from 'rehlds/public'
into 'publish/publishRoot/hlsdk/public' into 'publish/publishRoot/hlsdk/public'
include 'interface.h', 'interface.cpp', 'FileSystem.h' exclude '**/rehlds/*', '**/tier0/*'
} }
copy { copy {
from 'rehlds/public/rehlds' from 'rehlds/public/rehlds'

View File

@ -25,15 +25,19 @@
#define MAX_LIGHTSTYLE_INDEX_BITS 6 #define MAX_LIGHTSTYLE_INDEX_BITS 6
#define MAX_LIGHTSTYLES (1<<MAX_LIGHTSTYLE_INDEX_BITS) #define MAX_LIGHTSTYLES (1<<MAX_LIGHTSTYLE_INDEX_BITS)
// Resource counts; // Resource counts
#define MAX_MODEL_INDEX_BITS 9 // sent as a short #define MAX_MODEL_INDEX_BITS 9 // sent as a short
#define MAX_MODELS (1<<MAX_MODEL_INDEX_BITS) #define MAX_MODELS (1<<MAX_MODEL_INDEX_BITS)
#define MAX_SOUND_INDEX_BITS 9 #define MAX_SOUND_INDEX_BITS 9
#define MAX_SOUNDS (1<<MAX_SOUND_INDEX_BITS) #define MAX_SOUNDS (1<<MAX_SOUND_INDEX_BITS)
#define MAX_SOUNDS_HASHLOOKUP_SIZE (MAX_SOUNDS * 2 - 1)
#define MAX_GENERIC_INDEX_BITS 9 #define MAX_GENERIC_INDEX_BITS 9
#define MAX_GENERIC (1<<MAX_GENERIC_INDEX_BITS) #define MAX_GENERIC (1<<MAX_GENERIC_INDEX_BITS)
#define MAX_DECAL_INDEX_BITS 9 #define MAX_DECAL_INDEX_BITS 9
#define MAX_BASE_DECALS (1<<MAX_DECAL_INDEX_BITS) #define MAX_BASE_DECALS (1<<MAX_DECAL_INDEX_BITS)
#define MAX_EVENTS 256
#define MAX_PACKET_ENTITIES 256 // 256 visible entities per frame
#endif // QLIMITS_H #endif // QLIMITS_H

View File

@ -226,10 +226,10 @@ typedef struct client_state_s
local_state_t predicted_frames[64]; local_state_t predicted_frames[64];
int delta_sequence; int delta_sequence;
int playernum; int playernum;
event_t event_precache[HL_EVENT_MAX]; event_t event_precache[MAX_EVENTS];
model_t *model_precache[HL_MODEL_MAX]; model_t *model_precache[MAX_MODELS];
int model_precache_count; int model_precache_count;
sfx_s *sound_precache[HL_SOUND_MAX]; sfx_s *sound_precache[MAX_SOUNDS];
consistency_t consistency_list[MAX_CONSISTENCY_LIST]; consistency_t consistency_list[MAX_CONSISTENCY_LIST];
int num_consistency; int num_consistency;
int highentity; int highentity;

View File

@ -84,8 +84,8 @@ void COM_ClearCustomizationList(customization_t *pHead, qboolean bCleanDecals)
qboolean COM_CreateCustomization(customization_t *pListHead, resource_t *pResource, int playernumber, int flags, customization_t **pCustomization, int *nLumps) qboolean COM_CreateCustomization(customization_t *pListHead, resource_t *pResource, int playernumber, int flags, customization_t **pCustomization, int *nLumps)
{ {
customization_t *pCust; // 91 customization_t *pCust;
qboolean bError; // 92 qboolean bError;
bError = FALSE; bError = FALSE;
if (pCustomization) if (pCustomization)

View File

@ -311,7 +311,7 @@ static delta_definition_t g_ClientDataDefinition[] =
DELTA_DEF(clientdata_s, vuser4[2]), DELTA_DEF(clientdata_s, vuser4[2]),
}; };
#endif #endif // Delta_definitions_region
delta_description_t *DELTA_FindField(delta_t *pFields, const char *pszField) delta_description_t *DELTA_FindField(delta_t *pFields, const char *pszField)
{ {
@ -760,7 +760,6 @@ qboolean DELTA_WriteDeltaForceMask(unsigned char *from, unsigned char *to, qbool
} }
#endif #endif
qboolean _DELTA_WriteDelta(unsigned char *from, unsigned char *to, qboolean force, delta_t *pFields, void(*callback)( void ), qboolean sendfields) qboolean _DELTA_WriteDelta(unsigned char *from, unsigned char *to, qboolean force, delta_t *pFields, void(*callback)( void ), qboolean sendfields)
{ {
int i; int i;
@ -790,7 +789,6 @@ qboolean _DELTA_WriteDelta(unsigned char *from, unsigned char *to, qboolean forc
return 1; return 1;
} }
int DELTA_ParseDelta(unsigned char *from, unsigned char *to, delta_t *pFields) int DELTA_ParseDelta(unsigned char *from, unsigned char *to, delta_t *pFields)
{ {
delta_description_t *pTest; delta_description_t *pTest;

View File

@ -132,7 +132,7 @@ NOXREF void Host_EndGame(const char *message, ...)
longjmp(host_abortserver, 1); longjmp(host_abortserver, 1);
} }
void __declspec(noreturn) Host_Error(const char *error, ...) void NORETURN Host_Error(const char *error, ...)
{ {
va_list argptr; va_list argptr;
char string[1024]; char string[1024];

View File

@ -117,7 +117,7 @@ extern jmp_buf host_enddemo;
extern unsigned short *host_basepal; extern unsigned short *host_basepal;
NOXREF void Host_EndGame(const char *message, ...); NOXREF void Host_EndGame(const char *message, ...);
void __declspec(noreturn) Host_Error(const char *error, ...); void NORETURN Host_Error(const char *error, ...);
void Host_InitLocal(void); void Host_InitLocal(void);
NOBODY void Info_WriteVars(FileHandle_t fp); NOBODY void Info_WriteVars(FileHandle_t fp);
void Host_WriteConfiguration(void); void Host_WriteConfiguration(void);

View File

@ -403,7 +403,6 @@ void Mod_AdSwap(texture_t *src, int pixels, int entries)
if (!tested) if (!tested)
return; return;
int j;
uint8 *mippal; uint8 *mippal;
uint16 *texpal; uint16 *texpal;
texture_t *tex; texture_t *tex;
@ -1895,3 +1894,24 @@ NOXREF void Mod_ChangeGame(void)
p->initialCRC = 0; p->initialCRC = 0;
} }
} }
model_t *Mod_Handle(int modelindex)
{
#ifdef REHLDS_FIXES
if (modelindex <= 0 || modelindex >= MAX_MODELS) {
Sys_Error(__FUNCTION__ ": bad modelindex #%i\n", modelindex);
}
#endif
return g_psv.models[modelindex];
}
modtype_t Mod_GetType(int modelindex)
{
model_t *mod = Mod_Handle(modelindex);
if (!mod) {
return mod_bad;
}
return mod->type;
}

View File

@ -114,3 +114,5 @@ void Mod_LoadSpriteModel(model_t *mod, void *buffer);
NOXREF void Mod_UnloadSpriteTextures(model_t *pModel); NOXREF void Mod_UnloadSpriteTextures(model_t *pModel);
void Mod_Print(void); void Mod_Print(void);
NOXREF void Mod_ChangeGame(void); NOXREF void Mod_ChangeGame(void);
model_t *Mod_Handle(int modelindex);
modtype_t Mod_GetType(int modelindex);

View File

@ -277,7 +277,10 @@ int _PM_TestPlayerPosition(vec_t *pos, pmtrace_t *ptrace, int(*pfnIgnore)(physen
for (int i = 0; i < pmove->numphysent; i++) for (int i = 0; i < pmove->numphysent; i++)
{ {
physent_t *pe = &pmove->physents[i]; physent_t *pe = &pmove->physents[i];
if (pfnIgnore && pfnIgnore(pe) || pe->model && !pe->solid && pe->skin) if (pfnIgnore && pfnIgnore(pe))
continue;
if (pe->model && pe->solid == SOLID_NOT && pe->skin != 0)
continue; continue;
offset[0] = pe->origin[0]; offset[0] = pe->origin[0];
@ -291,7 +294,7 @@ int _PM_TestPlayerPosition(vec_t *pos, pmtrace_t *ptrace, int(*pfnIgnore)(physen
} }
else else
{ {
if (pe->studiomodel && pe->studiomodel->type == mod_studio && ((pe->studiomodel->flags & 0x200) || pmove->usehull == 2)) if (pe->studiomodel && pe->studiomodel->type == mod_studio && ((pe->studiomodel->flags & STUDIO_TRACE_HITBOX) || pmove->usehull == 2))
{ {
hull = PM_HullForStudioModel(pe->studiomodel, offset, pe->frame, pe->sequence, pe->angles, pe->origin, pe->controller, pe->blending, &numhulls); hull = PM_HullForStudioModel(pe->studiomodel, offset, pe->frame, pe->sequence, pe->angles, pe->origin, pe->controller, pe->blending, &numhulls);
} }
@ -309,7 +312,7 @@ int _PM_TestPlayerPosition(vec_t *pos, pmtrace_t *ptrace, int(*pfnIgnore)(physen
test[0] = pos[0] - offset[0]; test[0] = pos[0] - offset[0];
test[1] = pos[1] - offset[1]; test[1] = pos[1] - offset[1];
test[2] = pos[2] - offset[2]; test[2] = pos[2] - offset[2];
if (pe->solid == 4 && (pe->angles[0] != 0.0 || pe->angles[1] != 0.0 || pe->angles[2] != 0.0)) if (pe->solid == SOLID_BSP && (pe->angles[0] != 0.0 || pe->angles[1] != 0.0 || pe->angles[2] != 0.0))
{ {
vec3_t forward, right, up; vec3_t forward, right, up;
AngleVectors(pe->angles, forward, right, up); AngleVectors(pe->angles, forward, right, up);
@ -324,14 +327,14 @@ int _PM_TestPlayerPosition(vec_t *pos, pmtrace_t *ptrace, int(*pfnIgnore)(physen
for (int j = 0; j < numhulls; j++) for (int j = 0; j < numhulls; j++)
{ {
g_contentsresult = PM_HullPointContents(&hull[j], hull[j].firstclipnode, test); g_contentsresult = PM_HullPointContents(&hull[j], hull[j].firstclipnode, test);
if (g_contentsresult == -2) if (g_contentsresult == CONTENTS_SOLID)
return i; return i;
} }
} }
else else
{ {
g_contentsresult = PM_HullPointContents(hull, hull->firstclipnode, test); g_contentsresult = PM_HullPointContents(hull, hull->firstclipnode, test);
if (g_contentsresult == -2) if (g_contentsresult == CONTENTS_SOLID)
return i; return i;
} }
} }

View File

@ -127,7 +127,7 @@ void EXT_FUNC PF_setmodel_I(edict_t *e, const char *m)
int i = 0; int i = 0;
#ifdef REHLDS_CHECKS #ifdef REHLDS_CHECKS
for (; *check && i < HL_MODEL_MAX; i++, check++) for (; *check && i < MAX_MODELS; i++, check++)
#else #else
for (; *check; i++, check++) for (; *check; i++, check++)
#endif #endif
@ -287,7 +287,7 @@ void EXT_FUNC PF_ambientsound_I(edict_t *entity, float *pos, const char *samp, f
} }
else else
{ {
for (i = 0; i < HL_SOUND_MAX; i++) for (i = 0; i < MAX_SOUNDS; i++)
{ {
if (g_psv.sound_precache[i] && !Q_stricmp(g_psv.sound_precache[i], samp)) if (g_psv.sound_precache[i] && !Q_stricmp(g_psv.sound_precache[i], samp))
{ {
@ -296,7 +296,7 @@ void EXT_FUNC PF_ambientsound_I(edict_t *entity, float *pos, const char *samp, f
} }
} }
if (i == HL_SOUND_MAX) if (i == MAX_SOUNDS)
{ {
Con_Printf("no precache: %s\n", samp); Con_Printf("no precache: %s\n", samp);
return; return;
@ -1023,19 +1023,19 @@ int EXT_FUNC PF_precache_sound_I(const char *s)
int i; int i;
if (!s) if (!s)
Host_Error("PF_precache_sound_I: NULL pointer"); Host_Error(__FUNCTION__ ": NULL pointer");
if (PR_IsEmptyString(s)) if (PR_IsEmptyString(s))
Host_Error("PF_precache_sound_I: Bad string '%s'", s); Host_Error(__FUNCTION__ ": Bad string '%s'", s);
if (s[0] == '!') if (s[0] == '!')
Host_Error("PF_precache_sound_I: '%s' do not precache sentence names!", s); Host_Error(__FUNCTION__ ": '%s' do not precache sentence names!", s);
if (g_psv.state == ss_loading) if (g_psv.state == ss_loading)
{ {
g_psv.sound_precache_hashedlookup_built = 0; g_psv.sound_precache_hashedlookup_built = 0;
for (i = 0; i < HL_SOUND_MAX; i++) for (i = 0; i < MAX_SOUNDS; i++)
{ {
if (!g_psv.sound_precache[i]) if (!g_psv.sound_precache[i])
{ {
@ -1053,42 +1053,42 @@ int EXT_FUNC PF_precache_sound_I(const char *s)
} }
Host_Error( Host_Error(
"PF_precache_sound_I: Sound '%s' failed to precache because the item count is over the %d limit.\nReduce the number of brush models and/or regular models in the map to correct this.", __FUNCTION__ ": Sound '%s' failed to precache because the item count is over the %d limit.\nReduce the number of brush models and/or regular models in the map to correct this.",
s, s, MAX_SOUNDS);
HL_SOUND_MAX);
} }
else else
{ {
// precaching not enabled. check if already exists. // precaching not enabled. check if already exists.
for (i = 0; i < HL_SOUND_MAX; i++) for (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;
} }
Host_Error("PF_precache_sound_I: '%s' Precache can only be done in spawn functions", s); Host_Error(__FUNCTION__ ": '%s' Precache can only be done in spawn functions", s);
} }
return -1; // unreach // unreach
return -1;
} }
unsigned short EXT_FUNC EV_Precache(int type, const char *psz) unsigned short EXT_FUNC EV_Precache(int type, const char *psz)
{ {
if (!psz) if (!psz)
Host_Error("EV_Precache: NULL pointer"); Host_Error(__FUNCTION__ ": NULL pointer");
if (PR_IsEmptyString(psz)) if (PR_IsEmptyString(psz))
Host_Error("EV_Precache: Bad string '%s'", psz); Host_Error(__FUNCTION__ ": Bad string '%s'", psz);
if (g_psv.state == ss_loading) if (g_psv.state == ss_loading)
{ {
for (int i = 1; i < HL_EVENT_MAX; i++) for (int i = 1; i < MAX_EVENTS; i++)
{ {
struct event_s* ev = &g_psv.event_precache[i]; struct event_s* ev = &g_psv.event_precache[i];
if (!ev->filename) if (!ev->filename)
{ {
if (type != 1) if (type != 1)
Host_Error("EV_Precache: only file type 1 supported currently\n"); Host_Error(__FUNCTION__ ": only file type 1 supported currently\n");
char szpath[MAX_PATH]; char szpath[MAX_PATH];
Q_snprintf(szpath, sizeof(szpath), "%s", psz); Q_snprintf(szpath, sizeof(szpath), "%s", psz);
@ -1097,7 +1097,7 @@ unsigned short EXT_FUNC EV_Precache(int type, const char *psz)
int scriptSize = 0; int scriptSize = 0;
char* evScript = (char*) COM_LoadFile(szpath, 5, &scriptSize); char* evScript = (char*) COM_LoadFile(szpath, 5, &scriptSize);
if (!evScript) if (!evScript)
Host_Error("EV_Precache: file %s missing from server\n", psz); Host_Error(__FUNCTION__ ": file %s missing from server\n", psz);
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
// Many modders don't know that the resource names passed to precache functions must be a static strings. // Many modders don't know that the resource names passed to precache functions must be a static strings.
// Also some metamod modules can be unloaded during the server running. // Also some metamod modules can be unloaded during the server running.
@ -1117,18 +1117,18 @@ unsigned short EXT_FUNC EV_Precache(int type, const char *psz)
if (!Q_stricmp(ev->filename, psz)) if (!Q_stricmp(ev->filename, psz))
return i; return i;
} }
Host_Error("EV_Precache: '%s' overflow", psz); Host_Error(__FUNCTION__ ": '%s' overflow", psz);
} }
else else
{ {
for (int i = 1; i < HL_EVENT_MAX; i++) for (int i = 1; i < MAX_EVENTS; i++)
{ {
struct event_s* ev = &g_psv.event_precache[i]; struct event_s* ev = &g_psv.event_precache[i];
if (!Q_stricmp(ev->filename, psz)) if (!Q_stricmp(ev->filename, psz))
return i; return i;
} }
Host_Error("EV_Precache: '%s' Precache can only be done in spawn functions", psz); Host_Error(__FUNCTION__ ": '%s' Precache can only be done in spawn functions", psz);
} }
} }
@ -1219,15 +1219,15 @@ void EXT_FUNC EV_Playback(int flags, const edict_t *pInvoker, unsigned short eve
eargs.bparam1 = bparam1; eargs.bparam1 = bparam1;
eargs.bparam2 = bparam2; eargs.bparam2 = bparam2;
if (eventindex < 1u || eventindex >= HL_EVENT_MAX) if (eventindex < 1u || eventindex >= MAX_EVENTS)
{ {
Con_DPrintf("EV_Playback: index out of range %i\n", eventindex); Con_DPrintf(__FUNCTION__ ": index out of range %i\n", eventindex);
return; return;
} }
if (!g_psv.event_precache[eventindex].pszScript) if (!g_psv.event_precache[eventindex].pszScript)
{ {
Con_DPrintf("EV_Playback: no event for index %i\n", eventindex); Con_DPrintf(__FUNCTION__ ": no event for index %i\n", eventindex);
return; return;
} }
@ -1358,7 +1358,7 @@ void EXT_FUNC EV_SV_Playback(int flags, int clientindex, unsigned short eventind
return; return;
if (clientindex < 0 || clientindex >= g_psvs.maxclients) if (clientindex < 0 || clientindex >= g_psvs.maxclients)
Host_Error("EV_SV_Playback: Client index %i out of range\n", clientindex); Host_Error(__FUNCTION__ ": Client index %i out of range\n", clientindex);
edict_t *pEdict = g_psvs.clients[clientindex].edict; edict_t *pEdict = g_psvs.clients[clientindex].edict;
EV_Playback(flags,pEdict, eventindex, delay, origin, angles, fparam1, fparam2, iparam1, iparam2, bparam1, bparam2); EV_Playback(flags,pEdict, eventindex, delay, origin, angles, fparam1, fparam2, iparam1, iparam2, bparam1, bparam2);
@ -1376,7 +1376,7 @@ int SV_LookupModelIndex(const char *name)
return node->val; return node->val;
} }
#else // REHLDS_OPT_PEDANTIC #else // REHLDS_OPT_PEDANTIC
for (int i = 0; i < HL_MODEL_MAX; i++) for (int i = 0; i < MAX_MODELS; i++)
{ {
if (!g_psv.model_precache[i]) if (!g_psv.model_precache[i])
break; break;
@ -1394,10 +1394,10 @@ int EXT_FUNC PF_precache_model_I(const char *s)
{ {
int iOptional = 0; int iOptional = 0;
if (!s) if (!s)
Host_Error("PF_precache_model_I: NULL pointer"); Host_Error(__FUNCTION__ ": NULL pointer");
if (PR_IsEmptyString(s)) if (PR_IsEmptyString(s))
Host_Error("PF_precache_model_I: Bad string '%s'", s); Host_Error(__FUNCTION__ ": Bad string '%s'", s);
if (*s == '!') if (*s == '!')
{ {
@ -1407,7 +1407,7 @@ int EXT_FUNC PF_precache_model_I(const char *s)
if (g_psv.state == ss_loading) if (g_psv.state == ss_loading)
{ {
for (int i = 0; i < HL_MODEL_MAX; i++) for (int i = 0; i < MAX_MODELS; i++)
{ {
if (!g_psv.model_precache[i]) if (!g_psv.model_precache[i])
{ {
@ -1422,14 +1422,14 @@ int EXT_FUNC PF_precache_model_I(const char *s)
g_rehlds_sv.modelsMap.put(g_psv.model_precache[i], i); g_rehlds_sv.modelsMap.put(g_psv.model_precache[i], i);
#endif //REHLDS_OPT_PEDANTIC #endif //REHLDS_OPT_PEDANTIC
g_psv.models[i] = Mod_ForName(s, 1, 1); g_psv.models[i] = Mod_ForName(s, TRUE, TRUE);
if (!iOptional) if (!iOptional)
g_psv.model_precache_flags[i] |= 1u; g_psv.model_precache_flags[i] |= RES_FATALIFMISSING;
return i; return i;
} }
//use case-sensitive names to increase performance // use case-sensitive names to increase performance
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
if (!Q_strcmp(g_psv.model_precache[i], s)) if (!Q_strcmp(g_psv.model_precache[i], s))
return i; return i;
@ -1439,15 +1439,14 @@ int EXT_FUNC PF_precache_model_I(const char *s)
#endif #endif
} }
Host_Error( Host_Error(
"PF_precache_model_I: Model '%s' failed to precache because the item count is over the %d limit.\nReduce the number of brush models and/or regular models in the map to correct this.", __FUNCTION__ ": Model '%s' failed to precache because the item count is over the %d limit.\nReduce the number of brush models and/or regular models in the map to correct this.",
s, s, MAX_MODELS);
512);
} }
else else
{ {
for (int i = 0; i < HL_MODEL_MAX; i++) for (int i = 0; i < MAX_MODELS; i++)
{ {
//use case-sensitive names to increase performance // use case-sensitive names to increase performance
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
if (!Q_strcmp(g_psv.model_precache[i], s)) if (!Q_strcmp(g_psv.model_precache[i], s))
return i; return i;
@ -1456,19 +1455,21 @@ int EXT_FUNC PF_precache_model_I(const char *s)
return i; return i;
#endif #endif
} }
Host_Error("PF_precache_model_I: '%s' Precache can only be done in spawn functions", s); Host_Error(__FUNCTION__ ": '%s' Precache can only be done in spawn functions", s);
} }
} }
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
int EXT_FUNC PF_precache_generic_I(char *s) int EXT_FUNC PF_precache_generic_I(char *s)
// TODO: Call to Con_Printf is replaced with Host_Error in 6153
{ {
if (!s) if (!s)
Host_Error("PF_precache_generic_I: NULL pointer"); Host_Error(__FUNCTION__ ": NULL pointer");
if (PR_IsEmptyString(s)) if (PR_IsEmptyString(s))
Host_Error("PF_precache_generic_I: Bad string '%s'", s); {
// TODO: Call to Con_Printf is replaced with Host_Error in 6153
Host_Error(__FUNCTION__ ": Bad string '%s'", s);
}
char resName[MAX_QPATH]; char resName[MAX_QPATH];
Q_strncpy(resName, s, sizeof(resName)); Q_strncpy(resName, s, sizeof(resName));
@ -1492,14 +1493,15 @@ int EXT_FUNC PF_precache_generic_I(char *s)
} }
if (g_psv.state != ss_loading) if (g_psv.state != ss_loading)
Host_Error("PF_precache_generic_I: '%s' Precache can only be done in spawn functions", resName); Host_Error(__FUNCTION__ ": '%s' Precache can only be done in spawn functions", resName);
if (resCount >= ARRAYSIZE(g_rehlds_sv.precachedGenericResourceNames)) if (resCount >= ARRAYSIZE(g_rehlds_sv.precachedGenericResourceNames))
{
Host_Error( Host_Error(
"PF_precache_generic_I: Generic item '%s' failed to precache because the item count is over the %d limit.\n\ __FUNCTION__ ": Generic item '%s' failed to precache because the item count is over the %d limit.\n\
Reduce the number of brush models and/or regular models in the map to correct this.", Reduce the number of brush models and/or regular models in the map to correct this.",
resName, resName, ARRAYSIZE(g_rehlds_sv.precachedGenericResourceNames));
ARRAYSIZE(g_rehlds_sv.precachedGenericResourceNames)); }
Q_strcpy(g_rehlds_sv.precachedGenericResourceNames[resCount], resName); Q_strcpy(g_rehlds_sv.precachedGenericResourceNames[resCount], resName);
@ -1507,17 +1509,19 @@ Reduce the number of brush models and/or regular models in the map to correct th
} }
#else // REHLDS_FIXES #else // REHLDS_FIXES
int EXT_FUNC PF_precache_generic_I(char *s) int EXT_FUNC PF_precache_generic_I(char *s)
// TODO: Call to Con_Printf is replaced with Host_Error in 6153
{ {
if (!s) if (!s)
Host_Error("PF_precache_generic_I: NULL pointer"); Host_Error(__FUNCTION__ ": NULL pointer");
if (PR_IsEmptyString(s)) if (PR_IsEmptyString(s))
Host_Error("PF_precache_generic_I: Bad string '%s'", s); {
// TODO: Call to Con_Printf is replaced with Host_Error in 6153
Host_Error(__FUNCTION__ ": Bad string '%s'", s);
}
if (g_psv.state == ss_loading) if (g_psv.state == ss_loading)
{ {
for (int i = 0; i < HL_GENERIC_MAX; i++) for (int i = 0; i < MAX_GENERIC; i++)
{ {
if (!g_psv.generic_precache[i]) if (!g_psv.generic_precache[i])
{ {
@ -1529,18 +1533,18 @@ int EXT_FUNC PF_precache_generic_I(char *s)
return i; return i;
} }
Host_Error( Host_Error(
"PF_precache_generic_I: Generic item '%s' failed to precache because the item count is over the %d limit.\nReduce the number of brush models and/or regular models in the map to correct this.", __FUNCTION__ ": Generic item '%s' failed to precache because the item count is over the %d limit.\nReduce the number of brush models and/or regular models in the map to correct this.",
s, s, MAX_GENERIC
HL_GENERIC_MAX); );
} }
else else
{ {
for (int i = 0; i < HL_GENERIC_MAX; i++) for (int i = 0; i < MAX_GENERIC; i++)
{ {
if (!Q_stricmp(g_psv.generic_precache[i], s)) if (!Q_stricmp(g_psv.generic_precache[i], s))
return i; return i;
} }
Host_Error("PF_precache_generic_I: '%s' Precache can only be done in spawn functions", s); Host_Error(__FUNCTION__ ": '%s' Precache can only be done in spawn functions", s);
} }
} }
#endif // REHLDS_FIXES #endif // REHLDS_FIXES
@ -1975,13 +1979,13 @@ edict_t* EXT_FUNC PF_CreateFakeClient_I(const char *netname)
Q_strncpy(fakeclient->name, netname, sizeof(fakeclient->name) - 1); Q_strncpy(fakeclient->name, netname, sizeof(fakeclient->name) - 1);
fakeclient->name[sizeof(fakeclient->name) - 1] = 0; fakeclient->name[sizeof(fakeclient->name) - 1] = 0;
fakeclient->active = 1; fakeclient->active = TRUE;
fakeclient->spawned = 1; fakeclient->spawned = TRUE;
fakeclient->fully_connected = 1; fakeclient->fully_connected = TRUE;
fakeclient->connected = 1; fakeclient->connected = TRUE;
fakeclient->fakeclient = 1; fakeclient->fakeclient = TRUE;
fakeclient->userid = g_userid++; fakeclient->userid = g_userid++;
fakeclient->uploading = 0; fakeclient->uploading = FALSE;
fakeclient->edict = ent; fakeclient->edict = ent;
ent->v.netname = (size_t)fakeclient->name - (size_t)pr_strings; ent->v.netname = (size_t)fakeclient->name - (size_t)pr_strings;
ent->v.pContainingEntity = ent; ent->v.pContainingEntity = ent;

View File

@ -37,7 +37,6 @@
// TODO: I think this defines must be in /common/ // TODO: I think this defines must be in /common/
#define NUM_EDICTS 900 #define NUM_EDICTS 900
#define MAX_NAME 32 #define MAX_NAME 32
#define MAX_PACKET_ENTITIES 256
#include "custom_int.h" #include "custom_int.h"
#include "crc.h" #include "crc.h"
@ -86,13 +85,6 @@
#define RESOURCE_MAX_COUNT (1 << RESOURCE_INDEX_BITS) #define RESOURCE_MAX_COUNT (1 << RESOURCE_INDEX_BITS)
#endif // REHLDS_FIXES #endif // REHLDS_FIXES
#define HL_SOUND_MAX 512
#define HL_SOUND_HASHLOOKUP_SIZE (HL_SOUND_MAX * 2 - 1)
#define HL_MODEL_MAX 512
#define HL_GENERIC_MAX 512
#define HL_EVENT_MAX 256
typedef enum redirect_e typedef enum redirect_e
{ {
RD_NONE = 0, RD_NONE = 0,
@ -127,15 +119,15 @@ typedef struct server_s
int num_resources; int num_resources;
consistency_t consistency_list[MAX_CONSISTENCY_LIST]; consistency_t consistency_list[MAX_CONSISTENCY_LIST];
int num_consistency; int num_consistency;
const char *model_precache[HL_MODEL_MAX]; const char *model_precache[MAX_MODELS];
struct model_s *models[HL_MODEL_MAX]; struct model_s *models[MAX_MODELS];
unsigned char model_precache_flags[HL_MODEL_MAX]; unsigned char model_precache_flags[MAX_MODELS];
struct event_s event_precache[HL_EVENT_MAX]; struct event_s event_precache[MAX_EVENTS];
const char *sound_precache[HL_SOUND_MAX]; const char *sound_precache[MAX_SOUNDS];
short int sound_precache_hashedlookup[HL_SOUND_HASHLOOKUP_SIZE]; short int sound_precache_hashedlookup[MAX_SOUNDS_HASHLOOKUP_SIZE];
qboolean sound_precache_hashedlookup_built; qboolean sound_precache_hashedlookup_built;
const char *generic_precache[HL_GENERIC_MAX]; const char *generic_precache[MAX_GENERIC];
char generic_precache_names[HL_GENERIC_MAX][64]; char generic_precache_names[MAX_GENERIC][64];
int num_generic_names; int num_generic_names;
char *lightstyles[MAX_LIGHTSTYLES]; char *lightstyles[MAX_LIGHTSTYLES];
int num_edicts; int num_edicts;
@ -158,11 +150,11 @@ typedef struct server_s
struct rehlds_server_t { struct rehlds_server_t {
//map for sv.model_precache (for faster resolving of model index by its name) // map for sv.model_precache (for faster resolving of model index by its name)
#if defined(REHLDS_FIXES) #if defined(REHLDS_FIXES)
CStringKeyStaticMap<int, 7, HL_MODEL_MAX * 2> modelsMap; //case-sensitive keys for better performance CStringKeyStaticMap<int, 7, MAX_MODELS * 2> modelsMap; // case-sensitive keys for better performance
#elif defined(REHLDS_OPT_PEDANTIC) #elif defined(REHLDS_OPT_PEDANTIC)
CICaseStringKeyStaticMap<int, 7, HL_MODEL_MAX * 2> modelsMap; //use case-insensitive keys to conform original engine's behavior CICaseStringKeyStaticMap<int, 7, MAX_MODELS * 2> modelsMap; // use case-insensitive keys to conform original engine's behavior
#endif #endif
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES

View File

@ -692,12 +692,12 @@ void SV_FindModelNumbers(void)
{ {
sv_playermodel = -1; sv_playermodel = -1;
for (int i = 0; i < HL_MODEL_MAX; i++) for (int i = 0; i < MAX_MODELS; i++)
{ {
if (!g_psv.model_precache[i]) if (!g_psv.model_precache[i])
break; break;
//use case-sensitive names to increase performance // use case-sensitive names to increase performance
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
if (!Q_stricmp(g_psv.model_precache[i], "models/player.mdl")) if (!Q_stricmp(g_psv.model_precache[i], "models/player.mdl"))
sv_playermodel = i; sv_playermodel = i;
@ -869,7 +869,7 @@ int EXT_FUNC SV_LookupSoundIndex(const char *sample)
{ {
if (g_psv.state == ss_loading) if (g_psv.state == ss_loading)
{ {
for (index = 1; index < HL_SOUND_MAX && g_psv.sound_precache[index]; index++) // TODO: why from 1? for (index = 1; index < MAX_SOUNDS && g_psv.sound_precache[index]; index++) // TODO: why from 1?
{ {
if (!Q_stricmp(sample, g_psv.sound_precache[index])) if (!Q_stricmp(sample, g_psv.sound_precache[index]))
return index; return index;
@ -887,7 +887,7 @@ int EXT_FUNC SV_LookupSoundIndex(const char *sample)
return g_psv.sound_precache_hashedlookup[index]; return g_psv.sound_precache_hashedlookup[index];
index++; index++;
if (index >= HL_SOUND_HASHLOOKUP_SIZE) if (index >= MAX_SOUNDS_HASHLOOKUP_SIZE)
index = 0; index = 0;
if (index == starting_index) if (index == starting_index)
return 0; return 0;
@ -899,7 +899,7 @@ void SV_BuildHashedSoundLookupTable(void)
{ {
Q_memset(g_psv.sound_precache_hashedlookup, 0, sizeof(g_psv.sound_precache_hashedlookup)); Q_memset(g_psv.sound_precache_hashedlookup, 0, sizeof(g_psv.sound_precache_hashedlookup));
for (int sound_num = 0; sound_num < HL_SOUND_MAX; sound_num++) for (int sound_num = 0; sound_num < MAX_SOUNDS; sound_num++)
{ {
if (!g_psv.sound_precache[sound_num]) if (!g_psv.sound_precache[sound_num])
break; break;
@ -912,14 +912,14 @@ void SV_BuildHashedSoundLookupTable(void)
void SV_AddSampleToHashedLookupTable(const char *pszSample, int iSampleIndex) void SV_AddSampleToHashedLookupTable(const char *pszSample, int iSampleIndex)
{ {
int starting_index = SV_HashString(pszSample, HL_SOUND_HASHLOOKUP_SIZE); int starting_index = SV_HashString(pszSample, MAX_SOUNDS_HASHLOOKUP_SIZE);
int index = starting_index; int index = starting_index;
while (g_psv.sound_precache_hashedlookup[index]) while (g_psv.sound_precache_hashedlookup[index])
{ {
index++; index++;
hashstrings_collisions++; hashstrings_collisions++;
if (index >= HL_SOUND_HASHLOOKUP_SIZE) if (index >= MAX_SOUNDS_HASHLOOKUP_SIZE)
index = 0; index = 0;
if (index == starting_index) if (index == starting_index)
@ -1413,8 +1413,8 @@ void SV_WriteSpawn(sizebuf_t *msg)
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
// do it before PutInServer to allow mods send messages from forward // do it before PutInServer to allow mods send messages from forward
SZ_Clear( &host_client->netchan.message ); SZ_Clear(&host_client->netchan.message);
SZ_Clear( &host_client->datagram ); SZ_Clear(&host_client->datagram);
#endif // REHLDS_FIXES #endif // REHLDS_FIXES
if (g_psv.loadgame) if (g_psv.loadgame)
@ -4976,7 +4976,7 @@ int SV_ModelIndex(const char *name)
return node->val; return node->val;
} }
#else #else
for (int i = 0; i < HL_MODEL_MAX; i++) for (int i = 0; i < MAX_MODELS; i++)
{ {
if (!g_psv.model_precache[i]) if (!g_psv.model_precache[i])
break; break;
@ -5196,7 +5196,7 @@ void SV_CreateResourceList(void)
} }
#else // REHLDS_FIXES #else // REHLDS_FIXES
#ifdef REHLDS_CHECKS #ifdef REHLDS_CHECKS
for (i = 1, s = &g_psv.generic_precache[1]; i < HL_GENERIC_MAX && *s != NULL; i++, s++) for (i = 1, s = &g_psv.generic_precache[1]; i < MAX_GENERIC && *s != NULL; i++, s++)
#else // REHLDS_CHECKS #else // REHLDS_CHECKS
for (i = 1, s = &g_psv.generic_precache[1]; *s != NULL; i++, s++) for (i = 1, s = &g_psv.generic_precache[1]; *s != NULL; i++, s++)
#endif // REHLDS_CHECKS #endif // REHLDS_CHECKS
@ -5211,7 +5211,7 @@ void SV_CreateResourceList(void)
#endif // REHLDS_FIXES #endif // REHLDS_FIXES
#ifdef REHLDS_CHECKS #ifdef REHLDS_CHECKS
for (i = 1, s = &g_psv.sound_precache[1]; i < HL_SOUND_MAX && *s != NULL; i++, s++) for (i = 1, s = &g_psv.sound_precache[1]; i < MAX_SOUNDS && *s != NULL; i++, s++)
#else // REHLDS_CHECKS #else // REHLDS_CHECKS
for (i = 1, s = &g_psv.sound_precache[1]; *s != NULL; i++, s++) for (i = 1, s = &g_psv.sound_precache[1]; *s != NULL; i++, s++)
#endif // REHLDS_CHECKS #endif // REHLDS_CHECKS
@ -5233,7 +5233,7 @@ void SV_CreateResourceList(void)
} }
} }
#ifdef REHLDS_CHECKS #ifdef REHLDS_CHECKS
for (i = 1, s = &g_psv.model_precache[1]; i < HL_MODEL_MAX && *s != NULL; i++, s++) for (i = 1, s = &g_psv.model_precache[1]; i < MAX_MODELS && *s != NULL; i++, s++)
#else // REHLDS_CHECKS #else // REHLDS_CHECKS
for (i = 1, s = &g_psv.model_precache[1]; *s != NULL; i++, s++) for (i = 1, s = &g_psv.model_precache[1]; *s != NULL; i++, s++)
#endif // REHLDS_CHECKS #endif // REHLDS_CHECKS
@ -5248,7 +5248,7 @@ void SV_CreateResourceList(void)
for (i = 0; i < sv_decalnamecount; i++) for (i = 0; i < sv_decalnamecount; i++)
SV_AddResource(t_decal, sv_decalnames[i].name, Draw_DecalSize(i), 0, i); SV_AddResource(t_decal, sv_decalnames[i].name, Draw_DecalSize(i), 0, i);
for (i = 1; i < HL_EVENT_MAX; i++) for (i = 1; i < MAX_EVENTS; i++)
{ {
ep = &g_psv.event_precache[i]; ep = &g_psv.event_precache[i];
if (!ep->filename) if (!ep->filename)
@ -5262,7 +5262,7 @@ void SV_ClearCaches(void)
{ {
int i; int i;
event_t *ep; event_t *ep;
for (i = 1; i < HL_EVENT_MAX; i++) for (i = 1; i < MAX_EVENTS; i++)
{ {
ep = &g_psv.event_precache[i]; ep = &g_psv.event_precache[i];
if (ep->filename == NULL) if (ep->filename == NULL)
@ -5488,7 +5488,6 @@ NOXREF void SV_ReconnectAllClients(void)
SV_DropClient(client, FALSE, message); SV_DropClient(client, FALSE, message);
} }
} }
} }
void SetCStrikeFlags(void) void SetCStrikeFlags(void)

View File

@ -36,24 +36,24 @@
static int c_yes = 0; static int c_yes = 0;
static int c_no = 0; static int c_no = 0;
#else //HOOK_ENGINE #else // HOOK_ENGINE
int c_yes; int c_yes;
int c_no; int c_no;
#endif //HOOK_ENGINE #endif // HOOK_ENGINE
qboolean SV_CheckBottom(edict_t *ent) qboolean SV_CheckBottom(edict_t *ent)
{ {
vec3_t mins; vec3_t mins;
vec3_t maxs; vec3_t maxs;
vec3_t start; vec3_t start;
vec3_t stop; // 29 vec3_t stop;
trace_t trace; // 30 trace_t trace;
int x; // 31 int x;
int y; // 31 int y;
float mid; // 32 float mid;
float bottom; // 32 float bottom;
qboolean monsterClip = (ent->v.flags & FL_MONSTERCLIP) ? 1 : 0; qboolean monsterClip = (ent->v.flags & FL_MONSTERCLIP) ? 1 : 0;
_VectorAdd(ent->v.origin, ent->v.mins, mins); _VectorAdd(ent->v.origin, ent->v.mins, mins);

View File

@ -426,10 +426,10 @@ void SV_ParseResourceList(client_t *pSenderClient)
resource->nDownloadSize > 1024 * 1024 * 1024) // FIXME: Are they gone crazy??! resource->nDownloadSize > 1024 * 1024 * 1024) // FIXME: Are they gone crazy??!
{ {
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
SV_ClearResourceLists( host_client ); SV_ClearResourceLists(host_client);
#else // REHLDS_FIXES #else // REHLDS_FIXES
SV_ClearResourceList( &host_client->resourcesneeded ); SV_ClearResourceList(&host_client->resourcesneeded);
SV_ClearResourceList( &host_client->resourcesonhand ); SV_ClearResourceList(&host_client->resourcesonhand);
#endif // REHLDS_FIXES #endif // REHLDS_FIXES
return; return;
} }
@ -488,14 +488,13 @@ void SV_ParseResourceList(client_t *pSenderClient)
Con_DPrintf("----------------------\n"); Con_DPrintf("----------------------\n");
int bytestodownload = SV_EstimateNeededResources(); int bytestodownload = SV_EstimateNeededResources();
if (bytestodownload > sv_max_upload.value * 1024 * 1024) if (bytestodownload > sv_max_upload.value * 1024 * 1024)
{ {
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
SV_ClearResourceLists( host_client ); SV_ClearResourceLists(host_client);
#else // REHLDS_FIXES #else // REHLDS_FIXES
SV_ClearResourceList( &host_client->resourcesneeded ); SV_ClearResourceList(&host_client->resourcesneeded);
SV_ClearResourceList( &host_client->resourcesonhand ); SV_ClearResourceList(&host_client->resourcesonhand);
#endif //REHLDS_FIXES #endif //REHLDS_FIXES
return; return;
} }

View File

@ -1533,7 +1533,6 @@ void SV_ParseMove(client_t *pSenderClient)
if (!g_psv.active || !(host_client->active || host_client->spawned)) if (!g_psv.active || !(host_client->active || host_client->spawned))
return; return;
if (msg_badread) if (msg_badread)
{ {
Con_Printf("Client %s:%s sent a bogus command packet\n", host_client->name, NET_AdrToString(host_client->netchan.remote_address)); Con_Printf("Client %s:%s sent a bogus command packet\n", host_client->name, NET_AdrToString(host_client->netchan.remote_address));
@ -1807,7 +1806,7 @@ void SV_SendEnts_f(void)
{ {
if (host_client->connected) if (host_client->connected)
{ {
host_client->fully_connected = 1; host_client->fully_connected = TRUE;
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
// See SV_CheckFile function // See SV_CheckFile function

View File

@ -428,7 +428,7 @@ NOBODY void Sys_DebugOutStraight(const char *pStr);
//{ //{
//} //}
void __declspec(noreturn) Sys_Error(const char *error, ...) void NORETURN Sys_Error(const char *error, ...)
{ {
va_list argptr; va_list argptr;
char text[1024]; char text[1024];

View File

@ -160,7 +160,7 @@ NOBODY void MaskExceptions(void);
NOBODY void Sys_Init(void); NOBODY void Sys_Init(void);
NOXREF void Sys_Sleep(int msec); NOXREF void Sys_Sleep(int msec);
NOBODY void Sys_DebugOutStraight(const char *pStr); NOBODY void Sys_DebugOutStraight(const char *pStr);
NOBODY void __declspec(noreturn) Sys_Error(const char *error, ...); NOBODY void NORETURN Sys_Error(const char *error, ...);
NOXREF void Sys_Warning(const char *pszWarning, ...); NOXREF void Sys_Warning(const char *pszWarning, ...);
void Sys_Printf(const char *fmt, ...); void Sys_Printf(const char *fmt, ...);
void Sys_Quit(void); void Sys_Quit(void);

View File

@ -160,11 +160,8 @@ struct hull_s *SV_HullForBsp(edict_t *ent, const vec_t *mins, const vec_t *maxs,
model_t *model; model_t *model;
hull_t *hull; hull_t *hull;
model = g_psv.models[ent->v.modelindex]; model = Mod_Handle(ent->v.modelindex);
if (!model) if (!model || model->type != mod_brush)
Sys_Error("Hit a %s with no model (%s)", &pr_strings[ent->v.classname], &pr_strings[ent->v.model]);
if (model->type)
Sys_Error("Hit a %s with no model (%s)", &pr_strings[ent->v.classname], &pr_strings[ent->v.model]); Sys_Error("Hit a %s with no model (%s)", &pr_strings[ent->v.classname], &pr_strings[ent->v.model]);
float xSize = maxs[0] - mins[0]; float xSize = maxs[0] - mins[0];
@ -310,7 +307,6 @@ void SV_UnlinkEdict(edict_t *ent)
void SV_TouchLinks(edict_t *ent, areanode_t *node) void SV_TouchLinks(edict_t *ent, areanode_t *node)
{ {
edict_t *touch; edict_t *touch;
model_t *pModel;
link_t *next; link_t *next;
for (link_t *l = node->trigger_edicts.next; l != &node->trigger_edicts; l = next) for (link_t *l = node->trigger_edicts.next; l != &node->trigger_edicts; l = next)
@ -347,9 +343,7 @@ void SV_TouchLinks(edict_t *ent, areanode_t *node)
&& ent->v.absmax[1] >= touch->v.absmin[1] && ent->v.absmax[1] >= touch->v.absmin[1]
&& ent->v.absmax[2] >= touch->v.absmin[2]) && ent->v.absmax[2] >= touch->v.absmin[2])
{ {
pModel = g_psv.models[touch->v.modelindex]; if (Mod_GetType(touch->v.modelindex) == mod_brush)
if (pModel && pModel->type == mod_brush)
{ {
vec3_t offset; vec3_t offset;
hull_t *hull = SV_HullForBsp(touch, ent->v.mins, ent->v.maxs, offset); hull_t *hull = SV_HullForBsp(touch, ent->v.mins, ent->v.maxs, offset);
@ -560,8 +554,12 @@ void SV_LinkEdict(edict_t *ent, qboolean touch_triggers)
if (ent->v.solid == SOLID_NOT && ent->v.skin >= -1) if (ent->v.solid == SOLID_NOT && ent->v.skin >= -1)
return; return;
if (ent->v.solid != SOLID_BSP || g_psv.models[ent->v.modelindex] || Q_strlen(&pr_strings[ent->v.model])) if (ent->v.solid == SOLID_BSP && !Mod_Handle(ent->v.modelindex) && Q_strlen(&pr_strings[ent->v.model]) <= 0)
{ {
Con_DPrintf("Inserted %s with no model\n", &pr_strings[ent->v.classname]);
return;
}
node = sv_areanodes; node = sv_areanodes;
while (1) while (1)
{ {
@ -590,11 +588,6 @@ void SV_LinkEdict(edict_t *ent, qboolean touch_triggers)
iTouchLinkSemaphore = 0; iTouchLinkSemaphore = 0;
} }
} }
}
else
{
Con_DPrintf("Inserted %s with no model\n", &pr_strings[ent->v.classname]);
}
} }
int SV_HullPointContents(hull_t *hull, int num, const vec_t *p) int SV_HullPointContents(hull_t *hull, int num, const vec_t *p)
@ -625,7 +618,6 @@ int SV_LinkContents(areanode_t *node, const vec_t *pos)
link_t *l; link_t *l;
link_t *next; link_t *next;
edict_t *touch; edict_t *touch;
model_t *pModel;
hull_t *hull; hull_t *hull;
vec3_t localPosition; vec3_t localPosition;
vec3_t offset; vec3_t offset;
@ -654,9 +646,8 @@ int SV_LinkContents(areanode_t *node, const vec_t *pos)
continue; continue;
} }
} }
pModel = g_psv.models[touch->v.modelindex];
if (pModel if (Mod_GetType(touch->v.modelindex) == mod_brush
&& !pModel->type
&& pos[0] <= (double)touch->v.absmax[0] && pos[0] <= (double)touch->v.absmax[0]
&& pos[1] <= (double)touch->v.absmax[1] && pos[1] <= (double)touch->v.absmax[1]
&& pos[2] <= (double)touch->v.absmax[2] && pos[2] <= (double)touch->v.absmax[2]
@ -1051,7 +1042,12 @@ void SV_SingleClipMoveToEntity(edict_t *ent, const vec_t *start, const vec_t *mi
trace->endpos[0] = end[0]; trace->endpos[0] = end[0];
trace->endpos[1] = end[1]; trace->endpos[1] = end[1];
trace->endpos[2] = end[2]; trace->endpos[2] = end[2];
#ifdef REHLDS_FIXES
if (Mod_GetType(ent->v.modelindex) == mod_studio)
#else
if (g_psv.models[ent->v.modelindex]->type == mod_studio) if (g_psv.models[ent->v.modelindex]->type == mod_studio)
#endif // REHLDS_FIXES
{ {
hull = SV_HullForStudioModel(ent, mins, maxs, offset, &numhulls); hull = SV_HullForStudioModel(ent, mins, maxs, offset, &numhulls);
} }

View File

@ -23,8 +23,8 @@
#define ARRAYSIZE(p) (sizeof(p)/sizeof(p[0])) #define ARRAYSIZE(p) (sizeof(p)/sizeof(p[0]))
// Keeps clutter down a bit, when using a float as a bit-vector // Keeps clutter down a bit, when using a float as a bit-vector
#define SETBITS(flBitVector, bits) ((flBitVector) = (int)(flBitVector) | (bits)) #define SetBits(flBitVector, bits) ((flBitVector) = (int)(flBitVector) | (bits))
#define CLEARBITS(flBitVector, bits) ((flBitVector) = (int)(flBitVector) & ~(bits)) #define ClearBits(flBitVector, bits) ((flBitVector) = (int)(flBitVector) & ~(bits))
#define FBitSet(flBitVector, bit) ((flBitVector) & (bit)) #define FBitSet(flBitVector, bit) ((int)(flBitVector) & (bit))
#endif // COMMONMACROS_H #endif // COMMONMACROS_H

View File

@ -50,7 +50,7 @@ public:
// Specifies priorities for hooks call order in the chain. // Specifies priorities for hooks call order in the chain.
// For equal priorities first registered hook will be called first. // For equal priorities first registered hook will be called first.
enum HookChainPriority : int enum HookChainPriority
{ {
HC_PRIORITY_UNINTERRUPTABLE = 255, // Hook will be called before other hooks. HC_PRIORITY_UNINTERRUPTABLE = 255, // Hook will be called before other hooks.
HC_PRIORITY_HIGH = 192, // Hook will be called before hooks with default priority. HC_PRIORITY_HIGH = 192, // Hook will be called before hooks with default priority.

View File

@ -292,6 +292,7 @@ typedef struct aliashdr_s
typedef enum modtype_e typedef enum modtype_e
{ {
mod_bad = -1,
mod_brush, mod_brush,
mod_sprite, mod_sprite,
mod_alias, mod_alias,

View File

@ -103,6 +103,7 @@
#define HIDDEN #define HIDDEN
#define NOINLINE __declspec(noinline) #define NOINLINE __declspec(noinline)
#define ALIGN16 __declspec(align(16)) #define ALIGN16 __declspec(align(16))
#define NORETURN __declspec(noreturn)
#define FORCE_STACK_ALIGN #define FORCE_STACK_ALIGN
//inline bool SOCKET_FIONBIO(SOCKET s, int m) { return (ioctlsocket(s, FIONBIO, (u_long*)&m) == 0); } //inline bool SOCKET_FIONBIO(SOCKET s, int m) { return (ioctlsocket(s, FIONBIO, (u_long*)&m) == 0); }
@ -148,6 +149,7 @@
#define HIDDEN __attribute__((visibility("hidden"))) #define HIDDEN __attribute__((visibility("hidden")))
#define NOINLINE __attribute__((noinline)) #define NOINLINE __attribute__((noinline))
#define ALIGN16 __attribute__((aligned(16))) #define ALIGN16 __attribute__((aligned(16)))
#define NORETURN __attribute__((noreturn))
#define FORCE_STACK_ALIGN __attribute__((force_align_arg_pointer)) #define FORCE_STACK_ALIGN __attribute__((force_align_arg_pointer))
//inline bool SOCKET_FIONBIO(SOCKET s, int m) { return (ioctl(s, FIONBIO, (int*)&m) == 0); } //inline bool SOCKET_FIONBIO(SOCKET s, int m) { return (ioctl(s, FIONBIO, (int*)&m) == 0); }

View File

@ -310,6 +310,9 @@ typedef struct
} mstudiotrivert_t; } mstudiotrivert_t;
#endif #endif
#define STUDIO_DYNAMIC_LIGHT 0x0100 // dynamically get lighting from floor or ceil (flying monsters)
#define STUDIO_TRACE_HITBOX 0x0200 // always use hitbox trace instead of bbox
// lighting options // lighting options
#define STUDIO_NF_FLATSHADE 0x0001 #define STUDIO_NF_FLATSHADE 0x0001
#define STUDIO_NF_CHROME 0x0002 #define STUDIO_NF_CHROME 0x0002

View File

@ -198,7 +198,7 @@ void CSimplePlatform::SteamAPI_UnregisterCallback(CCallbackBase *pCallback)
::SteamAPI_UnregisterCallback(pCallback); ::SteamAPI_UnregisterCallback(pCallback);
} }
void __declspec(noreturn) rehlds_syserror(const char* fmt, ...) { void NORETURN rehlds_syserror(const char* fmt, ...) {
va_list argptr; va_list argptr;
static char string[8192]; static char string[8192];

View File

@ -122,4 +122,4 @@ public:
static void set(IReHLDSPlatform* p); static void set(IReHLDSPlatform* p);
}; };
extern void __declspec(noreturn) rehlds_syserror(const char* fmt, ...); extern void NORETURN rehlds_syserror(const char* fmt, ...);