Fix two Polymer crashes related to corrupted maps.

git-svn-id: https://svn.eduke32.com/eduke32@4471 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
hendricks266 2014-05-17 12:36:03 +00:00
parent 5f3921fa93
commit 20bf310cba

View file

@ -2884,7 +2884,7 @@ static void polymer_updatewall(int16_t wallnum)
w = prwalls[wallnum]; w = prwalls[wallnum];
s = prsectors[sectofwall]; s = prsectors[sectofwall];
invalid = s->invalidid; invalid = s->invalidid;
if (nwallnum >= 0 && nwallnum < numwalls) if (nwallnum >= 0 && nwallnum < numwalls && wal->nextsector >= 0 && wal->nextsector < numsectors)
{ {
ns = prsectors[wal->nextsector]; ns = prsectors[wal->nextsector];
invalid += ns->invalidid; invalid += ns->invalidid;
@ -2969,7 +2969,7 @@ static void polymer_updatewall(int16_t wallnum)
else else
xref = 0; xref = 0;
if (wal->nextsector < 0 || wal->nextsector >= numsectors) if (wal->nextsector < 0 || wal->nextsector >= numsectors || !ns)
{ {
Bmemcpy(w->wall.buffer, &s->floor.buffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3); Bmemcpy(w->wall.buffer, &s->floor.buffer[(wallnum - sec->wallptr) * 5], sizeof(GLfloat) * 3);
Bmemcpy(&w->wall.buffer[5], &s->floor.buffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3); Bmemcpy(&w->wall.buffer[5], &s->floor.buffer[(wal->point2 - sec->wallptr) * 5], sizeof(GLfloat) * 3);