diff options
Diffstat (limited to 'crawl-ref/source/spells1.cc')
-rw-r--r-- | crawl-ref/source/spells1.cc | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/crawl-ref/source/spells1.cc b/crawl-ref/source/spells1.cc index b08c12e433..a783bf7821 100644 --- a/crawl-ref/source/spells1.cc +++ b/crawl-ref/source/spells1.cc @@ -1250,11 +1250,26 @@ void abjuration(int pow) mon_enchant abj = monster->get_ench(ENCH_ABJ); if (abj.ench != ENCH_NONE) { - const int sockage = std::max(fuzz_value(abjdur, 60, 30), 40); + int sockage = std::max(fuzz_value(abjdur, 60, 30), 40); #ifdef DEBUG_DIAGNOSTICS mprf(MSGCH_DIAGNOSTICS, "%s abj: dur: %d, abj: %d", monster->name(DESC_PLAIN).c_str(), abj.duration, sockage); #endif + + // TSO and Trog's abjuration protection. + if (monster->god == GOD_SHINING_ONE) + { + sockage = sockage * monster->hit_dice / 45; + if (sockage < abj.duration) + simple_god_message(" protects a fellow warrior from your evil magic!"); + } + else if (monster->god == GOD_TROG) + { + sockage = sockage * 8 / 15; + if (sockage < abj.duration) + simple_god_message(" shields an ally from your puny magic!"); + } + if (!monster->lose_ench_duration(abj, sockage)) simple_monster_message(monster, " shudders."); } |