mirror of
https://github.com/rehlds/rehlds.git
synced 2025-01-19 10:08:04 +03:00
Merge remote-tracking branch 'remotes/tema/resourcelistextend'
This commit is contained in:
commit
5916655edd
@ -1516,6 +1516,7 @@ int EXT_FUNC PF_precache_model_I(const char *s)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
/* <79a3f> ../engine/pr_cmds.c:1903 */
|
/* <79a3f> ../engine/pr_cmds.c:1903 */
|
||||||
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
|
// TODO: Call to Con_Printf is replaced with Host_Error in 6153
|
||||||
@ -1526,14 +1527,51 @@ int EXT_FUNC PF_precache_generic_I(char *s)
|
|||||||
if (PR_IsEmptyString(s))
|
if (PR_IsEmptyString(s))
|
||||||
Host_Error("PF_precache_generic_I: Bad string '%s'", s);
|
Host_Error("PF_precache_generic_I: Bad string '%s'", s);
|
||||||
|
|
||||||
#ifdef REHLDS_FIXES
|
char resName[MAX_QPATH];
|
||||||
size_t soundPrefixLength = sizeof("sound/") - 1;
|
Q_strncpy(resName, s, sizeof(resName));
|
||||||
bool isSoundPrefixed = !Q_strnicmp(s, "sound/", soundPrefixLength);
|
resName[sizeof(resName) - 1] = '\0';
|
||||||
|
ForwardSlashes(resName);
|
||||||
|
|
||||||
if ((isSoundPrefixed && SV_LookupSoundIndex(&s[soundPrefixLength])) ||
|
size_t soundPrefixLength = sizeof("sound/") - 1;
|
||||||
SV_LookupModelIndex(s))
|
bool isSoundPrefixed = !Q_strnicmp(resName, "sound/", soundPrefixLength);
|
||||||
|
|
||||||
|
// TODO: check sound with index 0?
|
||||||
|
// UPD: no, not need, because engine do this: g_psv.sound_precache[0] = pr_strings;
|
||||||
|
if ((isSoundPrefixed && SV_LookupSoundIndex(&resName[soundPrefixLength])) ||
|
||||||
|
SV_LookupModelIndex(resName))
|
||||||
return 0;
|
return 0;
|
||||||
#endif // REHLDS_FIXES
|
|
||||||
|
size_t resCount = g_rehlds_sv.precachedGenericResourceCount;
|
||||||
|
for (size_t i = 0; i < resCount; i++)
|
||||||
|
{
|
||||||
|
if (!Q_stricmp(g_rehlds_sv.precachedGenericResourceNames[i], resName))
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (g_psv.state != ss_loading)
|
||||||
|
Host_Error("PF_precache_generic_I: '%s' Precache can only be done in spawn functions", resName);
|
||||||
|
|
||||||
|
if (resCount >= ARRAYSIZE(g_rehlds_sv.precachedGenericResourceNames))
|
||||||
|
Host_Error(
|
||||||
|
"PF_precache_generic_I: 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.",
|
||||||
|
resName,
|
||||||
|
ARRAYSIZE(g_rehlds_sv.precachedGenericResourceNames));
|
||||||
|
|
||||||
|
Q_strcpy(g_rehlds_sv.precachedGenericResourceNames[resCount], resName);
|
||||||
|
|
||||||
|
return g_rehlds_sv.precachedGenericResourceCount++;
|
||||||
|
}
|
||||||
|
#else // REHLDS_FIXES
|
||||||
|
/* <79a3f> ../engine/pr_cmds.c:1903 */
|
||||||
|
int EXT_FUNC PF_precache_generic_I(char *s)
|
||||||
|
// TODO: Call to Con_Printf is replaced with Host_Error in 6153
|
||||||
|
{
|
||||||
|
if (!s)
|
||||||
|
Host_Error("PF_precache_generic_I: NULL pointer");
|
||||||
|
|
||||||
|
if (PR_IsEmptyString(s))
|
||||||
|
Host_Error("PF_precache_generic_I: Bad string '%s'", s);
|
||||||
|
|
||||||
if (g_psv.state == ss_loading)
|
if (g_psv.state == ss_loading)
|
||||||
{
|
{
|
||||||
@ -1541,12 +1579,7 @@ int EXT_FUNC PF_precache_generic_I(char *s)
|
|||||||
{
|
{
|
||||||
if (!g_psv.generic_precache[i])
|
if (!g_psv.generic_precache[i])
|
||||||
{
|
{
|
||||||
#ifdef REHLDS_FIXES
|
|
||||||
// For more information, see EV_Precache
|
|
||||||
g_psv.generic_precache[i] = ED_NewString(s);
|
|
||||||
#else
|
|
||||||
g_psv.generic_precache[i] = s;
|
g_psv.generic_precache[i] = s;
|
||||||
#endif // REHLDS_FIXES
|
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1567,8 +1600,8 @@ int EXT_FUNC PF_precache_generic_I(char *s)
|
|||||||
}
|
}
|
||||||
Host_Error("PF_precache_generic_I: '%s' Precache can only be done in spawn functions", s);
|
Host_Error("PF_precache_generic_I: '%s' Precache can only be done in spawn functions", s);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
|
|
||||||
/* <79a93> ../engine/pr_cmds.c:1944 */
|
/* <79a93> ../engine/pr_cmds.c:1944 */
|
||||||
int EXT_FUNC PF_IsMapValid_I(char *mapname)
|
int EXT_FUNC PF_IsMapValid_I(char *mapname)
|
||||||
|
@ -81,6 +81,10 @@
|
|||||||
#define MSG_FL_PAS BIT(2) // Send to PAS
|
#define MSG_FL_PAS BIT(2) // Send to PAS
|
||||||
#define MSG_FL_ONE BIT(7) // Send to single client
|
#define MSG_FL_ONE BIT(7) // Send to single client
|
||||||
|
|
||||||
|
#define RESOURCE_INDEX_BITS 12
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
#define RESOURCE_MAX_COUNT (1 << RESOURCE_INDEX_BITS)
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
|
|
||||||
#define HL_SOUND_MAX 512
|
#define HL_SOUND_MAX 512
|
||||||
#define HL_SOUND_HASHLOOKUP_SIZE (HL_SOUND_MAX * 2 - 1)
|
#define HL_SOUND_HASHLOOKUP_SIZE (HL_SOUND_MAX * 2 - 1)
|
||||||
@ -168,6 +172,11 @@ struct rehlds_server_t {
|
|||||||
// Extended net buffers
|
// Extended net buffers
|
||||||
uint8_t reliableDatagramBuffer[NET_MAX_PAYLOAD];
|
uint8_t reliableDatagramBuffer[NET_MAX_PAYLOAD];
|
||||||
uint8_t signonData[NET_MAX_PAYLOAD];
|
uint8_t signonData[NET_MAX_PAYLOAD];
|
||||||
|
|
||||||
|
// Extended resource list
|
||||||
|
resource_t resources[RESOURCE_MAX_COUNT];
|
||||||
|
char precachedGenericResourceNames[RESOURCE_MAX_COUNT][MAX_QPATH];
|
||||||
|
size_t precachedGenericResourceCount;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1301,14 +1301,18 @@ void SV_SendResources(sizebuf_t *msg)
|
|||||||
|
|
||||||
MSG_WriteByte(msg, svc_resourcelist);
|
MSG_WriteByte(msg, svc_resourcelist);
|
||||||
MSG_StartBitWriting(msg);
|
MSG_StartBitWriting(msg);
|
||||||
MSG_WriteBits(g_psv.num_resources, 12);
|
MSG_WriteBits(g_psv.num_resources, RESOURCE_INDEX_BITS);
|
||||||
|
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
resource_t *r = g_rehlds_sv.resources;
|
||||||
|
#else // REHLDS_FIXES
|
||||||
resource_t *r = g_psv.resourcelist;
|
resource_t *r = g_psv.resourcelist;
|
||||||
|
#endif
|
||||||
for (int i = 0; i < g_psv.num_resources; i++, r++)
|
for (int i = 0; i < g_psv.num_resources; i++, r++)
|
||||||
{
|
{
|
||||||
MSG_WriteBits(r->type, 4);
|
MSG_WriteBits(r->type, 4);
|
||||||
MSG_WriteBitString(r->szFileName);
|
MSG_WriteBitString(r->szFileName);
|
||||||
MSG_WriteBits(r->nIndex, 12);
|
MSG_WriteBits(r->nIndex, RESOURCE_INDEX_BITS);
|
||||||
MSG_WriteBits(r->nDownloadSize, 24);
|
MSG_WriteBits(r->nDownloadSize, 24);
|
||||||
MSG_WriteBits(r->ucFlags & (RES_WASMISSING | RES_FATALIFMISSING), 3);
|
MSG_WriteBits(r->ucFlags & (RES_WASMISSING | RES_FATALIFMISSING), 3);
|
||||||
|
|
||||||
@ -4990,10 +4994,20 @@ int SV_ModelIndex(const char *name)
|
|||||||
void EXT_FUNC SV_AddResource(resourcetype_t type, const char *name, int size, unsigned char flags, int index)
|
void EXT_FUNC SV_AddResource(resourcetype_t type, const char *name, int size, unsigned char flags, int index)
|
||||||
{
|
{
|
||||||
resource_t *r;
|
resource_t *r;
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
if (g_psv.num_resources >= ARRAYSIZE(g_rehlds_sv.resources))
|
||||||
|
#else // REHLDS_FIXES
|
||||||
if (g_psv.num_resources >= MAX_RESOURCE_LIST)
|
if (g_psv.num_resources >= MAX_RESOURCE_LIST)
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
|
{
|
||||||
Sys_Error("Too many resources on server.");
|
Sys_Error("Too many resources on server.");
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
r = &g_rehlds_sv.resources[g_psv.num_resources++];
|
||||||
|
#else // REHLDS_FIXES
|
||||||
r = &g_psv.resourcelist[g_psv.num_resources++];
|
r = &g_psv.resourcelist[g_psv.num_resources++];
|
||||||
|
#endif
|
||||||
r->type = type;
|
r->type = type;
|
||||||
Q_strncpy(r->szFileName, name, sizeof(r->szFileName) - 1);
|
Q_strncpy(r->szFileName, name, sizeof(r->szFileName) - 1);
|
||||||
r->szFileName[sizeof(r->szFileName) - 1] = 0;
|
r->szFileName[sizeof(r->szFileName) - 1] = 0;
|
||||||
@ -5055,10 +5069,17 @@ void SV_CreateGenericResources(void)
|
|||||||
Con_Printf("Can't precache .dll files: %s\n", com_token);
|
Con_Printf("Can't precache .dll files: %s\n", com_token);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
// In fixed version of PrecacheGeneric we don't need local copy
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
PF_precache_generic_I(com_token);
|
||||||
|
Con_DPrintf(" %s\n", com_token);
|
||||||
|
g_psv.num_generic_names++;
|
||||||
|
#else // REHLDS_FIXES
|
||||||
Q_strncpy(g_psv.generic_precache_names[g_psv.num_generic_names], com_token, sizeof(g_psv.generic_precache_names[g_psv.num_generic_names]) - 1);
|
Q_strncpy(g_psv.generic_precache_names[g_psv.num_generic_names], com_token, sizeof(g_psv.generic_precache_names[g_psv.num_generic_names]) - 1);
|
||||||
g_psv.generic_precache_names[g_psv.num_generic_names][sizeof(g_psv.generic_precache_names[g_psv.num_generic_names]) - 1] = 0;
|
g_psv.generic_precache_names[g_psv.num_generic_names][sizeof(g_psv.generic_precache_names[g_psv.num_generic_names]) - 1] = 0;
|
||||||
PF_precache_generic_I(g_psv.generic_precache_names[g_psv.num_generic_names]);
|
PF_precache_generic_I(g_psv.generic_precache_names[g_psv.num_generic_names]);
|
||||||
Con_DPrintf(" %s\n", g_psv.generic_precache_names[g_psv.num_generic_names++]);
|
Con_DPrintf(" %s\n", g_psv.generic_precache_names[g_psv.num_generic_names++]);
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Con_DPrintf("----------------------------------\n");
|
Con_DPrintf("----------------------------------\n");
|
||||||
@ -5075,6 +5096,19 @@ void SV_CreateResourceList(void)
|
|||||||
event_t *ep;
|
event_t *ep;
|
||||||
|
|
||||||
g_psv.num_resources = 0;
|
g_psv.num_resources = 0;
|
||||||
|
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
// Generic resources can be indexed from 0, because client ignores resourceIndex for generic resources
|
||||||
|
for (size_t i = 0; i < g_rehlds_sv.precachedGenericResourceCount; i++)
|
||||||
|
{
|
||||||
|
if (g_psvs.maxclients > 1)
|
||||||
|
nSize = FS_FileSize(g_rehlds_sv.precachedGenericResourceNames[i]);
|
||||||
|
else
|
||||||
|
nSize = 0;
|
||||||
|
|
||||||
|
SV_AddResource(t_generic, g_rehlds_sv.precachedGenericResourceNames[i], nSize, RES_FATALIFMISSING, i);
|
||||||
|
}
|
||||||
|
#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 < HL_GENERIC_MAX && *s != NULL; i++, s++)
|
||||||
#else // REHLDS_CHECKS
|
#else // REHLDS_CHECKS
|
||||||
@ -5088,6 +5122,8 @@ void SV_CreateResourceList(void)
|
|||||||
|
|
||||||
SV_AddResource(t_generic, *s, nSize, RES_FATALIFMISSING, i);
|
SV_AddResource(t_generic, *s, nSize, RES_FATALIFMISSING, i);
|
||||||
}
|
}
|
||||||
|
#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 < HL_SOUND_MAX && *s != NULL; i++, s++)
|
||||||
#else // REHLDS_CHECKS
|
#else // REHLDS_CHECKS
|
||||||
@ -5487,6 +5523,29 @@ void PrecacheModelSpecifiedFiles()
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
void MoveCheckedResourcesToFirstPositions()
|
||||||
|
{
|
||||||
|
resource_t *pResources = g_rehlds_sv.resources;
|
||||||
|
size_t j = 0;
|
||||||
|
for (size_t i = 0; i < (size_t)g_psv.num_resources; i++)
|
||||||
|
{
|
||||||
|
if (!(pResources[i].ucFlags & RES_CHECKFILE))
|
||||||
|
continue;
|
||||||
|
if (i == j)
|
||||||
|
{
|
||||||
|
j++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
resource_t temp = pResources[i];
|
||||||
|
pResources[i] = pResources[j];
|
||||||
|
pResources[j] = temp;
|
||||||
|
j++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
|
|
||||||
void SV_ActivateServer(int runPhysics)
|
void SV_ActivateServer(int runPhysics)
|
||||||
{
|
{
|
||||||
g_RehldsHookchains.m_SV_ActivateServer.callChain(SV_ActivateServer_internal, runPhysics);
|
g_RehldsHookchains.m_SV_ActivateServer.callChain(SV_ActivateServer_internal, runPhysics);
|
||||||
@ -5548,6 +5607,9 @@ void EXT_FUNC SV_ActivateServer_internal(int runPhysics)
|
|||||||
SV_CreateBaseline();
|
SV_CreateBaseline();
|
||||||
SV_CreateResourceList();
|
SV_CreateResourceList();
|
||||||
g_psv.num_consistency = SV_TransferConsistencyInfo();
|
g_psv.num_consistency = SV_TransferConsistencyInfo();
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
MoveCheckedResourcesToFirstPositions();
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
for (i = 0, cl = g_psvs.clients; i < g_psvs.maxclients; cl++, i++)
|
for (i = 0, cl = g_psvs.clients; i < g_psvs.maxclients; cl++, i++)
|
||||||
{
|
{
|
||||||
if (!cl->fakeclient && (cl->active || cl->connected))
|
if (!cl->fakeclient && (cl->active || cl->connected))
|
||||||
@ -5688,6 +5750,9 @@ int SV_SpawnServer(qboolean bIsDemo, char *server, char *startspot)
|
|||||||
#ifdef REHLDS_OPT_PEDANTIC
|
#ifdef REHLDS_OPT_PEDANTIC
|
||||||
g_rehlds_sv.modelsMap.clear();
|
g_rehlds_sv.modelsMap.clear();
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
g_rehlds_sv.precachedGenericResourceCount = 0;
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
|
|
||||||
Q_strncpy(g_psv.oldname, oldname, sizeof(oldname) - 1);
|
Q_strncpy(g_psv.oldname, oldname, sizeof(oldname) - 1);
|
||||||
g_psv.oldname[sizeof(oldname) - 1] = 0;
|
g_psv.oldname[sizeof(oldname) - 1] = 0;
|
||||||
@ -5820,7 +5885,9 @@ int SV_SpawnServer(qboolean bIsDemo, char *server, char *startspot)
|
|||||||
|
|
||||||
g_psv.sound_precache[0] = pr_strings;
|
g_psv.sound_precache[0] = pr_strings;
|
||||||
g_psv.model_precache[0] = pr_strings;
|
g_psv.model_precache[0] = pr_strings;
|
||||||
|
#ifndef REHLDS_FIXES
|
||||||
g_psv.generic_precache[0] = pr_strings;
|
g_psv.generic_precache[0] = pr_strings;
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
|
|
||||||
for (i = 1; i < g_psv.worldmodel->numsubmodels; i++)
|
for (i = 1; i < g_psv.worldmodel->numsubmodels; i++)
|
||||||
{
|
{
|
||||||
|
@ -136,8 +136,12 @@ void SV_ParseConsistencyResponse(client_t *pSenderClient)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
resource_t *r = &g_rehlds_sv.resources[idx];
|
||||||
|
#else // REHLDS_FIXES
|
||||||
resource_t *r = &g_psv.resourcelist[idx];
|
resource_t *r = &g_psv.resourcelist[idx];
|
||||||
if (!(g_psv.resourcelist[idx].ucFlags & RES_CHECKFILE))
|
#endif // REHLDS_FIXES
|
||||||
|
if (!(r->ucFlags & RES_CHECKFILE))
|
||||||
{
|
{
|
||||||
c = -1;
|
c = -1;
|
||||||
break;
|
break;
|
||||||
@ -223,12 +227,12 @@ void SV_ParseConsistencyResponse(client_t *pSenderClient)
|
|||||||
#ifdef REHLDS_FIXES
|
#ifdef REHLDS_FIXES
|
||||||
dropmessage[0] = '\0';
|
dropmessage[0] = '\0';
|
||||||
|
|
||||||
if (gEntityInterface.pfnInconsistentFile(host_client->edict, g_psv.resourcelist[c - 1].szFileName, dropmessage))
|
if (gEntityInterface.pfnInconsistentFile(host_client->edict, g_rehlds_sv.resources[c - 1].szFileName, dropmessage))
|
||||||
{
|
{
|
||||||
if (dropmessage[0])
|
if (dropmessage[0])
|
||||||
SV_ClientPrintf("%s", dropmessage);
|
SV_ClientPrintf("%s", dropmessage);
|
||||||
|
|
||||||
SV_DropClient(host_client, FALSE, "Bad file %s", g_psv.resourcelist[c - 1].szFileName); // only filename. reason was printed in console if exists.
|
SV_DropClient(host_client, FALSE, "Bad file %s", g_rehlds_sv.resources[c - 1].szFileName); // only filename. reason was printed in console if exists.
|
||||||
}
|
}
|
||||||
#else // REHLDS_FIXES
|
#else // REHLDS_FIXES
|
||||||
if (gEntityInterface.pfnInconsistentFile(host_client->edict, g_psv.resourcelist[c - 1].szFileName, dropmessage))
|
if (gEntityInterface.pfnInconsistentFile(host_client->edict, g_psv.resourcelist[c - 1].szFileName, dropmessage))
|
||||||
@ -278,7 +282,11 @@ int EXT_FUNC SV_TransferConsistencyInfo_internal(void)
|
|||||||
int c = 0;
|
int c = 0;
|
||||||
for (int i = 0; i < g_psv.num_resources; i++)
|
for (int i = 0; i < g_psv.num_resources; i++)
|
||||||
{
|
{
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
resource_t *r = &g_rehlds_sv.resources[i];
|
||||||
|
#else // REHLDS_FIXES
|
||||||
resource_t *r = &g_psv.resourcelist[i];
|
resource_t *r = &g_psv.resourcelist[i];
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
if (r->ucFlags == (RES_CUSTOM | RES_REQUESTED | RES_UNK_6) || (r->ucFlags & RES_CHECKFILE))
|
if (r->ucFlags == (RES_CUSTOM | RES_REQUESTED | RES_UNK_6) || (r->ucFlags & RES_CHECKFILE))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
@ -345,7 +353,11 @@ void SV_SendConsistencyList(sizebuf_t *msg)
|
|||||||
|
|
||||||
int delta = 0;
|
int delta = 0;
|
||||||
int lastcheck = 0;
|
int lastcheck = 0;
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
resource_t *r = g_rehlds_sv.resources;
|
||||||
|
#else // REHLDS_FIXES
|
||||||
resource_t *r = g_psv.resourcelist;
|
resource_t *r = g_psv.resourcelist;
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
|
|
||||||
MSG_WriteBits(1, 1);
|
MSG_WriteBits(1, 1);
|
||||||
|
|
||||||
|
@ -235,7 +235,11 @@ void EXT_FUNC CRehldsServerData::SetResourcesNum(int num) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct resource_s *EXT_FUNC CRehldsServerData::GetResource(int index) {
|
struct resource_s *EXT_FUNC CRehldsServerData::GetResource(int index) {
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
return &g_rehlds_sv.resources[index];
|
||||||
|
#else // REHLDS_FIXES
|
||||||
return &g_psv.resourcelist[index];
|
return &g_psv.resourcelist[index];
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
}
|
}
|
||||||
|
|
||||||
void Rehlds_Interfaces_FreeClients()
|
void Rehlds_Interfaces_FreeClients()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user