mirror of
https://github.com/rehlds/rehlds.git
synced 2025-01-01 01:25:38 +03:00
HLTV: Closed #657
HLDS: Moved check to limit of leafs into SV_SpawnServer function.
This commit is contained in:
parent
0c8d3d76ac
commit
a0926eda44
@ -175,12 +175,7 @@ byte *BSPModel::DecompressVis(unsigned char *in)
|
|||||||
return m_novis;
|
return m_novis;
|
||||||
}
|
}
|
||||||
|
|
||||||
int row = (m_model.numleafs + 7) / 8;
|
DecompressPVS(in, decompressed, (m_model.numleafs + 7) / 8);
|
||||||
if (row < 0 || row > MODEL_MAX_PVS) {
|
|
||||||
m_System->Errorf("BSPModel::DecompressVis: oversized m_model.numleafs: %i\n", m_model.numleafs);
|
|
||||||
}
|
|
||||||
|
|
||||||
DecompressPVS(in, decompressed, row);
|
|
||||||
return decompressed;
|
return decompressed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,18 +47,8 @@ unsigned char *Mod_DecompressVis(unsigned char *in, model_t *model)
|
|||||||
{
|
{
|
||||||
return mod_novis;
|
return mod_novis;
|
||||||
}
|
}
|
||||||
#ifdef REHLDS_FIXES
|
|
||||||
CM_DecompressPVS(in, decompressed, (model->numleafs + 7) / 8);
|
CM_DecompressPVS(in, decompressed, (model->numleafs + 7) / 8);
|
||||||
#else
|
|
||||||
int row = (model->numleafs + 7) / 8;
|
|
||||||
|
|
||||||
if (row < 0 || row > MODEL_MAX_PVS)
|
|
||||||
{
|
|
||||||
Sys_Error("%s: oversized model->numleafs: %i", __func__, model->numleafs);
|
|
||||||
}
|
|
||||||
|
|
||||||
CM_DecompressPVS(in, decompressed, row);
|
|
||||||
#endif
|
|
||||||
return decompressed;
|
return decompressed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1036,18 +1036,7 @@ void Mod_LoadLeafs(lump_t *l)
|
|||||||
|
|
||||||
loadmodel->leafs = out;
|
loadmodel->leafs = out;
|
||||||
loadmodel->numleafs = count;
|
loadmodel->numleafs = count;
|
||||||
#ifdef REHLDS_FIXES
|
|
||||||
// Originally check was called only in singleplayer mode, that is why this "if" here (see Mod_LeafPVS, gPVS is not NULL for multiplayer)
|
|
||||||
if (g_psvs.maxclients <= 1)
|
|
||||||
{
|
|
||||||
int row = (loadmodel->numleafs + 7) / 8;
|
|
||||||
|
|
||||||
if (row < 0 || row > MODEL_MAX_PVS)
|
|
||||||
{
|
|
||||||
Sys_Error("%s: oversized loadmodel->numleafs: %i", __func__, loadmodel->numleafs);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
for (i = 0; i < count; i++, in++, out++)
|
for (i = 0; i < count; i++, in++, out++)
|
||||||
{
|
{
|
||||||
for (j = 0; j < 3; j++)
|
for (j = 0; j < 3; j++)
|
||||||
|
@ -6041,6 +6041,18 @@ int SV_SpawnServer(qboolean bIsDemo, char *server, char *startspot)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
// Originally check was called only in singleplayer mode, that is why this "if" here (see Mod_LeafPVS, gPVS is not NULL for multiplayer)
|
||||||
|
if (g_psvs.maxclients <= 1)
|
||||||
|
{
|
||||||
|
int row = (g_psv.worldmodel->numleafs + 7) / 8;
|
||||||
|
if (row < 0 || row > MODEL_MAX_PVS)
|
||||||
|
{
|
||||||
|
Sys_Error("%s: oversized g_psv.worldmodel->numleafs: %i", __func__, g_psv.worldmodel->numleafs);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
Sequence_OnLevelLoad(server);
|
Sequence_OnLevelLoad(server);
|
||||||
ContinueLoadingProgressBar("Server", 4, 0.0);
|
ContinueLoadingProgressBar("Server", 4, 0.0);
|
||||||
if (gmodinfo.clientcrccheck)
|
if (gmodinfo.clientcrccheck)
|
||||||
|
Loading…
Reference in New Issue
Block a user