diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/bindings/scripts/scripts/eastern_kingdoms/scarlet_enclave/the_scarlet_enclave.cpp | 9 | ||||
-rw-r--r-- | src/game/SpellEffects.cpp | 13 |
2 files changed, 20 insertions, 2 deletions
diff --git a/src/bindings/scripts/scripts/eastern_kingdoms/scarlet_enclave/the_scarlet_enclave.cpp b/src/bindings/scripts/scripts/eastern_kingdoms/scarlet_enclave/the_scarlet_enclave.cpp index b13423e850f..3a1f7304688 100644 --- a/src/bindings/scripts/scripts/eastern_kingdoms/scarlet_enclave/the_scarlet_enclave.cpp +++ b/src/bindings/scripts/scripts/eastern_kingdoms/scarlet_enclave/the_scarlet_enclave.cpp @@ -104,11 +104,16 @@ struct TRINITY_DLL_DECL mob_anti_airAI : public ScriptedAI { mob_anti_airAI(Creature *c) : ScriptedAI(c) { - assert(me->m_spells[0]); + if(!me->m_spells[0]) + spell = NULL; + else + spell = me->m_spells[0]; + range = DoGetSpellMaxRange(me->m_spells[0]); } float range; + uint32 spell; void MoveInLineOfSight(Unit *who) { @@ -136,7 +141,7 @@ struct TRINITY_DLL_DECL mob_anti_airAI : public ScriptedAI if(me->getVictim()->IsFlying() || !me->IsWithinMeleeRange(me->getVictim())) { - if(!DoSpellAttackIfReady(me->m_spells[0])) + if(!DoSpellAttackIfReady(spell)) EnterEvadeMode(); } else diff --git a/src/game/SpellEffects.cpp b/src/game/SpellEffects.cpp index 2cadd2262e6..857eb26cc88 100644 --- a/src/game/SpellEffects.cpp +++ b/src/game/SpellEffects.cpp @@ -591,6 +591,19 @@ void Spell::SpellDamageSchoolDmg(uint32 effect_idx) //TODO: should this be put on taken but not done? if(found) damage += m_spellInfo->EffectBasePoints[1]; + + if (m_caster->GetTypeId() == TYPEID_PLAYER) + { + // Add Ammo and Weapon damage + Item *item = ((Player*)m_caster)->GetWeaponForAttack(RANGED_ATTACK); + if(item) + { + damage += urand(uint32(item->GetProto()->Damage->DamageMin), uint32(item->GetProto()->Damage->DamageMax)); + damage += ((Player*)m_caster)->GetAmmoDPS()*item->GetProto()->Delay/1000; + damage += ((Player*)m_caster)->GetTotalAttackPowerValue(RANGED_ATTACK)*0.1f; + } + } + } break; } |