mirror of
https://github.com/rehlds/rehlds.git
synced 2025-01-03 18:45:46 +03:00
SV_WriteEntitiesToClient: don't use intermediate 'fullpack' storage for entities being transmitted
SV_SetupMove: Don't look examine frame->entities after last player
This commit is contained in:
parent
ed6e5b4a94
commit
f2fe5a6c74
@ -4385,7 +4385,7 @@ void SV_EmitPings(client_t *client, sizebuf_t *msg)
|
|||||||
/* <a947b> ../engine/sv_main.c:5878 */
|
/* <a947b> ../engine/sv_main.c:5878 */
|
||||||
void SV_WriteEntitiesToClient(client_t *client, sizebuf_t *msg)
|
void SV_WriteEntitiesToClient(client_t *client, sizebuf_t *msg)
|
||||||
{
|
{
|
||||||
full_packet_entities_t fullpack;
|
|
||||||
client_frame_t *frame = &client->frames[SV_UPDATE_MASK & client->netchan.outgoing_sequence];
|
client_frame_t *frame = &client->frames[SV_UPDATE_MASK & client->netchan.outgoing_sequence];
|
||||||
|
|
||||||
unsigned char *pvs = NULL;
|
unsigned char *pvs = NULL;
|
||||||
@ -4393,72 +4393,68 @@ void SV_WriteEntitiesToClient(client_t *client, sizebuf_t *msg)
|
|||||||
gEntityInterface.pfnSetupVisibility((edict_t*)client->pViewEntity, client->edict, &pvs, &pas);
|
gEntityInterface.pfnSetupVisibility((edict_t*)client->pViewEntity, client->edict, &pvs, &pas);
|
||||||
unsigned char *pSet = pvs;
|
unsigned char *pSet = pvs;
|
||||||
|
|
||||||
#ifndef REHLDS_FIXES
|
|
||||||
// don't reallocate entity states
|
|
||||||
SV_ClearPacketEntities(frame);
|
|
||||||
#endif // REHLDS_FIXES
|
|
||||||
packet_entities_t *pack = &frame->entities;
|
packet_entities_t *pack = &frame->entities;
|
||||||
|
|
||||||
|
// for REHLDS_FIXES: Allocate the MAX_PACKET_ENTITIES ents in the frame's storage
|
||||||
|
// This allows us to avoid intermediate 'fullpack' storage
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
SV_AllocPacketEntities(frame, MAX_PACKET_ENTITIES);
|
||||||
|
packet_entities_t *curPack = &frame->entities;
|
||||||
|
curPack->num_entities = 0;
|
||||||
|
#else
|
||||||
|
SV_ClearPacketEntities(frame);
|
||||||
|
full_packet_entities_t fullpack;
|
||||||
fullpack.num_entities = 0;
|
fullpack.num_entities = 0;
|
||||||
|
full_packet_entities_t* curPack = &fullpack;
|
||||||
|
#endif // REHLDS_FIXES
|
||||||
|
|
||||||
qboolean sendping = SV_ShouldUpdatePing(client);
|
qboolean sendping = SV_ShouldUpdatePing(client);
|
||||||
|
|
||||||
int flags = client->lw != 0;
|
int flags = client->lw != 0;
|
||||||
|
|
||||||
#ifdef REHLDS_FIXES
|
|
||||||
int e;
|
int e;
|
||||||
|
|
||||||
for (e = 1; e <= g_psvs.maxclients; e++)
|
for (e = 1; e <= g_psvs.maxclients; e++)
|
||||||
{
|
{
|
||||||
client_t *cl = &g_psvs.clients[e - 1];
|
client_t *cl = &g_psvs.clients[e - 1];
|
||||||
if( ( !cl->active && !cl->spawned ) || cl->proxy )
|
if( ( !cl->active && !cl->spawned ) || cl->proxy )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
qboolean add = gEntityInterface.pfnAddToFullPack(&fullpack.entities[fullpack.num_entities], e, &g_psv.edicts[e], host_client->edict, flags, TRUE, pSet);
|
qboolean add = gEntityInterface.pfnAddToFullPack(&curPack->entities[curPack->num_entities], e, &g_psv.edicts[e], host_client->edict, flags, TRUE, pSet);
|
||||||
if (add)
|
if (add)
|
||||||
++fullpack.num_entities;
|
++curPack->num_entities;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (; e < g_psv.num_edicts; e++)
|
for (; e < g_psv.num_edicts; e++)
|
||||||
{
|
{
|
||||||
if (fullpack.num_entities >= MAX_PACKET_ENTITIES)
|
if (curPack->num_entities >= MAX_PACKET_ENTITIES)
|
||||||
{
|
{
|
||||||
Con_DPrintf("Too many entities in visible packet list.\n");
|
Con_DPrintf("Too many entities in visible packet list.\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
edict_t* ent = &g_psv.edicts[e];
|
||||||
|
|
||||||
|
#ifdef REHLDS_FIXES
|
||||||
|
//Part of gamedll's code is moved here to decrease amount of calls to AddToFullPack()
|
||||||
|
//We don't even try to transmit entities without model as well as invisible entities
|
||||||
|
if (ent->v.modelindex && !(ent->v.effects & EF_NODRAW)) {
|
||||||
|
qboolean add = gEntityInterface.pfnAddToFullPack(&curPack->entities[curPack->num_entities], e, &g_psv.edicts[e], host_client->edict, flags, FALSE, pSet);
|
||||||
|
if (add)
|
||||||
|
++curPack->num_entities;
|
||||||
|
}
|
||||||
|
#else
|
||||||
qboolean add = gEntityInterface.pfnAddToFullPack(&fullpack.entities[fullpack.num_entities], e, &g_psv.edicts[e], host_client->edict, flags, FALSE, pSet);
|
qboolean add = gEntityInterface.pfnAddToFullPack(&fullpack.entities[fullpack.num_entities], e, &g_psv.edicts[e], host_client->edict, flags, FALSE, pSet);
|
||||||
if (add)
|
if (add)
|
||||||
++fullpack.num_entities;
|
++fullpack.num_entities;
|
||||||
}
|
#endif
|
||||||
#else // REHLDS_FIXES
|
|
||||||
for (int e = 1; e < g_psv.num_edicts; e++)
|
|
||||||
{
|
|
||||||
edict_t *ent = &g_psv.edicts[e];
|
|
||||||
int player = 0;
|
|
||||||
if (e >= 1 && e <= g_psvs.maxclients)
|
|
||||||
{
|
|
||||||
client_t *cl = &g_psvs.clients[e - 1];
|
|
||||||
if ((!cl->active && !cl->spawned) || cl->proxy)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
player = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fullpack.num_entities >= MAX_PACKET_ENTITIES)
|
//for REHLDS_FIXES: Entities are already in the frame's storage, no need to copy them
|
||||||
{
|
#ifndef REHLDS_FIXES
|
||||||
Con_DPrintf("Too many entities in visible packet list.\n");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
qboolean add = gEntityInterface.pfnAddToFullPack(&fullpack.entities[fullpack.num_entities], e, ent, host_client->edict, flags, player, pSet);
|
|
||||||
if (add)
|
|
||||||
++fullpack.num_entities;
|
|
||||||
}
|
|
||||||
#endif // REHLDS_FIXES
|
|
||||||
|
|
||||||
SV_AllocPacketEntities(frame, fullpack.num_entities);
|
SV_AllocPacketEntities(frame, fullpack.num_entities);
|
||||||
if (pack->num_entities)
|
if (pack->num_entities)
|
||||||
Q_memcpy(pack->entities, fullpack.entities, sizeof(entity_state_t) * pack->num_entities);
|
Q_memcpy(pack->entities, fullpack.entities, sizeof(entity_state_t) * pack->num_entities);
|
||||||
|
#endif
|
||||||
|
|
||||||
SV_EmitPacketEntities(client, pack, msg);
|
SV_EmitPacketEntities(client, pack, msg);
|
||||||
SV_EmitEvents(client, pack, msg);
|
SV_EmitEvents(client, pack, msg);
|
||||||
|
@ -1226,8 +1226,17 @@ void SV_SetupMove(client_t *_host_client)
|
|||||||
for (int j = 0; j < nextFrame->entities.num_entities; j++)
|
for (int j = 0; j < nextFrame->entities.num_entities; j++)
|
||||||
{
|
{
|
||||||
state = &nextFrame->entities.entities[j];
|
state = &nextFrame->entities.entities[j];
|
||||||
|
|
||||||
|
#ifdef REHLDS_OPT_PEDANTIC
|
||||||
|
if (state->number <= 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (state->number > g_psvs.maxclients)
|
||||||
|
break; // players are always in the beginning of the list, no need to look more
|
||||||
|
#else
|
||||||
if (state->number <= 0 || state->number > g_psvs.maxclients)
|
if (state->number <= 0 || state->number > g_psvs.maxclients)
|
||||||
continue;
|
continue;
|
||||||
|
#endif
|
||||||
|
|
||||||
pos = &truepositions[state->number - 1];
|
pos = &truepositions[state->number - 1];
|
||||||
if (pos->deadflag)
|
if (pos->deadflag)
|
||||||
|
Loading…
Reference in New Issue
Block a user