mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 11:10:39 +00:00
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:
parent
36c03b8610
commit
b9dfcc902d
1 changed files with 12 additions and 5 deletions
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue