Clean up actors.c and player.c.

git-svn-id: https://svn.eduke32.com/eduke32@3353 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
helixhorned 2013-01-01 15:24:14 +00:00
parent 25f6255d28
commit 37d8cda701
3 changed files with 58 additions and 64 deletions

View file

@ -102,16 +102,18 @@ void G_ClearCameraView(DukePlayer_t *ps)
void A_RadiusDamage(int32_t i, int32_t r, int32_t hp1, int32_t hp2, int32_t hp3, int32_t hp4) void A_RadiusDamage(int32_t i, int32_t r, int32_t hp1, int32_t hp2, int32_t hp3, int32_t hp4)
{ {
spritetype *s=&sprite[i],*sj; const spritetype *const s=&sprite[i];
walltype *wal; const walltype *wal;
int32_t d, q, x1, y1; int32_t d, q, x1, y1;
int32_t sectcnt, sectend, dasect, startwall, endwall, nextsect; int32_t sectcnt, sectend, dasect, startwall, endwall, nextsect;
int32_t j,k,x,nextj; int32_t j,k,x;
int16_t sect=-1; int16_t sect=-1;
char statlist[] = {STAT_DEFAULT,STAT_ACTOR,STAT_STANDABLE, char statlist[] = {
STAT_PLAYER,STAT_FALLER,STAT_ZOMBIEACTOR,STAT_MISC STAT_DEFAULT,STAT_ACTOR,STAT_STANDABLE,
}; STAT_PLAYER,STAT_FALLER,STAT_ZOMBIEACTOR,STAT_MISC
int16_t *tempshort = (int16_t *)tempbuf; };
int16_t *const tempshort = (int16_t *)tempbuf;
if (s->picnum == RPG && s->xrepeat < 11) goto SKIPWALLCHECK; if (s->picnum == RPG && s->xrepeat < 11) goto SKIPWALLCHECK;
@ -176,8 +178,8 @@ SKIPWALLCHECK:
j = headspritestat[(uint8_t)statlist[x]]; j = headspritestat[(uint8_t)statlist[x]];
while (j >= 0) while (j >= 0)
{ {
nextj = nextspritestat[j]; int32_t nextj = nextspritestat[j];
sj = &sprite[j]; spritetype *const sj = &sprite[j];
if (x == 0 || x >= 5 || AFLAMABLE(sj->picnum)) if (x == 0 || x >= 5 || AFLAMABLE(sj->picnum))
{ {

View file

@ -380,6 +380,31 @@ static int32_t GetAutoAimAngle(int32_t i, int32_t p, int32_t atwith,
return j; return j;
} }
static void Proj_MaybeSpawn(int32_t k, int32_t atwith, const hitdata_t *hit)
{
if (ProjectileData[atwith].spawns >= 0)
{
int32_t wh=A_Spawn(k,ProjectileData[atwith].spawns);
if (ProjectileData[atwith].sxrepeat > 4) sprite[wh].xrepeat=ProjectileData[atwith].sxrepeat;
if (ProjectileData[atwith].syrepeat > 4) sprite[wh].yrepeat=ProjectileData[atwith].syrepeat;
A_SetHitData(wh, hit);
}
}
static int32_t Proj_InsertShotspark(const hitdata_t *hit, int32_t i, int32_t atwith, int32_t sz, int32_t ang)
{
int32_t k = A_InsertSprite(hit->sect,hit->pos.x,hit->pos.y,hit->pos.z,SHOTSPARK1,-15,
sz,sz,ang,0,0,i,4);
sprite[k].extra = ProjectileData[atwith].extra;
if (ProjectileData[atwith].extra_rand > 0)
sprite[k].extra += (krand()%ProjectileData[atwith].extra_rand);
sprite[k].yvel = atwith; // this is a hack to allow you to detect which weapon spawned a SHOTSPARK1
A_SetHitData(k, hit);
return k;
}
int32_t A_Shoot(int32_t i, int32_t atwith) int32_t A_Shoot(int32_t i, int32_t atwith)
{ {
int16_t l, sa, j, k=-1; int16_t l, sa, j, k=-1;
@ -778,12 +803,7 @@ int32_t A_Shoot(int32_t i, int32_t atwith)
if (p >= 0) if (p >= 0)
{ {
k = A_InsertSprite(hit.sect,hit.pos.x,hit.pos.y,hit.pos.z,SHOTSPARK1,-15,10,10,sa,0,0,i,4); k = Proj_InsertShotspark(&hit, i, atwith, 10, sa);
sprite[k].extra = ProjectileData[atwith].extra;
if (ProjectileData[atwith].extra_rand > 0)
sprite[k].extra += (krand()%ProjectileData[atwith].extra_rand);
sprite[k].yvel = atwith; // this is a hack to allow you to detect which weapon spawned a SHOTSPARK1
A_SetHitData(k, &hit);
if (hit.wall == -1 && hit.sprite == -1) if (hit.wall == -1 && hit.sprite == -1)
{ {
@ -798,13 +818,8 @@ int32_t A_Shoot(int32_t i, int32_t atwith)
else else
Sect_DamageCeiling(hit.sect); Sect_DamageCeiling(hit.sect);
} }
if (ProjectileData[atwith].spawns >= 0)
{ Proj_MaybeSpawn(k, atwith, &hit);
int32_t wh=A_Spawn(k,ProjectileData[atwith].spawns);
if (ProjectileData[atwith].sxrepeat > 4) sprite[wh].xrepeat=ProjectileData[atwith].sxrepeat;
if (ProjectileData[atwith].syrepeat > 4) sprite[wh].yrepeat=ProjectileData[atwith].syrepeat;
A_SetHitData(wh, &hit);
}
} }
if (hit.sprite >= 0) if (hit.sprite >= 0)
@ -823,14 +838,9 @@ int32_t A_Shoot(int32_t i, int32_t atwith)
} }
else else
{ {
if (ProjectileData[atwith].spawns >= 0) Proj_MaybeSpawn(k, atwith, &hit);
{
int32_t wh=A_Spawn(k,ProjectileData[atwith].spawns);
if (ProjectileData[atwith].sxrepeat > 4) sprite[wh].xrepeat=ProjectileData[atwith].sxrepeat;
if (ProjectileData[atwith].syrepeat > 4) sprite[wh].yrepeat=ProjectileData[atwith].syrepeat;
A_SetHitData(wh, &hit);
}
} }
if (p >= 0 && CheckShootSwitchTile(sprite[hit.sprite].picnum)) if (p >= 0 && CheckShootSwitchTile(sprite[hit.sprite].picnum))
{ {
P_ActivateSwitch(p,hit.sprite,1); P_ActivateSwitch(p,hit.sprite,1);
@ -839,13 +849,8 @@ int32_t A_Shoot(int32_t i, int32_t atwith)
} }
else if (hit.wall >= 0) else if (hit.wall >= 0)
{ {
if (ProjectileData[atwith].spawns >= 0) Proj_MaybeSpawn(k, atwith, &hit);
{
int32_t wh=A_Spawn(k,ProjectileData[atwith].spawns);
if (ProjectileData[atwith].sxrepeat > 4) sprite[wh].xrepeat=ProjectileData[atwith].sxrepeat;
if (ProjectileData[atwith].syrepeat > 4) sprite[wh].yrepeat=ProjectileData[atwith].syrepeat;
A_SetHitData(wh, &hit);
}
if (CheckDoorTile(wall[hit.wall].picnum) == 1) if (CheckDoorTile(wall[hit.wall].picnum) == 1)
goto DOSKIPBULLETHOLE; goto DOSKIPBULLETHOLE;
if (p >= 0 && CheckShootSwitchTile(wall[hit.wall].picnum)) if (p >= 0 && CheckShootSwitchTile(wall[hit.wall].picnum))
@ -926,25 +931,14 @@ DOSKIPBULLETHOLE:
} }
else else
{ {
k = A_InsertSprite(hit.sect,hit.pos.x,hit.pos.y,hit.pos.z,SHOTSPARK1,-15,24,24,sa,0,0,i,4); k = Proj_InsertShotspark(&hit, i, atwith, 24, sa);
sprite[k].extra = ProjectileData[atwith].extra;
if (ProjectileData[atwith].extra_rand > 0)
sprite[k].extra += (krand()%ProjectileData[atwith].extra_rand);
sprite[k].yvel = atwith; // this is a hack to allow you to detect which weapon spawned a SHOTSPARK1
A_SetHitData(k, &hit);
if (hit.sprite >= 0) if (hit.sprite >= 0)
{ {
A_DamageObject(hit.sprite,k); A_DamageObject(hit.sprite,k);
if (sprite[hit.sprite].picnum != APLAYER) if (sprite[hit.sprite].picnum != APLAYER)
{ {
if (ProjectileData[atwith].spawns >= 0) Proj_MaybeSpawn(k, atwith, &hit);
{
int32_t wh=A_Spawn(k,ProjectileData[atwith].spawns);
if (ProjectileData[atwith].sxrepeat > 4) sprite[wh].xrepeat=ProjectileData[atwith].sxrepeat;
if (ProjectileData[atwith].syrepeat > 4) sprite[wh].yrepeat=ProjectileData[atwith].syrepeat;
A_SetHitData(wh, &hit);
}
} }
else sprite[k].xrepeat = sprite[k].yrepeat = 0; else sprite[k].xrepeat = sprite[k].yrepeat = 0;
} }
@ -1863,7 +1857,7 @@ static void P_DisplaySpit(int32_t snum)
} }
} }
static int32_t get_hud_pal(const DukePlayer_t *p) static int32_t P_GetHudPal(const DukePlayer_t *p)
{ {
if (sprite[p->i].pal == 1) if (sprite[p->i].pal == 1)
return 1; return 1;
@ -1898,7 +1892,7 @@ static int32_t P_DisplayFist(int32_t gs,int32_t snum)
fistz = 194 + (sintable[((6+fisti)<<7)&2047]>>9); fistz = 194 + (sintable[((6+fisti)<<7)&2047]>>9);
fistpal = get_hud_pal(ps); fistpal = P_GetHudPal(ps);
// XXX: this is outdated, doesn't handle above/below split. // XXX: this is outdated, doesn't handle above/below split.
if (g_fakeMultiMode==2) if (g_fakeMultiMode==2)
@ -1945,7 +1939,7 @@ static void G_DrawTileScaled(int32_t x, int32_t y, int32_t tilenum, int32_t shad
break; break;
} }
// for G_DrawTileScaled, bit 4 means "flip x" // bit 4 means "flip x" for G_DrawTileScaled
if (orientation&4) if (orientation&4)
ang = 1024; ang = 1024;
@ -2054,7 +2048,7 @@ static int32_t P_DisplayKnee(int32_t gs,int32_t snum)
looking_arc -= (ps->hard_landing<<3); looking_arc -= (ps->hard_landing<<3);
pal = get_hud_pal(ps); pal = P_GetHudPal(ps);
if (pal == 0) if (pal == 0)
pal = ps->palookup; pal = ps->palookup;
@ -2077,7 +2071,7 @@ static int32_t P_DisplayKnuckles(int32_t gs,int32_t snum)
looking_arc -= (ps->hard_landing<<3); looking_arc -= (ps->hard_landing<<3);
pal = get_hud_pal(ps); pal = P_GetHudPal(ps);
G_DrawTileScaled(160+(g_player[snum].sync->avel>>4)-(ps->look_ang>>1), G_DrawTileScaled(160+(g_player[snum].sync->avel>>4)-(ps->look_ang>>1),
looking_arc+180-((ps->horiz-ps->horizoff)>>4), looking_arc+180-((ps->horiz-ps->horizoff)>>4),
@ -2086,7 +2080,7 @@ static int32_t P_DisplayKnuckles(int32_t gs,int32_t snum)
return 1; return 1;
} }
void P_FireWeapon(DukePlayer_t *p) static void P_FireWeapon(DukePlayer_t *p)
{ {
int32_t i, snum = sprite[p->i].yvel; int32_t i, snum = sprite[p->i].yvel;
@ -2170,7 +2164,7 @@ void P_DisplayScuba(int32_t snum)
{ {
if (g_player[snum].ps->scuba_on) if (g_player[snum].ps->scuba_on)
{ {
int32_t p = get_hud_pal(g_player[snum].ps); int32_t p = P_GetHudPal(g_player[snum].ps);
g_snum = snum; g_snum = snum;
G_DrawTileScaled(43, (200-tilesizy[SCUBAMASK]), SCUBAMASK, 0, 2+16+DRAWEAP_CENTER, p); G_DrawTileScaled(43, (200-tilesizy[SCUBAMASK]), SCUBAMASK, 0, 2+16+DRAWEAP_CENTER, p);
@ -2197,7 +2191,7 @@ static int32_t P_DisplayTip(int32_t gs,int32_t snum)
looking_arc = klabs(ps->look_ang)/9; looking_arc = klabs(ps->look_ang)/9;
looking_arc -= (ps->hard_landing<<3); looking_arc -= (ps->hard_landing<<3);
p = get_hud_pal(ps); p = P_GetHudPal(ps);
/* if(ps->access_spritenum >= 0) /* if(ps->access_spritenum >= 0)
p = sprite[ps->access_spritenum].pal; p = sprite[ps->access_spritenum].pal;
@ -2269,7 +2263,7 @@ void P_DisplayWeapon(int32_t snum)
int32_t weapon_xoffset, i, j; int32_t weapon_xoffset, i, j;
int32_t o = 0,pal = 0; int32_t o = 0,pal = 0;
DukePlayer_t *const p = g_player[snum].ps; DukePlayer_t *const p = g_player[snum].ps;
uint8_t *kb = &p->kickback_pic; const uint8_t *const kb = &p->kickback_pic;
int32_t gs; int32_t gs;
g_snum = snum; g_snum = snum;
@ -2320,7 +2314,7 @@ void P_DisplayWeapon(int32_t snum)
j = 14-p->quick_kick; j = 14-p->quick_kick;
if (j != 14 || p->last_quick_kick) if (j != 14 || p->last_quick_kick)
{ {
pal = get_hud_pal(p); pal = P_GetHudPal(p);
if (pal == 0) if (pal == 0)
pal = p->palookup; pal = p->palookup;
@ -2335,7 +2329,7 @@ void P_DisplayWeapon(int32_t snum)
if (sprite[p->i].xrepeat < 40) if (sprite[p->i].xrepeat < 40)
{ {
pal = get_hud_pal(p); pal = P_GetHudPal(p);
if (p->jetpack_on == 0) if (p->jetpack_on == 0)
{ {
@ -2356,7 +2350,7 @@ void P_DisplayWeapon(int32_t snum)
} }
else else
{ {
pal = get_hud_pal(p); pal = P_GetHudPal(p);
switch (cw) switch (cw)
{ {
@ -3754,7 +3748,7 @@ void P_FragPlayer(int32_t snum)
} }
} }
void P_ProcessWeapon(int32_t snum) static void P_ProcessWeapon(int32_t snum)
{ {
DukePlayer_t *const p = g_player[snum].ps; DukePlayer_t *const p = g_player[snum].ps;
uint8_t *const kb = &p->kickback_pic; uint8_t *const kb = &p->kickback_pic;

View file

@ -336,11 +336,9 @@ int32_t P_DoFist(DukePlayer_t *p);
void P_DoWeaponSpawn(DukePlayer_t *p); void P_DoWeaponSpawn(DukePlayer_t *p);
void P_DropWeapon(DukePlayer_t *p); void P_DropWeapon(DukePlayer_t *p);
int32_t P_FindOtherPlayer(int32_t p,int32_t *d); int32_t P_FindOtherPlayer(int32_t p,int32_t *d);
void P_FireWeapon(DukePlayer_t *p);
void P_FragPlayer(int32_t snum); void P_FragPlayer(int32_t snum);
void P_UpdatePosWhenViewingCam(DukePlayer_t *p); void P_UpdatePosWhenViewingCam(DukePlayer_t *p);
void P_ProcessInput(int32_t snum); void P_ProcessInput(int32_t snum);
void P_ProcessWeapon(int32_t snum);
void P_QuickKill(DukePlayer_t *p); void P_QuickKill(DukePlayer_t *p);
void P_SelectNextInvItem(DukePlayer_t *p); void P_SelectNextInvItem(DukePlayer_t *p);
void P_UpdateScreenPal(DukePlayer_t *p); void P_UpdateScreenPal(DukePlayer_t *p);