- removed the few remaining uses of actDamageSprite_.

This commit is contained in:
Christoph Oelckers 2021-09-16 21:36:34 +02:00
parent 3ab636a13a
commit f712a674ce
4 changed files with 16 additions and 15 deletions

View file

@ -7404,11 +7404,6 @@ void SerializeActor(FSerializer& arc)
} }
// dumping ground for temporary wrappers. // dumping ground for temporary wrappers.
int actDamageSprite_(int nSource, spritetype* pSprite, DAMAGE_TYPE damageType, int damage)
{
return actDamageSprite(nSource == -1 ? nullptr : &bloodActors[nSource], &bloodActors[pSprite->index], damageType, damage);
}
void actPostSprite(int nSprite, int nStatus) void actPostSprite(int nSprite, int nStatus)
{ {
actPostSprite(&bloodActors[nSprite], nStatus); actPostSprite(&bloodActors[nSprite], nStatus);

View file

@ -223,7 +223,6 @@ void actRadiusDamage(DBloodActor* source, int x, int y, int z, int nSector, int
DBloodActor *actDropObject(DBloodActor *pSprite, int nType); DBloodActor *actDropObject(DBloodActor *pSprite, int nType);
bool actHealDude(DBloodActor* pXDude, int a2, int a3); bool actHealDude(DBloodActor* pXDude, int a2, int a3);
void actKillDude(DBloodActor* a1, DBloodActor* pSprite, DAMAGE_TYPE a3, int a4); void actKillDude(DBloodActor* a1, DBloodActor* pSprite, DAMAGE_TYPE a3, int a4);
int actDamageSprite_(int nSource, spritetype *pSprite, DAMAGE_TYPE a3, int a4);
int actDamageSprite(DBloodActor* pSource, DBloodActor* pTarget, DAMAGE_TYPE damageType, int damage); int actDamageSprite(DBloodActor* pSource, DBloodActor* pTarget, DAMAGE_TYPE damageType, int damage);
void actHitcodeToData(int a1, HITINFO *pHitInfo, DBloodActor **actor, walltype **a7 = nullptr); void actHitcodeToData(int a1, HITINFO *pHitInfo, DBloodActor **actor, walltype **a7 = nullptr);
void actAirDrag(DBloodActor *pSprite, int a2); void actAirDrag(DBloodActor *pSprite, int a2);

View file

@ -1480,9 +1480,13 @@ int debrisGetFreeIndex(void) {
return -1; return -1;
} }
void debrisConcuss(int nOwner, int listIndex, int x, int y, int z, int dmg) { void debrisConcuss(int nOwner, int listIndex, int x, int y, int z, int dmg)
{
auto owner = &bloodActors[nOwner];
spritetype* pSprite = (gPhysSpritesList[listIndex] >= 0) ? &sprite[gPhysSpritesList[listIndex]] : NULL; spritetype* pSprite = (gPhysSpritesList[listIndex] >= 0) ? &sprite[gPhysSpritesList[listIndex]] : NULL;
if (pSprite != NULL && xspriRangeIsFine(pSprite->extra)) { if (pSprite != NULL && xspriRangeIsFine(pSprite->extra))
{
auto actor = &bloodActors[pSprite->index];
int dx = pSprite->x - x; int dy = pSprite->y - y; int dz = (pSprite->z - z) >> 4; int dx = pSprite->x - x; int dy = pSprite->y - y; int dz = (pSprite->z - z) >> 4;
dmg = scale(0x40000, dmg, 0x40000 + dx * dx + dy * dy + dz * dz); dmg = scale(0x40000, dmg, 0x40000 + dx * dx + dy * dy + dz * dz);
bool thing = (pSprite->type >= kThingBase && pSprite->type < kThingMax); bool thing = (pSprite->type >= kThingBase && pSprite->type < kThingMax);
@ -1500,7 +1504,7 @@ void debrisConcuss(int nOwner, int listIndex, int x, int y, int z, int dmg) {
pSprite->statnum = kStatThing; // temporary change statnum property pSprite->statnum = kStatThing; // temporary change statnum property
} }
actDamageSprite_(nOwner, pSprite, kDamageExplode, dmg); actDamageSprite(owner, actor, kDamageExplode, dmg);
if (thing) if (thing)
pSprite->statnum = kStatDecoration; // return statnum property back pSprite->statnum = kStatDecoration; // return statnum property back
@ -2985,15 +2989,18 @@ void useSpriteDamager(XSPRITE* pXSource, int objType, int objIndex) {
} }
} }
void damageSprites(XSPRITE* pXSource, spritetype* pSprite) { void damageSprites(XSPRITE* pXSource, spritetype* pSprite)
{
auto actor = &bloodActors[pSprite->index]; auto actor = &bloodActors[pSprite->index];
spritetype* pSource = &sprite[pXSource->reference]; auto sourceactor = &bloodActors[pXSource->reference];
spritetype* pSource = &sourceactor->s();
if (!IsDudeSprite(pSprite) || !xspriRangeIsFine(pSprite->extra) || xsprite[pSprite->extra].health <= 0 || pXSource->data3 < 0) if (!IsDudeSprite(pSprite) || !xspriRangeIsFine(pSprite->extra) || xsprite[pSprite->extra].health <= 0 || pXSource->data3 < 0)
return; return;
int health = 0; int health = 0;
XSPRITE* pXSprite = &xsprite[pSprite->extra]; PLAYER* pPlayer = getPlayerById(pSprite->type); XSPRITE* pXSprite = &xsprite[pSprite->extra];
PLAYER* pPlayer = getPlayerById(pSprite->type);
int dmgType = (pXSource->data2 >= kDmgFall) ? ClipHigh(pXSource->data2, kDmgElectric) : -1; int dmgType = (pXSource->data2 >= kDmgFall) ? ClipHigh(pXSource->data2, kDmgElectric) : -1;
int dmg = pXSprite->health << 4; int armor[3]; int dmg = pXSprite->health << 4; int armor[3];
@ -3017,13 +3024,13 @@ void damageSprites(XSPRITE* pXSource, spritetype* pSprite) {
playerDamageArmor(pPlayer, (DAMAGE_TYPE)dmgType, dmg); playerDamageArmor(pPlayer, (DAMAGE_TYPE)dmgType, dmg);
for (int i = 0; i < 3; armor[i] = pPlayer->armor[i], pPlayer->armor[i] = 0, i++); for (int i = 0; i < 3; armor[i] = pPlayer->armor[i], pPlayer->armor[i] = 0, i++);
actDamageSprite_(pSource->index, pSprite, (DAMAGE_TYPE)dmgType, dmg); actDamageSprite(sourceactor, actor, (DAMAGE_TYPE)dmgType, dmg);
for (int i = 0; i < 3; pPlayer->armor[i] = armor[i], i++); for (int i = 0; i < 3; pPlayer->armor[i] = armor[i], i++);
} }
else { else {
actDamageSprite_(pSource->index, pSprite, (DAMAGE_TYPE)dmgType, dmg); actDamageSprite(sourceactor, actor, (DAMAGE_TYPE)dmgType, dmg);
} }

View file

@ -1728,7 +1728,7 @@ void AltFireLifeLeech(int , PLAYER *pPlayer)
int nAmmo = pPlayer->ammoCount[8]; int nAmmo = pPlayer->ammoCount[8];
if (nAmmo < 25 && pPlayer->pXSprite->health > unsigned((25-nAmmo)<<4)) if (nAmmo < 25 && pPlayer->pXSprite->health > unsigned((25-nAmmo)<<4))
{ {
actDamageSprite_(pPlayer->nSprite, pPlayer->pSprite, kDamageSpirit, ((25-nAmmo)<<4)); actDamageSprite(actor, actor, kDamageSpirit, ((25-nAmmo)<<4));
nAmmo = 25; nAmmo = 25;
} }
pXSprite->data3 = nAmmo; pXSprite->data3 = nAmmo;