2
0
mirror of https://github.com/rehlds/rehlds.git synced 2025-01-07 12:35:33 +03:00

Merge remote-tracking branch 'remotes/tema/resourcelistextend'

This commit is contained in:
asmodai 2016-02-06 14:25:19 +03:00
commit 5916655edd
5 changed files with 142 additions and 17 deletions

View File

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

View File

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

View File

@ -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++)
{ {

View File

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

View File

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