game.c: read sprites-on-screen count for DNDEBUG at end of G_DoSpriteAnimations.

Because that function might have inserted tsprites itself, e.g. for the fake
floor shadow. Also add one "spritesortcnt < MAXSPRITESONSCREEN" bound check
in legacy ROR code.

git-svn-id: https://svn.eduke32.com/eduke32@3952 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
helixhorned 2013-07-13 21:04:55 +00:00
parent 36c03b8610
commit b9dfcc902d

View file

@ -4131,7 +4131,7 @@ static void G_SE40(int32_t smoothratio)
{ {
int32_t k = headspritesect[sp->sectnum]; int32_t k = headspritesect[sp->sectnum];
while (k != -1) while (k != -1 && spritesortcnt < MAXSPRITESONSCREEN)
{ {
if (sprite[k].picnum != SECTOREFFECTOR && (sprite[k].z >= sp->z)) if (sprite[k].picnum != SECTOREFFECTOR && (sprite[k].z >= sp->z))
{ {
@ -7066,11 +7066,13 @@ void G_DoSpriteAnimations(int32_t ourx, int32_t oury, int32_t oura, int32_t smoo
int32_t j, k, p, sect; int32_t j, k, p, sect;
intptr_t l; intptr_t l;
#ifdef DEBUGGINGAIDS
g_spriteStat.numonscreen = spritesortcnt;
#endif
if (spritesortcnt == 0) if (spritesortcnt == 0)
{
#ifdef DEBUGGINGAIDS
g_spriteStat.numonscreen = 0;
#endif
return; return;
}
ror_sprite = -1; ror_sprite = -1;
@ -7684,6 +7686,7 @@ PALONLY:
#if !defined LUNATIC #if !defined LUNATIC
skip: skip:
#endif #endif
// Night vision goggles tsprite tinting.
// XXX: Currently, for the splitscreen mod, sprites will be pal6-colored iff the first // XXX: Currently, for the splitscreen mod, sprites will be pal6-colored iff the first
// player has nightvision on. We should pass stuff like "from which player is this view // player has nightvision on. We should pass stuff like "from which player is this view
// supposed to be" as parameters ("drawing context") instead of relying on globals. // supposed to be" as parameters ("drawing context") instead of relying on globals.
@ -7694,6 +7697,7 @@ skip:
t->shade = 0; t->shade = 0;
} }
// Fake floor shadow, implemented by inserting a new tsprite.
if (s->statnum == STAT_DUMMYPLAYER || A_CheckEnemySprite(s) || A_CheckSpriteFlags(t->owner,SPRITE_SHADOW) || (s->picnum == APLAYER && s->owner >= 0)) if (s->statnum == STAT_DUMMYPLAYER || A_CheckEnemySprite(s) || A_CheckSpriteFlags(t->owner,SPRITE_SHADOW) || (s->picnum == APLAYER && s->owner >= 0))
if (t->statnum != TSPR_TEMP && s->picnum != EXPLOSION2 && s->picnum != HANGLIGHT && s->picnum != DOMELITE && s->picnum != HOTMEAT) if (t->statnum != TSPR_TEMP && s->picnum != EXPLOSION2 && s->picnum != HANGLIGHT && s->picnum != DOMELITE && s->picnum != HOTMEAT)
{ {
@ -7716,7 +7720,7 @@ skip:
int32_t daz; int32_t daz;
if ((sector[sect].lotag&0xff) > 2 || s->statnum == STAT_PROJECTILE || s->statnum == STAT_MISC if ((sector[sect].lotag&0xff) > 2 || s->statnum == STAT_PROJECTILE || s->statnum == STAT_MISC
|| s->picnum == DRONE || s->picnum == COMMANDER) || s->picnum == DRONE || s->picnum == COMMANDER)
daz = sector[sect].floorz; daz = sector[sect].floorz;
else else
daz = actor[i].floorz; daz = actor[i].floorz;
@ -7894,6 +7898,9 @@ skip:
if (G_HaveEvent(EVENT_ANIMATEALLSPRITES)) if (G_HaveEvent(EVENT_ANIMATEALLSPRITES))
VM_OnEvent(EVENT_ANIMATEALLSPRITES, -1, -1, -1, 0); VM_OnEvent(EVENT_ANIMATEALLSPRITES, -1, -1, -1, 0);
#endif #endif
#ifdef DEBUGGINGAIDS
g_spriteStat.numonscreen = spritesortcnt;
#endif
} }