mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-11 18:50:46 +00:00
git-svn-id: https://svn.eduke32.com/eduke32@1021 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
9e39f47e0e
commit
bdb2f26c13
1 changed files with 145 additions and 155 deletions
|
@ -4998,12 +4998,11 @@ static int parse(void)
|
||||||
else if (floorspace(g_sp->sectnum))
|
else if (floorspace(g_sp->sectnum))
|
||||||
j = 0;
|
j = 0;
|
||||||
|
|
||||||
if (hittype[g_i].cgg <= 0 || (sector[g_sp->sectnum].floorstat&2))
|
if (!hittype[g_i].cgg-- || (sector[g_sp->sectnum].floorstat&2))
|
||||||
{
|
{
|
||||||
getglobalz(g_i);
|
getglobalz(g_i);
|
||||||
hittype[g_i].cgg = 3;
|
hittype[g_i].cgg = 3;
|
||||||
}
|
}
|
||||||
else hittype[g_i].cgg --;
|
|
||||||
|
|
||||||
if (g_sp->z < (hittype[g_i].floorz-FOURSLEIGHT))
|
if (g_sp->z < (hittype[g_i].floorz-FOURSLEIGHT))
|
||||||
{
|
{
|
||||||
|
@ -5014,25 +5013,20 @@ static int parse(void)
|
||||||
|
|
||||||
if (g_sp->z > (hittype[g_i].floorz - FOURSLEIGHT))
|
if (g_sp->z > (hittype[g_i].floorz - FOURSLEIGHT))
|
||||||
g_sp->z = (hittype[g_i].floorz - FOURSLEIGHT);
|
g_sp->z = (hittype[g_i].floorz - FOURSLEIGHT);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
g_sp->z = hittype[g_i].floorz - FOURSLEIGHT;
|
g_sp->z = hittype[g_i].floorz - FOURSLEIGHT;
|
||||||
|
|
||||||
if (badguy(g_sp) || (g_sp->picnum == APLAYER && g_sp->owner >= 0))
|
if (badguy(g_sp) || (g_sp->picnum == APLAYER && g_sp->owner >= 0))
|
||||||
{
|
{
|
||||||
if (g_sp->zvel > 3084 && g_sp->extra <= 1)
|
if (g_sp->zvel > 3084 && g_sp->extra <= 1)
|
||||||
{
|
{
|
||||||
if (g_sp->pal != 1 && g_sp->picnum != DRONE)
|
if (!(g_sp->picnum == APLAYER && g_sp->extra > 0) && g_sp->pal != 1 && g_sp->picnum != DRONE)
|
||||||
{
|
|
||||||
if (!(g_sp->picnum == APLAYER && g_sp->extra > 0))
|
|
||||||
{
|
{
|
||||||
guts(g_i,JIBS6,15);
|
guts(g_i,JIBS6,15);
|
||||||
spritesound(SQUISHED,g_i);
|
spritesound(SQUISHED,g_i);
|
||||||
spawn(g_i,BLOODPOOL);
|
spawn(g_i,BLOODPOOL);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
hittype[g_i].picnum = SHOTSPARK1;
|
hittype[g_i].picnum = SHOTSPARK1;
|
||||||
hittype[g_i].extra = 1;
|
hittype[g_i].extra = 1;
|
||||||
g_sp->zvel = 0;
|
g_sp->zvel = 0;
|
||||||
|
@ -5043,7 +5037,6 @@ static int parse(void)
|
||||||
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);
|
||||||
if (j != g_sp->sectnum && j >= 0 && j < MAXSECTORS)
|
if (j != g_sp->sectnum && j >= 0 && j < MAXSECTORS)
|
||||||
changespritesect(g_i,j);
|
changespritesect(g_i,j);
|
||||||
|
|
||||||
spritesound(THUD,g_i);
|
spritesound(THUD,g_i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5053,22 +5046,22 @@ static int parse(void)
|
||||||
getglobalz(g_i);
|
getglobalz(g_i);
|
||||||
if (hittype[g_i].floorz != sector[g_sp->sectnum].floorz)
|
if (hittype[g_i].floorz != sector[g_sp->sectnum].floorz)
|
||||||
g_sp->z = (hittype[g_i].floorz - FOURSLEIGHT);
|
g_sp->z = (hittype[g_i].floorz - FOURSLEIGHT);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
else if (sector[g_sp->sectnum].lotag == 1)
|
else if (sector[g_sp->sectnum].lotag == 1)
|
||||||
{
|
{
|
||||||
switch (dynamictostatic[g_sp->picnum])
|
switch (dynamictostatic[g_sp->picnum])
|
||||||
{
|
{
|
||||||
|
default:
|
||||||
|
g_sp->z += (24<<8);
|
||||||
case OCTABRAIN__STATIC:
|
case OCTABRAIN__STATIC:
|
||||||
case COMMANDER__STATIC:
|
case COMMANDER__STATIC:
|
||||||
case DRONE__STATIC:
|
case DRONE__STATIC:
|
||||||
break;
|
break;
|
||||||
default:
|
}
|
||||||
g_sp->z += (24<<8);
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
g_sp->zvel = 0;
|
||||||
else g_sp->zvel = 0;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CON_ENDA:
|
case CON_ENDA:
|
||||||
|
@ -5091,8 +5084,7 @@ static int parse(void)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
addammo(*insptr, g_player[g_p].ps, *(insptr+1));
|
addammo(*insptr, g_player[g_p].ps, *(insptr+1));
|
||||||
if (g_player[g_p].ps->curr_weapon == KNEE_WEAPON)
|
if (g_player[g_p].ps->curr_weapon == KNEE_WEAPON && g_player[g_p].ps->gotweapon[*insptr])
|
||||||
if (g_player[g_p].ps->gotweapon[*insptr])
|
|
||||||
{
|
{
|
||||||
if (!(g_player[g_p].ps->weaponswitch & 1)) addweaponnoswitch(g_player[g_p].ps, *insptr);
|
if (!(g_player[g_p].ps->weaponswitch & 1)) addweaponnoswitch(g_player[g_p].ps, *insptr);
|
||||||
else addweapon(g_player[g_p].ps, *insptr);
|
else addweapon(g_player[g_p].ps, *insptr);
|
||||||
|
@ -5154,8 +5146,7 @@ static int parse(void)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
addammo(*insptr, g_player[g_p].ps, *(insptr+1));
|
addammo(*insptr, g_player[g_p].ps, *(insptr+1));
|
||||||
if (g_player[g_p].ps->curr_weapon == KNEE_WEAPON)
|
if (g_player[g_p].ps->curr_weapon == KNEE_WEAPON && g_player[g_p].ps->gotweapon[*insptr])
|
||||||
if (g_player[g_p].ps->gotweapon[*insptr])
|
|
||||||
{
|
{
|
||||||
if (!(g_player[g_p].ps->weaponswitch & 1)) addweaponnoswitch(g_player[g_p].ps, *insptr);
|
if (!(g_player[g_p].ps->weaponswitch & 1)) addweaponnoswitch(g_player[g_p].ps, *insptr);
|
||||||
else addweapon(g_player[g_p].ps, *insptr);
|
else addweapon(g_player[g_p].ps, *insptr);
|
||||||
|
@ -5278,8 +5269,7 @@ static int parse(void)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
addammo(GetGameVarID(*(insptr),g_i,g_p), g_player[g_p].ps, GetGameVarID(*(insptr+1),g_i,g_p));
|
addammo(GetGameVarID(*(insptr),g_i,g_p), g_player[g_p].ps, GetGameVarID(*(insptr+1),g_i,g_p));
|
||||||
if (g_player[g_p].ps->curr_weapon == KNEE_WEAPON)
|
if (g_player[g_p].ps->curr_weapon == KNEE_WEAPON && g_player[g_p].ps->gotweapon[GetGameVarID(*(insptr),g_i,g_p)])
|
||||||
if (g_player[g_p].ps->gotweapon[GetGameVarID(*(insptr),g_i,g_p)])
|
|
||||||
{
|
{
|
||||||
if (!(g_player[g_p].ps->weaponswitch & 1)) addweaponnoswitch(g_player[g_p].ps, GetGameVarID(*(insptr),g_i,g_p));
|
if (!(g_player[g_p].ps->weaponswitch & 1)) addweaponnoswitch(g_player[g_p].ps, GetGameVarID(*(insptr),g_i,g_p));
|
||||||
else addweapon(g_player[g_p].ps, GetGameVarID(*(insptr),g_i,g_p));
|
else addweapon(g_player[g_p].ps, GetGameVarID(*(insptr),g_i,g_p));
|
||||||
|
@ -5456,9 +5446,12 @@ static int parse(void)
|
||||||
int i = GetGameVarID(*insptr++, g_i, g_p),
|
int i = GetGameVarID(*insptr++, g_i, g_p),
|
||||||
f=GetGameVarID(*insptr++, g_i, g_p);
|
f=GetGameVarID(*insptr++, g_i, g_p);
|
||||||
j=GetGameVarID(*insptr++, g_i, g_p);
|
j=GetGameVarID(*insptr++, g_i, g_p);
|
||||||
if ((i<0 || i>=MAXQUOTES) && checkCON) OSD_Printf(CON_ERROR "invalid quote ID %d\n",line_num,keyw[g_tw],i);
|
if ((i<0 || i>=MAXQUOTES) && checkCON)
|
||||||
else if ((fta_quotes[i] == NULL) && checkCON) OSD_Printf(CON_ERROR "null quote %d\n",line_num,keyw[g_tw],i);
|
OSD_Printf(CON_ERROR "invalid quote ID %d\n",line_num,keyw[g_tw],i);
|
||||||
else if ((f<0 || f>=NUMGAMEFUNCTIONS) && checkCON) OSD_Printf(CON_ERROR "invalid function %d\n",line_num,keyw[g_tw],f);
|
else if ((fta_quotes[i] == NULL) && checkCON)
|
||||||
|
OSD_Printf(CON_ERROR "null quote %d\n",line_num,keyw[g_tw],i);
|
||||||
|
else if ((f<0 || f>=NUMGAMEFUNCTIONS) && checkCON)
|
||||||
|
OSD_Printf(CON_ERROR "invalid function %d\n",line_num,keyw[g_tw],f);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (j<2)
|
if (j<2)
|
||||||
|
@ -5678,9 +5671,11 @@ static int parse(void)
|
||||||
//AddLog(g_szBuf);
|
//AddLog(g_szBuf);
|
||||||
lCheckCase=(left+right)/2;
|
lCheckCase=(left+right)/2;
|
||||||
// initprintf("(%2d..%2d..%2d) [%2d..%2d..%2d]==%2d\n",left,lCheckCase,right,lpCases[left*2],lpCases[lCheckCase*2],lpCases[right*2],lValue);
|
// initprintf("(%2d..%2d..%2d) [%2d..%2d..%2d]==%2d\n",left,lCheckCase,right,lpCases[left*2],lpCases[lCheckCase*2],lpCases[right*2],lValue);
|
||||||
if (lpCases[lCheckCase*2] > lValue) right=lCheckCase-1; else
|
if (lpCases[lCheckCase*2] > lValue)
|
||||||
if (lpCases[lCheckCase*2] < lValue) left =lCheckCase+1; else
|
right=lCheckCase-1;
|
||||||
if (lpCases[lCheckCase*2] == lValue)
|
else if (lpCases[lCheckCase*2] < lValue)
|
||||||
|
left =lCheckCase+1;
|
||||||
|
else if (lpCases[lCheckCase*2] == lValue)
|
||||||
{
|
{
|
||||||
//AddLog("Found Case Match");
|
//AddLog("Found Case Match");
|
||||||
//Bsprintf(g_szBuf,"insptr=%d. lCheckCase=%d, offset=%d, &script[0]=%d",
|
//Bsprintf(g_szBuf,"insptr=%d. lCheckCase=%d, offset=%d, &script[0]=%d",
|
||||||
|
@ -5698,7 +5693,8 @@ static int parse(void)
|
||||||
//AddLog("Done Executing Case");
|
//AddLog("Done Executing Case");
|
||||||
bMatched=1;
|
bMatched=1;
|
||||||
}
|
}
|
||||||
if (right-left<0)break;
|
if (right-left < 0)
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
if (!bMatched)
|
if (!bMatched)
|
||||||
{
|
{
|
||||||
|
@ -5737,7 +5733,11 @@ static int parse(void)
|
||||||
{
|
{
|
||||||
int wallnum = GetGameVarID(*insptr++, g_i, g_p), newx = GetGameVarID(*insptr++, g_i, g_p), newy = GetGameVarID(*insptr++, g_i, g_p);
|
int wallnum = GetGameVarID(*insptr++, g_i, g_p), newx = GetGameVarID(*insptr++, g_i, g_p), newy = GetGameVarID(*insptr++, g_i, g_p);
|
||||||
|
|
||||||
if ((wallnum<0 || wallnum>=numwalls) && checkCON) {OSD_Printf(CON_ERROR "Invalid wall %d\n",line_num,keyw[g_tw],wallnum);break;}
|
if ((wallnum<0 || wallnum>=numwalls) && checkCON)
|
||||||
|
{
|
||||||
|
OSD_Printf(CON_ERROR "Invalid wall %d\n",line_num,keyw[g_tw],wallnum);
|
||||||
|
break;
|
||||||
|
}
|
||||||
dragpoint(wallnum,newx,newy);
|
dragpoint(wallnum,newx,newy);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -6348,7 +6348,7 @@ static int parse(void)
|
||||||
short w=sprite[g_i].sectnum;
|
short w=sprite[g_i].sectnum;
|
||||||
|
|
||||||
if (tw==CON_UPDATESECTOR) updatesector(x,y,&w);
|
if (tw==CON_UPDATESECTOR) updatesector(x,y,&w);
|
||||||
else if (tw==CON_UPDATESECTORZ) updatesectorz(x,y,z,&w);
|
else updatesectorz(x,y,z,&w);
|
||||||
|
|
||||||
SetGameVarID(var, w, g_i, g_p);
|
SetGameVarID(var, w, g_i, g_p);
|
||||||
break;
|
break;
|
||||||
|
@ -7199,7 +7199,7 @@ static int parse(void)
|
||||||
int var1 = *insptr++, d;
|
int var1 = *insptr++, d;
|
||||||
|
|
||||||
if (tw == CON_FINDPLAYER) j=findplayer(&sprite[g_i],&d);
|
if (tw == CON_FINDPLAYER) j=findplayer(&sprite[g_i],&d);
|
||||||
else if (tw == CON_FINDOTHERPLAYER) j=findotherplayer(g_i,&d);
|
else j=findotherplayer(g_i,&d);
|
||||||
|
|
||||||
SetGameVarID(g_iReturnVarID, j, g_i, g_p);
|
SetGameVarID(g_iReturnVarID, j, g_i, g_p);
|
||||||
SetGameVarID(var1, d, g_i, g_p);
|
SetGameVarID(var1, d, g_i, g_p);
|
||||||
|
@ -7776,36 +7776,34 @@ static int parse(void)
|
||||||
|
|
||||||
case CON_WHILEVARN:
|
case CON_WHILEVARN:
|
||||||
{
|
{
|
||||||
int i;
|
intptr_t *savedinsptr=insptr+2;
|
||||||
intptr_t *savedinsptr=insptr;
|
|
||||||
j=1;
|
j=1;
|
||||||
while (j)
|
do
|
||||||
{
|
{
|
||||||
insptr=savedinsptr;
|
insptr=savedinsptr;
|
||||||
insptr++;
|
if (GetGameVarID(*(insptr-1), g_i, g_p) == *insptr)
|
||||||
i=*insptr++;
|
|
||||||
if (GetGameVarID(i, g_i, g_p) == *insptr)
|
|
||||||
j=0;
|
j=0;
|
||||||
parseifelse(j);
|
parseifelse(j);
|
||||||
}
|
}
|
||||||
|
while (j);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case CON_WHILEVARVARN:
|
case CON_WHILEVARVARN:
|
||||||
{
|
{
|
||||||
int i,k;
|
int i,k;
|
||||||
intptr_t *savedinsptr=insptr;
|
intptr_t *savedinsptr=insptr+2;
|
||||||
j=1;
|
j=1;
|
||||||
while (j)
|
do
|
||||||
{
|
{
|
||||||
insptr=savedinsptr;
|
insptr=savedinsptr;
|
||||||
insptr++;
|
i = GetGameVarID(*(insptr-1), g_i, g_p);
|
||||||
i=*insptr++;
|
|
||||||
k=*(insptr);
|
k=*(insptr);
|
||||||
if (GetGameVarID(i, g_i, g_p) == GetGameVarID(k, g_i, g_p))
|
if (i == GetGameVarID(k, g_i, g_p))
|
||||||
j=0;
|
j=0;
|
||||||
parseifelse(j);
|
parseifelse(j);
|
||||||
}
|
}
|
||||||
|
while (j);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8083,16 +8081,8 @@ void LoadActor(int iActor)
|
||||||
while (1) if (parse()) break;
|
while (1) if (parse()) break;
|
||||||
|
|
||||||
if (killit_flag == 1)
|
if (killit_flag == 1)
|
||||||
{
|
|
||||||
// if player was set to squish, first stop that...
|
|
||||||
if (g_p >= 0)
|
|
||||||
{
|
|
||||||
if (g_player[g_p].ps->actorsqu == g_i)
|
|
||||||
g_player[g_p].ps->actorsqu = -1;
|
|
||||||
}
|
|
||||||
deletesprite(g_i);
|
deletesprite(g_i);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void execute(int iActor,int iPlayer,int lDist)
|
void execute(int iActor,int iPlayer,int lDist)
|
||||||
{
|
{
|
||||||
|
@ -8144,9 +8134,9 @@ void execute(int iActor,int iPlayer,int lDist)
|
||||||
if (g_player[g_p].ps->actorsqu == g_i)
|
if (g_player[g_p].ps->actorsqu == g_i)
|
||||||
g_player[g_p].ps->actorsqu = -1;
|
g_player[g_p].ps->actorsqu = -1;
|
||||||
deletesprite(g_i);
|
deletesprite(g_i);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
move();
|
move();
|
||||||
|
|
||||||
if (ud.angleinterpolation)
|
if (ud.angleinterpolation)
|
||||||
|
@ -8164,22 +8154,7 @@ void execute(int iActor,int iPlayer,int lDist)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_sp->statnum == 1)
|
if (g_sp->statnum == 6)
|
||||||
{
|
|
||||||
if (badguy(g_sp))
|
|
||||||
{
|
|
||||||
if (g_sp->xrepeat > 60) return;
|
|
||||||
if (ud.respawn_monsters == 1 && g_sp->extra <= 0) return;
|
|
||||||
}
|
|
||||||
else if (ud.respawn_items == 1 && (g_sp->cstat&32768)) return;
|
|
||||||
|
|
||||||
if (hittype[g_i].timetosleep > 1)
|
|
||||||
hittype[g_i].timetosleep--;
|
|
||||||
else if (hittype[g_i].timetosleep == 1)
|
|
||||||
changespritestat(g_i,2);
|
|
||||||
}
|
|
||||||
|
|
||||||
else if (g_sp->statnum == 6)
|
|
||||||
switch (dynamictostatic[g_sp->picnum])
|
switch (dynamictostatic[g_sp->picnum])
|
||||||
{
|
{
|
||||||
case RUBBERCAN__STATIC:
|
case RUBBERCAN__STATIC:
|
||||||
|
@ -8197,9 +8172,24 @@ void execute(int iActor,int iPlayer,int lDist)
|
||||||
hittype[g_i].timetosleep--;
|
hittype[g_i].timetosleep--;
|
||||||
else if (hittype[g_i].timetosleep == 1)
|
else if (hittype[g_i].timetosleep == 1)
|
||||||
changespritestat(g_i,2);
|
changespritestat(g_i,2);
|
||||||
break;
|
default:
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (g_sp->statnum != 1)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (badguy(g_sp))
|
||||||
|
{
|
||||||
|
if (g_sp->xrepeat > 60) return;
|
||||||
|
if (ud.respawn_monsters == 1 && g_sp->extra <= 0) return;
|
||||||
}
|
}
|
||||||
|
else if (ud.respawn_items == 1 && (g_sp->cstat&32768)) return;
|
||||||
|
|
||||||
|
if (hittype[g_i].timetosleep > 1)
|
||||||
|
hittype[g_i].timetosleep--;
|
||||||
|
else if (hittype[g_i].timetosleep == 1)
|
||||||
|
changespritestat(g_i,2);
|
||||||
}
|
}
|
||||||
|
|
||||||
void savemapstate(mapstate_t *save)
|
void savemapstate(mapstate_t *save)
|
||||||
|
|
Loading…
Reference in a new issue