mirror of
https://github.com/rehlds/rehlds.git
synced 2025-01-04 02:55:50 +03:00
Merge remote-tracking branch 'remotes/tema/autoprecachetextureandanimgroup'
This commit is contained in:
commit
30519ea2ee
@ -1482,41 +1482,6 @@ int EXT_FUNC PF_precache_model_I(const char *s)
|
|||||||
if (!iOptional)
|
if (!iOptional)
|
||||||
g_psv.model_precache_flags[i] |= 1u;
|
g_psv.model_precache_flags[i] |= 1u;
|
||||||
|
|
||||||
#ifdef REHLDS_FIXES
|
|
||||||
if (g_psv.models[i]->type == mod_studio)
|
|
||||||
{
|
|
||||||
studiohdr_t *pStudioHeader = (studiohdr_t *)Mod_Extradata(g_psv.models[i]);
|
|
||||||
|
|
||||||
size_t modelNameLength = Q_strlen(s);
|
|
||||||
if (!pStudioHeader->textureindex && modelNameLength < MAX_QPATH - 1)
|
|
||||||
{
|
|
||||||
char textureModelName[MAX_QPATH];
|
|
||||||
Q_strcpy(textureModelName, s);
|
|
||||||
|
|
||||||
size_t modelExtensionLength = sizeof(".mdl") - 1;
|
|
||||||
char *modelExtension = &textureModelName[modelNameLength - modelExtensionLength];
|
|
||||||
Q_strcpy(modelExtension, "T.mdl");
|
|
||||||
|
|
||||||
PF_precache_model_I(textureModelName);
|
|
||||||
}
|
|
||||||
if (pStudioHeader->numseqgroups)
|
|
||||||
{
|
|
||||||
mstudioseqgroup_t *pSeqGroup = (mstudioseqgroup_t *)((uint8_t *)pStudioHeader + pStudioHeader->seqgroupindex);
|
|
||||||
for (int i = 0; i < pStudioHeader->numseqgroups; i++, pSeqGroup++)
|
|
||||||
{
|
|
||||||
if (pSeqGroup->name[0] == '\0')
|
|
||||||
continue;
|
|
||||||
|
|
||||||
char seqGroupName[MAX_QPATH];
|
|
||||||
Q_strcpy(seqGroupName, pSeqGroup->name);
|
|
||||||
ForwardSlashes(seqGroupName);
|
|
||||||
|
|
||||||
PF_precache_generic_I(seqGroupName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif // REHLDS_FIXES
|
|
||||||
|
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -531,6 +531,7 @@ extern cvar_t sv_allow_dlfile;
|
|||||||
extern cvar_t sv_version;
|
extern cvar_t sv_version;
|
||||||
#ifdef REHLDS_FIXES
|
#ifdef REHLDS_FIXES
|
||||||
extern cvar_t sv_echo_unknown_cmd;
|
extern cvar_t sv_echo_unknown_cmd;
|
||||||
|
extern cvar_t sv_auto_precache_sounds_in_models;
|
||||||
#endif
|
#endif
|
||||||
extern int sv_playermodel;
|
extern int sv_playermodel;
|
||||||
|
|
||||||
|
@ -200,6 +200,7 @@ cvar_t sv_allow_dlfile = { "sv_allow_dlfile", "1", 0, 0.0f, NULL };
|
|||||||
#ifdef REHLDS_FIXES
|
#ifdef REHLDS_FIXES
|
||||||
cvar_t sv_version = { "sv_version", "", FCVAR_SERVER, 0.0f, NULL };
|
cvar_t sv_version = { "sv_version", "", FCVAR_SERVER, 0.0f, NULL };
|
||||||
cvar_t sv_echo_unknown_cmd = { "sv_echo_unknown_cmd", "0", 0, 0.0f, NULL };
|
cvar_t sv_echo_unknown_cmd = { "sv_echo_unknown_cmd", "0", 0, 0.0f, NULL };
|
||||||
|
cvar_t sv_auto_precache_sounds_in_models = { "sv_auto_precache_sounds_in_models", "0", 0, 0.0f, nullptr };
|
||||||
#else
|
#else
|
||||||
cvar_t sv_version = {"sv_version", "", 0, 0.0f, NULL};
|
cvar_t sv_version = {"sv_version", "", 0, 0.0f, NULL};
|
||||||
#endif
|
#endif
|
||||||
@ -5409,6 +5410,83 @@ void SetCStrikeFlags(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
void PrecacheModelTexture(const char *s, studiohdr_t *pStudioHeader)
|
||||||
|
{
|
||||||
|
if (pStudioHeader->textureindex)
|
||||||
|
return;
|
||||||
|
|
||||||
|
size_t modelNameLength = Q_strlen(s);
|
||||||
|
if (modelNameLength >= MAX_QPATH - 1)
|
||||||
|
return;
|
||||||
|
|
||||||
|
char textureModelName[MAX_QPATH];
|
||||||
|
Q_strcpy(textureModelName, s);
|
||||||
|
|
||||||
|
size_t modelExtensionLength = sizeof(".mdl") - 1;
|
||||||
|
char *modelExtension = &textureModelName[modelNameLength - modelExtensionLength];
|
||||||
|
Q_strcpy(modelExtension, "T.mdl");
|
||||||
|
|
||||||
|
// Use generic, because model max count is 512...
|
||||||
|
PF_precache_generic_I(textureModelName);
|
||||||
|
}
|
||||||
|
|
||||||
|
void PrecacheModelSeqGroups(studiohdr_t *pStudioHeader)
|
||||||
|
{
|
||||||
|
// 0 seqgroup is reserved for sequences in this model
|
||||||
|
if (pStudioHeader->numseqgroups <= 1)
|
||||||
|
return;
|
||||||
|
|
||||||
|
mstudioseqgroup_t *pSeqGroup = (mstudioseqgroup_t *)((uint8_t *)pStudioHeader + pStudioHeader->seqgroupindex);
|
||||||
|
for (int i = 1; i < pStudioHeader->numseqgroups; i++)
|
||||||
|
{
|
||||||
|
if (pSeqGroup[i].name[0] == '\0')
|
||||||
|
continue;
|
||||||
|
|
||||||
|
char seqGroupName[MAX_QPATH];
|
||||||
|
Q_strcpy(seqGroupName, pSeqGroup[i].name);
|
||||||
|
|
||||||
|
ForwardSlashes(seqGroupName);
|
||||||
|
PF_precache_generic_I(seqGroupName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void PrecacheModelSounds(studiohdr_t *pStudioHeader)
|
||||||
|
{
|
||||||
|
mstudioseqdesc_t *pSeqDesc = (mstudioseqdesc_t *)((uintptr_t)pStudioHeader + pStudioHeader->seqindex);
|
||||||
|
for (int index = 0; index < pStudioHeader->numseq; index++)
|
||||||
|
{
|
||||||
|
mstudioevent_t *pEvent = (mstudioevent_t *)((uintptr_t)pStudioHeader + pSeqDesc[index].eventindex);
|
||||||
|
for (int i = 0; i < pSeqDesc[index].numevents; i++)
|
||||||
|
{
|
||||||
|
if (pEvent[i].event != 5004)
|
||||||
|
continue;
|
||||||
|
if (pEvent[i].options[0] == '\0')
|
||||||
|
continue;
|
||||||
|
|
||||||
|
PF_precache_generic_I(va("sound/%s", pEvent[i].options));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void PrecacheModelSpecifiedFiles()
|
||||||
|
{
|
||||||
|
const char **s = &g_psv.model_precache[1];
|
||||||
|
for (size_t i = 1; i < ARRAYSIZE(g_psv.model_precache) && *s != nullptr; i++, s++)
|
||||||
|
{
|
||||||
|
if (g_psv.models[i]->type != mod_studio)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
studiohdr_t *pStudioHeader = (studiohdr_t *)Mod_Extradata(g_psv.models[i]);
|
||||||
|
|
||||||
|
PrecacheModelTexture(*s, pStudioHeader);
|
||||||
|
PrecacheModelSeqGroups(pStudioHeader);
|
||||||
|
if (sv_auto_precache_sounds_in_models.value)
|
||||||
|
PrecacheModelSounds(pStudioHeader);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
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);
|
||||||
@ -5438,6 +5516,10 @@ void EXT_FUNC SV_ActivateServer_internal(int runPhysics)
|
|||||||
gEntityInterface.pfnServerActivate(g_psv.edicts, g_psv.num_edicts, g_psvs.maxclients);
|
gEntityInterface.pfnServerActivate(g_psv.edicts, g_psv.num_edicts, g_psvs.maxclients);
|
||||||
Steam_Activate();
|
Steam_Activate();
|
||||||
ContinueLoadingProgressBar("Server", 9, 0.0f);
|
ContinueLoadingProgressBar("Server", 9, 0.0f);
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
// Precache after all models and sounds is precached, because we use PrecacheGeneric, which checks is that resource already precached as model or sound
|
||||||
|
PrecacheModelSpecifiedFiles();
|
||||||
|
#endif
|
||||||
SV_CreateGenericResources();
|
SV_CreateGenericResources();
|
||||||
g_psv.active = TRUE;
|
g_psv.active = TRUE;
|
||||||
g_psv.state = ss_active;
|
g_psv.state = ss_active;
|
||||||
@ -7230,6 +7312,7 @@ void SV_Init(void)
|
|||||||
#ifdef REHLDS_FIXES
|
#ifdef REHLDS_FIXES
|
||||||
Cvar_RegisterVariable(&sv_force_ent_intersection);
|
Cvar_RegisterVariable(&sv_force_ent_intersection);
|
||||||
Cvar_RegisterVariable(&sv_echo_unknown_cmd);
|
Cvar_RegisterVariable(&sv_echo_unknown_cmd);
|
||||||
|
Cvar_RegisterVariable(&sv_auto_precache_sounds_in_models);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (int i = 0; i < MAX_MODELS; i++)
|
for (int i = 0; i < MAX_MODELS; i++)
|
||||||
|
Loading…
Reference in New Issue
Block a user