A bunch of random shit

git-svn-id: https://svn.eduke32.com/eduke32@1044 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
terminx 2008-09-01 07:15:16 +00:00
parent 882fbd6851
commit ef3c5e6ad8
9 changed files with 304 additions and 94 deletions

View file

@ -76,6 +76,8 @@ extern void ExtEditSpriteData(short spritenum);
extern char ExtCustomSpriteColor(short picnum); extern char ExtCustomSpriteColor(short picnum);
extern void ExtSetupSpecialSpriteCols(void); extern void ExtSetupSpecialSpriteCols(void);
extern int circlewall;
int loadsetup(const char *fn); // from config.c int loadsetup(const char *fn); // from config.c
int writesetup(const char *fn); // from config.c int writesetup(const char *fn); // from config.c

View file

@ -2945,7 +2945,7 @@ void overheadeditor(void)
short splitstartwall=0, splitendwall, loopnum; short splitstartwall=0, splitendwall, loopnum;
int mousx, mousy, bstatus; int mousx, mousy, bstatus;
int centerx, centery, circlerad; int centerx, centery, circlerad;
short circlewall, circlepoints, circleang1, circleang2, circleangdir; short circlepoints, circleang1, circleang2, circleangdir;
int sectorhighlightx=0, sectorhighlighty=0; int sectorhighlightx=0, sectorhighlighty=0;
short cursectorhighlight, sectorhighlightstat; short cursectorhighlight, sectorhighlightstat;
short hitsect, hitwall, hitsprite; short hitsect, hitwall, hitsprite;
@ -2971,17 +2971,17 @@ void overheadeditor(void)
ydim16 = ydim; ydim16 = ydim;
drawline16(0,ydim-STATUS2DSIZ,xdim-1,ydim-STATUS2DSIZ,1); drawline16(0,ydim-STATUS2DSIZ,xdim-1,ydim-STATUS2DSIZ,1);
drawline16(0,ydim-1,xdim-1,ydim-1,1); /* drawline16(0,ydim-1,xdim-1,ydim-1,1);
drawline16(0,ydim-STATUS2DSIZ,0,ydim-1,1); drawline16(0,ydim-STATUS2DSIZ,0,ydim-1,1);
drawline16(xdim-1,ydim-STATUS2DSIZ,xdim-1,ydim-1,1); drawline16(xdim-1,ydim-STATUS2DSIZ,xdim-1,ydim-1,1);
drawline16(0,ydim-STATUS2DSIZ+24,xdim-1,ydim-STATUS2DSIZ+24,1); drawline16(0,ydim-STATUS2DSIZ+24,xdim-1,ydim-STATUS2DSIZ+24,1);
drawline16(192-24,ydim-STATUS2DSIZ,192-24,ydim-STATUS2DSIZ+24,1); drawline16(192-24,ydim-STATUS2DSIZ,192-24,ydim-STATUS2DSIZ+24,1); */
if (totalclock < 120*5) if (totalclock < 120*5)
printext16(8L,ydim-STATUS2DSIZ+32L,9,-1,kensig,0); printext16(8L,ydim-STATUS2DSIZ+32L,9,-1,kensig,0);
// printmessage16("Version: "VERSION); // printmessage16("Version: "VERSION);
if (totalclock < 30) printmessage16("Press F1 for help"); if (totalclock < 30) printmessage16("Press F1 for help");
drawline16(0,ydim-1-20,xdim-1,ydim-1-20,1); // drawline16(0,ydim-1-20,xdim-1,ydim-1-20,1);
drawline16(256,ydim-1-20,256,ydim-1,1); drawline16(256,ydim-1-20,256,ydim-1,1);
ydim16 = ydim-STATUS2DSIZ; ydim16 = ydim-STATUS2DSIZ;
enddrawing(); //}}} enddrawing(); //}}}
@ -3164,8 +3164,16 @@ void overheadeditor(void)
y1 = midydim16+day-4; y1 = midydim16+day-4;
x2 = x1 + (Bstrlen(dabuffer)<<2)+2; x2 = x1 + (Bstrlen(dabuffer)<<2)+2;
y2 = y1 + 7; y2 = y1 + 7;
if ((x1 >= 0) && (x2 < xdim) && (y1 >= 0) && (y2 < ydim16)) if ((x1 > 3) && (x2 < xdim) && (y1 > 1) && (y2 < ydim16))
{
printext16(x1,y1,0,7,dabuffer,1); printext16(x1,y1,0,7,dabuffer,1);
drawline16(x1-1,y1-1,x2-3,y1-1,7);
drawline16(x1-1,y2+1,x2-3,y2+1,7);
drawline16(x1-2,y1,x1-2,y2,7);
drawline16(x2-2,y1,x2-2,y2,7);
drawline16(x2-3,y1,x2-3,y2,7);
}
} }
} }
@ -3190,8 +3198,16 @@ void overheadeditor(void)
y1 = midydim16+day-4; y1 = midydim16+day-4;
x2 = x1 + (Bstrlen(dabuffer)<<2)+2; x2 = x1 + (Bstrlen(dabuffer)<<2)+2;
y2 = y1 + 7; y2 = y1 + 7;
if ((x1 >= 0) && (x2 < xdim) && (y1 >= 0) && (y2 < ydim16)) if ((x1 > 3) && (x2 < xdim) && (y1 > 1) && (y2 < ydim16))
{
printext16(x1,y1,0,4,dabuffer,1); printext16(x1,y1,0,4,dabuffer,1);
drawline16(x1-1,y1-1,x2-3,y1-1,4);
drawline16(x1-1,y2+1,x2-3,y2+1,4);
drawline16(x1-2,y1,x1-2,y2,4);
drawline16(x2-2,y1,x2-2,y2,4);
drawline16(x2-3,y1,x2-3,y2,4);
}
} }
} }
} }
@ -3215,7 +3231,7 @@ void overheadeditor(void)
y1 = midydim16+day-4; y1 = midydim16+day-4;
x2 = x1 + (Bstrlen(dabuffer)<<2)+2; x2 = x1 + (Bstrlen(dabuffer)<<2)+2;
y2 = y1 + 7; y2 = y1 + 7;
if ((x1 >= 0) && (x2 < xdim) && (y1 >= 0) && (y2 < ydim16)) if ((x1 > 3) && (x2 < xdim) && (y1 > 1) && (y2 < ydim16))
{ {
col = 3; col = 3;
if (spritecol2d[sprite[i].picnum][0]) if (spritecol2d[sprite[i].picnum][0])
@ -3230,6 +3246,13 @@ void overheadeditor(void)
if ((i == pointhighlight-16384) && (totalclock & 32)) col += (2<<2); if ((i == pointhighlight-16384) && (totalclock & 32)) col += (2<<2);
printext16(x1,y1,0,col,dabuffer,1); printext16(x1,y1,0,col,dabuffer,1);
drawline16(x1-1,y1-1,x2-3,y1-1,col);
drawline16(x1-1,y2+1,x2-3,y2+1,col);
drawline16(x1-2,y1,x1-2,y2,col);
drawline16(x2-2,y1,x2-2,y2,col);
drawline16(x2-3,y1,x2-3,y2,col);
} }
} }
j--; j--;
@ -4861,6 +4884,8 @@ void overheadeditor(void)
tempint2 = dmulscale4(y1-y2,x1-x3,y1-y3,x2-x1); tempint2 = dmulscale4(y1-y2,x1-x3,y1-y3,x2-x1);
if (tempint2 != 0) if (tempint2 != 0)
{ {
int pointsize = 2;
centerx = (((x1+x2) + scale(y1-y2,tempint1,tempint2))>>1); centerx = (((x1+x2) + scale(y1-y2,tempint1,tempint2))>>1);
centery = (((y1+y2) + scale(x2-x1,tempint1,tempint2))>>1); centery = (((y1+y2) + scale(x2-x1,tempint1,tempint2))>>1);
@ -4903,11 +4928,11 @@ void overheadeditor(void)
} }
dax = mulscale14(dax-posx,zoom); dax = mulscale14(dax-posx,zoom);
day = mulscale14(day-posy,zoom); day = mulscale14(day-posy,zoom);
/* drawline16(halfxdim16+dax-2,midydim16+day-2,halfxdim16+dax+2,midydim16+day-2,14); drawline16(halfxdim16+dax-pointsize,midydim16+day-pointsize,halfxdim16+dax+pointsize,midydim16+day-pointsize,14);
drawline16(halfxdim16+dax+2,midydim16+day-2,halfxdim16+dax+2,midydim16+day+2,14); drawline16(halfxdim16+dax+pointsize,midydim16+day-pointsize,halfxdim16+dax+pointsize,midydim16+day+pointsize,14);
drawline16(halfxdim16+dax+2,midydim16+day+2,halfxdim16+dax-2,midydim16+day+2,14); drawline16(halfxdim16+dax+pointsize,midydim16+day+pointsize,halfxdim16+dax-pointsize,midydim16+day+pointsize,14);
drawline16(halfxdim16+dax-2,midydim16+day+2,halfxdim16+dax-2,midydim16+day-2,14); */ drawline16(halfxdim16+dax-pointsize,midydim16+day+pointsize,halfxdim16+dax-pointsize,midydim16+day-pointsize,14);
drawcircle16(halfxdim16+dax, midydim16+day, 3, 14); // drawcircle16(halfxdim16+dax, midydim16+day, 3, 14);
} }
if (bad > 0) if (bad > 0)
{ {
@ -5786,7 +5811,8 @@ CANCEL:
if (keystatus[1]) if (keystatus[1])
{ {
keystatus[1] = 0; keystatus[1] = 0;
printmessage16("(N)ew, (L)oad, (S)ave, save (A)s, (Q)uit"); printmessage16("(N)ew, (L)oad, (S)ave, save (A)s, (Q)uit,");
// printext16(200L+248, ydim-STATUS2DSIZ+17L, 9, 0, "(U)ndo, (R)edo", 0);
showframe(1); showframe(1);
bflushchars(); bflushchars();
bad = 1; bad = 1;
@ -7807,6 +7833,14 @@ void _printmessage16(const char *fmt, ...)
snotbuf[54] = 0; snotbuf[54] = 0;
begindrawing(); begindrawing();
printext16(200L-24, ydim-STATUS2DSIZ+8L, 9, 0, snotbuf, 0); printext16(200L-24, ydim-STATUS2DSIZ+8L, 9, 0, snotbuf, 0);
i = 0;
while (i < 54)
{
snotbuf[i] = 32;
i++;
}
snotbuf[54] = 0;
printext16(200L-24, ydim-STATUS2DSIZ+17L, 9, 0, snotbuf, 0);
enddrawing(); enddrawing();
} }

View file

@ -11045,7 +11045,7 @@ void draw2dgrid(int posxe, int posye, short ange, int zoome, short gride)
{ {
if (xp1 != xp2) if (xp1 != xp2)
{ {
drawline16(xp1,yp1,xp1,yp2,8); drawline16(xp1,yp1,xp1,yp2,25);
} }
} }
} }
@ -11053,7 +11053,7 @@ void draw2dgrid(int posxe, int posye, short ange, int zoome, short gride)
xp2 = xp1; xp2 = xp1;
if ((xp2 >= 0) && (xp2 < xdim)) if ((xp2 >= 0) && (xp2 < xdim))
{ {
drawline16(xp2,yp1,xp2,yp2,8); drawline16(xp2,yp1,xp2,yp2,25);
} }
} }
xp1 = mulscale14(posxe+editorgridextent,zoome); xp1 = mulscale14(posxe+editorgridextent,zoome);
@ -11066,7 +11066,7 @@ void draw2dgrid(int posxe, int posye, short ange, int zoome, short gride)
{ {
if ((yp1 > midydim16-ydim16) && (yp1 <= midydim16)) if ((yp1 > midydim16-ydim16) && (yp1 <= midydim16))
{ {
drawline16(halfxdim16-xp1,midydim16-yp1,halfxdim16-xp2,midydim16-yp1,8); drawline16(halfxdim16-xp1,midydim16-yp1,halfxdim16-xp2,midydim16-yp1,25);
tempy = yp1; tempy = yp1;
} }
} }
@ -11082,6 +11082,7 @@ void draw2dgrid(int posxe, int posye, short ange, int zoome, short gride)
char spritecol2d[MAXTILES][2]; char spritecol2d[MAXTILES][2];
int showfirstwall=0; int showfirstwall=0;
int circlewall=-1;
void draw2dscreen(int posxe, int posye, short ange, int zoome, short gride) void draw2dscreen(int posxe, int posye, short ange, int zoome, short gride)
{ {
@ -11127,7 +11128,7 @@ void draw2dscreen(int posxe, int posye, short ange, int zoome, short gride)
} }
else else
{ {
col = 4; col = 31;
if ((wal->cstat&1) != 0) col = 5; if ((wal->cstat&1) != 0) col = 5;
if (wal->nextwall!=-1&&((wal->cstat^wall[wal->nextwall].cstat)&1)) col = 2; if (wal->nextwall!=-1&&((wal->cstat^wall[wal->nextwall].cstat)&1)) col = 2;
if ((i == linehighlight) || ((linehighlight >= 0) && (i == wall[linehighlight].nextwall))) if ((i == linehighlight) || ((linehighlight >= 0) && (i == wall[linehighlight].nextwall)))
@ -11139,6 +11140,9 @@ void draw2dscreen(int posxe, int posye, short ange, int zoome, short gride)
if (i == linehighlight) if (totalclock & 16) col -= (2<<2); if (i == linehighlight) if (totalclock & 16) col -= (2<<2);
} }
if (circlewall >= 0 && (i == circlewall || wal->nextwall == circlewall))
col = 14;
xp1 = mulscale14(wal->x-posxe,zoome); xp1 = mulscale14(wal->x-posxe,zoome);
yp1 = mulscale14(wal->y-posye,zoome); yp1 = mulscale14(wal->y-posye,zoome);
xp2 = mulscale14(wall[wal->point2].x-posxe,zoome); xp2 = mulscale14(wall[wal->point2].x-posxe,zoome);
@ -11182,29 +11186,29 @@ void draw2dscreen(int posxe, int posye, short ange, int zoome, short gride)
if (jj == ii) if (jj == ii)
{ {
int dax3 = mulscale11(sintable[(k+1024)&2047],zoome) / 4096; int dax3 = mulscale11(sintable[(k+1024)&2047],zoome) / 2560;
int day3 = mulscale11(sintable[(k+512)&2047],zoome) / 4096; int day3 = mulscale11(sintable[(k+512)&2047],zoome) / 2560;
int dax2 = mulscale11(sintable[(k+2048)&2047],zoome) / 4096; int dax2 = mulscale11(sintable[(k+2048)&2047],zoome) / 2560;
int day2 = mulscale11(sintable[(k+1536)&2047],zoome) / 4096; int day2 = mulscale11(sintable[(k+1536)&2047],zoome) / 2560;
drawline16(halfxdim16+dax+dax3,midydim16+day+day3,halfxdim16+dax+dax2,midydim16+day+day2,col); drawline16(halfxdim16+dax+dax3,midydim16+day+day3,halfxdim16+dax+dax2,midydim16+day+day2,col);
} }
else if (jj > ii) else if (jj > ii)
{ {
int dax2 = mulscale11(sintable[(k+1024)&2047],zoome) / 3072; int dax2 = mulscale11(sintable[(k+1024)&2047],zoome) / 2560;
int day2 = mulscale11(sintable[(k+512)&2047],zoome) / 3072; int day2 = mulscale11(sintable[(k+512)&2047],zoome) / 2560;
drawline16(halfxdim16+dax,midydim16+day,halfxdim16+dax+dax2,midydim16+day+day2,col); drawline16(halfxdim16+dax,midydim16+day,halfxdim16+dax+dax2,midydim16+day+day2,col);
} }
else else
{ {
int dax2 = mulscale11(sintable[(k+2048)&2047],zoome) / 3072; int dax2 = mulscale11(sintable[(k+2048)&2047],zoome) / 2560;
int day2 = mulscale11(sintable[(k+1536)&2047],zoome) / 3072; int day2 = mulscale11(sintable[(k+1536)&2047],zoome) / 2560;
drawline16(halfxdim16+dax,midydim16+day,halfxdim16+dax+dax2,midydim16+day+day2,col); drawline16(halfxdim16+dax,midydim16+day,halfxdim16+dax+dax2,midydim16+day+day2,col);
} }
} }
else else
{ {
int dax2 = mulscale11(sintable[(k+2048)&2047],zoome) / 3072; int dax2 = mulscale11(sintable[(k+2048)&2047],zoome) / 2560;
int day2 = mulscale11(sintable[(k+1536)&2047],zoome) / 3072; int day2 = mulscale11(sintable[(k+1536)&2047],zoome) / 2560;
drawline16(halfxdim16+dax,midydim16+day,halfxdim16+dax+dax2,midydim16+day+day2,col); drawline16(halfxdim16+dax,midydim16+day,halfxdim16+dax+dax2,midydim16+day+day2,col);
} }
} }
@ -11212,13 +11216,13 @@ void draw2dscreen(int posxe, int posye, short ange, int zoome, short gride)
if (((halfxdim16+xp1) >= 2) && ((halfxdim16+xp1) <= xdim-3)) if (((halfxdim16+xp1) >= 2) && ((halfxdim16+xp1) <= xdim-3))
if (((midydim16+yp1) >= 2) && ((midydim16+yp1) <= ydim16-3)) if (((midydim16+yp1) >= 2) && ((midydim16+yp1) <= ydim16-3))
{ {
int pointsize = 3; int pointsize = 1;
col = 6; col = 15;
if (i == pointhighlight || ((pointhighlight < MAXWALLS) && (pointhighlight >= 0) && (wall[i].x == wall[pointhighlight].x) && (wall[i].y == wall[pointhighlight].y))) if (i == pointhighlight || ((pointhighlight < MAXWALLS) && (pointhighlight >= 0) && (wall[i].x == wall[pointhighlight].x) && (wall[i].y == wall[pointhighlight].y)))
{ {
if (totalclock & 16) if (totalclock & 16)
{ {
col += (2<<2); // JBF 20040116: two braces is all this needed. man I'm a fool sometimes. //col += (2<<2); // JBF 20040116: two braces is all this needed. man I'm a fool sometimes.
pointsize += 1; pointsize += 1;
} }
} }
@ -11227,17 +11231,22 @@ void draw2dscreen(int posxe, int posye, short ange, int zoome, short gride)
if (show2dwall[i>>3]&pow2char[i&7]) if (show2dwall[i>>3]&pow2char[i&7])
if (totalclock & 16) if (totalclock & 16)
{ {
col += (2<<2); // JBF 20040116: two braces is all this needed. man I'm a fool sometimes. // col += (2<<2); // JBF 20040116: two braces is all this needed. man I'm a fool sometimes.
pointsize += 1; pointsize += 1;
} }
} }
tempint = ((midydim16+yp1)*bytesperline)+(halfxdim16+xp1)+frameplace; tempint = ((midydim16+yp1)*bytesperline)+(halfxdim16+xp1)+frameplace;
#if 0 #if 1
drawline16(halfxdim16+xp1-pointsize,midydim16+yp1+pointsize,halfxdim16+xp1+pointsize,midydim16+yp1+pointsize,col); do
drawline16(halfxdim16+xp1+pointsize,midydim16+yp1+pointsize,halfxdim16+xp1+pointsize,midydim16+yp1-pointsize,col); {
drawline16(halfxdim16+xp1+pointsize,midydim16+yp1-pointsize,halfxdim16+xp1-pointsize,midydim16+yp1-pointsize,col); /* drawline16(halfxdim16+xp1-pointsize,midydim16+yp1+pointsize,halfxdim16+xp1+pointsize,midydim16+yp1+pointsize,col);
drawline16(halfxdim16+xp1-pointsize,midydim16+yp1-pointsize,halfxdim16+xp1-pointsize,midydim16+yp1+pointsize,col); drawline16(halfxdim16+xp1+pointsize,midydim16+yp1+pointsize,halfxdim16+xp1+pointsize,midydim16+yp1-pointsize,col);
drawline16(halfxdim16+xp1+pointsize,midydim16+yp1-pointsize,halfxdim16+xp1-pointsize,midydim16+yp1-pointsize,col);
drawline16(halfxdim16+xp1-pointsize,midydim16+yp1-pointsize,halfxdim16+xp1-pointsize,midydim16+yp1+pointsize,col); */
drawcircle16(halfxdim16+xp1, midydim16+yp1, pointsize, col);
}
while (pointsize--);
#else #else
drawcircle16(halfxdim16+xp1, midydim16+yp1, pointsize, col); drawcircle16(halfxdim16+xp1, midydim16+yp1, pointsize, col);
#endif #endif

View file

@ -495,17 +495,17 @@ int movesprite(int spritenum, int xchange, int ychange, int zchange, unsigned in
if (dasectnum < 0 || (dasectnum >= 0 && if (dasectnum < 0 || (dasectnum >= 0 &&
((hittype[spritenum].actorstayput >= 0 && hittype[spritenum].actorstayput != dasectnum) || ((hittype[spritenum].actorstayput >= 0 && hittype[spritenum].actorstayput != dasectnum) ||
((sprite[spritenum].picnum == BOSS2) && sprite[spritenum].pal == 0 && sector[dasectnum].lotag != 3) || ((sprite[spritenum].picnum == BOSS2) && sprite[spritenum].pal == 0 && sector[dasectnum].lotag != 3) ||
((sprite[spritenum].picnum == BOSS1 || sprite[spritenum].picnum == BOSS2) && sector[dasectnum].lotag == 1) || ((sprite[spritenum].picnum == BOSS1 || sprite[spritenum].picnum == BOSS2) && sector[dasectnum].lotag == 1) /*||
(sector[dasectnum].lotag == 1 && (sprite[spritenum].picnum == LIZMAN || (sprite[spritenum].picnum == LIZTROOP && sprite[spritenum].zvel == 0))) (sector[dasectnum].lotag == 1 && (sprite[spritenum].picnum == LIZMAN || (sprite[spritenum].picnum == LIZTROOP && sprite[spritenum].zvel == 0)))*/
)) ))
) )
{ {
sprite[spritenum].x = oldx; sprite[spritenum].x = oldx;
sprite[spritenum].y = oldy; sprite[spritenum].y = oldy;
if (dasectnum >= 0 && sector[dasectnum].lotag == 1 && sprite[spritenum].picnum == LIZMAN) /* if (dasectnum >= 0 && sector[dasectnum].lotag == 1 && sprite[spritenum].picnum == LIZMAN)
sprite[spritenum].ang = (TRAND&2047); sprite[spritenum].ang = (TRAND&2047);
else if ((hittype[spritenum].temp_data[0]&3) == 1 && sprite[spritenum].picnum != COMMANDER) else if ((hittype[spritenum].temp_data[0]&3) == 1 && sprite[spritenum].picnum != COMMANDER)
sprite[spritenum].ang = (TRAND&2047); sprite[spritenum].ang = (TRAND&2047); */
setsprite(spritenum,oldx,oldy,sprite[spritenum].z); setsprite(spritenum,oldx,oldy,sprite[spritenum].z);
if (dasectnum < 0) dasectnum = 0; if (dasectnum < 0) dasectnum = 0;
return (16384+dasectnum); return (16384+dasectnum);

View file

@ -361,6 +361,7 @@ int tileInGroup(int group, int tilenum)
const char *ExtGetSectorCaption(short sectnum) const char *ExtGetSectorCaption(short sectnum)
{ {
static char tempbuf[1024]; static char tempbuf[1024];
Bmemset(tempbuf,0,sizeof(tempbuf));
if (qsetmode != 200 && (!(onnames==1 || onnames==4 || onnames==7) || (onnames==8))) if (qsetmode != 200 && (!(onnames==1 || onnames==4 || onnames==7) || (onnames==8)))
{ {
tempbuf[0] = 0; tempbuf[0] = 0;
@ -454,6 +455,7 @@ const char *ExtGetSectorCaption(short sectnum)
const char *ExtGetWallCaption(short wallnum) const char *ExtGetWallCaption(short wallnum)
{ {
static char tempbuf[1024]; static char tempbuf[1024];
Bmemset(tempbuf,0,sizeof(tempbuf));
if (!(onnames==2 || onnames==4)) if (!(onnames==2 || onnames==4))
{ {
tempbuf[0] = 0; tempbuf[0] = 0;
@ -476,6 +478,7 @@ const char *ExtGetWallCaption(short wallnum)
const char *SectorEffectorText(short spritenum) const char *SectorEffectorText(short spritenum)
{ {
static char tempbuf[1024]; static char tempbuf[1024];
Bmemset(tempbuf,0,sizeof(tempbuf));
switch (sprite[spritenum].lotag) switch (sprite[spritenum].lotag)
{ {
case 0: case 0:
@ -587,6 +590,8 @@ const char *SectorEffectorText(short spritenum)
const char *ExtGetSpriteCaption(short spritenum) const char *ExtGetSpriteCaption(short spritenum)
{ {
static char tempbuf[1024]; static char tempbuf[1024];
Bmemset(tempbuf,0,sizeof(tempbuf));
if ((onnames!=5 && onnames!=6 &&(!(onnames==3 || onnames==4 || onnames==7 || onnames==8))) || (onnames==7 && sprite[spritenum].picnum!=1)) if ((onnames!=5 && onnames!=6 &&(!(onnames==3 || onnames==4 || onnames==7 || onnames==8))) || (onnames==7 && sprite[spritenum].picnum!=1))
{ {
tempbuf[0] = 0; tempbuf[0] = 0;
@ -6362,7 +6367,9 @@ static void Keys2d(void)
} }
if (autogrid) if (autogrid)
{ {
grid = scale(zoom,6,3072); grid = zoom+512;
if (grid > 16384) grid = 16384;
grid = scale(grid,6,6144);
if (grid > 7) grid = 7; if (grid > 7) grid = 7;
if (grid < 0) grid = 0; if (grid < 0) grid = 0;
} }
@ -6526,6 +6533,25 @@ static void InitCustomColors(void)
vgapal16[32*4+0] = 60; vgapal16[32*4+0] = 60;
vgapal16[32*4+1] = 50; vgapal16[32*4+1] = 50;
vgapal16[32*4+2] = 21; vgapal16[32*4+2] = 21;
// grid color
vgapal16[25*4+0] = 19;
vgapal16[25*4+1] = 17;
vgapal16[25*4+2] = 17;
vgapal16[26*4+0] = 24;
vgapal16[26*4+1] = 24;
vgapal16[26*4+2] = 24;
vgapal16[33*4+0] = 15; // blue
vgapal16[33*4+1] = 30; // green
vgapal16[33*4+2] = 45; // red
vgapal16[41*4+0] = 24;
vgapal16[41*4+1] = 40;
vgapal16[41*4+2] = 48;
} }
void ExtPreSaveMap(void) void ExtPreSaveMap(void)
@ -9417,3 +9443,27 @@ static void FuncMenu(void)
showframe(1); showframe(1);
keystatus[KEYSC_ESC] = 0; keystatus[KEYSC_ESC] = 0;
} }
/*
#define UNDODEPTH 96
typedef struct
{
int numsectors;
int numwalls;
int numsprites;
sectortype *sectors;
walltype *walls;
spritetype *sprites;
short *headspritesect;
short *prevspritesect;
short *nextspritesect;
short *headspritestat;
short *prevspritestat;
short *nextspritestat;
} mapundo_t;
mapundo_t undoredo[UNDODEPTH];
*/

View file

@ -23,7 +23,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
//------------------------------------------------------------------------- //-------------------------------------------------------------------------
// this is checked against http://eduke32.com/VERSION // this is checked against http://eduke32.com/VERSION
#define BUILDDATE " 20080828" #define BUILDDATE " 20080831"
#define APPNAME "EDuke32" #define APPNAME "EDuke32"
#define VERSION " 1.5.0devel" #define VERSION " 1.5.0devel"
#define HEAD2 APPNAME VERSION BUILDDATE #define HEAD2 APPNAME VERSION BUILDDATE

View file

@ -1684,6 +1684,7 @@ static void transvartype(int type)
{ {
ReportError(-1); ReportError(-1);
initprintf("%s:%d: warning: found local gamevar `%s' used within %s; expect multiplayer synchronization issues.\n",compilefile,line_number,label+(labelcnt<<6),parsing_event?"a synced event":"an actor"); initprintf("%s:%d: warning: found local gamevar `%s' used within %s; expect multiplayer synchronization issues.\n",compilefile,line_number,label+(labelcnt<<6),parsing_event?"a synced event":"an actor");
warning++;
} }
if (!(error || warning) && g_ScriptDebug > 1) if (!(error || warning) && g_ScriptDebug > 1)
initprintf("%s:%d: debug: accepted gamevar `%s'.\n",compilefile,line_number,label+(labelcnt<<6)); initprintf("%s:%d: debug: accepted gamevar `%s'.\n",compilefile,line_number,label+(labelcnt<<6));
@ -1765,6 +1766,7 @@ static int transnum(int type)
gl = (char *)translatelabeltype(labeltype[i]); gl = (char *)translatelabeltype(labeltype[i]);
ReportError(-1); ReportError(-1);
initprintf("%s:%d: warning: expected a %s, found a %s.\n",compilefile,line_number,el,gl); initprintf("%s:%d: warning: expected a %s, found a %s.\n",compilefile,line_number,el,gl);
warning++;
Bfree(el); Bfree(el);
Bfree(gl); Bfree(gl);
return -1; // valid label name, but wrong type return -1; // valid label name, but wrong type
@ -1781,7 +1783,7 @@ static int transnum(int type)
if (isdigit(*textptr) && labelsonly) if (isdigit(*textptr) && labelsonly)
{ {
ReportError(WARNING_LABELSONLY); ReportError(WARNING_LABELSONLY);
// warning++; warning++;
} }
if (!(error || warning) && g_ScriptDebug > 1) if (!(error || warning) && g_ScriptDebug > 1)
initprintf("%s:%d: debug: accepted constant %d.\n",compilefile,line_number,atol(textptr)); initprintf("%s:%d: debug: accepted constant %d.\n",compilefile,line_number,atol(textptr));
@ -1845,7 +1847,7 @@ static int parsecommand(void)
exit(0); exit(0);
} }
if ((error+warning) > 63 || (*textptr == '\0') || (*(textptr+1) == '\0')) return 1; if (error > 63 || (*textptr == '\0') || (*(textptr+1) == '\0')) return 1;
if (g_ScriptDebug) if (g_ScriptDebug)
ReportError(-1); ReportError(-1);
@ -1894,7 +1896,7 @@ static int parsecommand(void)
i = HASH_find(&gamevarH,label+(labelcnt<<6)); i = HASH_find(&gamevarH,label+(labelcnt<<6));
if (i>=0) if (i>=0)
{ {
// warning++; warning++;
ReportError(WARNING_NAMEMATCHESVAR); ReportError(WARNING_NAMEMATCHESVAR);
} }
@ -1917,6 +1919,7 @@ static int parsecommand(void)
char *gl = (char *)translatelabeltype(labeltype[j]); char *gl = (char *)translatelabeltype(labeltype[j]);
ReportError(-1); ReportError(-1);
initprintf("%s:%d: warning: expected a state, found a %s.\n",compilefile,line_number,gl); initprintf("%s:%d: warning: expected a state, found a %s.\n",compilefile,line_number,gl);
warning++;
Bfree(gl); Bfree(gl);
*(scriptptr-1) = CON_NULLOP; // get rid of the state, leaving a nullop to satisfy if conditions *(scriptptr-1) = CON_NULLOP; // get rid of the state, leaving a nullop to satisfy if conditions
bitptr[(scriptptr-script-1)] = BITPTR_DONTFUCKWITHIT; bitptr[(scriptptr-script-1)] = BITPTR_DONTFUCKWITHIT;
@ -2117,7 +2120,7 @@ static int parsecommand(void)
i = HASH_find(&gamevarH,label+(labelcnt<<6)); i = HASH_find(&gamevarH,label+(labelcnt<<6));
if (i>=0) if (i>=0)
{ {
// warning++; warning++;
ReportError(WARNING_NAMEMATCHESVAR); ReportError(WARNING_NAMEMATCHESVAR);
} }
@ -2145,18 +2148,18 @@ static int parsecommand(void)
i = HASH_find(&gamevarH,label+(labelcnt<<6)); i = HASH_find(&gamevarH,label+(labelcnt<<6));
if (i>=0) if (i>=0)
{ {
// warning++; warning++;
ReportError(WARNING_NAMEMATCHESVAR); ReportError(WARNING_NAMEMATCHESVAR);
} }
i = HASH_find(&labelH,label+(labelcnt<<6)); i = HASH_find(&labelH,label+(labelcnt<<6));
if (i>=0) if (i>=0)
{ {
if (i >= defaultlabelcnt) /* if (i >= defaultlabelcnt)
{ {
warning++; warning++;
ReportError(WARNING_DUPLICATEDEFINITION); ReportError(WARNING_DUPLICATEDEFINITION);
} } */
} }
//printf("Translating. '%.20s'\n",textptr); //printf("Translating. '%.20s'\n",textptr);
@ -2165,7 +2168,7 @@ static int parsecommand(void)
if (i == -1) if (i == -1)
{ {
// printf("Defining Definition '%s' to be '%d'\n",label+(labelcnt<<6),*(scriptptr-1)); // printf("Defining Definition '%s' to be '%d'\n",label+(labelcnt<<6),*(scriptptr-1));
HASH_add(&labelH,label+(labelcnt<<6),labelcnt); HASH_replace(&labelH,label+(labelcnt<<6),labelcnt);
labeltype[labelcnt] = LABEL_DEFINE; labeltype[labelcnt] = LABEL_DEFINE;
labelcode[labelcnt++] = *(scriptptr-1); labelcode[labelcnt++] = *(scriptptr-1);
if (*(scriptptr-1) >= 0 && *(scriptptr-1) < MAXTILES && dynamicremap) if (*(scriptptr-1) >= 0 && *(scriptptr-1) < MAXTILES && dynamicremap)
@ -2196,7 +2199,10 @@ static int parsecommand(void)
if (parsing_actor || parsing_state) if (parsing_actor || parsing_state)
{ {
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
warning++;
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
}
if ((transnum(LABEL_MOVE|LABEL_DEFINE) == 0) && (*(scriptptr-1) != 0) && (*(scriptptr-1) != 1)) if ((transnum(LABEL_MOVE|LABEL_DEFINE) == 0) && (*(scriptptr-1) != 0) && (*(scriptptr-1) != 1))
{ {
@ -2204,6 +2210,7 @@ static int parsecommand(void)
bitptr[(scriptptr-script-1)] = BITPTR_DONTFUCKWITHIT; bitptr[(scriptptr-script-1)] = BITPTR_DONTFUCKWITHIT;
*(scriptptr-1) = 0; *(scriptptr-1) = 0;
initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number); initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number);
warning++;
} }
j = 0; j = 0;
@ -2234,7 +2241,7 @@ static int parsecommand(void)
i = HASH_find(&gamevarH,label+(labelcnt<<6)); i = HASH_find(&gamevarH,label+(labelcnt<<6));
if (i>=0) if (i>=0)
{ {
// warning++; warning++;
ReportError(WARNING_NAMEMATCHESVAR); ReportError(WARNING_NAMEMATCHESVAR);
} }
@ -2415,7 +2422,10 @@ static int parsecommand(void)
if (parsing_actor || parsing_state) if (parsing_actor || parsing_state)
{ {
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
transnum(LABEL_AI); transnum(LABEL_AI);
} }
else else
@ -2433,7 +2443,7 @@ static int parsecommand(void)
i = HASH_find(&gamevarH,label+(labelcnt<<6)); i = HASH_find(&gamevarH,label+(labelcnt<<6));
if (i>=0) if (i>=0)
{ {
// warning++; warning++;
ReportError(WARNING_NAMEMATCHESVAR); ReportError(WARNING_NAMEMATCHESVAR);
} }
@ -2464,6 +2474,7 @@ static int parsecommand(void)
bitptr[(scriptptr-script-1)] = BITPTR_DONTFUCKWITHIT; bitptr[(scriptptr-script-1)] = BITPTR_DONTFUCKWITHIT;
*(scriptptr-1) = 0; *(scriptptr-1) = 0;
initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number); initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number);
warning++;
} }
k = 0; k = 0;
while (keyword() == -1) while (keyword() == -1)
@ -2491,7 +2502,10 @@ static int parsecommand(void)
if (parsing_actor || parsing_state) if (parsing_actor || parsing_state)
{ {
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
transnum(LABEL_ACTION); transnum(LABEL_ACTION);
} }
else else
@ -2510,7 +2524,7 @@ static int parsecommand(void)
i = HASH_find(&gamevarH,label+(labelcnt<<6)); i = HASH_find(&gamevarH,label+(labelcnt<<6));
if (i>=0) if (i>=0)
{ {
// warning++; warning++;
ReportError(WARNING_NAMEMATCHESVAR); ReportError(WARNING_NAMEMATCHESVAR);
} }
@ -2611,6 +2625,7 @@ static int parsecommand(void)
bitptr[(scriptptr-script-1)] = BITPTR_DONTFUCKWITHIT; bitptr[(scriptptr-script-1)] = BITPTR_DONTFUCKWITHIT;
*(scriptptr-1) = 0; *(scriptptr-1) = 0;
initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number); initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number);
warning++;
} }
break; break;
} }
@ -2666,6 +2681,7 @@ static int parsecommand(void)
ReportError(-1); ReportError(-1);
parsing_event = parsing_actor = tempscrptr; parsing_event = parsing_actor = tempscrptr;
initprintf("%s:%d: warning: duplicate event `%s'.\n",compilefile,line_number,parsing_item_name); initprintf("%s:%d: warning: duplicate event `%s'.\n",compilefile,line_number,parsing_item_name);
warning++;
} }
else apScriptGameEvent[j]=parsing_event; else apScriptGameEvent[j]=parsing_event;
@ -2728,6 +2744,7 @@ static int parsecommand(void)
{ {
ReportError(-1); ReportError(-1);
initprintf("%s:%d: warning: invalid useractor type.\n",compilefile,line_number); initprintf("%s:%d: warning: invalid useractor type.\n",compilefile,line_number);
warning++;
j = 0; j = 0;
} }
@ -2780,6 +2797,7 @@ static int parsecommand(void)
bitptr[(scriptptr-script-1)] = BITPTR_DONTFUCKWITHIT; bitptr[(scriptptr-script-1)] = BITPTR_DONTFUCKWITHIT;
*(scriptptr-1) = 0; *(scriptptr-1) = 0;
initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number); initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number);
warning++;
} }
break; break;
} }
@ -2795,7 +2813,10 @@ static int parsecommand(void)
case CON_INSERTSPRITEQ: case CON_INSERTSPRITEQ:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
return 0; return 0;
case CON_QSPRINTF: case CON_QSPRINTF:
@ -2842,7 +2863,10 @@ static int parsecommand(void)
case CON_LOTSOFGLASS: case CON_LOTSOFGLASS:
case CON_SAVE: case CON_SAVE:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_ANGOFF: case CON_ANGOFF:
case CON_QUOTE: case CON_QUOTE:
case CON_SOUND: case CON_SOUND:
@ -2857,6 +2881,7 @@ static int parsecommand(void)
*(scriptptr-1) = 32768; *(scriptptr-1) = 32768;
ReportError(-1); ReportError(-1);
initprintf("%s:%d: warning: tried to set cstat 32767, using 32768 instead.\n",compilefile,line_number); initprintf("%s:%d: warning: tried to set cstat 32767, using 32768 instead.\n",compilefile,line_number);
warning++;
} }
else if ((*(scriptptr-1) & 32) && (*(scriptptr-1) & 16)) else if ((*(scriptptr-1) & 32) && (*(scriptptr-1) & 16))
{ {
@ -2864,13 +2889,17 @@ static int parsecommand(void)
*(scriptptr-1) ^= 48; *(scriptptr-1) ^= 48;
ReportError(-1); ReportError(-1);
initprintf("%s:%d: warning: tried to set cstat %d, using %d instead.\n",compilefile,line_number,i,*(scriptptr-1)); initprintf("%s:%d: warning: tried to set cstat %d, using %d instead.\n",compilefile,line_number,i,*(scriptptr-1));
warning++;
} }
} }
return 0; return 0;
case CON_HITRADIUSVAR: case CON_HITRADIUSVAR:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
transmultvars(5); transmultvars(5);
break; break;
case CON_HITRADIUS: case CON_HITRADIUS:
@ -2885,7 +2914,10 @@ static int parsecommand(void)
case CON_ADDINVENTORY: case CON_ADDINVENTORY:
case CON_GUTS: case CON_GUTS:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
transnum(LABEL_DEFINE); transnum(LABEL_DEFINE);
transnum(LABEL_DEFINE); transnum(LABEL_DEFINE);
break; break;
@ -2914,7 +2946,10 @@ static int parsecommand(void)
case CON_SETSECTOR: case CON_SETSECTOR:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_GETSECTOR: case CON_GETSECTOR:
{ {
int lLabelID; int lLabelID;
@ -3046,7 +3081,10 @@ static int parsecommand(void)
case CON_SETWALL: case CON_SETWALL:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_GETWALL: case CON_GETWALL:
{ {
int lLabelID; int lLabelID;
@ -3110,7 +3148,10 @@ static int parsecommand(void)
case CON_SETPLAYER: case CON_SETPLAYER:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_GETPLAYER: case CON_GETPLAYER:
{ {
int lLabelID; int lLabelID;
@ -3188,7 +3229,10 @@ static int parsecommand(void)
case CON_SETINPUT: case CON_SETINPUT:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_GETINPUT: case CON_GETINPUT:
{ {
int lLabelID; int lLabelID;
@ -3304,7 +3348,10 @@ static int parsecommand(void)
case CON_SETACTORVAR: case CON_SETACTORVAR:
case CON_SETPLAYERVAR: case CON_SETPLAYERVAR:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_GETACTORVAR: case CON_GETACTORVAR:
case CON_GETPLAYERVAR: case CON_GETPLAYERVAR:
{ {
@ -3438,7 +3485,10 @@ static int parsecommand(void)
case CON_SETACTOR: case CON_SETACTOR:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_GETACTOR: case CON_GETACTOR:
{ {
int lLabelID; int lLabelID;
@ -3523,6 +3573,7 @@ static int parsecommand(void)
{ {
ReportError(-1); ReportError(-1);
initprintf("%s:%d: warning: found `%s' outside of EVENT_ANIMATESPRITES\n",compilefile,line_number,tempbuf); initprintf("%s:%d: warning: found `%s' outside of EVENT_ANIMATESPRITES\n",compilefile,line_number,tempbuf);
warning++;
} }
// syntax getwall[<var>].x <VAR> // syntax getwall[<var>].x <VAR>
@ -3587,7 +3638,10 @@ static int parsecommand(void)
case CON_GETTICKS: case CON_GETTICKS:
if (CheckEventSync(current_event)) if (CheckEventSync(current_event))
{
ReportError(WARNING_REVEVENTSYNC); ReportError(WARNING_REVEVENTSYNC);
warning++;
}
case CON_GETCURRADDRESS: case CON_GETCURRADDRESS:
transvartype(GAMEVAR_FLAG_READONLY); transvartype(GAMEVAR_FLAG_READONLY);
return 0; return 0;
@ -3605,7 +3659,10 @@ static int parsecommand(void)
case CON_SHOOTVAR: case CON_SHOOTVAR:
case CON_QUAKE: case CON_QUAKE:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_JUMP: case CON_JUMP:
case CON_CMENU: case CON_CMENU:
case CON_SOUNDVAR: case CON_SOUNDVAR:
@ -3644,7 +3701,11 @@ static int parsecommand(void)
case CON_DYNAMICREMAP: case CON_DYNAMICREMAP:
{ {
scriptptr--; scriptptr--;
if (dynamicremap++) initprintf("%s:%d: warning: duplicate dynamicremap statement\n",compilefile,line_number); if (dynamicremap++)
{
initprintf("%s:%d: warning: duplicate dynamicremap statement\n",compilefile,line_number);
warning++;
}
else initprintf("Using dynamic tile remapping\n"); else initprintf("Using dynamic tile remapping\n");
break; break;
} }
@ -3653,7 +3714,10 @@ static int parsecommand(void)
case CON_ZSHOOT: case CON_ZSHOOT:
case CON_EZSHOOT: case CON_EZSHOOT:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_SETVAR: case CON_SETVAR:
case CON_ADDVAR: case CON_ADDVAR:
case CON_SUBVAR: case CON_SUBVAR:
@ -3723,7 +3787,10 @@ static int parsecommand(void)
return 0; return 0;
case CON_RANDVARVAR: case CON_RANDVARVAR:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_SETVARVAR: case CON_SETVARVAR:
case CON_ADDVARVAR: case CON_ADDVARVAR:
case CON_SUBVARVAR: case CON_SUBVARVAR:
@ -3747,7 +3814,10 @@ static int parsecommand(void)
case CON_OPERATEACTIVATORS: case CON_OPERATEACTIVATORS:
case CON_SSP: case CON_SSP:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_GMAXAMMO: case CON_GMAXAMMO:
case CON_DIST: case CON_DIST:
case CON_LDIST: case CON_LDIST:
@ -3859,7 +3929,10 @@ static int parsecommand(void)
return 0; return 0;
} }
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
transvar(); transvar();
return 0; return 0;
} }
@ -4064,7 +4137,10 @@ static int parsecommand(void)
case CON_MOVESPRITE: case CON_MOVESPRITE:
case CON_SETSPRITE: case CON_SETSPRITE:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
transmultvars(4); transmultvars(4);
if (tw == CON_MOVESPRITE) if (tw == CON_MOVESPRITE)
{ {
@ -4294,7 +4370,7 @@ repeatcase:
for (i=(casecount/2)-1;i>=0;i--) for (i=(casecount/2)-1;i>=0;i--)
if (casescriptptr[i*2+1]==j) if (casescriptptr[i*2+1]==j)
{ {
//warning++; warning++;
ReportError(WARNING_DUPLICATECASE); ReportError(WARNING_DUPLICATECASE);
break; break;
} }
@ -4382,7 +4458,10 @@ repeatcase:
case CON_ZSHOOTVAR: case CON_ZSHOOTVAR:
case CON_EZSHOOTVAR: case CON_EZSHOOTVAR:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
warning++;
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
}
case CON_GETPNAME: case CON_GETPNAME:
case CON_STARTLEVEL: case CON_STARTLEVEL:
case CON_QSTRCAT: case CON_QSTRCAT:
@ -4403,7 +4482,10 @@ repeatcase:
case CON_SETACTORANGLE: case CON_SETACTORANGLE:
case CON_SETPLAYERANGLE: case CON_SETPLAYERANGLE:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
warning++;
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
}
case CON_GETANGLETOTARGET: case CON_GETANGLETOTARGET:
case CON_GETACTORANGLE: case CON_GETACTORANGLE:
case CON_GETPLAYERANGLE: case CON_GETPLAYERANGLE:
@ -4424,7 +4506,10 @@ repeatcase:
case CON_IFPINVENTORY: case CON_IFPINVENTORY:
case CON_IFRND: case CON_IFRND:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_IFPDISTL: case CON_IFPDISTL:
case CON_IFPDISTG: case CON_IFPDISTG:
case CON_IFWASWEAPON: case CON_IFWASWEAPON:
@ -4459,6 +4544,7 @@ repeatcase:
ReportError(-1); ReportError(-1);
*(scriptptr-1) = 0; *(scriptptr-1) = 0;
initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number); initprintf("%s:%d: warning: expected a move, found a constant.\n",compilefile,line_number);
warning++;
} }
break; break;
case CON_IFPINVENTORY: case CON_IFPINVENTORY:
@ -4467,7 +4553,10 @@ repeatcase:
break; break;
case CON_IFSOUND: case CON_IFSOUND:
if (CheckEventSync(current_event)) if (CheckEventSync(current_event))
{
ReportError(WARNING_REVEVENTSYNC); ReportError(WARNING_REVEVENTSYNC);
warning++;
}
default: default:
transnum(LABEL_DEFINE); transnum(LABEL_DEFINE);
break; break;
@ -4617,13 +4706,14 @@ repeatcase:
if (*textptr == '/' || *textptr == ' ') if (*textptr == '/' || *textptr == ' ')
{ {
initprintf("%s:%d: warning: invalid character in function name.\n",compilefile,line_number); initprintf("%s:%d: warning: invalid character in function name.\n",compilefile,line_number);
warning++;
while (*textptr != 0x0a && *textptr != 0x0d && *textptr != 0) textptr++; while (*textptr != 0x0a && *textptr != 0x0d && *textptr != 0) textptr++;
break; break;
} }
if (i >= MAXGAMEFUNCLEN-1) if (i >= MAXGAMEFUNCLEN-1)
{ {
initprintf("%s:%d: warning: function name exceeds limit of %d characters.\n",compilefile,line_number,MAXGAMEFUNCLEN); initprintf("%s:%d: warning: function name exceeds limit of %d characters, truncating.\n",compilefile,line_number,MAXGAMEFUNCLEN);
// error++; warning++;
while (*textptr != 0x0a && *textptr != 0x0d && *textptr != 0) textptr++; while (*textptr != 0x0a && *textptr != 0x0d && *textptr != 0) textptr++;
break; break;
} }
@ -5152,7 +5242,10 @@ repeatcase:
case CON_MIKESND: case CON_MIKESND:
case CON_TOSSWEAPON: case CON_TOSSWEAPON:
if (!CheckEventSync(current_event)) if (!CheckEventSync(current_event))
{
ReportError(WARNING_EVENTSYNC); ReportError(WARNING_EVENTSYNC);
warning++;
}
case CON_NULLOP: case CON_NULLOP:
case CON_STOPALLSOUNDS: case CON_STOPALLSOUNDS:
return 0; return 0;
@ -5263,8 +5356,8 @@ static void passone(void)
{ {
while (parsecommand() == 0); while (parsecommand() == 0);
if ((error+warning) > 63) if (error > 63)
initprintf("fatal error: too many warnings or errors: Aborted\n"); initprintf("fatal error: too many errors: Aborted\n");
#ifdef DEBUG #ifdef DEBUG
{ {
@ -5582,7 +5675,7 @@ void loadefs(const char *filenam)
if (warning|error) if (warning|error)
initprintf("Found %d warning(s), %d error(s).\n",warning,error); initprintf("Found %d warning(s), %d error(s).\n",warning,error);
if (error == 0 && warning != 0) /* if (error == 0 && warning != 0)
{ {
if (groupfile != -1 && loadfromgrouponly == 0) if (groupfile != -1 && loadfromgrouponly == 0)
{ {
@ -5598,7 +5691,7 @@ void loadefs(const char *filenam)
return; return;
} }
} }
} } */
if (error) if (error)
{ {

View file

@ -5046,7 +5046,7 @@ static int parse(void)
hittype[g_i].extra = 1; hittype[g_i].extra = 1;
g_sp->zvel = 0; g_sp->zvel = 0;
} }
else if (g_sp->zvel > 2048 && sector[g_sp->sectnum].lotag != 1) else if (g_sp->zvel > 2048 /* && sector[g_sp->sectnum].lotag != 1*/)
{ {
j = g_sp->sectnum; j = g_sp->sectnum;
pushmove(&g_sp->x,&g_sp->y,&g_sp->z,(short*)&j,128L,(4L<<8),(4L<<8),CLIPMASK0); pushmove(&g_sp->x,&g_sp->y,&g_sp->z,(short*)&j,128L,(4L<<8),(4L<<8),CLIPMASK0);
@ -5065,9 +5065,18 @@ static int parse(void)
} }
else if (sector[g_sp->sectnum].lotag == 1) else if (sector[g_sp->sectnum].lotag == 1)
{ {
intptr_t *moveptr = (intptr_t *)g_t[1];
switch (dynamictostatic[g_sp->picnum]) switch (dynamictostatic[g_sp->picnum])
{ {
default: default:
// fix for flying/jumping monsters getting stuck in water
if (g_sp->statnum != MAXSTATUS && actorscrptr[g_sp->picnum] &&
((moveptr && *(moveptr+1)) || g_sp->hitag & jumptoplayer))
{
// OSD_Printf("%d\n",*(moveptr+1));
break;
}
// OSD_Printf("hitag: %d\n",g_sp->hitag);
g_sp->z += (24<<8); g_sp->z += (24<<8);
case OCTABRAIN__STATIC: case OCTABRAIN__STATIC:
case COMMANDER__STATIC: case COMMANDER__STATIC:
@ -5583,6 +5592,19 @@ static int parse(void)
case CON_CHANGESPRITESTAT: case CON_CHANGESPRITESTAT:
if ((i<0 || i>=MAXSPRITES) && checkCON) {OSD_Printf(CON_ERROR "Invalid sprite %d\n",line_num,keyw[g_tw],i);break;} if ((i<0 || i>=MAXSPRITES) && checkCON) {OSD_Printf(CON_ERROR "Invalid sprite %d\n",line_num,keyw[g_tw],i);break;}
if ((j<0 || j>=MAXSTATUS) && checkCON) {OSD_Printf(CON_ERROR "Invalid status %d\n",line_num,keyw[g_tw],j);break;} if ((j<0 || j>=MAXSTATUS) && checkCON) {OSD_Printf(CON_ERROR "Invalid status %d\n",line_num,keyw[g_tw],j);break;}
/* initialize actor pointers when changing to an actor statnum because they usually
have garbage left over from being handled as a hard coded object */
if ((j == 1 || j == 2) && actorscrptr[sprite[i].picnum])
{
T5 = *(actorscrptr[sprite[i].picnum]+1);
T2 = *(actorscrptr[sprite[i].picnum]+2);
sprite[i].hitag = *(actorscrptr[sprite[i].picnum]+3);
}
else
{
T2=T5=0;
sprite[i].hitag = 0;
}
changespritestat(i,j); changespritestat(i,j);
break; break;
case CON_CHANGESPRITESECT: case CON_CHANGESPRITESECT:

View file

@ -42,6 +42,7 @@ int32 lastcontroltime; //MED
void setpal(player_struct *p) void setpal(player_struct *p)
{ {
if (p->heat_on) p->palette = slimepal; if (p->heat_on) p->palette = slimepal;
else if (p->cursectnum < 0) p->palette = palette;
else if ((sector[p->cursectnum].ceilingpicnum >= FLOORSLIME)&&(sector[p->cursectnum].ceilingpicnum <=FLOORSLIME+2)) else if ((sector[p->cursectnum].ceilingpicnum >= FLOORSLIME)&&(sector[p->cursectnum].ceilingpicnum <=FLOORSLIME+2))
{ {
p->palette = slimepal; p->palette = slimepal;
@ -50,7 +51,6 @@ void setpal(player_struct *p)
{ {
if (sector[p->cursectnum].lotag == 2) p->palette = waterpal; if (sector[p->cursectnum].lotag == 2) p->palette = waterpal;
else p->palette = palette; else p->palette = palette;
} }
restorepalette = 1; restorepalette = 1;
} }
@ -502,7 +502,7 @@ int shoot(int i,int atwith)
hittype[k].temp_data[7] = hitsect; hittype[k].temp_data[7] = hitsect;
hittype[k].temp_data[8] = hitspr; hittype[k].temp_data[8] = hitspr;
} }
if (projectile[atwith].sound > -1) spritesound(projectile[atwith].sound,j); if (projectile[atwith].sound >= 0) spritesound(projectile[atwith].sound,j);
} }
if (p >= 0 && g_player[p].ps->steroids_amount > 0 && g_player[p].ps->steroids_amount < 400) if (p >= 0 && g_player[p].ps->steroids_amount > 0 && g_player[p].ps->steroids_amount < 400)
@ -650,7 +650,7 @@ int shoot(int i,int atwith)
if ((projectile[atwith].range > 0) && ((klabs(sx-hitx)+klabs(sy-hity)) > projectile[atwith].range)) return -1; if ((projectile[atwith].range > 0) && ((klabs(sx-hitx)+klabs(sy-hity)) > projectile[atwith].range)) return -1;
if (projectile[atwith].trail > -1) if (projectile[atwith].trail >= 0)
hitscantrail(sx,sy,sz,hitx,hity,hitz,sa,atwith); hitscantrail(sx,sy,sz,hitx,hity,hitz,sa,atwith);
if (projectile[atwith].workslike & PROJECTILE_FLAG_WATERBUBBLES) if (projectile[atwith].workslike & PROJECTILE_FLAG_WATERBUBBLES)
@ -898,7 +898,7 @@ DOSKIPBULLETHOLE:
} }
// else zvel = (100-g_player[p].ps->horiz-g_player[p].ps->horizoff)*81; // else zvel = (100-g_player[p].ps->horiz-g_player[p].ps->horizoff)*81;
else zvel = ((100-g_player[p].ps->horiz-g_player[p].ps->horizoff)*(projectile[atwith].vel/8)); else zvel = ((100-g_player[p].ps->horiz-g_player[p].ps->horizoff)*(projectile[atwith].vel/8));
if (projectile[atwith].sound > -1) spritesound(projectile[atwith].sound,i); if (projectile[atwith].sound >= 0) spritesound(projectile[atwith].sound,i);
} }
else else
{ {
@ -1908,8 +1908,9 @@ static int animatefist(int gs,int snum)
if (sprite[g_player[snum].ps->i].pal == 1) if (sprite[g_player[snum].ps->i].pal == 1)
fistpal = 1; fistpal = 1;
else else if (g_player[snum].ps->cursectnum >= 0)
fistpal = sector[g_player[snum].ps->cursectnum].floorpal; fistpal = sector[g_player[snum].ps->cursectnum].floorpal;
else fistpal = 0;
rotatesprite( rotatesprite(
(-fisti+222+(g_player[snum].sync->avel>>4))<<16, (-fisti+222+(g_player[snum].sync->avel>>4))<<16,
@ -1922,7 +1923,7 @@ static int animatefist(int gs,int snum)
static int animateknee(int gs,int snum) static int animateknee(int gs,int snum)
{ {
static signed char knee_y[] = {0,-8,-16,-32,-64,-84,-108,-108,-108,-72,-32,-8}; static signed char knee_y[] = {0,-8,-16,-32,-64,-84,-108,-108,-108,-72,-32,-8};
int looking_arc, pal; int looking_arc, pal = g_player[snum].ps->palookup;
if (g_player[snum].ps->knee_incs > 11 || g_player[snum].ps->knee_incs == 0 || sprite[g_player[snum].ps->i].extra <= 0) return 0; if (g_player[snum].ps->knee_incs > 11 || g_player[snum].ps->knee_incs == 0 || sprite[g_player[snum].ps->i].extra <= 0) return 0;
@ -1932,7 +1933,7 @@ static int animateknee(int gs,int snum)
if (sprite[g_player[snum].ps->i].pal == 1) if (sprite[g_player[snum].ps->i].pal == 1)
pal = 1; pal = 1;
else else if (g_player[snum].ps->cursectnum >= 0)
{ {
pal = sector[g_player[snum].ps->cursectnum].floorpal; pal = sector[g_player[snum].ps->cursectnum].floorpal;
if (pal == 0) if (pal == 0)
@ -1947,7 +1948,7 @@ static int animateknee(int gs,int snum)
static int animateknuckles(int gs,int snum) static int animateknuckles(int gs,int snum)
{ {
static char knuckle_frames[] = {0,1,2,2,3,3,3,2,2,1,0}; static char knuckle_frames[] = {0,1,2,2,3,3,3,2,2,1,0};
int looking_arc, pal; int looking_arc, pal = 0;
if (g_player[snum].ps->knuckle_incs == 0 || sprite[g_player[snum].ps->i].extra <= 0) return 0; if (g_player[snum].ps->knuckle_incs == 0 || sprite[g_player[snum].ps->i].extra <= 0) return 0;
@ -1957,7 +1958,7 @@ static int animateknuckles(int gs,int snum)
if (sprite[g_player[snum].ps->i].pal == 1) if (sprite[g_player[snum].ps->i].pal == 1)
pal = 1; pal = 1;
else else if (g_player[snum].ps->cursectnum >= 0)
pal = sector[g_player[snum].ps->cursectnum].floorpal; pal = sector[g_player[snum].ps->cursectnum].floorpal;
myospal(160+(g_player[snum].sync->avel>>4)-(g_player[snum].ps->look_ang>>1),looking_arc+180-((g_player[snum].ps->horiz-g_player[snum].ps->horizoff)>>4),CRACKKNUCKLES+knuckle_frames[g_player[snum].ps->knuckle_incs>>1],gs,4,pal); myospal(160+(g_player[snum].sync->avel>>4)-(g_player[snum].ps->look_ang>>1),looking_arc+180-((g_player[snum].ps->horiz-g_player[snum].ps->horizoff)>>4),CRACKKNUCKLES+knuckle_frames[g_player[snum].ps->knuckle_incs>>1],gs,4,pal);
@ -2053,7 +2054,7 @@ void displaymasks(int snum)
if (sprite[g_player[snum].ps->i].pal == 1) if (sprite[g_player[snum].ps->i].pal == 1)
p = 1; p = 1;
else if (g_player[snum].ps->cursectnum > -1) else if (g_player[snum].ps->cursectnum >= 0)
p = sector[g_player[snum].ps->cursectnum].floorpal; p = sector[g_player[snum].ps->cursectnum].floorpal;
else p = 0; else p = 0;
@ -2205,7 +2206,7 @@ void displayweapon(int snum)
pal = 1; pal = 1;
else else
{ {
if (p->cursectnum > -1) if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
if (pal == 0) if (pal == 0)
pal = p->palookup; pal = p->palookup;
@ -2254,7 +2255,7 @@ void displayweapon(int snum)
pal = 1; pal = 1;
else else
{ {
if (p->cursectnum > -1) if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
if (pal == 0) if (pal == 0)
pal = p->palookup; pal = p->palookup;
@ -2278,7 +2279,7 @@ void displayweapon(int snum)
{ {
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
pal = 1; pal = 1;
else if (p->cursectnum > -1) else if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
else pal = 0; else pal = 0;
@ -2308,7 +2309,7 @@ void displayweapon(int snum)
{ {
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
pal = 1; pal = 1;
else if (p->cursectnum > -1) else if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
else pal = 0; else pal = 0;
@ -2337,7 +2338,7 @@ void displayweapon(int snum)
{ {
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
pal = 1; pal = 1;
else if (p->cursectnum > -1) else if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
else pal = 0; else pal = 0;
@ -2423,7 +2424,7 @@ void displayweapon(int snum)
{ {
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
pal = 1; pal = 1;
else if (p->cursectnum > -1) else if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
else pal = 0; else pal = 0;
@ -2474,7 +2475,7 @@ void displayweapon(int snum)
{ {
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
pal = 1; pal = 1;
else if (p->cursectnum > -1) else if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
else pal = 0; else pal = 0;
@ -2529,7 +2530,7 @@ void displayweapon(int snum)
{ {
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
pal = 1; pal = 1;
else if (p->cursectnum > -1) else if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
else pal = 0; else pal = 0;
@ -2566,7 +2567,7 @@ void displayweapon(int snum)
static char remote_frames[] = {0,1,1,2,1,1,0,0,0,0,0}; static char remote_frames[] = {0,1,1,2,1,1,0,0,0,0,0};
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
pal = 1; pal = 1;
else if (p->cursectnum > -1) else if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
else pal = 0; else pal = 0;
@ -2587,7 +2588,7 @@ void displayweapon(int snum)
{ {
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
pal = 1; pal = 1;
else if (p->cursectnum > -1) else if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
else pal = 0; else pal = 0;
@ -2624,7 +2625,7 @@ void displayweapon(int snum)
{ {
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
pal = 1; pal = 1;
else if (p->cursectnum > -1) else if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
else pal = 0; else pal = 0;
@ -2655,7 +2656,7 @@ void displayweapon(int snum)
looking_arc += 18; looking_arc += 18;
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
pal = 1; pal = 1;
else if (p->cursectnum > -1) else if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
else pal = 0; else pal = 0;
{ {
@ -2698,7 +2699,7 @@ void displayweapon(int snum)
looking_arc += 18; looking_arc += 18;
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
pal = 1; pal = 1;
else if (p->cursectnum > -1) else if (p->cursectnum >= 0)
pal = sector[p->cursectnum].floorpal; pal = sector[p->cursectnum].floorpal;
else pal = 0; else pal = 0;
if (((*kb) > 0) && ((*kb) < aplWeaponTotalTime[p->curr_weapon][snum])) if (((*kb) > 0) && ((*kb) < aplWeaponTotalTime[p->curr_weapon][snum]))
@ -3207,7 +3208,7 @@ static int doincrements(player_struct *p)
} }
} }
if (p->cursectnum > -1 && p->scuba_on == 0 && sector[p->cursectnum].lotag == 2) if (p->cursectnum >= 0 && p->scuba_on == 0 && sector[p->cursectnum].lotag == 2)
{ {
if (p->scuba_amount > 0) if (p->scuba_amount > 0)
{ {
@ -3335,10 +3336,9 @@ void processinput(int snum)
truefdist = klabs(p->posz-j); truefdist = klabs(p->posz-j);
/* wtf is this supposed to do? /* wtf is this supposed to do? */
if ((lz&49152) == 16384 && psectlotag == 1 && truefdist > PHEIGHT+(16<<8)) if ((lz&49152) == 16384 && psectlotag == 1 && truefdist > PHEIGHT+(16<<8))
psectlotag = 0; psectlotag = 0;
*/
hittype[pi].floorz = fz; hittype[pi].floorz = fz;
hittype[pi].ceilingz = cz; hittype[pi].ceilingz = cz;
@ -4006,7 +4006,7 @@ void processinput(int snum)
else else
{ {
if (p->footprintcount > 0 && p->on_ground) if (p->footprintcount > 0 && p->on_ground)
if (p->cursectnum > -1 && (sector[p->cursectnum].floorstat&2) != 2) if (p->cursectnum >= 0 && (sector[p->cursectnum].floorstat&2) != 2)
{ {
for (j=headspritesect[psect];j>=0;j=nextspritesect[j]) for (j=headspritesect[psect];j>=0;j=nextspritesect[j])
if (sprite[j].picnum == FOOTPRINTS || sprite[j].picnum == FOOTPRINTS2 || sprite[j].picnum == FOOTPRINTS3 || sprite[j].picnum == FOOTPRINTS4) if (sprite[j].picnum == FOOTPRINTS || sprite[j].picnum == FOOTPRINTS2 || sprite[j].picnum == FOOTPRINTS3 || sprite[j].picnum == FOOTPRINTS4)
@ -4016,7 +4016,7 @@ void processinput(int snum)
if (j < 0) if (j < 0)
{ {
p->footprintcount--; p->footprintcount--;
if (p->cursectnum > -1 && sector[p->cursectnum].lotag == 0 && sector[p->cursectnum].hitag == 0) if (p->cursectnum >= 0 && sector[p->cursectnum].lotag == 0 && sector[p->cursectnum].hitag == 0)
{ {
switch (TRAND&3) switch (TRAND&3)
{ {
@ -4059,7 +4059,7 @@ void processinput(int snum)
} }
if ((p->posz+p->poszv) >= (fz-(i<<8)) && p->cursectnum >= 0) // hit the ground if ((p->posz+p->poszv) >= (fz-(i<<8)) && p->cursectnum >= 0) // hit the ground
if (psectlotag != 1) if (sector[p->cursectnum].lotag != 1)
{ {
if (p->falling_counter > 62) quickkill(p); if (p->falling_counter > 62) quickkill(p);
@ -4422,7 +4422,7 @@ HORIZONLY:
if (psectlotag == 1 || p->spritebridge == 1) i = (4L<<8); if (psectlotag == 1 || p->spritebridge == 1) i = (4L<<8);
else i = (20L<<8); else i = (20L<<8);
if (p->cursectnum > -1 && sector[p->cursectnum].lotag == 2) k = 0; if (p->cursectnum >= 0 && sector[p->cursectnum].lotag == 2) k = 0;
else k = 1; else k = 1;
if (ud.clipping) if (ud.clipping)
@ -4476,7 +4476,7 @@ HORIZONLY:
} }
} }
if (p->cursectnum > -1 && truefdist < PHEIGHT && p->on_ground && psectlotag != 1 && shrunk == 0 && sector[p->cursectnum].lotag == 1) if (p->cursectnum >= 0 && truefdist < PHEIGHT && p->on_ground && psectlotag != 1 && shrunk == 0 && sector[p->cursectnum].lotag == 1)
if (!isspritemakingsound(pi,DUKE_ONWATER)) if (!isspritemakingsound(pi,DUKE_ONWATER))
spritesound(DUKE_ONWATER,pi); spritesound(DUKE_ONWATER,pi);