diff options
| author | Edder <d.rosenauer@googlemail.com> | 2021-04-25 11:36:54 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-04-25 11:36:54 +0200 |
| commit | 3e407c7d1c79cc94bf932880ee0eb68058d139fd (patch) | |
| tree | 6882170fc056d061a00b52b92932e8196cb82b22 /src/server/scripts/Spells | |
| parent | d5f1fefe7f6772b11e9fbb052bfd36be9bda98e2 (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>
Diffstat (limited to 'src/server/scripts/Spells')
| -rw-r--r-- | src/server/scripts/Spells/spell_generic.cpp | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/src/server/scripts/Spells/spell_generic.cpp b/src/server/scripts/Spells/spell_generic.cpp index 3d4a012cf2b..af37d81e776 100644 --- a/src/server/scripts/Spells/spell_generic.cpp +++ b/src/server/scripts/Spells/spell_generic.cpp @@ -3735,6 +3735,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 @@ -4545,6 +4570,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); |
