mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-19 22:00:49 +00:00
- parse - part 3.
This commit is contained in:
parent
65fc6dd3c7
commit
59d9138b77
1 changed files with 28 additions and 27 deletions
|
@ -75,6 +75,7 @@ struct ParseState
|
||||||
spritetype* g_sp;
|
spritetype* g_sp;
|
||||||
DDukeActor *g_ac;
|
DDukeActor *g_ac;
|
||||||
int* insptr;
|
int* insptr;
|
||||||
|
Collision coll;
|
||||||
|
|
||||||
int parse(void);
|
int parse(void);
|
||||||
void parseifelse(int condition);
|
void parseifelse(int condition);
|
||||||
|
@ -1893,19 +1894,19 @@ int ParseState::parse(void)
|
||||||
insptr++;
|
insptr++;
|
||||||
if (isRR())
|
if (isRR())
|
||||||
{
|
{
|
||||||
if (hittype[g_i].spriteextra < 1 || hittype[g_i].spriteextra == 128)
|
if (g_ac->spriteextra < 1 || g_ac->spriteextra == 128)
|
||||||
{
|
{
|
||||||
if (actorfella(g_i))
|
if (actorfella(g_ac->GetIndex()))
|
||||||
ps[g_p].actors_killed += *insptr;
|
ps[g_p].actors_killed += *insptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else ps[g_p].actors_killed += *insptr;
|
else ps[g_p].actors_killed += *insptr;
|
||||||
hittype[g_i].actorstayput = -1;
|
g_ac->actorstayput = -1;
|
||||||
insptr++;
|
insptr++;
|
||||||
break;
|
break;
|
||||||
case concmd_lotsofglass:
|
case concmd_lotsofglass:
|
||||||
insptr++;
|
insptr++;
|
||||||
spriteglass(g_i,*insptr);
|
spriteglass(g_ac->GetIndex(),*insptr);
|
||||||
insptr++;
|
insptr++;
|
||||||
break;
|
break;
|
||||||
case concmd_killit:
|
case concmd_killit:
|
||||||
|
@ -1942,7 +1943,7 @@ int ParseState::parse(void)
|
||||||
case concmd_isdrunk: // todo: move out to player_r.
|
case concmd_isdrunk: // todo: move out to player_r.
|
||||||
insptr++;
|
insptr++;
|
||||||
ps[g_p].drink_amt += *insptr;
|
ps[g_p].drink_amt += *insptr;
|
||||||
j = sprite[ps[g_p].i].extra;
|
j = ps[g_p].GetActor()->s.extra;
|
||||||
if (j > 0)
|
if (j > 0)
|
||||||
j += *insptr;
|
j += *insptr;
|
||||||
if (j > max_player_health * 2)
|
if (j > max_player_health * 2)
|
||||||
|
@ -1961,30 +1962,30 @@ int ParseState::parse(void)
|
||||||
ps[g_p].last_extra = j;
|
ps[g_p].last_extra = j;
|
||||||
}
|
}
|
||||||
|
|
||||||
sprite[ps[g_p].i].extra = j;
|
ps[g_p].GetActor()->s.extra = j;
|
||||||
}
|
}
|
||||||
if (ps[g_p].drink_amt > 100)
|
if (ps[g_p].drink_amt > 100)
|
||||||
ps[g_p].drink_amt = 100;
|
ps[g_p].drink_amt = 100;
|
||||||
|
|
||||||
if (sprite[ps[g_p].i].extra >= max_player_health)
|
if (ps[g_p].GetActor()->s.extra >= max_player_health)
|
||||||
{
|
{
|
||||||
sprite[ps[g_p].i].extra = max_player_health;
|
ps[g_p].GetActor()->s.extra = max_player_health;
|
||||||
ps[g_p].last_extra = max_player_health;
|
ps[g_p].last_extra = max_player_health;
|
||||||
}
|
}
|
||||||
insptr++;
|
insptr++;
|
||||||
break;
|
break;
|
||||||
case concmd_strafeleft:
|
case concmd_strafeleft:
|
||||||
insptr++;
|
insptr++;
|
||||||
fi.movesprite(g_i, sintable[(g_sp->ang + 1024) & 2047] >> 10, sintable[(g_sp->ang + 512) & 2047] >> 10, g_sp->zvel, CLIPMASK0);
|
movesprite_ex(g_ac, sintable[(g_sp->ang + 1024) & 2047] >> 10, sintable[(g_sp->ang + 512) & 2047] >> 10, g_sp->zvel, CLIPMASK0, coll);
|
||||||
break;
|
break;
|
||||||
case concmd_straferight:
|
case concmd_straferight:
|
||||||
insptr++;
|
insptr++;
|
||||||
fi.movesprite(g_i, sintable[(g_sp->ang - 0) & 2047] >> 10, sintable[(g_sp->ang - 512) & 2047] >> 10, g_sp->zvel, CLIPMASK0);
|
movesprite_ex(g_ac, sintable[(g_sp->ang - 0) & 2047] >> 10, sintable[(g_sp->ang - 512) & 2047] >> 10, g_sp->zvel, CLIPMASK0, coll);
|
||||||
break;
|
break;
|
||||||
case concmd_larrybird:
|
case concmd_larrybird:
|
||||||
insptr++;
|
insptr++;
|
||||||
ps[g_p].posz = sector[sprite[ps[g_p].i].sectnum].ceilingz;
|
ps[g_p].posz = sector[ps[g_p].GetActor()->s.sectnum].ceilingz;
|
||||||
sprite[ps[g_p].i].z = ps[g_p].posz;
|
ps[g_p].GetActor()->s.z = ps[g_p].posz;
|
||||||
break;
|
break;
|
||||||
case concmd_destroyit:
|
case concmd_destroyit:
|
||||||
insptr++;
|
insptr++;
|
||||||
|
@ -2000,7 +2001,7 @@ int ParseState::parse(void)
|
||||||
ps[g_p].drink_amt -= *insptr;
|
ps[g_p].drink_amt -= *insptr;
|
||||||
if (ps[g_p].drink_amt < 0)
|
if (ps[g_p].drink_amt < 0)
|
||||||
ps[g_p].drink_amt = 0;
|
ps[g_p].drink_amt = 0;
|
||||||
j = sprite[ps[g_p].i].extra;
|
j = ps[g_p].GetActor()->s.extra;
|
||||||
if (g_sp->picnum != TILE_ATOMICHEALTH)
|
if (g_sp->picnum != TILE_ATOMICHEALTH)
|
||||||
{
|
{
|
||||||
if (j > max_player_health && *insptr > 0)
|
if (j > max_player_health && *insptr > 0)
|
||||||
|
@ -2037,7 +2038,7 @@ int ParseState::parse(void)
|
||||||
ps[g_p].last_extra = j;
|
ps[g_p].last_extra = j;
|
||||||
}
|
}
|
||||||
|
|
||||||
sprite[ps[g_p].i].extra = j;
|
ps[g_p].GetActor()->s.extra = j;
|
||||||
}
|
}
|
||||||
|
|
||||||
insptr++;
|
insptr++;
|
||||||
|
@ -2056,15 +2057,15 @@ int ParseState::parse(void)
|
||||||
updatesector(ps[g_p].posx,ps[g_p].posy,&ps[g_p].cursectnum);
|
updatesector(ps[g_p].posx,ps[g_p].posy,&ps[g_p].cursectnum);
|
||||||
setpal(&ps[g_p]);
|
setpal(&ps[g_p]);
|
||||||
|
|
||||||
StatIterator it(STAT_ACTOR);
|
DukeStatIterator it(STAT_ACTOR);
|
||||||
while ((j = it.NextIndex()) >= 0)
|
while (auto j = it.Next())
|
||||||
{
|
{
|
||||||
if (sprite[j].picnum == TILE_CAMERA1)
|
if (j->s.picnum == TILE_CAMERA1)
|
||||||
sprite[j].yvel = 0;
|
j->s.yvel = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
j = sprite[ps[g_p].i].extra;
|
j = ps[g_p].GetActor()->s.extra;
|
||||||
|
|
||||||
if(g_sp->picnum != TILE_ATOMICHEALTH)
|
if(g_sp->picnum != TILE_ATOMICHEALTH)
|
||||||
{
|
{
|
||||||
|
@ -2102,7 +2103,7 @@ int ParseState::parse(void)
|
||||||
ps[g_p].last_extra = j;
|
ps[g_p].last_extra = j;
|
||||||
}
|
}
|
||||||
|
|
||||||
sprite[ps[g_p].i].extra = j;
|
ps[g_p].GetActor()->s.extra = j;
|
||||||
}
|
}
|
||||||
|
|
||||||
insptr++;
|
insptr++;
|
||||||
|
@ -2133,13 +2134,13 @@ int ParseState::parse(void)
|
||||||
case concmd_spawn:
|
case concmd_spawn:
|
||||||
insptr++;
|
insptr++;
|
||||||
if(g_sp->sectnum >= 0 && g_sp->sectnum < MAXSECTORS)
|
if(g_sp->sectnum >= 0 && g_sp->sectnum < MAXSECTORS)
|
||||||
fi.spawn(g_i,*insptr);
|
spawn(g_ac,*insptr);
|
||||||
insptr++;
|
insptr++;
|
||||||
break;
|
break;
|
||||||
case concmd_ifwasweapon:
|
case concmd_ifwasweapon:
|
||||||
case concmd_ifspawnedby: // these two are the same
|
case concmd_ifspawnedby: // these two are the same
|
||||||
insptr++;
|
insptr++;
|
||||||
parseifelse( hittype[g_i].picnum == *insptr);
|
parseifelse( g_ac->picnum == *insptr);
|
||||||
break;
|
break;
|
||||||
case concmd_ifai:
|
case concmd_ifai:
|
||||||
insptr++;
|
insptr++;
|
||||||
|
@ -2173,14 +2174,14 @@ int ParseState::parse(void)
|
||||||
s = 0;
|
s = 0;
|
||||||
else s = (krand()%3);
|
else s = (krand()%3);
|
||||||
|
|
||||||
l = EGS(g_sp->sectnum,
|
auto l = EGS(g_sp->sectnum,
|
||||||
g_sp->x + (krand() & 255) - 128, g_sp->y + (krand() & 255) - 128, g_sp->z - (8 << 8) - (krand() & 8191),
|
g_sp->x + (krand() & 255) - 128, g_sp->y + (krand() & 255) - 128, g_sp->z - (8 << 8) - (krand() & 8191),
|
||||||
dnum + s, g_sp->shade, 32 + (krand() & 15), 32 + (krand() & 15),
|
dnum + s, g_sp->shade, 32 + (krand() & 15), 32 + (krand() & 15),
|
||||||
krand() & 2047, (krand() & 127) + 32, -(krand() & 2047), g_i, 5);
|
krand() & 2047, (krand() & 127) + 32, -(krand() & 2047), g_ac, 5);
|
||||||
if(weap)
|
if(weap)
|
||||||
sprite[l].yvel = weaponsandammosprites[j%14];
|
l->s.yvel = weaponsandammosprites[j%14];
|
||||||
else sprite[l].yvel = -1;
|
else l->s.yvel = -1;
|
||||||
sprite[l].pal = g_sp->pal;
|
l->s.pal = g_sp->pal;
|
||||||
}
|
}
|
||||||
insptr++;
|
insptr++;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue