diff options
author | Edder <d.rosenauer@googlemail.com> | 2021-04-25 11:36:54 +0200 |
---|---|---|
committer | Shauren <shauren.trinity@gmail.com> | 2022-03-09 00:42:48 +0100 |
commit | 8202dc28c2dae613c14a52ef4e84932d8c1c9e39 (patch) | |
tree | 774199b2874026e52f2b7e1b85b882b0029d94a6 | |
parent | 9845fe92bb414e05cc5dff4fed507f30f39ca0db (diff) |
Core/Quest: Threat From Above (#26468)
* [Quest] Threat From Above #26355
* [Quest] Threat From Above TrinityCore#26355
* Core/Quest: Threat From Above #26468 - modified sql according to guidelines; added override keyword
* Rename 2021_04_24_00_world.sql to 2021_04_25_00_world.sql
Co-authored-by: Edder <d.rosenauer@gmail.com>
Co-authored-by: Giacomo Pozzoni <giacomopoz@gmail.com>
(cherry picked from commit 3e407c7d1c79cc94bf932880ee0eb68058d139fd)
-rw-r--r-- | sql/updates/world/master/2022_03_08_08_world_2021_04_25_00_world.sql | 13 | ||||
-rw-r--r-- | src/server/game/Entities/Creature/Creature.cpp | 9 | ||||
-rw-r--r-- | src/server/game/Entities/Creature/Creature.h | 2 | ||||
-rw-r--r-- | src/server/game/Entities/Unit/Unit.h | 2 | ||||
-rw-r--r-- | src/server/scripts/Northrend/zone_storm_peaks.cpp | 33 | ||||
-rw-r--r-- | src/server/scripts/Spells/spell_generic.cpp | 27 |
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); |