summaryrefslogtreecommitdiffstats
path: root/crawl-ref/source/abl-show.cc
diff options
context:
space:
mode:
authordolorous <dolorous@c06c8d41-db1a-0410-9941-cceddc491573>2009-05-16 00:30:01 +0000
committerdolorous <dolorous@c06c8d41-db1a-0410-9941-cceddc491573>2009-05-16 00:30:01 +0000
commit5bf0b52eb3d937b93c1c7ebcb80678a251a0502c (patch)
tree63143cba732b84ae93843a92143f9c6d9749dde5 /crawl-ref/source/abl-show.cc
parent3ac377c1d12efdc4bb8ab217aa2d4089f12542ec (diff)
downloadcrawl-ref-5bf0b52eb3d937b93c1c7ebcb80678a251a0502c.tar.gz
crawl-ref-5bf0b52eb3d937b93c1c7ebcb80678a251a0502c.zip
Properly disallow Elyvilon's "Heal Other" abilities when they're aimed
at the player, just as we do with Lugonu's "Banish" ability. git-svn-id: https://crawl-ref.svn.sourceforge.net/svnroot/crawl-ref/trunk@9778 c06c8d41-db1a-0410-9941-cceddc491573
Diffstat (limited to 'crawl-ref/source/abl-show.cc')
-rw-r--r--crawl-ref/source/abl-show.cc9
1 files changed, 7 insertions, 2 deletions
diff --git a/crawl-ref/source/abl-show.cc b/crawl-ref/source/abl-show.cc
index d77898512f..a608e28acc 100644
--- a/crawl-ref/source/abl-show.cc
+++ b/crawl-ref/source/abl-show.cc
@@ -1704,8 +1704,9 @@ static bool _do_ability(const ability_def& abil)
case ABIL_ELYVILON_LESSER_HEALING_OTHERS:
{
const bool self = (abil.ability == ABIL_ELYVILON_LESSER_HEALING_SELF);
+
if (cast_healing(3 + (you.skills[SK_INVOCATIONS] / 6), true,
- self ? you.pos() : coord_def(0,0),
+ self ? you.pos() : coord_def(0, 0), !self,
self ? TARG_NUM_MODES : TARG_HOSTILE) < 0)
{
return (false);
@@ -1723,8 +1724,9 @@ static bool _do_ability(const ability_def& abil)
case ABIL_ELYVILON_GREATER_HEALING_OTHERS:
{
const bool self = (abil.ability == ABIL_ELYVILON_GREATER_HEALING_SELF);
+
if (cast_healing(10 + (you.skills[SK_INVOCATIONS] / 3), true,
- self ? you.pos() : coord_def(0,0),
+ self ? you.pos() : coord_def(0, 0), !self,
self ? TARG_NUM_MODES : TARG_HOSTILE) < 0)
{
return (false);
@@ -1753,6 +1755,7 @@ static bool _do_ability(const ability_def& abil)
mpr("You aren't in the Abyss!");
return (false); // Don't incur costs.
}
+
banished(DNGN_EXIT_ABYSS);
exercise(SK_INVOCATIONS, 8 + random2(10));
break;
@@ -1772,11 +1775,13 @@ static bool _do_ability(const ability_def& abil)
mpr("You cannot banish yourself!");
return (false);
}
+
if (!zapping(ZAP_BANISHMENT, 16 + you.skills[SK_INVOCATIONS] * 8, beam,
true))
{
return (false);
}
+
exercise(SK_INVOCATIONS, 3 + random2(5));
break;