From 65e0e75a8c1e1ec69433609cd8478abe6a31fa91 Mon Sep 17 00:00:00 2001 From: helixhorned Date: Fri, 9 Dec 2011 19:12:15 +0000 Subject: [PATCH] Fix negative array access in premap.c git-svn-id: https://svn.eduke32.com/eduke32@2172 1a8010ca-5511-0410-912e-c29ae57300e0 --- polymer/eduke32/source/premap.c | 46 ++++++++++++++++++--------------- 1 file changed, 25 insertions(+), 21 deletions(-) diff --git a/polymer/eduke32/source/premap.c b/polymer/eduke32/source/premap.c index 4164e91e0..165b5c9e0 100644 --- a/polymer/eduke32/source/premap.c +++ b/polymer/eduke32/source/premap.c @@ -1331,34 +1331,38 @@ static inline void prelevel(char g) { switchpicnum = W_FORCEFIELD; } - switch (DynamicTileMap[switchpicnum]) + + if (switchpicnum >= 0) { - case FANSHADOW__STATIC: - case FANSPRITE__STATIC: - wall->cstat |= 65; - animwall[g_numAnimWalls].wallnum = i; - g_numAnimWalls++; - break; + switch (DynamicTileMap[switchpicnum]) + { + case FANSHADOW__STATIC: + case FANSPRITE__STATIC: + wall->cstat |= 65; + animwall[g_numAnimWalls].wallnum = i; + g_numAnimWalls++; + break; - case W_FORCEFIELD__STATIC: - if (wal->overpicnum==W_FORCEFIELD__STATIC) - for (j=0; j<3; j++) - tloadtile(W_FORCEFIELD+j, 0); - if (wal->shade > 31) - wal->cstat = 0; - else wal->cstat |= 85+256; + case W_FORCEFIELD__STATIC: + if (wal->overpicnum==W_FORCEFIELD__STATIC) + for (j=0; j<3; j++) + tloadtile(W_FORCEFIELD+j, 0); + if (wal->shade > 31) + wal->cstat = 0; + else wal->cstat |= 85+256; - if (wal->lotag && wal->nextwall >= 0) - wall[wal->nextwall].lotag = - wal->lotag; + if (wal->lotag && wal->nextwall >= 0) + wall[wal->nextwall].lotag = + wal->lotag; - case BIGFORCE__STATIC: + case BIGFORCE__STATIC: - animwall[g_numAnimWalls].wallnum = i; - g_numAnimWalls++; + animwall[g_numAnimWalls].wallnum = i; + g_numAnimWalls++; - continue; + continue; + } } wal->extra = -1;