diff options
author | Eduardo Gonzalez <ed.gonzalez3@gmail.com> | 2014-05-03 23:17:45 -0700 |
---|---|---|
committer | Jesse Luehrs <doy@tozt.net> | 2014-08-15 15:55:25 -0400 |
commit | fedf9161c42865e6853449f5bd701a4fef40e690 (patch) | |
tree | d20b25bbd787afce90bf00b98ca9e5a4c0dc251f /crawl-ref/source/spl-summoning.cc | |
parent | 0d61daab317636fdbfa7b6100f41aa3d67bfe514 (diff) | |
download | crawl-ref-fedf9161c42865e6853449f5bd701a4fef40e690.tar.gz crawl-ref-fedf9161c42865e6853449f5bd701a4fef40e690.zip |
Don't crash if a battlesphere or avatar expires inside a wall (#8448)
All the other monsters that place clouds on death make a safety check
that the cell isn't solid. Update these two summons to match.
Diffstat (limited to 'crawl-ref/source/spl-summoning.cc')
-rw-r--r-- | crawl-ref/source/spl-summoning.cc | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/crawl-ref/source/spl-summoning.cc b/crawl-ref/source/spl-summoning.cc index a7974a337c..912612a7b8 100644 --- a/crawl-ref/source/spl-summoning.cc +++ b/crawl-ref/source/spl-summoning.cc @@ -2749,8 +2749,8 @@ void end_battlesphere(monster* mons, bool killed) else if (you.can_see(mons)) simple_monster_message(mons, " dissipates."); - place_cloud(CLOUD_MAGIC_TRAIL, mons->pos(), - 3 + random2(3), mons); + if (!cell_is_solid(mons->pos())) + place_cloud(CLOUD_MAGIC_TRAIL, mons->pos(), 3 + random2(3), mons); monster_die(mons, KILL_RESET, NON_MONSTER); } @@ -3418,8 +3418,8 @@ void end_grand_avatar(monster* mons, bool killed) if (!killed) { - place_cloud(CLOUD_MAGIC_TRAIL, mons->pos(), - 3 + random2(3), mons); + if (!cell_is_solid(mons->pos())) + place_cloud(CLOUD_MAGIC_TRAIL, mons->pos(), 3 + random2(3), mons); monster_die(mons, KILL_RESET, NON_MONSTER); } } |