From 84ce3a3c647520815b0cd00af1a9558b993b4c05 Mon Sep 17 00:00:00 2001 From: Michael Meyer Date: Wed, 13 Dec 2023 12:13:55 -0500 Subject: [PATCH] Assess iron material damage for spiked pits The spikes in spiked pits are described as iron, so apply the additional iron damage when the hero or a monster is harmed by them. --- src/sit.c | 6 ++++-- src/trap.c | 12 +++++++++--- 2 files changed, 13 insertions(+), 5 deletions(-) diff --git a/src/sit.c b/src/sit.c index 5aa46107c..fa2ee7b3b 100644 --- a/src/sit.c +++ b/src/sit.c @@ -301,9 +301,11 @@ dosit(void) u.utrap++; } else if (u.utraptype == TT_PIT) { if (trap && trap->ttyp == SPIKED_PIT) { + int dmg = Half_physical_damage ? rn2(2) : 1; + if (mon_hates_material(&gy.youmonst, IRON)) + dmg += Maybe_Half_Phys(rnd(sear_damage(IRON))); You("sit down on a spike. Ouch!"); - losehp(Half_physical_damage ? rn2(2) : 1, - "sitting on an iron spike", KILLED_BY); + losehp(dmg, "sitting on an iron spike", KILLED_BY); exercise(A_STR, FALSE); } else You("sit down in the pit."); diff --git a/src/trap.c b/src/trap.c index 764c10513..1cb24c4b0 100644 --- a/src/trap.c +++ b/src/trap.c @@ -2056,8 +2056,11 @@ trapeffect_pit( set_utrap((unsigned) rn1(6, 2), TT_PIT); if (!steedintrap(trap, (struct obj *) 0)) { if (ttype == SPIKED_PIT) { + int dmg = rnd(conj_pit ? 4 : adj_pit ? 6 : 10); + if (mon_hates_material(mtmp, IRON)) + dmg += rnd(sear_damage(IRON)); oldumort = u.umortality; - losehp(Maybe_Half_Phys(rnd(conj_pit ? 4 : adj_pit ? 6 : 10)), + losehp(Maybe_Half_Phys(dmg), /* note: these don't need locomotion() handling; if fatal while poly'd and Unchanging, the death reason will be overridden with @@ -2099,7 +2102,7 @@ trapeffect_pit( exercise(A_DEX, FALSE); } } else { - int tt = trap->ttyp; + int tt = trap->ttyp, dmg; boolean in_sight = canseemon(mtmp) || (mtmp == u.usteed); boolean trapkilled = FALSE; boolean forcetrap = ((trflags & FORCETRAP) != 0); @@ -2134,8 +2137,11 @@ trapeffect_pit( seetrap(trap); } mselftouch(mtmp, "Falling, ", FALSE); + dmg = rnd((tt == PIT) ? 6 : 10); + if (tt == SPIKED_PIT && mon_hates_material(mtmp, IRON)) + dmg += rnd(sear_damage(IRON)); if (DEADMONSTER(mtmp) || thitm(0, mtmp, (struct obj *) 0, - rnd((tt == PIT) ? 6 : 10), FALSE)) + dmg, FALSE)) trapkilled = TRUE; return trapkilled ? Trap_Killed_Mon : mtmp->mtrapped