- wrapped hitscan in a variant returning an actor.

This commit is contained in:
Christoph Oelckers 2020-10-23 23:18:05 +02:00
parent 768487584e
commit 17737eea85
5 changed files with 93 additions and 79 deletions

View file

@ -5125,8 +5125,9 @@ int dodge(DDukeActor* actor)
int furthestangle(DDukeActor *actor, int angs) int furthestangle(DDukeActor *actor, int angs)
{ {
auto s = &actor->s; auto s = &actor->s;
short j, hitsect, hitwall, hitspr, furthest_angle, angincs; short j, hitsect, hitwall, furthest_angle, angincs;
int hx, hy, hz, d, greatestd; int hx, hy, hz, d, greatestd;
DDukeActor* dd;
greatestd = -(1 << 30); greatestd = -(1 << 30);
angincs = 2048 / angs; angincs = 2048 / angs;
@ -5136,10 +5137,7 @@ int furthestangle(DDukeActor *actor, int angs)
for (j = s->ang; j < (2048 + s->ang); j += angincs) for (j = s->ang; j < (2048 + s->ang); j += angincs)
{ {
hitscan(s->x, s->y, s->z - (8 << 8), s->sectnum, hitscan(s->x, s->y, s->z - (8 << 8), s->sectnum, sintable[(j + 512) & 2047], sintable[j & 2047], 0, &hitsect, &hitwall, &dd, &hx, &hy, &hz, CLIPMASK1);
sintable[(j + 512) & 2047],
sintable[j & 2047], 0,
&hitsect, &hitwall, &hitspr, &hx, &hy, &hz, CLIPMASK1);
d = abs(hx - s->x) + abs(hy - s->y); d = abs(hx - s->x) + abs(hy - s->y);
@ -5161,8 +5159,9 @@ int furthestangle(DDukeActor *actor, int angs)
int furthestcanseepoint(DDukeActor *actor, DDukeActor* tosee, int* dax, int* day) int furthestcanseepoint(DDukeActor *actor, DDukeActor* tosee, int* dax, int* day)
{ {
auto s = &actor->s; auto s = &actor->s;
short j, hitsect, hitwall, hitspr, angincs; short j, hitsect, hitwall, angincs;
int hx, hy, hz, d, da;//, d, cd, ca,tempx,tempy,cx,cy; int hx, hy, hz, d, da;//, d, cd, ca,tempx,tempy,cx,cy;
DDukeActor* dd;
if ((actor->temp_data[0] & 63)) return -1; if ((actor->temp_data[0] & 63)) return -1;
@ -5173,10 +5172,8 @@ int furthestcanseepoint(DDukeActor *actor, DDukeActor* tosee, int* dax, int* day
auto ts = &tosee->s; auto ts = &tosee->s;
for (j = ts->ang; j < (2048 + ts->ang); j += (angincs - (krand() & 511))) for (j = ts->ang; j < (2048 + ts->ang); j += (angincs - (krand() & 511)))
{ {
hitscan(ts->x, ts->y, ts->z - (16 << 8), ts->sectnum, hitscan(ts->x, ts->y, ts->z - (16 << 8), ts->sectnum, sintable[(j + 512) & 2047], sintable[j & 2047], 16384 - (krand() & 32767),
sintable[(j + 512) & 2047], &hitsect, &hitwall, &dd, &hx, &hy, &hz, CLIPMASK1);
sintable[j & 2047], 16384 - (krand() & 32767),
&hitsect, &hitwall, &hitspr, &hx, &hy, &hz, CLIPMASK1);
d = abs(hx - ts->x) + abs(hy - ts->y); d = abs(hx - ts->x) + abs(hy - ts->y);
da = abs(hx - s->x) + abs(hy - s->y); da = abs(hx - s->x) + abs(hy - s->y);

View file

@ -274,4 +274,13 @@ inline int callsound(int sect, int a)
return callsound(sect, a == -1? nullptr : &hittype[a]); return callsound(sect, a == -1? nullptr : &hittype[a]);
} }
inline int hitscan(int x, int y, int z, int16_t sectnum, int32_t vx, int32_t vy, int32_t vz,
short* hitsect, short* hitwall, DDukeActor** hitspr, int* hitx, int* hity, int* hitz, uint32_t cliptype)
{
short hitsprt;
int res = ::hitscan(x, y, z, sectnum, vx, vy, vz, hitsect, hitwall, &hitsprt, hitx, hity, hitz, cliptype);
if (hitspr) *hitspr = hitsprt == -1 ? nullptr : &hittype[hitsprt];
return res;
}
END_DUKE_NS END_DUKE_NS

View file

@ -218,13 +218,14 @@ int hits(DDukeActor* actor)
auto sp = &actor->s; auto sp = &actor->s;
int sx, sy, sz; int sx, sy, sz;
short sect; short sect;
short hw, hs; short hw;
int zoff; int zoff;
DDukeActor* d;
if (sp->picnum == TILE_APLAYER) zoff = (40 << 8); if (sp->picnum == TILE_APLAYER) zoff = (40 << 8);
else zoff = 0; else zoff = 0;
hitscan(sp->x, sp->y, sp->z - zoff, sp->sectnum, sintable[(sp->ang + 512) & 2047], sintable[sp->ang & 2047], 0, &sect, &hw, &hs, &sx, &sy, &sz, CLIPMASK1); hitscan(sp->x, sp->y, sp->z - zoff, sp->sectnum, sintable[(sp->ang + 512) & 2047], sintable[sp->ang & 2047], 0, &sect, &hw, &d, &sx, &sy, &sz, CLIPMASK1);
return (FindDistance2D(sx - sp->x, sy - sp->y)); return (FindDistance2D(sx - sp->x, sy - sp->y));
} }
@ -246,9 +247,7 @@ int hitasprite(DDukeActor* actor, DDukeActor** hitsp)
else if (sp->picnum == TILE_APLAYER) zoff = (39 << 8); else if (sp->picnum == TILE_APLAYER) zoff = (39 << 8);
else zoff = 0; else zoff = 0;
short hitthis = -1; hitscan(sp->x, sp->y, sp->z - zoff, sp->sectnum, sintable[(sp->ang + 512) & 2047], sintable[sp->ang & 2047], 0, &sect, &hw, hitsp, &sx, &sy, &sz, CLIPMASK1);
hitscan(sp->x, sp->y, sp->z - zoff, sp->sectnum, sintable[(sp->ang + 512) & 2047], sintable[sp->ang & 2047], 0, &sect, &hw, &hitthis, &sx, &sy, &sz, CLIPMASK1);
if (hitsp) *hitsp = (hitthis == -1 ? nullptr : &hittype[hitthis]);
if (hw >= 0 && (wall[hw].cstat & 16) && badguy(actor)) if (hw >= 0 && (wall[hw].cstat & 16) && badguy(actor))
return((1 << 30)); return((1 << 30));
@ -265,10 +264,11 @@ int hitasprite(DDukeActor* actor, DDukeActor** hitsp)
int hitawall(struct player_struct* p, int* hitw) int hitawall(struct player_struct* p, int* hitw)
{ {
int sx, sy, sz; int sx, sy, sz;
short sect, hs, hitw1; short sect, hitw1;
DDukeActor* d;
hitscan(p->posx, p->posy, p->posz, p->cursectnum, hitscan(p->posx, p->posy, p->posz, p->cursectnum,
sintable[(p->angle.ang.asbuild() + 512) & 2047], sintable[p->angle.ang.asbuild() & 2047], 0, &sect, &hitw1, &hs, &sx, &sy, &sz, CLIPMASK0); sintable[(p->angle.ang.asbuild() + 512) & 2047], sintable[p->angle.ang.asbuild() & 2047], 0, &sect, &hitw1, &d, &sx, &sy, &sz, CLIPMASK0);
*hitw = hitw1; *hitw = hitw1;
return (FindDistance2D(sx - p->posx, sy - p->posy)); return (FindDistance2D(sx - p->posx, sy - p->posy));
@ -1074,8 +1074,9 @@ void shootbloodsplat(DDukeActor* actor, int p, int sx, int sy, int sz, int sa, i
spritetype* const s = &actor->s; spritetype* const s = &actor->s;
int sect = s->sectnum; int sect = s->sectnum;
int zvel; int zvel;
short hitsect, hitspr, hitwall; short hitsect, hitwall;
int hitx, hity, hitz; int hitx, hity, hitz;
DDukeActor* d;
if (p >= 0) if (p >= 0)
sa += 64 - (krand() & 127); sa += 64 - (krand() & 127);
@ -1086,7 +1087,7 @@ void shootbloodsplat(DDukeActor* actor, int p, int sx, int sy, int sz, int sa, i
hitscan(sx, sy, sz, sect, hitscan(sx, sy, sz, sect,
sintable[(sa + 512) & 2047], sintable[(sa + 512) & 2047],
sintable[sa & 2047], zvel << 6, sintable[sa & 2047], zvel << 6,
&hitsect, &hitwall, &hitspr, &hitx, &hity, &hitz, CLIPMASK1); &hitsect, &hitwall, &d, &hitx, &hity, &hitz, CLIPMASK1);
// oh my... // oh my...
if (FindDistance2D(sx - hitx, sy - hity) < 1024 && if (FindDistance2D(sx - hitx, sy - hity) < 1024 &&
@ -1143,7 +1144,8 @@ bool view(struct player_struct* pp, int* vx, int* vy, int* vz, short* vsectnum,
{ {
spritetype* sp; spritetype* sp;
int i, nx, ny, nz, hx, hy, hitx, hity, hitz; int i, nx, ny, nz, hx, hy, hitx, hity, hitz;
short bakcstat, hitsect, hitwall, hitsprite, daang; short bakcstat, hitsect, hitwall, daang;
DDukeActor* hitsprt;
nx = (sintable[(ang + 1536) & 2047] >> 4); nx = (sintable[(ang + 1536) & 2047] >> 4);
ny = (sintable[(ang + 1024) & 2047] >> 4); ny = (sintable[(ang + 1024) & 2047] >> 4);
@ -1155,7 +1157,7 @@ bool view(struct player_struct* pp, int* vx, int* vy, int* vz, short* vsectnum,
sp->cstat &= (short)~0x101; sp->cstat &= (short)~0x101;
updatesectorz(*vx, *vy, *vz, vsectnum); updatesectorz(*vx, *vy, *vz, vsectnum);
hitscan(*vx, *vy, *vz, *vsectnum, nx, ny, nz, &hitsect, &hitwall, &hitsprite, &hitx, &hity, &hitz, CLIPMASK1); hitscan(*vx, *vy, *vz, *vsectnum, nx, ny, nz, &hitsect, &hitwall, &hitsprt, &hitx, &hity, &hitz, CLIPMASK1);
if (*vsectnum < 0) if (*vsectnum < 0)
{ {
@ -1176,7 +1178,7 @@ bool view(struct player_struct* pp, int* vx, int* vy, int* vz, short* vsectnum,
if (abs(nx) > abs(ny)) hx -= mulscale28(nx, i); if (abs(nx) > abs(ny)) hx -= mulscale28(nx, i);
else hy -= mulscale28(ny, i); else hy -= mulscale28(ny, i);
} }
else if (hitsprite < 0) else if (!hitsprt)
{ {
if (abs(nx) > abs(ny)) hx -= (nx >> 5); if (abs(nx) > abs(ny)) hx -= (nx >> 5);
else hy -= (ny >> 5); else hy -= (ny >> 5);

View file

@ -232,8 +232,9 @@ static void shootknee(DDukeActor* actor, int p, int sx, int sy, int sz, int sa)
auto s = &actor->s; auto s = &actor->s;
int sect = s->sectnum; int sect = s->sectnum;
int zvel; int zvel;
short hitsect, hitspr, hitwall; short hitsect, hitwall;
int hitx, hity, hitz; int hitx, hity, hitz;
DDukeActor* hitsprt;
if (p >= 0) if (p >= 0)
{ {
@ -252,14 +253,14 @@ static void shootknee(DDukeActor* actor, int p, int sx, int sy, int sz, int sa)
hitscan(sx, sy, sz, sect, hitscan(sx, sy, sz, sect,
sintable[(sa + 512) & 2047], sintable[(sa + 512) & 2047],
sintable[sa & 2047], zvel << 6, sintable[sa & 2047], zvel << 6,
&hitsect, &hitwall, &hitspr, &hitx, &hity, &hitz, CLIPMASK1); &hitsect, &hitwall, &hitsprt, &hitx, &hity, &hitz, CLIPMASK1);
if (hitsect < 0) return; if (hitsect < 0) return;
if ((abs(sx - hitx) + abs(sy - hity)) < 1024) if ((abs(sx - hitx) + abs(sy - hity)) < 1024)
{ {
if (hitwall >= 0 || hitspr >= 0) if (hitwall >= 0 || hitsprt)
{ {
auto knee = EGS(hitsect, hitx, hity, hitz, KNEE, -15, 0, 0, sa, 32, 0, actor, 4); auto knee = EGS(hitsect, hitx, hity, hitz, KNEE, -15, 0, 0, sa, 32, 0, actor, 4);
knee->s.extra += (krand() & 7); knee->s.extra += (krand() & 7);
@ -273,10 +274,10 @@ static void shootknee(DDukeActor* actor, int p, int sx, int sy, int sz, int sa)
if (p >= 0 && ps[p].steroids_amount > 0 && ps[p].steroids_amount < 400) if (p >= 0 && ps[p].steroids_amount > 0 && ps[p].steroids_amount < 400)
knee->s.extra += (max_player_health >> 2); knee->s.extra += (max_player_health >> 2);
if (hitspr >= 0 && sprite[hitspr].picnum != ACCESSSWITCH && sprite[hitspr].picnum != ACCESSSWITCH2) if (hitsprt && hitsprt->s.picnum != ACCESSSWITCH && hitsprt->s.picnum != ACCESSSWITCH2)
{ {
fi.checkhitsprite(hitspr, knee->GetIndex()); fi.checkhitsprite(hitsprt->GetIndex(), knee->GetIndex());
if (p >= 0) fi.checkhitswitch(p, hitspr, 1); if (p >= 0) fi.checkhitswitch(p, hitsprt->GetIndex(), 1);
} }
else if (hitwall >= 0) else if (hitwall >= 0)
@ -319,8 +320,9 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
auto s = &actor->s; auto s = &actor->s;
int sect = s->sectnum; int sect = s->sectnum;
int zvel; int zvel;
short hitsect, hitspr, hitwall, l, k; short hitsect, hitwall, l, k;
int hitx, hity, hitz; int hitx, hity, hitz;
DDukeActor* hitact;
if (s->extra >= 0) s->shade = -96; if (s->extra >= 0) s->shade = -96;
@ -405,12 +407,11 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
hitscan(sx, sy, sz, sect, hitscan(sx, sy, sz, sect,
sintable[(sa + 512) & 2047], sintable[(sa + 512) & 2047],
sintable[sa & 2047], sintable[sa & 2047],
zvel << 6, &hitsect, &hitwall, &hitspr, &hitx, &hity, &hitz, CLIPMASK1); zvel << 6, &hitsect, &hitwall, &hitact, &hitx, &hity, &hitz, CLIPMASK1);
s->cstat |= 257; s->cstat |= 257;
if (hitsect < 0) return; if (hitsect < 0) return;
auto hitact = &hittype[hitspr];
if ((krand() & 15) == 0 && sector[hitsect].lotag == 2) if ((krand() & 15) == 0 && sector[hitsect].lotag == 2)
tracers(hitx, hity, hitz, sx, sy, sz, 8 - (ud.multimode >> 1)); tracers(hitx, hity, hitz, sx, sy, sz, 8 - (ud.multimode >> 1));
@ -421,7 +422,7 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
spark->s.extra = ScriptCode[actorinfo[atwith].scriptaddress]; spark->s.extra = ScriptCode[actorinfo[atwith].scriptaddress];
spark->s.extra += (krand() % 6); spark->s.extra += (krand() % 6);
if (hitwall == -1 && hitspr == -1) if (hitwall == -1 && hitact == nullptr)
{ {
if (zvel < 0) if (zvel < 0)
{ {
@ -437,10 +438,10 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
spawn(spark, SMALLSMOKE); spawn(spark, SMALLSMOKE);
} }
if (hitspr >= 0) if (hitact)
{ {
fi.checkhitsprite(hitspr, spark->GetIndex()); fi.checkhitsprite(hitact->GetIndex(), spark->GetIndex());
if (sprite[hitspr].picnum == TILE_APLAYER && (ud.coop != 1 || ud.ffire == 1)) if (hitact->s.picnum == TILE_APLAYER && (ud.coop != 1 || ud.ffire == 1))
{ {
auto jib = spawn(spark, JIBS6); auto jib = spawn(spark, JIBS6);
spark->s.xrepeat = spark->s.yrepeat = 0; spark->s.xrepeat = spark->s.yrepeat = 0;
@ -461,7 +462,7 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
hitact->s.picnum == HANDSWITCH || hitact->s.picnum == HANDSWITCH ||
hitact->s.picnum == HANDSWITCH + 1)) hitact->s.picnum == HANDSWITCH + 1))
{ {
fi.checkhitswitch(p, hitspr, 1); fi.checkhitswitch(p, hitact->GetIndex(), 1);
return; return;
} }
} }
@ -533,10 +534,10 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
k = EGS(hitsect, hitx, hity, hitz, SHOTSPARK1, -15, 24, 24, sa, 0, 0, i, 4); k = EGS(hitsect, hitx, hity, hitz, SHOTSPARK1, -15, 24, 24, sa, 0, 0, i, 4);
sprite[k].extra = ScriptCode[actorinfo[atwith].scriptaddress]; sprite[k].extra = ScriptCode[actorinfo[atwith].scriptaddress];
if (hitspr >= 0) if (hitact)
{ {
fi.checkhitsprite(hitspr, k); fi.checkhitsprite(hitact->GetIndex(), k);
if (sprite[hitspr].picnum != TILE_APLAYER) if (hitact->s.picnum != TILE_APLAYER)
fi.spawn(k, SMALLSMOKE); fi.spawn(k, SMALLSMOKE);
else sprite[k].xrepeat = sprite[k].yrepeat = 0; else sprite[k].xrepeat = sprite[k].yrepeat = 0;
} }
@ -846,8 +847,9 @@ static void shootlaser(int i, int p, int sx, int sy, int sz, int sa)
spritetype* const s = &sprite[i]; spritetype* const s = &sprite[i];
int sect = s->sectnum; int sect = s->sectnum;
int zvel; int zvel;
short hitsect, hitspr, hitwall, j, k; short hitsect, hitwall, j, k;
int hitx, hity, hitz; int hitx, hity, hitz;
DDukeActor* hitsprt;
if (p >= 0) if (p >= 0)
zvel = -ps[p].horizon.sum().asq16() >> 11; zvel = -ps[p].horizon.sum().asq16() >> 11;
@ -856,10 +858,10 @@ static void shootlaser(int i, int p, int sx, int sy, int sz, int sa)
hitscan(sx, sy, sz - ps[p].pyoff, sect, hitscan(sx, sy, sz - ps[p].pyoff, sect,
sintable[(sa + 512) & 2047], sintable[(sa + 512) & 2047],
sintable[sa & 2047], sintable[sa & 2047],
zvel << 6, &hitsect, &hitwall, &hitspr, &hitx, &hity, &hitz, CLIPMASK1); zvel << 6, &hitsect, &hitwall, &hitsprt, &hitx, &hity, &hitz, CLIPMASK1);
j = 0; j = 0;
if (hitspr >= 0) return; if (hitsprt) return;
if (hitwall >= 0 && hitsect >= 0) if (hitwall >= 0 && hitsect >= 0)
if (((hitx - sx) * (hitx - sx) + (hity - sy) * (hity - sy)) < (290 * 290)) if (((hitx - sx) * (hitx - sx) + (hity - sy) * (hity - sy)) < (290 * 290))
@ -914,8 +916,9 @@ static void shootgrowspark(int i, int p, int sx, int sy, int sz, int sa)
auto s = &actor->s; auto s = &actor->s;
int sect = s->sectnum; int sect = s->sectnum;
int zvel; int zvel;
short hitsect, hitspr, hitwall, k; short hitsect, hitwall, k;
int hitx, hity, hitz; int hitx, hity, hitz;
DDukeActor* hitsprt;
if (p >= 0) if (p >= 0)
{ {
@ -967,7 +970,7 @@ static void shootgrowspark(int i, int p, int sx, int sy, int sz, int sa)
hitscan(sx, sy, sz, sect, hitscan(sx, sy, sz, sect,
sintable[(sa + 512) & 2047], sintable[(sa + 512) & 2047],
sintable[sa & 2047], sintable[sa & 2047],
zvel << 6, &hitsect, &hitwall, &hitspr, &hitx, &hity, &hitz, CLIPMASK1); zvel << 6, &hitsect, &hitwall, &hitsprt, &hitx, &hity, &hitz, CLIPMASK1);
s->cstat |= 257; s->cstat |= 257;
@ -977,12 +980,12 @@ static void shootgrowspark(int i, int p, int sx, int sy, int sz, int sa)
sprite[j].cstat |= 130; sprite[j].cstat |= 130;
sprite[j].xrepeat = sprite[j].yrepeat = 1; sprite[j].xrepeat = sprite[j].yrepeat = 1;
if (hitwall == -1 && hitspr == -1 && hitsect >= 0) if (hitwall == -1 && hitsprt == nullptr && hitsect >= 0)
{ {
if (zvel < 0 && (sector[hitsect].ceilingstat & 1) == 0) if (zvel < 0 && (sector[hitsect].ceilingstat & 1) == 0)
fi.checkhitceiling(hitsect); fi.checkhitceiling(hitsect);
} }
else if (hitspr >= 0) fi.checkhitsprite(hitspr, j); else if (hitsprt != nullptr) fi.checkhitsprite(hitsprt->GetIndex(), j);
else if (hitwall >= 0 && wall[hitwall].picnum != ACCESSSWITCH && wall[hitwall].picnum != ACCESSSWITCH2) else if (hitwall >= 0 && wall[hitwall].picnum != ACCESSSWITCH && wall[hitwall].picnum != ACCESSSWITCH2)
{ {
fi.checkhitwall(j, hitwall, hitx, hity, hitz, GROWSPARK); fi.checkhitwall(j, hitwall, hitx, hity, hitz, GROWSPARK);
@ -1993,14 +1996,15 @@ int operateTripbomb(int snum)
int pi = p->i; int pi = p->i;
int sx, sy, sz; int sx, sy, sz;
short sect, hw, hitsp; short sect, hw;
DDukeActor* hitsprt;
hitscan(p->posx, p->posy, p->posz, hitscan(p->posx, p->posy, p->posz,
p->cursectnum, sintable[(p->angle.ang.asbuild() + 512) & 2047], p->cursectnum, sintable[(p->angle.ang.asbuild() + 512) & 2047],
sintable[p->angle.ang.asbuild() & 2047], -p->horizon.sum().asq16() >> 11, sintable[p->angle.ang.asbuild() & 2047], -p->horizon.sum().asq16() >> 11,
&sect, &hw, &hitsp, &sx, &sy, &sz, CLIPMASK1); &sect, &hw, &hitsprt, &sx, &sy, &sz, CLIPMASK1);
if (sect < 0 || hitsp >= 0) if (sect < 0 || hitsprt)
return 0; return 0;
if (hw >= 0 && sector[sect].lotag > 2) if (hw >= 0 && sector[sect].lotag > 2)

View file

@ -93,8 +93,9 @@ static void shootmelee(int i, int p, int sx, int sy, int sz, int sa, int atwith)
spritetype* const s = &sprite[i]; spritetype* const s = &sprite[i];
int sect = s->sectnum; int sect = s->sectnum;
int zvel; int zvel;
short hitsect, hitspr, hitwall, j, k; short hitsect, hitwall, j, k;
int hitx, hity, hitz; int hitx, hity, hitz;
DDukeActor* hitsprt;
if (p >= 0) if (p >= 0)
{ {
@ -113,10 +114,10 @@ static void shootmelee(int i, int p, int sx, int sy, int sz, int sa, int atwith)
hitscan(sx, sy, sz, sect, hitscan(sx, sy, sz, sect,
sintable[(sa + 512) & 2047], sintable[(sa + 512) & 2047],
sintable[sa & 2047], zvel << 6, sintable[sa & 2047], zvel << 6,
&hitsect, &hitwall, &hitspr, &hitx, &hity, &hitz, CLIPMASK1); &hitsect, &hitwall, &hitsprt, &hitx, &hity, &hitz, CLIPMASK1);
if (isRRRA() && ((sector[hitsect].lotag == 160 && zvel > 0) || (sector[hitsect].lotag == 161 && zvel < 0)) if (isRRRA() && ((sector[hitsect].lotag == 160 && zvel > 0) || (sector[hitsect].lotag == 161 && zvel < 0))
&& hitspr == -1 && hitwall == -1) && hitsprt == nullptr && hitwall == -1)
{ {
short ii; short ii;
for (ii = 0; ii < MAXSPRITES; ii++) for (ii = 0; ii < MAXSPRITES; ii++)
@ -138,7 +139,7 @@ static void shootmelee(int i, int p, int sx, int sy, int sz, int sa, int atwith)
hitscan(nx, ny, nz, sprite[sprite[ii].owner].sectnum, hitscan(nx, ny, nz, sprite[sprite[ii].owner].sectnum,
sintable[(sa + 512) & 2047], sintable[(sa + 512) & 2047],
sintable[sa & 2047], zvel << 6, sintable[sa & 2047], zvel << 6,
&hitsect, &hitwall, &hitspr, &hitx, &hity, &hitz, CLIPMASK1); &hitsect, &hitwall, &hitsprt, &hitx, &hity, &hitz, CLIPMASK1);
break; break;
} }
} }
@ -148,7 +149,7 @@ static void shootmelee(int i, int p, int sx, int sy, int sz, int sa, int atwith)
if ((abs(sx - hitx) + abs(sy - hity)) < 1024) if ((abs(sx - hitx) + abs(sy - hity)) < 1024)
{ {
if (hitwall >= 0 || hitspr >= 0) if (hitwall >= 0 || hitsprt)
{ {
if (isRRRA() && atwith == SLINGBLADE) if (isRRRA() && atwith == SLINGBLADE)
{ {
@ -173,10 +174,10 @@ static void shootmelee(int i, int p, int sx, int sy, int sz, int sa, int atwith)
if (p >= 0 && ps[p].steroids_amount > 0 && ps[p].steroids_amount < 400) if (p >= 0 && ps[p].steroids_amount > 0 && ps[p].steroids_amount < 400)
sprite[j].extra += (max_player_health >> 2); sprite[j].extra += (max_player_health >> 2);
if (hitspr >= 0 && sprite[hitspr].picnum != ACCESSSWITCH && sprite[hitspr].picnum != ACCESSSWITCH2) if (hitsprt && hitsprt->s.picnum != ACCESSSWITCH && hitsprt->s.picnum != ACCESSSWITCH2)
{ {
fi.checkhitsprite(hitspr, j); fi.checkhitsprite(hitsprt->GetIndex(), j);
if (p >= 0) fi.checkhitswitch(p, hitspr, 1); if (p >= 0) fi.checkhitswitch(p, hitsprt->GetIndex(), 1);
} }
else if (hitwall >= 0) else if (hitwall >= 0)
{ {
@ -217,8 +218,9 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
auto s = &actor->s; auto s = &actor->s;
int sect = s->sectnum; int sect = s->sectnum;
int zvel; int zvel;
short hitsect, hitspr, hitwall, l, k; short hitsect, hitwall, l, k;
int hitx, hity, hitz; int hitx, hity, hitz;
DDukeActor* hitsprt;
if (s->extra >= 0) s->shade = -96; if (s->extra >= 0) s->shade = -96;
@ -274,10 +276,10 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
hitscan(sx, sy, sz, sect, hitscan(sx, sy, sz, sect,
sintable[(sa + 512) & 2047], sintable[(sa + 512) & 2047],
sintable[sa & 2047], sintable[sa & 2047],
zvel << 6, &hitsect, &hitwall, &hitspr, &hitx, &hity, &hitz, CLIPMASK1); zvel << 6, &hitsect, &hitwall, &hitsprt, &hitx, &hity, &hitz, CLIPMASK1);
if (isRRRA() && (((sector[hitsect].lotag == 160 && zvel > 0) || (sector[hitsect].lotag == 161 && zvel < 0)) if (isRRRA() && (((sector[hitsect].lotag == 160 && zvel > 0) || (sector[hitsect].lotag == 161 && zvel < 0))
&& hitspr == -1 && hitwall == -1)) && hitsprt == nullptr && hitwall == -1))
{ {
short ii; short ii;
for (ii = 0; ii < MAXSPRITES; ii++) for (ii = 0; ii < MAXSPRITES; ii++)
@ -299,7 +301,7 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
hitscan(nx, ny, nz, sprite[sprite[ii].owner].sectnum, hitscan(nx, ny, nz, sprite[sprite[ii].owner].sectnum,
sintable[(sa + 512) & 2047], sintable[(sa + 512) & 2047],
sintable[sa & 2047], zvel << 6, sintable[sa & 2047], zvel << 6,
&hitsect, &hitwall, &hitspr, &hitx, &hity, &hitz, CLIPMASK1); &hitsect, &hitwall, &hitsprt, &hitx, &hity, &hitz, CLIPMASK1);
break; break;
} }
} }
@ -323,7 +325,7 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
sprite[k].extra = ScriptCode[actorinfo[atwith].scriptaddress]; sprite[k].extra = ScriptCode[actorinfo[atwith].scriptaddress];
sprite[k].extra += (krand() % 6); sprite[k].extra += (krand() % 6);
if (hitwall == -1 && hitspr == -1) if (hitwall == -1 && hitsprt == nullptr)
{ {
if (zvel < 0) if (zvel < 0)
{ {
@ -340,12 +342,12 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
fi.spawn(k, SMALLSMOKE); fi.spawn(k, SMALLSMOKE);
} }
if (hitspr >= 0) if (hitsprt)
{ {
if (sprite[hitspr].picnum == 1930) if (hitsprt->s.picnum == 1930)
return; return;
fi.checkhitsprite(hitspr, k); fi.checkhitsprite(hitsprt->GetIndex(), k);
if (sprite[hitspr].picnum == TILE_APLAYER && (ud.coop != 1 || ud.ffire == 1)) if (hitsprt->s.picnum == TILE_APLAYER && (ud.coop != 1 || ud.ffire == 1))
{ {
l = fi.spawn(k, JIBS6); l = fi.spawn(k, JIBS6);
sprite[k].xrepeat = sprite[k].yrepeat = 0; sprite[k].xrepeat = sprite[k].yrepeat = 0;
@ -357,17 +359,17 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
else fi.spawn(k, SMALLSMOKE); else fi.spawn(k, SMALLSMOKE);
if (p >= 0 && ( if (p >= 0 && (
sprite[hitspr].picnum == DIPSWITCH || hitsprt->s.picnum == DIPSWITCH ||
sprite[hitspr].picnum == DIPSWITCH + 1 || hitsprt->s.picnum == DIPSWITCH + 1 ||
sprite[hitspr].picnum == DIPSWITCH2 || hitsprt->s.picnum == DIPSWITCH2 ||
sprite[hitspr].picnum == DIPSWITCH2 + 1 || hitsprt->s.picnum == DIPSWITCH2 + 1 ||
sprite[hitspr].picnum == DIPSWITCH3 || hitsprt->s.picnum == DIPSWITCH3 ||
sprite[hitspr].picnum == DIPSWITCH3 + 1 || hitsprt->s.picnum == DIPSWITCH3 + 1 ||
(isRRRA() && sprite[hitspr].picnum == RRTILE8660) || (isRRRA() && hitsprt->s.picnum == RRTILE8660) ||
sprite[hitspr].picnum == HANDSWITCH || hitsprt->s.picnum == HANDSWITCH ||
sprite[hitspr].picnum == HANDSWITCH + 1)) hitsprt->s.picnum == HANDSWITCH + 1))
{ {
fi.checkhitswitch(p, hitspr, 1); fi.checkhitswitch(p, hitsprt->GetIndex(), 1);
return; return;
} }
} }
@ -442,10 +444,10 @@ static void shootweapon(int i, int p, int sx, int sy, int sz, int sa, int atwith
k = EGS(hitsect, hitx, hity, hitz, SHOTSPARK1, -15, 24, 24, sa, 0, 0, i, 4); k = EGS(hitsect, hitx, hity, hitz, SHOTSPARK1, -15, 24, 24, sa, 0, 0, i, 4);
sprite[k].extra = ScriptCode[actorinfo[atwith].scriptaddress]; sprite[k].extra = ScriptCode[actorinfo[atwith].scriptaddress];
if (hitspr >= 0) if (hitsprt)
{ {
fi.checkhitsprite(hitspr, k); fi.checkhitsprite(hitsprt->GetIndex(), k);
if (sprite[hitspr].picnum != TILE_APLAYER) if (hitsprt->s.picnum != TILE_APLAYER)
fi.spawn(k, SMALLSMOKE); fi.spawn(k, SMALLSMOKE);
else sprite[k].xrepeat = sprite[k].yrepeat = 0; else sprite[k].xrepeat = sprite[k].yrepeat = 0;
} }