- tabification of new sources and replacement of the CON instruction symbols.

# Conflicts:
#	source/games/duke/src/zz_gamedef.cpp
This commit is contained in:
Christoph Oelckers 2020-05-12 13:43:24 +02:00
parent deef1b5936
commit 358d1a460f
16 changed files with 6687 additions and 6497 deletions

View file

@ -5,6 +5,7 @@ set( PCH_SOURCES
src/actors_d.cpp src/actors_d.cpp
src/actors_lava.cpp src/actors_lava.cpp
src/bowling.cpp src/bowling.cpp
src/gamedef.cpp
src/zz_actors.cpp src/zz_actors.cpp
src/sectors.cpp src/sectors.cpp
src/sectors_d.cpp src/sectors_d.cpp

View file

@ -1577,7 +1577,7 @@ bool queball(int i, int pocket, int queball, int stripeball)
if (x < 1596) if (x < 1596)
{ {
// if(s->pal == 12) // if(s->pal == 12)
{ {
j = getincangle(ps[p].getang(), getangle(s->x - ps[p].posx, s->y - ps[p].posy)); j = getincangle(ps[p].getang(), getangle(s->x - ps[p].posx, s->y - ps[p].posy));
if (j > -64 && j < 64 && PlayerInput(p, SK_OPEN)) if (j > -64 && j < 64 && PlayerInput(p, SK_OPEN))
@ -3174,7 +3174,7 @@ void handle_se30(int i, int JIBS6)
l = nextspritesect[j]; l = nextspritesect[j];
if (sprite[j].statnum == 1 && badguy(&sprite[j]) && sprite[j].picnum != SECTOREFFECTOR && sprite[j].picnum != LOCATORS) if (sprite[j].statnum == 1 && badguy(&sprite[j]) && sprite[j].picnum != SECTOREFFECTOR && sprite[j].picnum != LOCATORS)
{ {
// if(sprite[j].sectnum != s->sectnum) // if(sprite[j].sectnum != s->sectnum)
{ {
short k = sprite[j].sectnum; short k = sprite[j].sectnum;
updatesector(sprite[j].x, sprite[j].y, &k); updatesector(sprite[j].x, sprite[j].y, &k);
@ -3289,18 +3289,18 @@ void handle_se03(int i)
if (t[4] == 0) return; if (t[4] == 0) return;
int x, p = findplayer(s, &x); int x, p = findplayer(s, &x);
// if(t[5] > 0) { t[5]--; break; } // if(t[5] > 0) { t[5]--; break; }
if ((global_random / (sh + 1) & 31) < 4 && !t[2]) if ((global_random / (sh + 1) & 31) < 4 && !t[2])
{ {
// t[5] = 4+(global_random&7); // t[5] = 4+(global_random&7);
sc->ceilingpal = s->owner >> 8; sc->ceilingpal = s->owner >> 8;
sc->floorpal = s->owner & 0xff; sc->floorpal = s->owner & 0xff;
t[0] = s->shade + (global_random & 15); t[0] = s->shade + (global_random & 15);
} }
else else
{ {
// t[5] = 4+(global_random&3); // t[5] = 4+(global_random&3);
sc->ceilingpal = s->pal; sc->ceilingpal = s->pal;
sc->floorpal = s->pal; sc->floorpal = s->pal;
t[0] = t[3]; t[0] = t[3];

View file

@ -1932,7 +1932,7 @@ void movetransports_d(void)
switch (sprite[j].statnum) switch (sprite[j].statnum)
{ {
case STAT_PLAYER: // Player case STAT_PLAYER: // Player
if (sprite[j].owner != -1) if (sprite[j].owner != -1)
{ {
@ -2009,7 +2009,7 @@ void movetransports_d(void)
k = 0; k = 0;
if (onfloorz && sectlotag == ST_1_ABOVE_WATER && ps[p].on_ground && ps[p].posz > (sector[sect].floorz - (16 << 8)) && (PlayerInput(p, SK_CROUCH) || ps[p].poszv > 2048)) if (onfloorz && sectlotag == ST_1_ABOVE_WATER && ps[p].on_ground && ps[p].posz > (sector[sect].floorz - (16 << 8)) && (PlayerInput(p, SK_CROUCH) || ps[p].poszv > 2048))
// if( onfloorz && sectlotag == 1 && ps[p].posz > (sector[sect].floorz-(6<<8)) ) // if( onfloorz && sectlotag == 1 && ps[p].posz > (sector[sect].floorz-(6<<8)) )
{ {
k = 1; k = 1;
if (screenpeek == p) if (screenpeek == p)
@ -2029,7 +2029,7 @@ void movetransports_d(void)
if (onfloorz && sectlotag == ST_2_UNDERWATER && ps[p].posz < (sector[sect].ceilingz + (6 << 8))) if (onfloorz && sectlotag == ST_2_UNDERWATER && ps[p].posz < (sector[sect].ceilingz + (6 << 8)))
{ {
k = 1; k = 1;
// if( sprite[j].extra <= 0) break; // if( sprite[j].extra <= 0) break;
if (screenpeek == p) if (screenpeek == p)
{ {
FX_StopAllSounds(); FX_StopAllSounds();
@ -2137,8 +2137,8 @@ void movetransports_d(void)
break; break;
case WATERBUBBLE: case WATERBUBBLE:
// if( rnd(192) && sprite[j].picnum == WATERBUBBLE) // if( rnd(192) && sprite[j].picnum == WATERBUBBLE)
// break; // break;
if (sectlotag > 0) if (sectlotag > 0)
{ {
@ -2470,8 +2470,8 @@ static void greenslime(int i)
s->cstat &= 65535 - 8; s->cstat &= 65535 - 8;
s->picnum = GREENSLIME + 4; s->picnum = GREENSLIME + 4;
// if(s->yrepeat > 62) // if(s->yrepeat > 62)
// guts(s,JIBS6,5,myconnectindex); // guts(s,JIBS6,5,myconnectindex);
if (s->xrepeat > 32) s->xrepeat -= krand() & 7; if (s->xrepeat > 32) s->xrepeat -= krand() & 7;
if (s->yrepeat > 16) s->yrepeat -= krand() & 7; if (s->yrepeat > 16) s->yrepeat -= krand() & 7;
@ -3453,7 +3453,7 @@ void moveeffectors_d(void) //STATNUM 3
if ((sprite[j].lotag == 14) && (sh == sprite[j].hitag) && (hittype[j].temp_data[0] == t[0])) if ((sprite[j].lotag == 14) && (sh == sprite[j].hitag) && (hittype[j].temp_data[0] == t[0]))
{ {
sprite[j].xvel = s->xvel; sprite[j].xvel = s->xvel;
// if( t[4] == 1 ) // if( t[4] == 1 )
{ {
if (hittype[j].temp_data[5] == 0) if (hittype[j].temp_data[5] == 0)
hittype[j].temp_data[5] = dist(&sprite[j], s); hittype[j].temp_data[5] = dist(&sprite[j], s);

File diff suppressed because it is too large Load diff

View file

@ -1691,7 +1691,7 @@ void movetransports_r(void)
switch (sprite[j].statnum) switch (sprite[j].statnum)
{ {
case STAT_PLAYER: // Player case STAT_PLAYER: // Player
if (sprite[j].owner != -1) if (sprite[j].owner != -1)
{ {
@ -2978,12 +2978,12 @@ static int henstand(int i)
void moveactors_r(void) void moveactors_r(void)
{ {
int x, nexti; int x, nexti;
int j, sect, p; int j, sect, p;
spritetype *s; spritetype *s;
dojaildoor(); dojaildoor();
moveminecart(); moveminecart();
if (isRRRA()) if (isRRRA())
{ {
@ -2991,176 +2991,176 @@ void moveactors_r(void)
} }
rr_specialstats(); rr_specialstats();
for (int i = headspritestat[STAT_ACTOR]; i >= 0; i = nexti) for (int i = headspritestat[STAT_ACTOR]; i >= 0; i = nexti)
{ {
nexti = nextspritestat[i]; nexti = nextspritestat[i];
bool deleteafterexecute = false; // taking a cue here from RedNukem to not run scripts on deleted sprites. bool deleteafterexecute = false; // taking a cue here from RedNukem to not run scripts on deleted sprites.
s = &sprite[i]; s = &sprite[i];
sect = s->sectnum; sect = s->sectnum;
if( s->xrepeat == 0 || sect < 0 || sect >= MAXSECTORS) if( s->xrepeat == 0 || sect < 0 || sect >= MAXSECTORS)
{ {
deletesprite(i); deletesprite(i);
continue; continue;
} }
auto t = &hittype[i].temp_data[0]; auto t = &hittype[i].temp_data[0];
hittype[i].bposx = s->x; hittype[i].bposx = s->x;
hittype[i].bposy = s->y; hittype[i].bposy = s->y;
hittype[i].bposz = s->z; hittype[i].bposz = s->z;
switch(s->picnum) switch(s->picnum)
{ {
case RESPAWNMARKERRED: case RESPAWNMARKERRED:
case RESPAWNMARKERYELLOW: case RESPAWNMARKERYELLOW:
case RESPAWNMARKERGREEN: case RESPAWNMARKERGREEN:
if (!respawnmarker(i, RESPAWNMARKERYELLOW, RESPAWNMARKERGREEN)) continue; if (!respawnmarker(i, RESPAWNMARKERYELLOW, RESPAWNMARKERGREEN)) continue;
break; break;
case RAT: case RAT:
if (!rat(i, !isRRRA())) continue; if (!rat(i, !isRRRA())) continue;
break; break;
case RRTILE3190: case RRTILE3190:
case RRTILE3191: case RRTILE3191:
case RRTILE3192: case RRTILE3192:
if (!chickenplant) if (!chickenplant)
{ {
deletesprite(i); deletesprite(i);
continue; continue;
} }
if (sector[sprite[i].sectnum].lotag == 903) if (sector[sprite[i].sectnum].lotag == 903)
makeitfall(i); makeitfall(i);
j = movesprite(i, j = movesprite(i,
(s->xvel*sintable[(s->ang+512)&2047])>>14, (s->xvel*sintable[(s->ang+512)&2047])>>14,
(s->xvel*sintable[s->ang&2047])>>14, (s->xvel*sintable[s->ang&2047])>>14,
s->zvel,CLIPMASK0); s->zvel,CLIPMASK0);
switch (sector[sprite[i].sectnum].lotag) switch (sector[sprite[i].sectnum].lotag)
{ {
case 901: case 901:
sprite[i].picnum = RRTILE3191; sprite[i].picnum = RRTILE3191;
break; break;
case 902: case 902:
sprite[i].picnum = RRTILE3192; sprite[i].picnum = RRTILE3192;
break; break;
case 903: case 903:
if (sprite[i].z >= sector[sprite[i].sectnum].floorz - (8<<8)) if (sprite[i].z >= sector[sprite[i].sectnum].floorz - (8<<8))
{ {
deletesprite(i); deletesprite(i);
continue; continue;
} }
break; break;
case 904: case 904:
deletesprite(i); deletesprite(i);
continue; continue;
break; break;
} }
if ((j & 32768) == 32768) if ((j & 32768) == 32768)
{ {
deletesprite(i); deletesprite(i);
continue; continue;
} }
break; break;
case RRTILE3120: case RRTILE3120:
case RRTILE3122: case RRTILE3122:
case RRTILE3123: case RRTILE3123:
case RRTILE3124: case RRTILE3124:
if (!chickenplant) if (!chickenplant)
{ {
deletesprite(i); deletesprite(i);
continue; continue;
} }
makeitfall(i); makeitfall(i);
j = movesprite(i, j = movesprite(i,
(s->xvel*(sintable[(s->ang+512)&2047]))>>14, (s->xvel*(sintable[(s->ang+512)&2047]))>>14,
(s->xvel*(sintable[s->ang&2047]))>>14, (s->xvel*(sintable[s->ang&2047]))>>14,
s->zvel,CLIPMASK0); s->zvel,CLIPMASK0);
if ((j & 32768) == 32768) if ((j & 32768) == 32768)
{ {
deletesprite(i); deletesprite(i);
continue; continue;
} }
if (sector[s->sectnum].lotag == 903) if (sector[s->sectnum].lotag == 903)
{ {
if (sprite[i].z >= sector[sprite[i].sectnum].floorz - (4<<8)) if (sprite[i].z >= sector[sprite[i].sectnum].floorz - (4<<8))
{ {
deletesprite(i); deletesprite(i);
continue; continue;
} }
} }
else if (sector[s->sectnum].lotag == 904) else if (sector[s->sectnum].lotag == 904)
{ {
deletesprite(i); deletesprite(i);
continue; continue;
} }
break; break;
case RRTILE3132: case RRTILE3132:
if (!chickenplant) if (!chickenplant)
{ {
deletesprite(i); deletesprite(i);
continue; continue;
} }
makeitfall(i); makeitfall(i);
j = movesprite(i, j = movesprite(i,
(s->xvel*sintable[(s->ang+512)&2047])>>14, (s->xvel*sintable[(s->ang+512)&2047])>>14,
(s->xvel*sintable[s->ang&2047])>>14, (s->xvel*sintable[s->ang&2047])>>14,
s->zvel,CLIPMASK0); s->zvel,CLIPMASK0);
if (s->z >= sector[s->sectnum].floorz - (8<<8)) if (s->z >= sector[s->sectnum].floorz - (8<<8))
{ {
if (sector[s->sectnum].lotag == 1) if (sector[s->sectnum].lotag == 1)
{ {
j = spawn(i,WATERSPLASH2); j = spawn(i,WATERSPLASH2);
sprite[j].z = sector[sprite[j].sectnum].floorz; sprite[j].z = sector[sprite[j].sectnum].floorz;
} }
deletesprite(i); deletesprite(i);
continue; continue;
} }
break; break;
case BOWLINGBALL: case BOWLINGBALL:
if (s->xvel) if (s->xvel)
{ {
if(!S_CheckSoundPlaying(356)) if(!S_CheckSoundPlaying(356))
spritesound(356,i); spritesound(356,i);
} }
else else
{ {
spawn(i,BOWLINGBALLSPRITE); spawn(i,BOWLINGBALLSPRITE);
deletesprite(i); deletesprite(i);
continue; continue;
} }
if (sector[s->sectnum].lotag == 900) if (sector[s->sectnum].lotag == 900)
{ {
S_StopEnvSound(356, -1); S_StopEnvSound(356, -1);
} }
case RRTILE3440: case RRTILE3440:
case RRTILE3440+1: case RRTILE3440+1:
case HENSTAND: case HENSTAND:
case HENSTAND+1: case HENSTAND+1:
{ {
int todo = henstand(i); int todo = henstand(i);
if (todo == 2) deleteafterexecute = true; if (todo == 2) deleteafterexecute = true;
if (todo == 1) continue; if (todo == 1) continue;
break; break;
} }
case QUEBALL: case QUEBALL:
case STRIPEBALL: case STRIPEBALL:
if (!queball(i, POCKET, QUEBALL, STRIPEBALL)) continue; if (!queball(i, POCKET, QUEBALL, STRIPEBALL)) continue;
break; break;
case FORCESPHERE: case FORCESPHERE:
forcesphere(i, FORCESPHERE); forcesphere(i, FORCESPHERE);
continue; continue;
case RECON: case RECON:
case UFO1_RR: case UFO1_RR:
case UFO2: case UFO2:
case UFO3: case UFO3:
case UFO4: case UFO4:
case UFO5: case UFO5:
recon(i, EXPLOSION2, FIRELASER, -1, -1, 457, 8, [](int i) ->int recon(i, EXPLOSION2, FIRELASER, -1, -1, 457, 8, [](int i) ->int
{ {
auto s = &sprite[i]; auto s = &sprite[i];
@ -3178,30 +3178,30 @@ void moveactors_r(void)
return BILLYRAY; return BILLYRAY;
else return -1; else return -1;
}); });
continue; continue;
case OOZ: case OOZ:
ooz(i); ooz(i);
continue; continue;
case EMPTYBIKE: case EMPTYBIKE:
if (!isRRRA()) break;
makeitfall(i);
getglobalz(i);
if (sector[sect].lotag == 1)
{
setsprite(i,s->x,s->y,hittype[i].floorz+(16<<8));
}
break;
case EMPTYBOAT:
if (!isRRRA()) break; if (!isRRRA()) break;
makeitfall(i); makeitfall(i);
getglobalz(i); getglobalz(i);
break; if (sector[sect].lotag == 1)
{
setsprite(i,s->x,s->y,hittype[i].floorz+(16<<8));
}
break;
case TRIPBOMBSPRITE: case EMPTYBOAT:
if (!isRRRA() || (sector[sect].lotag != 1 && sector[sect].lotag != 160)) if (!isRRRA()) break;
makeitfall(i);
getglobalz(i);
break;
case TRIPBOMBSPRITE:
if (!isRRRA() || (sector[sect].lotag != 1 && sector[sect].lotag != 160))
if (s->xvel) if (s->xvel)
{ {
j = movesprite(i, j = movesprite(i,
@ -3210,47 +3210,47 @@ void moveactors_r(void)
s->zvel,CLIPMASK0); s->zvel,CLIPMASK0);
s->xvel--; s->xvel--;
} }
break; break;
case CHEERBOMB: case CHEERBOMB:
if (!isRRRA()) break; if (!isRRRA()) break;
case MORTER: case MORTER:
case HEAVYHBOMB: case HEAVYHBOMB:
heavyhbomb(i); heavyhbomb(i);
continue; continue;
case REACTORBURNT: case REACTORBURNT:
case REACTOR2BURNT: case REACTOR2BURNT:
continue; continue;
case REACTOR: case REACTOR:
case REACTOR2: case REACTOR2:
reactor(i, REACTOR, REACTOR2, REACTOR2BURNT, REACTOR2BURNT); reactor(i, REACTOR, REACTOR2, REACTOR2BURNT, REACTOR2BURNT);
continue; continue;
case RR_CAMERA1: case RR_CAMERA1:
camera(i); camera(i);
continue; continue;
} }
// #ifndef VOLOMEONE // #ifndef VOLOMEONE
if( ud.multimode < 2 && badguy(s) ) if( ud.multimode < 2 && badguy(s) )
{ {
if( actor_tog == 1) if( actor_tog == 1)
{ {
s->cstat = (short)32768; s->cstat = (short)32768;
continue; continue;
} }
else if(actor_tog == 2) s->cstat = 257; else if(actor_tog == 2) s->cstat = 257;
} }
// #endif // #endif
p = findplayer(s,&x); p = findplayer(s,&x);
execute(i,p,x); execute(i,p,x);
if (deleteafterexecute) deletesprite(i); if (deleteafterexecute) deletesprite(i);
} }
} }
@ -3617,7 +3617,7 @@ void moveeffectors_r(void) //STATNUM 3
if ((sprite[j].lotag == 14) && (sh == sprite[j].hitag) && (hittype[j].temp_data[0] == t[0])) if ((sprite[j].lotag == 14) && (sh == sprite[j].hitag) && (hittype[j].temp_data[0] == t[0]))
{ {
sprite[j].xvel = s->xvel; sprite[j].xvel = s->xvel;
// if( t[4] == 1 ) // if( t[4] == 1 )
{ {
if (hittype[j].temp_data[5] == 0) if (hittype[j].temp_data[5] == 0)
hittype[j].temp_data[5] = dist(&sprite[j], s); hittype[j].temp_data[5] = dist(&sprite[j], s);

View file

@ -37,304 +37,304 @@ short pinsectorresetdown(short sect);
void ballreturn(short spr) void ballreturn(short spr)
{ {
short j, i, nexti, nextj; short j, i, nexti, nextj;
i = headspritestat[105]; i = headspritestat[105];
while (i >= 0) while (i >= 0)
{ {
nexti = nextspritestat[i]; nexti = nextspritestat[i];
if (sprite[i].picnum == RRTILE281) if (sprite[i].picnum == RRTILE281)
if (sprite[spr].sectnum == sprite[i].sectnum) if (sprite[spr].sectnum == sprite[i].sectnum)
{ {
j = headspritestat[105]; j = headspritestat[105];
while (j >= 0) while (j >= 0)
{ {
nextj = nextspritestat[j]; nextj = nextspritestat[j];
if (sprite[j].picnum == RRTILE282) if (sprite[j].picnum == RRTILE282)
if (sprite[i].hitag == sprite[j].hitag) if (sprite[i].hitag == sprite[j].hitag)
spawn(j, BOWLINGBALLSPRITE); spawn(j, BOWLINGBALLSPRITE);
if (sprite[j].picnum == RRTILE280) if (sprite[j].picnum == RRTILE280)
if (sprite[i].hitag == sprite[j].hitag) if (sprite[i].hitag == sprite[j].hitag)
if (sprite[j].lotag == 0) if (sprite[j].lotag == 0)
{ {
sprite[j].lotag = 100; sprite[j].lotag = 100;
sprite[j].extra++; sprite[j].extra++;
pinsectorresetdown(sprite[j].sectnum); pinsectorresetdown(sprite[j].sectnum);
} }
j = nextj; j = nextj;
} }
} }
i = nexti; i = nexti;
} }
} }
short pinsectorresetdown(short sect) short pinsectorresetdown(short sect)
{ {
int vel, j; int vel, j;
j = getanimationgoal(&sector[sect].ceilingz); j = getanimationgoal(&sector[sect].ceilingz);
if (j == -1) if (j == -1)
{ {
j = sector[sect].floorz; j = sector[sect].floorz;
vel = 64; vel = 64;
setanimation(sect,&sector[sect].ceilingz,j,vel); setanimation(sect,&sector[sect].ceilingz,j,vel);
return 1; return 1;
} }
return 0; return 0;
} }
short pinsectorresetup(short sect) short pinsectorresetup(short sect)
{ {
int vel, j; int vel, j;
j = getanimationgoal(&sector[sect].ceilingz); j = getanimationgoal(&sector[sect].ceilingz);
if (j == -1) if (j == -1)
{ {
j = sector[nextsectorneighborz(sect,sector[sect].ceilingz,-1,-1)].ceilingz; j = sector[nextsectorneighborz(sect,sector[sect].ceilingz,-1,-1)].ceilingz;
vel = 64; vel = 64;
setanimation(sect,&sector[sect].ceilingz,j,vel); setanimation(sect,&sector[sect].ceilingz,j,vel);
return 1; return 1;
} }
return 0; return 0;
} }
short checkpins(short sect) short checkpins(short sect)
{ {
short i, pin; short i, pin;
int x, y; int x, y;
short pins[10]; short pins[10];
short nexti, tag; short nexti, tag;
pin = 0; pin = 0;
for(i=0;i<10;i++) pins[i] = 0; for(i=0;i<10;i++) pins[i] = 0;
i = headspritesect[sect]; i = headspritesect[sect];
while (i >= 0) while (i >= 0)
{ {
nexti = nextspritesect[i]; nexti = nextspritesect[i];
if (sprite[i].picnum == RRTILE3440) if (sprite[i].picnum == RRTILE3440)
{ {
pin++; pin++;
pins[sprite[i].lotag] = 1; pins[sprite[i].lotag] = 1;
} }
if (sprite[i].picnum == RRTILE280) if (sprite[i].picnum == RRTILE280)
{ {
tag = sprite[i].hitag; tag = sprite[i].hitag;
} }
i = nexti; i = nexti;
} }
if (tag) if (tag)
{ {
tag += 2024; tag += 2024;
tileCopySection(2024,0,0,128,64,tag,0,0); tileCopySection(2024,0,0,128,64,tag,0,0);
for(i=0;i<10;i++) for(i=0;i<10;i++)
{ {
if (pins[i] == 1) if (pins[i] == 1)
{ {
switch (i) switch (i)
{ {
case 0: case 0:
x = 64; x = 64;
y = 48; y = 48;
break; break;
case 1: case 1:
x = 56; x = 56;
y = 40; y = 40;
break; break;
case 2: case 2:
x = 72; x = 72;
y = 40; y = 40;
break; break;
case 3: case 3:
x = 48; x = 48;
y = 32; y = 32;
break; break;
case 4: case 4:
x = 64; x = 64;
y = 32; y = 32;
break; break;
case 5: case 5:
x = 80; x = 80;
y = 32; y = 32;
break; break;
case 6: case 6:
x = 40; x = 40;
y = 24; y = 24;
break; break;
case 7: case 7:
x = 56; x = 56;
y = 24; y = 24;
break; break;
case 8: case 8:
x = 72; x = 72;
y = 24; y = 24;
break; break;
case 9: case 9:
x = 88; x = 88;
y = 24; y = 24;
break; break;
} }
tileCopySection(2023,0,0,8,8,tag,x-4,y-10); tileCopySection(2023,0,0,8,8,tag,x-4,y-10);
} }
} }
} }
return pin; return pin;
} }
void resetpins(short sect) void resetpins(short sect)
{ {
short i, j, nexti, tag; short i, j, nexti, tag;
int x, y; int x, y;
i = headspritesect[sect]; i = headspritesect[sect];
while (i >= 0) while (i >= 0)
{ {
nexti = headspritesect[i]; nexti = headspritesect[i];
if (sprite[i].picnum == 3440) if (sprite[i].picnum == 3440)
deletesprite(i); deletesprite(i);
i = nexti; i = nexti;
} }
i = headspritesect[sect]; i = headspritesect[sect];
while (i >= 0) while (i >= 0)
{ {
nexti = nextspritesect[i]; nexti = nextspritesect[i];
if (sprite[i].picnum == 283) if (sprite[i].picnum == 283)
{ {
j = spawn(i,3440); j = spawn(i,3440);
sprite[j].lotag = sprite[i].lotag; sprite[j].lotag = sprite[i].lotag;
if (sprite[j].lotag == 3 || sprite[j].lotag == 5) if (sprite[j].lotag == 3 || sprite[j].lotag == 5)
{ {
sprite[j].clipdist = (1+(krand()%1))*16+32; sprite[j].clipdist = (1+(krand()%1))*16+32;
} }
else else
{ {
sprite[j].clipdist = (1+(krand()%1))*16+32; sprite[j].clipdist = (1+(krand()%1))*16+32;
} }
sprite[j].ang -= ((krand()&32)-(krand()&64))&2047; sprite[j].ang -= ((krand()&32)-(krand()&64))&2047;
} }
if (sprite[i].picnum == 280) if (sprite[i].picnum == 280)
tag = sprite[i].hitag; tag = sprite[i].hitag;
i = nexti; i = nexti;
} }
if (tag) if (tag)
{ {
tag += LANEPICS+1; tag += LANEPICS+1;
tileCopySection(LANEPICS+1,0,0,128,64,tag,0,0); tileCopySection(LANEPICS+1,0,0,128,64,tag,0,0);
for(i=0;i<10;i++) for(i=0;i<10;i++)
{ {
switch (i) switch (i)
{ {
case 0: case 0:
x = 64; x = 64;
y = 48; y = 48;
break; break;
case 1: case 1:
x = 56; x = 56;
y = 40; y = 40;
break; break;
case 2: case 2:
x = 72; x = 72;
y = 40; y = 40;
break; break;
case 3: case 3:
x = 48; x = 48;
y = 32; y = 32;
break; break;
case 4: case 4:
x = 64; x = 64;
y = 32; y = 32;
break; break;
case 5: case 5:
x = 80; x = 80;
y = 32; y = 32;
break; break;
case 6: case 6:
x = 40; x = 40;
y = 24; y = 24;
break; break;
case 7: case 7:
x = 56; x = 56;
y = 24; y = 24;
break; break;
case 8: case 8:
x = 72; x = 72;
y = 24; y = 24;
break; break;
case 9: case 9:
x = 88; x = 88;
y = 24; y = 24;
break; break;
} }
tileCopySection(LANEPICS,0,0,8,8,tag,x-4,y-10); tileCopySection(LANEPICS,0,0,8,8,tag,x-4,y-10);
} }
} }
} }
void resetlanepics(void) void resetlanepics(void)
{ {
int x, y; int x, y;
short i; short i;
short tag, pic; short tag, pic;
for(tag=0;tag<4;tag++) for(tag=0;tag<4;tag++)
{ {
pic = tag + 1; pic = tag + 1;
if (pic == 0) continue; if (pic == 0) continue;
pic += LANEPICS+1; pic += LANEPICS+1;
tileCopySection(LANEPICS+1,0,0,128,64, pic,0,0); tileCopySection(LANEPICS+1,0,0,128,64, pic,0,0);
for(i=0;i<10;i++) for(i=0;i<10;i++)
{ {
switch (i) switch (i)
{ {
case 0: case 0:
x = 64; x = 64;
y = 48; y = 48;
break; break;
case 1: case 1:
x = 56; x = 56;
y = 40; y = 40;
break; break;
case 2: case 2:
x = 72; x = 72;
y = 40; y = 40;
break; break;
case 3: case 3:
x = 48; x = 48;
y = 32; y = 32;
break; break;
case 4: case 4:
x = 64; x = 64;
y = 32; y = 32;
break; break;
case 5: case 5:
x = 80; x = 80;
y = 32; y = 32;
break; break;
case 6: case 6:
x = 40; x = 40;
y = 24; y = 24;
break; break;
case 7: case 7:
x = 56; x = 56;
y = 24; y = 24;
break; break;
case 8: case 8:
x = 72; x = 72;
y = 24; y = 24;
break; break;
case 9: case 9:
x = 88; x = 88;
y = 24; y = 24;
break; break;
} }
tileCopySection(LANEPICS,0,0,8,8,pic,x-4,y-10); tileCopySection(LANEPICS,0,0,8,8,pic,x-4,y-10);
} }
} }
} }
END_DUKE_NS END_DUKE_NS

View file

@ -0,0 +1,19 @@
#pragma once
struct sprite_type;
BEGIN_DUKE_NS
#define cmd(a) concmd_ ## a,
#define cmdx(a, b) concmd_ ## a,
#define cmda(a,b)
enum EConCommands
{
#include "condef.h"
};
#undef cmd
#undef cmdx
#undef cmda
END_DUKE_NS

View file

@ -0,0 +1,176 @@
cmd(definelevelname) // 0
cmd(actor) // 1
cmd(addammo) // 2
cmd(ifrnd) // 3
cmd(enda) // 4
cmd(ifcansee) // 5
cmd(ifhitweapon) // 6
cmd(action) // 7
cmd(ifpdistl) // 8
cmd(ifpdistg) // 9
cmd(else) // 10
cmd(strength) // 11
cmd(break) // 12
cmd(shoot) // 13
cmd(palfrom) // 14
cmd(sound) // 15
cmd(fall) // 16
cmd(state) // 17
cmd(ends) // 18
cmd(define) // 19
cmdx(comment, "//") // 20
cmd(ifai) // 21
cmd(killit) // 22
cmd(addweapon) // 23
cmd(ai) // 24
cmd(addphealth) // 25
cmd(ifdead) // 26
cmd(ifsquished) // 27
cmd(sizeto) // 28
cmdx(leftbrace, "{") // 29
cmdx(rightbrace, "}") // 30
cmd(spawn) // 31
cmd(move) // 32
cmd(ifwasweapon) // 33
cmd(ifaction) // 34
cmd(ifactioncount) // 35
cmd(resetactioncount) // 36
cmd(debris) // 37
cmd(pstomp) // 38
cmdx(blockcomment, "/*") // 39
cmd(cstat) // 40
cmd(ifmove) // 41
cmd(resetplayer) // 42
cmd(ifonwater) // 43
cmd(ifinwater) // 44
cmd(ifcanshoottarget) // 45
cmd(ifcount) // 46
cmd(resetcount) // 47
cmd(addinventory) // 48
cmd(ifactornotstayput) // 49
cmd(hitradius) // 50
cmd(ifp) // 51
cmd(count) // 52
cmd(ifactor) // 53
cmd(music) // 54
cmd(include) // 55
cmd(ifstrength) // 56
cmd(definesound) // 57
cmd(guts) // 58
cmd(ifspawnedby) // 59
cmd(gamestartup) // 60
cmd(wackplayer) // 61
cmd(ifgapzl) // 62
cmd(ifhitspace) // 63
cmd(ifoutside) // 64
cmd(ifmultiplayer) // 65
cmd(operate) // 66
cmd(ifinspace) // 67
cmd(debug) // 68
cmd(endofgame) // 69
cmd(ifbulletnear) // 70
cmd(ifrespawn) // 71
cmd(iffloordistl) // 72
cmd(ifceilingdistl) // 73
cmd(spritepal) // 74
cmd(ifpinventory) // 75
cmd(betaname) // 76
cmd(cactor) // 77
cmd(ifphealthl) // 78
cmd(definequote) // 79
cmd(quote) // 80
cmd(ifinouterspace) // 81
cmd(ifnotmoving) // 82
cmd(respawnhitag) // 83
cmd(tip) // 84
cmd(ifspritepal) // 85
cmd(money) // 86
cmda(feathers, money) // RR alias
cmd(soundonce) // 87
cmd(addkills) // 88
cmd(stopsound) // 89
cmd(ifawayfromwall) // 90
cmd(ifcanseetarget) // 91
cmd(globalsound) // 92
cmd(lotsofglass) // 93
cmd(ifgotweaponce) // 94
cmd(getlastpal) // 95
cmd(pkick) // 96
cmd(mikesnd) // 97
cmd(useractor) // 98
cmd(sizeat) // 99
cmd(addstrength) // 100
cmd(cstator) // 101
cmd(mail) // 102
cmd(paper) // 103
cmd(tossweapon) // 104
cmd(sleeptime) // 105
cmd(nullop) // 106
cmd(definevolumename) // 107
cmd(defineskillname) // 108
cmd(ifnosounds) // 109
cmd(clipdist) // 110
cmd(ifangdiffl) // 111
cmd(ifplaybackon) // World Tour 112
// WW2GI
cmd(gamevar) // 112
cmd(ifvarl) // 113
cmd(ifvarg) // 114
cmd(setvarvar) // 115
cmd(setvar) // 116
cmd(addvarvar) // 117
cmd(addvar) // 118
cmd(ifvarvarl) // 119
cmd(ifvarvarg) // 120
cmd(addlogvar) // 121
cmd(addlog) // 122
cmd(onevent) // 123
cmd(endevent) // 124
cmd(ifvare) // 125
cmd(ifvarvare) // 126
// RR
cmd(ifnocover) // 110
cmd(ifhittruck) // 111
cmd(iftipcow) // 112
cmd(isdrunk) // 113
cmd(iseat) // 114
cmd(destroyit) // 115
cmd(larrybird) // 116
cmd(strafeleft) // 117
cmd(straferight) // 118
cmd(ifactorhealthg) // 119
cmd(ifactorhealthl) // 120
cmd(slapplayer) // 121
cmd(ifpdrunk) // 122
cmd(tearitup) // 123
cmd(smackbubba) // 124
cmd(soundtagonce) // 125
cmd(soundtag) // 126
cmd(ifsoundid) // 127
cmd(ifsounddist) // 128
cmd(ifonmud) // 129
cmd(ifcoop) // 130
// RRRA
cmd(ifmotofast) // 131
cmd(ifwind) // 132
cmd(smacksprite) // 133
cmd(ifonmoto) // 134
cmd(ifonboat) // 135
cmd(fakebubba) // 136
cmd(mamatrigger) // 137
cmd(mamaspawn) // 138
cmd(mamaquake) // 139
cmd(mamaend) // 141
cmd(newpic) // 142
cmd(garybanjo) // 143
cmd(motoloopsnd) // 144
cmd(ifsizedown) // 145
cmd(rndmove) // 146
// RR Deer Huntin'. These are merely here for reference because the game is not supported.
// cmd(iffindnewspot)
// cmd(ifpupwind)

View file

@ -0,0 +1,166 @@
//-------------------------------------------------------------------------
/*
Copyright (C) 1996, 2003 - 3D Realms Entertainment
This file is part of Enhanced Duke Nukem 3D version 1.5 - Atomic Edition
Duke Nukem 3D is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
Original Source: 1996 - Todd Replogle
Prepared for public release: 03/21/2003 - Charlie Wiederhold, 3D Realms
EDuke enhancements integrated: 04/13/2003 - Matt Saettler
Note: This source file IS NOT USED in EDuke source. It has been split
into many sub-files.
*/
//-------------------------------------------------------------------------
#include "ns.h"
#include <string.h>
#include "concmd.h"
#include "cmdlib.h"
BEGIN_DUKE_NS
// parser state: todo: turn into a class
char* textptr;
int32_t line_count;
//---------------------------------------------------------------------------
//
// synthesize the instruction list
//
//---------------------------------------------------------------------------
#define cmd(a) { #a, concmd_ ## a },
#define cmdx(a, b) { b, concmd_ ## a },
#define cmda(a,b) { #a, concmd_ ## b },
struct ConCommand
{
char cmd[20]; // the longest instruction name is 'ifactornotstayput' at 17 characters so if this changes this field must be enlarged.
int instr;
};
static ConCommand cmdList[] =
{
#include "condef.h"
};
#undef cmd
#undef cmdx
#undef cmda
static int cmdCmp(const void *a, const void *b)
{
auto A = (ConCommand*)a;
auto B = (ConCommand*)b;
return strcmp(A->cmd, B->cmd);
}
void SortCommands()
{
qsort(cmdList, countof(cmdList), sizeof(ConCommand), cmdCmp);
}
//---------------------------------------------------------------------------
//
// binary search for keyword
//
//---------------------------------------------------------------------------
int getkeyword(const char* text)
{
ptrdiff_t min = 0;
ptrdiff_t max = countof(cmdList) - 1;
while (min <= max)
{
int mid = (min + max) >> 1;
const int comp = strcmp(text, cmdList[mid].cmd);
if (comp == 0)
{
return cmdList[mid].instr;
}
else if (comp > 0)
{
min = mid + 1;
}
else
{
max = mid - 1;
}
}
return -1;
}
//---------------------------------------------------------------------------
//
//
//
//---------------------------------------------------------------------------
void skiptoendofline()
{
while (*textptr != 0x0a && *textptr != 0x0d && *textptr != 0)
textptr++;
}
void skipwhitespace()
{
while (*textptr == ' ' || *textptr == '\t' || *textptr == '\r' || *textptr == '\n')
{
if (*textptr == '\n') line_count++;
textptr++;
}
}
void skipblockcomment()
{
while (*textptr != '*' && textptr[1] != '/')
{
if (*textptr == '\n') line_count++;
if (*textptr == 0) return; // reached the end of the file
textptr++;
}
}
bool skipcomments()
{
while (true)
{
skipwhitespace();
if (*textptr == '/' && textptr[1] == '/')
{
skiptoendofline();
continue;
}
if (*textptr == '/' && textptr[1] == '*')
{
skipblockcomment();
continue;
}
// stop if we got something else
break;
}
return *textptr != 0;
}
END_DUKE_NS

View file

@ -55,7 +55,7 @@ enum
do \ do \
{ \ { \
C_ReportError(-1); \ C_ReportError(-1); \
Printf("%s:%d: error: " Text "\n", g_scriptFileName, g_lineNumber, ##__VA_ARGS__); \ Printf("%s:%d: error: " Text "\n", g_scriptFileName, line_count, ##__VA_ARGS__); \
g_errorCnt++; \ g_errorCnt++; \
} while (0) } while (0)
@ -63,7 +63,7 @@ enum
do \ do \
{ \ { \
C_ReportError(-1); \ C_ReportError(-1); \
Printf("%s:%d: warning: " Text "\n", g_scriptFileName, g_lineNumber, ##__VA_ARGS__); \ Printf("%s:%d: warning: " Text "\n", g_scriptFileName, line_count, ##__VA_ARGS__); \
g_warningCnt++; \ g_warningCnt++; \
} while (0) } while (0)
@ -91,7 +91,7 @@ extern const uint32_t CheatFunctionFlags[];
extern const uint8_t CheatFunctionIDs[]; extern const uint8_t CheatFunctionIDs[];
extern int32_t g_errorCnt; extern int32_t g_errorCnt;
extern int32_t g_lineNumber; extern int32_t line_count;
extern int32_t g_scriptVersion; extern int32_t g_scriptVersion;
extern int32_t g_totalLines; extern int32_t g_totalLines;
extern int32_t g_warningCnt; extern int32_t g_warningCnt;
@ -177,8 +177,19 @@ enum ScriptError_t
WARNING_DUPLICATEDEFINITION, WARNING_DUPLICATEDEFINITION,
WARNING_LABELSONLY, WARNING_LABELSONLY,
WARNING_VARMASKSKEYWORD, WARNING_VARMASKSKEYWORD,
ERROR_COULDNOTFIND,
ERROR_NOTAGAMEDEF,
ERROR_NOENDSWITCH
}; };
enum
{
};
#include "concmd.h"
enum ScriptKeywords_t enum ScriptKeywords_t
{ {
CON_ELSE, // 0 CON_ELSE, // 0

File diff suppressed because it is too large Load diff

File diff suppressed because it is too large Load diff

File diff suppressed because it is too large Load diff

File diff suppressed because it is too large Load diff

File diff suppressed because it is too large Load diff

View file

@ -275,7 +275,7 @@ void Gv_NewVar(const char *pszLabel, intptr_t lValue, uint32_t dwFlags)
{ {
g_errorCnt++; g_errorCnt++;
C_ReportError(-1); C_ReportError(-1);
Printf("%s:%d: error: too many gamevars!\n",g_scriptFileName,g_lineNumber); Printf("%s:%d: error: too many gamevars!\n",g_scriptFileName,line_count);
return; return;
} }
@ -283,7 +283,7 @@ void Gv_NewVar(const char *pszLabel, intptr_t lValue, uint32_t dwFlags)
{ {
g_errorCnt++; g_errorCnt++;
C_ReportError(-1); C_ReportError(-1);
Printf("%s:%d: error: variable name `%s' exceeds limit of %d characters.\n",g_scriptFileName,g_lineNumber,pszLabel, MAXVARLABEL); Printf("%s:%d: error: variable name `%s' exceeds limit of %d characters.\n",g_scriptFileName,line_count,pszLabel, MAXVARLABEL);
return; return;
} }
@ -295,7 +295,7 @@ void Gv_NewVar(const char *pszLabel, intptr_t lValue, uint32_t dwFlags)
if (EDUKE32_PREDICT_FALSE(aGameVars[gV].flags & (GAMEVAR_PTR_MASK))) if (EDUKE32_PREDICT_FALSE(aGameVars[gV].flags & (GAMEVAR_PTR_MASK)))
{ {
C_ReportError(-1); C_ReportError(-1);
Printf("%s:%d: warning: cannot redefine internal gamevar `%s'.\n",g_scriptFileName,g_lineNumber,label+(g_labelCnt<<6)); Printf("%s:%d: warning: cannot redefine internal gamevar `%s'.\n",g_scriptFileName,line_count,label+(g_labelCnt<<6));
return; return;
} }
else if (EDUKE32_PREDICT_FALSE(!(aGameVars[gV].flags & GAMEVAR_SYSTEM))) else if (EDUKE32_PREDICT_FALSE(!(aGameVars[gV].flags & GAMEVAR_SYSTEM)))