summaryrefslogtreecommitdiffstats
path: root/crawl-ref/source/fight.cc
diff options
context:
space:
mode:
Diffstat (limited to 'crawl-ref/source/fight.cc')
-rw-r--r--crawl-ref/source/fight.cc19
1 files changed, 12 insertions, 7 deletions
diff --git a/crawl-ref/source/fight.cc b/crawl-ref/source/fight.cc
index bc90cc39de..0090ce03e0 100644
--- a/crawl-ref/source/fight.cc
+++ b/crawl-ref/source/fight.cc
@@ -583,6 +583,8 @@ bool melee_attack::attack()
identify_mimic(attacker);
identify_mimic(defender);
+ coord_def defender_pos = defender->pos();
+
if (attacker->atype() == ACT_PLAYER && defender->atype() == ACT_MONSTER)
{
if (stop_attack_prompt(defender_as_monster(), false, attacker->pos()))
@@ -715,7 +717,7 @@ bool melee_attack::attack()
if (attacker->atype() == ACT_PLAYER)
{
- handle_noise();
+ handle_noise(defender_pos);
if (damage_brand == SPWPN_CHAOS)
chaos_affects_attacker();
@@ -988,6 +990,7 @@ bool melee_attack::player_aux_unarmed()
bool simple_miss_message = false;
std::string miss_verb;
+ coord_def defender_pos = defender->pos();
if (can_do_unarmed)
{
if (you.species == SP_NAGA)
@@ -1262,7 +1265,7 @@ bool melee_attack::player_aux_unarmed()
make_hungry(2, true);
- handle_noise();
+ handle_noise(defender_pos);
alert_nearby_monsters();
// XXX We're clobbering did_hit
@@ -3451,7 +3454,7 @@ bool melee_attack::apply_damage_brand()
//
// * Randart property to make randart weapons louder or softer when
// they hit.
-void melee_attack::handle_noise()
+void melee_attack::handle_noise(const coord_def & pos)
{
// Successful stabs make no noise.
if (stab_attempt)
@@ -3467,7 +3470,7 @@ void melee_attack::handle_noise()
level = std::max(1, level);
if (level > 0)
- noisy(level, defender->pos(), attacker->mindex());
+ noisy(level, pos, attacker->mindex());
noise_factor = 0;
extra_noise = 0;
@@ -5142,7 +5145,7 @@ void melee_attack::mons_perform_attack_rounds()
{
const int nrounds = attacker_as_monster()->has_hydra_multi_attack() ?
attacker_as_monster()->number : 4;
- const coord_def pos = defender->pos();
+ coord_def pos = defender->pos();
const bool was_delayed = you_are_delayed();
// Melee combat, tell attacker to wield its melee weapon.
@@ -5152,7 +5155,8 @@ void melee_attack::mons_perform_attack_rounds()
for (attack_number = 0; attack_number < nrounds; ++attack_number)
{
// Handle noise from previous round.
- handle_noise();
+ if(attack_number > 0)
+ handle_noise(pos);
// Monster went away?
if (!defender->alive() || defender->pos() != pos)
@@ -5184,6 +5188,7 @@ void melee_attack::mons_perform_attack_rounds()
{
defender = mons;
end = false;
+ pos = mons->pos();
break;
}
}
@@ -5521,7 +5526,7 @@ void melee_attack::mons_perform_attack_rounds()
}
// Handle noise from last round.
- handle_noise();
+ handle_noise(pos);
if (def_copy)
delete def_copy;