mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 08:50:55 +00:00
Various stylistic cleanup.
- Move ARRAY_SIZE() macro to compat.h, add another one ARRAY_SSIZE() - In A_RadiusDamage(): note maybe-unaligned access issue, prevent unlikely oob - sector.c: use SPRITES_OF* macros where appropriate git-svn-id: https://svn.eduke32.com/eduke32@4199 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
9e4f10f3e1
commit
ee9e84c356
4 changed files with 34 additions and 43 deletions
|
@ -777,5 +777,8 @@ static inline void append_ext_UNSAFE(char *outbuf, const char *ext)
|
||||||
extern void EDUKE32_ASSERT_NAME(__LINE__)(int STATIC_ASSERTION_FAILED[(cond)?1:-1])
|
extern void EDUKE32_ASSERT_NAME(__LINE__)(int STATIC_ASSERTION_FAILED[(cond)?1:-1])
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define ARRAY_SIZE(Ar) (sizeof(Ar)/sizeof((Ar)[0]))
|
||||||
|
#define ARRAY_SSIZE(Ar) (bssize_t)ARRAY_SIZE(Ar)
|
||||||
|
|
||||||
#endif // __compat_h__
|
#endif // __compat_h__
|
||||||
|
|
||||||
|
|
|
@ -117,7 +117,9 @@ void A_RadiusDamage(int32_t i, int32_t r, int32_t hp1, int32_t hp2, int32_t hp3,
|
||||||
STAT_PLAYER, STAT_FALLER, STAT_ZOMBIEACTOR, STAT_MISC
|
STAT_PLAYER, STAT_FALLER, STAT_ZOMBIEACTOR, STAT_MISC
|
||||||
};
|
};
|
||||||
|
|
||||||
int16_t *const tempshort = (int16_t *)tempbuf;
|
// XXX: accesses to 'sectorlist' potentially unaligned
|
||||||
|
int16_t *const sectorlist = (int16_t *)tempbuf;
|
||||||
|
const int32_t maxsects = sizeof(tempbuf)/sizeof(int16_t);
|
||||||
|
|
||||||
if (s->picnum == RPG && s->xrepeat < 11)
|
if (s->picnum == RPG && s->xrepeat < 11)
|
||||||
goto SKIPWALLCHECK;
|
goto SKIPWALLCHECK;
|
||||||
|
@ -127,12 +129,12 @@ void A_RadiusDamage(int32_t i, int32_t r, int32_t hp1, int32_t hp2, int32_t hp3,
|
||||||
int32_t sectcnt = 0;
|
int32_t sectcnt = 0;
|
||||||
int32_t sectend = 1;
|
int32_t sectend = 1;
|
||||||
|
|
||||||
tempshort[0] = s->sectnum;
|
sectorlist[0] = s->sectnum;
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
const walltype *wal;
|
const walltype *wal;
|
||||||
const int32_t dasect = tempshort[sectcnt++];
|
const int32_t dasect = sectorlist[sectcnt++];
|
||||||
const int32_t startwall = sector[dasect].wallptr;
|
const int32_t startwall = sector[dasect].wallptr;
|
||||||
const int32_t endwall = startwall+sector[dasect].wallnum;
|
const int32_t endwall = startwall+sector[dasect].wallnum;
|
||||||
int32_t w;
|
int32_t w;
|
||||||
|
@ -163,11 +165,15 @@ void A_RadiusDamage(int32_t i, int32_t r, int32_t hp1, int32_t hp2, int32_t hp3,
|
||||||
{
|
{
|
||||||
int32_t dasect2;
|
int32_t dasect2;
|
||||||
for (dasect2=sectend-1; dasect2>=0; dasect2--)
|
for (dasect2=sectend-1; dasect2>=0; dasect2--)
|
||||||
if (tempshort[dasect2] == nextsect)
|
if (sectorlist[dasect2] == nextsect)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (dasect2 < 0)
|
if (dasect2 < 0)
|
||||||
tempshort[sectend++] = nextsect;
|
{
|
||||||
|
if (sectend == maxsects)
|
||||||
|
goto SKIPWALLCHECK; // prevent oob access of 'sectorlist'
|
||||||
|
sectorlist[sectend++] = nextsect;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
x1 = (((wal->x+wall[wal->point2].x)>>1)+s->x)>>1;
|
x1 = (((wal->x+wall[wal->point2].x)>>1)+s->x)>>1;
|
||||||
|
@ -189,7 +195,7 @@ SKIPWALLCHECK:
|
||||||
|
|
||||||
q = -(16<<8) + (krand()&((32<<8)-1));
|
q = -(16<<8) + (krand()&((32<<8)-1));
|
||||||
|
|
||||||
for (stati=0; stati<7; stati++) // TODO: ARRAY_SIZE
|
for (stati=0; stati < ARRAY_SSIZE(statlist); stati++)
|
||||||
{
|
{
|
||||||
int32_t j = headspritestat[statlist[stati]];
|
int32_t j = headspritestat[statlist[stati]];
|
||||||
|
|
||||||
|
|
|
@ -1816,8 +1816,6 @@ static void G_DrawWeaponTile(int32_t x, int32_t y, int32_t tilenum, int32_t shad
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define ARRAY_SIZE(Ar) (sizeof(Ar)/sizeof((Ar)[0]))
|
|
||||||
|
|
||||||
static int32_t P_DisplayKnee(int32_t gs,int32_t snum)
|
static int32_t P_DisplayKnee(int32_t gs,int32_t snum)
|
||||||
{
|
{
|
||||||
static const int8_t knee_y[] = {0,-8,-16,-32,-64,-84,-108,-108,-108,-72,-32,-8};
|
static const int8_t knee_y[] = {0,-8,-16,-32,-64,-84,-108,-108,-108,-72,-32,-8};
|
||||||
|
|
|
@ -1844,10 +1844,12 @@ void A_DamageWall(int32_t spr,int32_t dawallnum,const vec3_t *pos,int32_t atwith
|
||||||
if (wal->picnum == TECHLIGHT4)
|
if (wal->picnum == TECHLIGHT4)
|
||||||
wal->picnum = TECHLIGHTBUST4;
|
wal->picnum = TECHLIGHTBUST4;
|
||||||
|
|
||||||
if (!wal->lotag) return;
|
if (wal->lotag == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
sn = wal->nextsector;
|
sn = wal->nextsector;
|
||||||
if (sn < 0) return;
|
if (sn < 0)
|
||||||
|
return;
|
||||||
darkestwall = 0;
|
darkestwall = 0;
|
||||||
|
|
||||||
wal = &wall[sector[sn].wallptr];
|
wal = &wall[sector[sn].wallptr];
|
||||||
|
@ -1856,17 +1858,15 @@ void A_DamageWall(int32_t spr,int32_t dawallnum,const vec3_t *pos,int32_t atwith
|
||||||
darkestwall=wal->shade;
|
darkestwall=wal->shade;
|
||||||
|
|
||||||
j = krand()&1;
|
j = krand()&1;
|
||||||
i= headspritestat[STAT_EFFECTOR];
|
|
||||||
while (i >= 0)
|
for (SPRITES_OF(STAT_EFFECTOR, i))
|
||||||
{
|
|
||||||
if (SHT == wall[dawallnum].lotag && SLT == SE_3_RANDOM_LIGHTS_AFTER_SHOT_OUT)
|
if (SHT == wall[dawallnum].lotag && SLT == SE_3_RANDOM_LIGHTS_AFTER_SHOT_OUT)
|
||||||
{
|
{
|
||||||
T3 = j;
|
T3 = j;
|
||||||
T4 = darkestwall;
|
T4 = darkestwall;
|
||||||
T5 = 1;
|
T5 = 1;
|
||||||
}
|
}
|
||||||
i = nextspritestat[i];
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1906,37 +1906,28 @@ int32_t Sect_DamageCeiling(int32_t sn)
|
||||||
sector[sn].ceilingpicnum = TECHLIGHTBUST4;
|
sector[sn].ceilingpicnum = TECHLIGHTBUST4;
|
||||||
|
|
||||||
|
|
||||||
if (!sector[sn].hitag)
|
if (sector[sn].hitag == 0)
|
||||||
{
|
{
|
||||||
i = headspritesect[sn];
|
for (SPRITES_OF_SECT(sn, i))
|
||||||
while (i >= 0)
|
|
||||||
{
|
{
|
||||||
if (PN == SECTOREFFECTOR && SLT == SE_12_LIGHT_SWITCH)
|
if (PN == SECTOREFFECTOR && SLT == SE_12_LIGHT_SWITCH)
|
||||||
{
|
{
|
||||||
j = headspritestat[STAT_EFFECTOR];
|
for (SPRITES_OF(STAT_EFFECTOR, j))
|
||||||
while (j >= 0)
|
|
||||||
{
|
|
||||||
if (sprite[j].hitag == SHT)
|
if (sprite[j].hitag == SHT)
|
||||||
actor[j].t_data[3] = 1;
|
actor[j].t_data[3] = 1;
|
||||||
j = nextspritestat[j];
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
i = nextspritesect[i];
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
i = headspritestat[STAT_EFFECTOR];
|
|
||||||
j = krand()&1;
|
j = krand()&1;
|
||||||
while (i >= 0)
|
|
||||||
{
|
for (SPRITES_OF(STAT_EFFECTOR, i))
|
||||||
if (SHT == (sector[sn].hitag) && SLT == SE_3_RANDOM_LIGHTS_AFTER_SHOT_OUT)
|
if (SHT == sector[sn].hitag && SLT == SE_3_RANDOM_LIGHTS_AFTER_SHOT_OUT)
|
||||||
{
|
{
|
||||||
T3 = j;
|
T3 = j;
|
||||||
T5 = 1;
|
T5 = 1;
|
||||||
}
|
}
|
||||||
i = nextspritestat[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -2413,28 +2404,21 @@ void A_DamageObject(int32_t i,int32_t sn)
|
||||||
|
|
||||||
void G_AlignWarpElevators(void)
|
void G_AlignWarpElevators(void)
|
||||||
{
|
{
|
||||||
int32_t j, i = headspritestat[STAT_EFFECTOR];
|
int32_t i, j;
|
||||||
|
|
||||||
while (i >= 0)
|
for (SPRITES_OF(STAT_EFFECTOR, i))
|
||||||
{
|
{
|
||||||
if (SLT == SE_17_WARP_ELEVATOR && SS > 16)
|
if (SLT == SE_17_WARP_ELEVATOR && SS > 16)
|
||||||
{
|
{
|
||||||
j = headspritestat[STAT_EFFECTOR];
|
for (SPRITES_OF(STAT_EFFECTOR, j))
|
||||||
while (j >= 0)
|
|
||||||
{
|
{
|
||||||
if ((sprite[j].lotag) == SE_17_WARP_ELEVATOR && i != j &&
|
if (i != j && sprite[j].lotag == SE_17_WARP_ELEVATOR && SHT == sprite[j].hitag)
|
||||||
(SHT) == (sprite[j].hitag))
|
|
||||||
{
|
{
|
||||||
sector[sprite[j].sectnum].floorz =
|
sector[sprite[j].sectnum].floorz = sector[SECT].floorz;
|
||||||
sector[SECT].floorz;
|
sector[sprite[j].sectnum].ceilingz = sector[SECT].ceilingz;
|
||||||
sector[sprite[j].sectnum].ceilingz =
|
|
||||||
sector[SECT].ceilingz;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
j = nextspritestat[j];
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
i = nextspritestat[i];
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue