aboutsummaryrefslogtreecommitdiff
path: root/src/server/scripts
diff options
context:
space:
mode:
authorAqua Deus <95978183+aquadeus@users.noreply.github.com>2024-09-01 21:03:17 +0200
committerGitHub <noreply@github.com>2024-09-01 21:03:17 +0200
commit0411c3b5afcfe0178301d5a13afcf76be4cb55fb (patch)
tree53d406c5e7af1fc596e39deef44a94e9cc681642 /src/server/scripts
parent45757d95c42883609e734123944091cee7592891 (diff)
Scripts/RagefireChasm: Implement non-boss creature scripts (#30015)
Diffstat (limited to 'src/server/scripts')
-rw-r--r--src/server/scripts/Kalimdor/RagefireChasm/ragefire_chasm.cpp98
-rw-r--r--src/server/scripts/Kalimdor/kalimdor_script_loader.cpp2
2 files changed, 100 insertions, 0 deletions
diff --git a/src/server/scripts/Kalimdor/RagefireChasm/ragefire_chasm.cpp b/src/server/scripts/Kalimdor/RagefireChasm/ragefire_chasm.cpp
new file mode 100644
index 00000000000..84418e24c0d
--- /dev/null
+++ b/src/server/scripts/Kalimdor/RagefireChasm/ragefire_chasm.cpp
@@ -0,0 +1,98 @@
+/*
+ * This file is part of the TrinityCore Project. See AUTHORS file for Copyright information
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
+ * more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "Creature.h"
+#include "MotionMaster.h"
+#include "Player.h"
+#include "Position.h"
+#include "ScriptMgr.h"
+#include "SpellScript.h"
+#include "ragefire_chasm.h"
+
+enum RFCMisc
+{
+ PATH_RESCUED_1 = 6178805,
+ PATH_RESCUED_2 = 6178806,
+ PATH_RESCUED_3 = 6178807,
+
+ POINT_INTRO = 0
+};
+
+constexpr Position AdolescentFlameHoundIntro[4] =
+{
+ { -34.332058f, -53.474606f, -21.372412f },
+ { -33.650555f, -53.704865f, -21.371508f },
+ { -30.366037f, -39.565018f, -21.747667f },
+ { -34.273827f, -37.673744f, -21.493523f }
+};
+
+// Areatrigger - 7966
+struct at_rfc_cosmetic_intro : OnlyOnceAreaTriggerScript
+{
+public:
+ at_rfc_cosmetic_intro() : OnlyOnceAreaTriggerScript("at_rfc_cosmetic_intro") { }
+
+ bool TryHandleOnce(Player* player, AreaTriggerEntry const* /*areaTrigger*/) override
+ {
+ if (player->IsGameMaster())
+ return false;
+
+ if (Creature* adolescentFlameHound = player->FindNearestCreatureWithOptions(80.0f, { .StringId = "npc_adolescent_flame_hound_1" }))
+ adolescentFlameHound->GetMotionMaster()->MovePoint(POINT_INTRO, AdolescentFlameHoundIntro[0]);
+
+ if (Creature* adolescentFlameHound = player->FindNearestCreatureWithOptions(80.0f, { .StringId = "npc_adolescent_flame_hound_2" }))
+ adolescentFlameHound->GetMotionMaster()->MovePoint(POINT_INTRO, AdolescentFlameHoundIntro[1]);
+
+ if (Creature* adolescentFlameHound = player->FindNearestCreatureWithOptions(80.0f, { .StringId = "npc_adolescent_flame_hound_3" }))
+ adolescentFlameHound->GetMotionMaster()->MovePoint(POINT_INTRO, AdolescentFlameHoundIntro[2]);
+
+ if (Creature* adolescentFlameHound = player->FindNearestCreatureWithOptions(80.0f, { .StringId = "npc_adolescent_flame_hound_4" }))
+ adolescentFlameHound->GetMotionMaster()->MovePoint(POINT_INTRO, AdolescentFlameHoundIntro[3]);
+
+ return true;
+ }
+};
+
+// 101163 - General Trigger 221 to Self
+class spell_ragefire_chasm_general_trigger_221_to_self : public SpellScript
+{
+ void HandleDummy(SpellEffIndex /*effIndex*/)
+ {
+ Creature* casterCreature = GetCaster()->ToCreature();
+
+ if (!casterCreature)
+ return;
+
+ if (casterCreature->HasStringId("npc_rescued_cage_1"))
+ casterCreature->GetMotionMaster()->MovePath(PATH_RESCUED_1, false);
+ else if (casterCreature->HasStringId("npc_rescued_cage_2"))
+ casterCreature->GetMotionMaster()->MovePath(PATH_RESCUED_2, false);
+ else if (casterCreature->HasStringId("npc_rescued_cage_3"))
+ casterCreature->GetMotionMaster()->MovePath(PATH_RESCUED_3, false);
+ }
+
+ void Register() override
+ {
+ OnEffectHitTarget += SpellEffectFn(spell_ragefire_chasm_general_trigger_221_to_self::HandleDummy, EFFECT_0, SPELL_EFFECT_SCRIPT_EFFECT);
+ }
+};
+
+void AddSC_ragefire_chasm()
+{
+ new at_rfc_cosmetic_intro();
+ RegisterSpellScript(spell_ragefire_chasm_general_trigger_221_to_self);
+}
diff --git a/src/server/scripts/Kalimdor/kalimdor_script_loader.cpp b/src/server/scripts/Kalimdor/kalimdor_script_loader.cpp
index 50c3cb20ee1..64c0a381f33 100644
--- a/src/server/scripts/Kalimdor/kalimdor_script_loader.cpp
+++ b/src/server/scripts/Kalimdor/kalimdor_script_loader.cpp
@@ -67,6 +67,7 @@ void AddSC_boss_adarogg();
void AddSC_boss_dark_shaman_koranthal();
void AddSC_boss_slagmaw();
void AddSC_boss_lava_guard_gordoth();
+void AddSC_ragefire_chasm();
void AddSC_instance_ragefire_chasm();
// Maraudon
void AddSC_boss_celebras_the_cursed();
@@ -212,6 +213,7 @@ void AddKalimdorScripts()
AddSC_boss_dark_shaman_koranthal();
AddSC_boss_slagmaw();
AddSC_boss_lava_guard_gordoth();
+ AddSC_ragefire_chasm();
AddSC_instance_ragefire_chasm();
//Maraudon
AddSC_boss_celebras_the_cursed();