aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sql/updates/world/master/2022_03_08_08_world_2021_04_25_00_world.sql13
-rw-r--r--src/server/game/Entities/Creature/Creature.cpp9
-rw-r--r--src/server/game/Entities/Creature/Creature.h2
-rw-r--r--src/server/game/Entities/Unit/Unit.h2
-rw-r--r--src/server/scripts/Northrend/zone_storm_peaks.cpp33
-rw-r--r--src/server/scripts/Spells/spell_generic.cpp27
6 files changed, 52 insertions, 34 deletions
diff --git a/sql/updates/world/master/2022_03_08_08_world_2021_04_25_00_world.sql b/sql/updates/world/master/2022_03_08_08_world_2021_04_25_00_world.sql
new file mode 100644
index 00000000000..567676f5185
--- /dev/null
+++ b/sql/updates/world/master/2022_03_08_08_world_2021_04_25_00_world.sql
@@ -0,0 +1,13 @@
+-- delete non generic spell script for npc_wild_wyrm
+DELETE FROM `spell_script_names` WHERE `ScriptName`= 'spell_eject_passenger_wild_wyrm';
+
+-- add "special" generic spell script for "Eject Passenger 1"
+-- the spell script "spell_eject_passenger_wild_wyrm" used this spell too
+DELETE FROM `spell_script_names` WHERE `ScriptName`= 'spell_gen_eject_passenger_1';
+INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES
+(60603, 'spell_gen_eject_passenger_1');
+
+-- add "special" generic spell script for "Eject Passenger 3"
+DELETE FROM `spell_script_names` WHERE `ScriptName`= 'spell_gen_eject_passenger_3';
+INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES
+(52205, 'spell_gen_eject_passenger_3');
diff --git a/src/server/game/Entities/Creature/Creature.cpp b/src/server/game/Entities/Creature/Creature.cpp
index 28b6e1efb4a..b431d0e1b19 100644
--- a/src/server/game/Entities/Creature/Creature.cpp
+++ b/src/server/game/Entities/Creature/Creature.cpp
@@ -3503,3 +3503,12 @@ std::string Creature::GetDebugInfo() const
<< " WaypointPath: " << GetWaypointPath() << " SpawnId: " << GetSpawnId();
return sstr.str();
}
+
+void Creature::ExitVehicle(Position const* /*exitPosition*/)
+{
+ Unit::ExitVehicle();
+
+ // if the creature exits a vehicle, set it's home position to the
+ // exited position so it won't run away (home) and evade if it's hostile
+ SetHomePosition(GetPosition());
+}
diff --git a/src/server/game/Entities/Creature/Creature.h b/src/server/game/Entities/Creature/Creature.h
index 594bdf21eb7..c091f78eb02 100644
--- a/src/server/game/Entities/Creature/Creature.h
+++ b/src/server/game/Entities/Creature/Creature.h
@@ -385,6 +385,8 @@ class TC_GAME_API Creature : public Unit, public GridObject<Creature>, public Ma
std::string GetDebugInfo() const override;
+ void ExitVehicle(Position const* exitPosition = nullptr) override;
+
protected:
bool CreateFromProto(ObjectGuid::LowType guidlow, uint32 entry, CreatureData const* data = nullptr, uint32 vehId = 0);
bool InitEntry(uint32 entry, CreatureData const* data = nullptr);
diff --git a/src/server/game/Entities/Unit/Unit.h b/src/server/game/Entities/Unit/Unit.h
index 8c579aa29b1..4e5b7cf42f1 100644
--- a/src/server/game/Entities/Unit/Unit.h
+++ b/src/server/game/Entities/Unit/Unit.h
@@ -1795,7 +1795,7 @@ class TC_GAME_API Unit : public WorldObject
void HandleSpellClick(Unit* clicker, int8 seatId = -1);
void EnterVehicle(Unit* base, int8 seatId = -1);
- void ExitVehicle(Position const* exitPosition = nullptr);
+ virtual void ExitVehicle(Position const* exitPosition = nullptr);
void ChangeSeat(int8 seatId, bool next = true);
// Should only be called by AuraEffect::HandleAuraControlVehicle(AuraApplication const* auraApp, uint8 mode, bool apply) const;
diff --git a/src/server/scripts/Northrend/zone_storm_peaks.cpp b/src/server/scripts/Northrend/zone_storm_peaks.cpp
index 66ab85bbf94..7491a05dc9a 100644
--- a/src/server/scripts/Northrend/zone_storm_peaks.cpp
+++ b/src/server/scripts/Northrend/zone_storm_peaks.cpp
@@ -1158,38 +1158,6 @@ class spell_close_rift : public SpellScriptLoader
}
};
-// 60603 - Eject Passenger 1
-class spell_eject_passenger_wild_wyrm : public SpellScriptLoader
-{
-public:
- spell_eject_passenger_wild_wyrm() : SpellScriptLoader("spell_eject_passenger_wild_wyrm") { }
-
- class spell_eject_passenger_wild_wyrm_SpellScript : public SpellScript
- {
- PrepareSpellScript(spell_eject_passenger_wild_wyrm_SpellScript);
-
- bool Validate(SpellInfo const* /*spellInfo*/) override
- {
- return ValidateSpellInfo({ SPELL_FIGHT_WYRM });
- }
-
- void HandleScript(SpellEffIndex /*effIndex*/)
- {
- GetHitUnit()->RemoveAurasDueToSpell(SPELL_FIGHT_WYRM);
- }
-
- void Register() override
- {
- OnEffectHitTarget += SpellEffectFn(spell_eject_passenger_wild_wyrm_SpellScript::HandleScript, EFFECT_0, SPELL_EFFECT_SCRIPT_EFFECT);
- }
- };
-
- SpellScript* GetSpellScript() const override
- {
- return new spell_eject_passenger_wild_wyrm_SpellScript();
- }
-};
-
// 56689 - Grip
class spell_grip : public SpellScriptLoader
{
@@ -1572,7 +1540,6 @@ void AddSC_storm_peaks()
new spell_jokkum_scriptcast();
new spell_veranus_summon();
new spell_close_rift();
- new spell_eject_passenger_wild_wyrm();
new spell_grip();
new spell_grab_on();
new spell_loosen_grip<5>("spell_thrust_spear");
diff --git a/src/server/scripts/Spells/spell_generic.cpp b/src/server/scripts/Spells/spell_generic.cpp
index b3803a8ffcc..08ae2ab112a 100644
--- a/src/server/scripts/Spells/spell_generic.cpp
+++ b/src/server/scripts/Spells/spell_generic.cpp
@@ -3695,6 +3695,31 @@ class spell_gen_eject_passenger : public SpellScript
}
};
+class spell_gen_eject_passenger_with_seatId : public SpellScript
+{
+ PrepareSpellScript(spell_gen_eject_passenger_with_seatId);
+
+public:
+ spell_gen_eject_passenger_with_seatId(uint8 seatId) : SpellScript(), _seatId(seatId) { }
+
+private:
+ uint8 _seatId;
+
+ void EjectPassenger(SpellEffIndex /*effIndex*/)
+ {
+ if (Vehicle* vehicle = GetHitUnit()->GetVehicleKit())
+ {
+ if (Unit* passenger = vehicle->GetPassenger(_seatId))
+ passenger->ExitVehicle();
+ }
+ }
+
+ void Register() override
+ {
+ OnEffectHitTarget += SpellEffectFn(spell_gen_eject_passenger_with_seatId::EjectPassenger, EFFECT_0, SPELL_EFFECT_SCRIPT_EFFECT);
+ }
+};
+
enum GMFreeze
{
SPELL_GM_FREEZE = 9454
@@ -4842,6 +4867,8 @@ void AddSC_generic_spell_scripts()
RegisterSpellScript(spell_gen_whisper_gulch_yogg_saron_whisper);
RegisterSpellScript(spell_gen_eject_all_passengers);
RegisterSpellScript(spell_gen_eject_passenger);
+ RegisterSpellScriptWithArgs(spell_gen_eject_passenger_with_seatId, "spell_gen_eject_passenger_1", 0);
+ RegisterSpellScriptWithArgs(spell_gen_eject_passenger_with_seatId, "spell_gen_eject_passenger_3", 2);
RegisterSpellScript(spell_gen_gm_freeze);
RegisterSpellScript(spell_gen_stand);
RegisterSpellScript(spell_gen_mixology_bonus);