aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoroffl <11556157+offl@users.noreply.github.com>2025-09-09 12:03:05 +0300
committerGitHub <noreply@github.com>2025-09-09 11:03:05 +0200
commite8b921886f08fe6eb63ec74d4dd7bb0df9d3e43f (patch)
tree6c4bb491088903fdbcf98cd592fbc2b1f3ffb55e
parenteb05494f128c98cb3bfb9c98ca2d8534fbed14d5 (diff)
Scripts/Quest: Update & convert to SAI 'The Escape' (#31160)
-rw-r--r--sql/updates/world/3.3.5/2025_09_09_00_world.sql103
-rw-r--r--src/server/scripts/Kalimdor/zone_the_barrens.cpp152
2 files changed, 103 insertions, 152 deletions
diff --git a/sql/updates/world/3.3.5/2025_09_09_00_world.sql b/sql/updates/world/3.3.5/2025_09_09_00_world.sql
new file mode 100644
index 00000000000..1f85505e6b9
--- /dev/null
+++ b/sql/updates/world/3.3.5/2025_09_09_00_world.sql
@@ -0,0 +1,103 @@
+--
+UPDATE `creature_template` SET `AIName` = 'SmartAI', `ScriptName` = '' WHERE `entry` = 3439;
+DELETE FROM `smart_scripts` WHERE `entryorguid` = 3439 AND `source_type` = 0;
+DELETE FROM `smart_scripts` WHERE `entryorguid` BETWEEN 343900 AND 343903 AND `source_type` = 9;
+INSERT INTO `smart_scripts` (`entryorguid`, `source_type`, `id`, `link`, `event_type`, `event_phase_mask`, `event_chance`, `event_flags`, `event_param1`, `event_param2`, `event_param3`, `event_param4`, `event_param5`, `action_type`, `action_param1`, `action_param2`, `action_param3`, `action_param4`, `action_param5`, `action_param6`, `target_type`, `target_param1`, `target_param2`, `target_param3`, `target_param4`, `target_x`, `target_y`, `target_z`, `target_o`, `comment`) VALUES
+(3439,0,0,0,19,0,100,0,863,0,0,0,0,80,343900,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Quest 'The Escape' Taken - Run Script"),
+
+(343900,9,0,0,0,0,100,0,0,0,0,0,0,64,1,0,0,0,0,0,16,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Store Targetlist"),
+(343900,9,1,0,0,0,100,0,0,0,0,0,0,2,113,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Set Faction 113"),
+(343900,9,2,0,0,0,100,0,0,0,0,0,0,83,2,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Remove NPC Flag Questgiver"),
+(343900,9,3,0,0,0,100,0,0,0,0,0,0,1,0,0,0,0,0,0,12,1,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Say Line 0"),
+(343900,9,4,0,0,0,100,0,6000,6000,0,0,0,1,1,0,0,0,0,0,12,1,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Say Line 1"),
+(343900,9,5,0,0,0,100,0,0,0,0,0,0,53,1,343900,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Start Waypoint"),
+
+(3439,0,1,0,58,0,100,0,0,343900,0,0,0,80,343901,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Waypoint Finished - Run Script"),
+
+(343901,9,0,0,0,0,100,0,3000,3000,0,0,0,1,2,0,0,0,0,0,12,1,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Say Line 2"),
+(343901,9,1,0,0,0,100,0,0,0,0,0,0,53,0,343901,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Start Waypoint"),
+
+(3439,0,2,0,58,0,100,0,0,343901,0,0,0,80,343902,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Waypoint Finished - Run Script"),
+
+(343902,9,0,0,0,0,100,0,5000,5000,0,0,0,107,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Summon Group 0"),
+-- Our ugly hack
+(343902,9,1,0,0,0,100,0,0,0,0,0,0,1,0,0,0,0,0,0,19,3282,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Say Line 0 (Venture Co. Mercenary)"),
+-- Not entirely correct, more like when both summons are killed
+(343902,9,2,0,0,0,100,0,8000,8000,0,0,0,1,3,0,0,0,0,0,12,1,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Say Line 3"),
+(343902,9,3,0,0,0,100,0,3000,3000,0,0,0,53,1,343902,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Start Waypoint"),
+
+(3439,0,3,0,58,0,100,0,0,343902,0,0,0,80,343903,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Waypoint Finished - Run Script"),
+
+(343903,9,0,0,0,0,100,0,0,0,0,0,0,1,4,0,0,0,0,0,12,1,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Say Line 4"),
+(343903,9,1,0,0,0,100,0,4000,4000,0,0,0,1,5,0,0,0,0,0,12,1,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Say Line 5"),
+(343903,9,2,0,0,0,100,0,2000,2000,0,0,0,1,6,0,0,0,0,0,12,1,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Say Line 6"),
+(343903,9,4,0,0,0,100,0,6000,6000,0,0,0,15,863,0,0,0,0,0,12,1,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Quest Credit 'The Escape'"),
+(343903,9,5,0,0,0,100,0,0,0,0,0,0,11,5162,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Cast 'Self Explosion'"),
+-- Summon should be handled by GameEvent from the spell above but it doesn't work
+(343903,9,6,0,0,0,100,0,0,0,0,0,0,107,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Summon Group 1"),
+(343903,9,7,0,0,0,100,0,0,0,0,0,0,41,10000,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Script - Despawn"),
+
+(3439,0,4,0,6,0,100,0,0,0,0,0,0,6,863,0,0,0,0,0,12,1,0,0,0,0,0,0,0,"Wizzlecrank's Shredder - On Death - Fail Quest 'The Escape'");
+
+DELETE FROM `smart_scripts` WHERE `entryorguid` = 3451 AND `source_type` = 0;
+DELETE FROM `smart_scripts` WHERE `entryorguid` = 345100 AND `source_type` = 9;
+INSERT INTO `smart_scripts` (`entryorguid`, `source_type`, `id`, `link`, `event_type`, `event_phase_mask`, `event_chance`, `event_flags`, `event_param1`, `event_param2`, `event_param3`, `event_param4`, `event_param5`, `action_type`, `action_param1`, `action_param2`, `action_param3`, `action_param4`, `action_param5`, `action_param6`, `target_type`, `target_param1`, `target_param2`, `target_param3`, `target_param4`, `target_x`, `target_y`, `target_z`, `target_o`, `comment`) VALUES
+(3451,0,0,0,11,0,100,0,0,0,0,0,0,80,345100,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Pilot Wizzlecrank - On Spawn - Run Script"),
+
+(345100,9,0,0,0,0,100,0,0,0,0,0,0,69,0,0,0,0,0,0,8,0,0,0,0,1011.5695,-2948.5574,94.42255,0,"Pilot Wizzlecrank - On Script - Move To Position"),
+(345100,9,1,0,0,0,100,0,1500,1500,0,0,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Pilot Wizzlecrank - On Script - Say Line 0"),
+(345100,9,2,0,0,0,100,0,4000,4000,0,0,0,1,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Pilot Wizzlecrank - On Script - Say Line 1"),
+-- Guessed
+(345100,9,3,0,0,0,100,0,20000,20000,0,0,0,41,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,"Pilot Wizzlecrank - On Script - Despawn");
+
+DELETE FROM `creature_summon_groups` WHERE `summonerId` = 3439 AND `summonerType` = 0;
+INSERT INTO `creature_summon_groups` (`summonerId`,`summonerType`,`groupId`,`entry`,`position_x`,`position_y`,`position_z`,`orientation`,`summonType`,`summonTime`,`Comment`) VALUES
+(3439,0,0,3282,1075.1216,-2983.9827,92.90724,5.811946392059326171,4,60000,"Wizzlecrank's Shredder - Group 0 - Venture Co. Mercenary"),
+(3439,0,0,3282,1119.6910,-2970.8733,97.15814,4.014257431030273437,4,60000,"Wizzlecrank's Shredder - Group 0 - Venture Co. Mercenary"),
+
+(3439,0,1,3451,1014.9248,-2945.6086,94.50288,2.114160060882568359,8,0,"Wizzlecrank's Shredder - Group 1 - Pilot Wizzlecrank");
+
+DELETE FROM `script_waypoint` WHERE `entry` = 3439;
+DELETE FROM `waypoints` WHERE `entry` BETWEEN 343900 AND 343902;
+INSERT INTO `waypoints` (`entry`,`pointid`,`position_x`,`position_y`,`position_z`,`point_comment`) VALUES
+-- There only 4 waypoints at start but without adding all points we get too short path
+(343900,1,1107.5569,-3102.9243,82.8109,"Wizzlecrank's Shredder"),
+(343900,2,1106.3069,-3105.4243,83.0609,"Wizzlecrank's Shredder"),
+(343900,3,1109.0569,-3106.9243,82.8109,"Wizzlecrank's Shredder"),
+(343900,4,1110.8069,-3104.6743,82.5609,"Wizzlecrank's Shredder"),
+(343900,5,1108.4622,-3101.7402,82.21095,"Wizzlecrank's Shredder"), --
+(343900,6,1111.0613,-3104.9868,82.52319,"Wizzlecrank's Shredder"),
+(343900,7,1108.8113,-3101.7368,82.52319,"Wizzlecrank's Shredder"),
+(343900,8,1105.0613,-3102.9868,83.02319,"Wizzlecrank's Shredder"),
+(343900,9,1104.5613,-3103.2368,83.02319,"Wizzlecrank's Shredder"),
+(343900,10,1109.3113,-3103.7368,82.52319,"Wizzlecrank's Shredder"),
+(343900,11,1113.4314,-3104.049,82.46095,"Wizzlecrank's Shredder"), --
+(343900,12,1104.9719,-3103.0159,83.22392,"Wizzlecrank's Shredder"),
+(343900,13,1104.4719,-3103.2659,83.22392,"Wizzlecrank's Shredder"),
+(343900,14,1109.2219,-3103.7659,82.72392,"Wizzlecrank's Shredder"),
+(343900,15,1113.4719,-3104.0159,82.97392,"Wizzlecrank's Shredder"),
+(343900,16,1113.4719,-3107.0159,82.97392,"Wizzlecrank's Shredder"),
+(343900,17,1106.7219,-3108.2659,83.22392,"Wizzlecrank's Shredder"),
+(343900,18,1106.2535,-3108.632,83.08595,"Wizzlecrank's Shredder"), --
+(343900,19,1113.3845,-3104.1714,82.82361,"Wizzlecrank's Shredder"),
+(343900,20,1113.3845,-3106.9214,82.82361,"Wizzlecrank's Shredder"),
+(343900,21,1106.8845,-3108.4214,83.32361,"Wizzlecrank's Shredder"),
+(343900,22,1106.3845,-3108.4214,83.32361,"Wizzlecrank's Shredder"),
+(343900,23,1101.6771,-3104.3665,83.21095,"Wizzlecrank's Shredder"), --
+
+(343901,1,1101.3541,-3096.9792,83.0092,"Wizzlecrank's Shredder"),
+(343901,2,1098.4445,-3060.212,82.08001,"Wizzlecrank's Shredder"),
+(343901,3,1090.5764,-3034.908,82.70501,"Wizzlecrank's Shredder"),
+(343901,4,1103.0762,-3013.2773,85.65292,"Wizzlecrank's Shredder"),
+(343901,5,1100.8525,-3002.5137,89.65292,"Wizzlecrank's Shredder"),
+(343901,6,1093.6041,-2977.8281,92.21579,"Wizzlecrank's Shredder"),
+
+(343902,1,1068.5104,-2980.486,93.59079,"Wizzlecrank's Shredder"),
+(343902,2,1070.0381,-2957.5312,93.54168,"Wizzlecrank's Shredder"),
+(343902,3,1042.0365,-2964.448,93.29168,"Wizzlecrank's Shredder"),
+(343902,4,1037.1163,-2938.5747,91.91668,"Wizzlecrank's Shredder"),
+(343902,5,1014.908,-2943.962,94.54755,"Wizzlecrank's Shredder");
+
+DELETE FROM `smart_scripts` WHERE `entryorguid` = 3282 AND `source_type` = 0 AND `id` = 2;
+INSERT INTO `smart_scripts` (`entryorguid`,`source_type`,`id`,`link`,`event_type`,`event_phase_mask`,`event_chance`,`event_flags`,`event_param1`,`event_param2`,`event_param3`,`event_param4`,`event_param5`,`action_type`,`action_param1`,`action_param2`,`action_param3`,`action_param4`,`action_param5`,`action_param6`,`target_type`,`target_param1`,`target_param2`,`target_param3`,`target_param4`,`target_x`,`target_y`,`target_z`,`target_o`,`comment`) VALUES
+(3282,0,2,0,54,0,100,0,0,0,0,0,0,49,0,0,0,0,0,0,7,0,0,0,0,0,0,0,0,"Venture Co. Mercenary - On Just Summoned - Start Attack");
diff --git a/src/server/scripts/Kalimdor/zone_the_barrens.cpp b/src/server/scripts/Kalimdor/zone_the_barrens.cpp
index 3874e7c688c..798ee849699 100644
--- a/src/server/scripts/Kalimdor/zone_the_barrens.cpp
+++ b/src/server/scripts/Kalimdor/zone_the_barrens.cpp
@@ -466,161 +466,9 @@ public:
};
-/*#####
-## npc_wizzlecrank_shredder
-#####*/
-
-enum Wizzlecrank
-{
- SAY_MERCENARY = 0,
- SAY_START = 0,
- SAY_STARTUP1 = 1,
- SAY_STARTUP2 = 2,
- SAY_PROGRESS_1 = 3,
- SAY_PROGRESS_2 = 4,
- SAY_PROGRESS_3 = 5,
- SAY_END = 6,
-
- QUEST_ESCAPE = 863,
- NPC_PILOT_WIZZ = 3451,
- NPC_MERCENARY = 3282,
-};
-
-class npc_wizzlecrank_shredder : public CreatureScript
-{
-public:
- npc_wizzlecrank_shredder() : CreatureScript("npc_wizzlecrank_shredder") { }
-
- struct npc_wizzlecrank_shredderAI : public EscortAI
- {
- npc_wizzlecrank_shredderAI(Creature* creature) : EscortAI(creature)
- {
- IsPostEvent = false;
- PostEventTimer = 1000;
- PostEventCount = 0;
- me->SetReactState(REACT_DEFENSIVE);
- }
-
- bool IsPostEvent;
- uint32 PostEventTimer;
- uint32 PostEventCount;
-
- void WaypointReached(uint32 waypointId, uint32 /*pathId*/) override
- {
- switch (waypointId)
- {
- case 0:
- Talk(SAY_STARTUP1);
- break;
- case 9:
- SetRun(false);
- break;
- case 17:
- if (Creature* temp = me->SummonCreature(NPC_MERCENARY, 1128.489f, -3037.611f, 92.701f, 1.472f, TEMPSUMMON_TIMED_DESPAWN_OUT_OF_COMBAT, 2min))
- {
- temp->AI()->Talk(SAY_MERCENARY);
- me->SummonCreature(NPC_MERCENARY, 1160.172f, -2980.168f, 97.313f, 3.690f, TEMPSUMMON_TIMED_DESPAWN_OUT_OF_COMBAT, 2min);
- }
- break;
- case 24:
- IsPostEvent = true;
- break;
- }
- }
-
- void WaypointStarted(uint32 PointId, uint32 /*pathId*/) override
- {
- Player* player = GetPlayerForEscort();
-
- if (!player)
- return;
-
- switch (PointId)
- {
- case 9:
- Talk(SAY_STARTUP2, player);
- break;
- case 18:
- Talk(SAY_PROGRESS_1, player);
- SetRun();
- break;
- }
- }
-
- void JustSummoned(Creature* summoned) override
- {
- if (summoned->GetEntry() == NPC_PILOT_WIZZ)
- me->SetStandState(UNIT_STAND_STATE_DEAD);
-
- if (summoned->GetEntry() == NPC_MERCENARY)
- summoned->AI()->AttackStart(me);
- }
-
- void UpdateEscortAI(uint32 Diff) override
- {
- if (UpdateVictim())
- {
- DoMeleeAttackIfReady();
- return;
- }
-
- if (!IsPostEvent)
- return;
-
- if (PostEventTimer > Diff)
- {
- PostEventTimer -= Diff;
- return;
- }
-
- switch (PostEventCount)
- {
- case 0:
- Talk(SAY_PROGRESS_2);
- break;
- case 1:
- Talk(SAY_PROGRESS_3);
- break;
- case 2:
- Talk(SAY_END);
- break;
- case 3:
- if (Player* player = GetPlayerForEscort())
- {
- player->GroupEventHappens(QUEST_ESCAPE, me);
- me->DespawnOrUnsummon(5min);
- me->SummonCreature(NPC_PILOT_WIZZ, 0.0f, 0.0f, 0.0f, 0.0f, TEMPSUMMON_TIMED_DESPAWN, 3min);
- }
- break;
- }
-
- ++PostEventCount;
- PostEventTimer = 5000;
- }
-
- void OnQuestAccept(Player* player, Quest const* quest) override
- {
- if (quest->GetQuestId() == QUEST_ESCAPE)
- {
- me->SetFaction(FACTION_RATCHET);
- Talk(SAY_START);
- SetDespawnAtEnd(false);
- Start(true, false, player->GetGUID());
- }
- }
- };
-
- CreatureAI* GetAI(Creature* creature) const override
- {
- return new npc_wizzlecrank_shredderAI(creature);
- }
-
-};
-
void AddSC_the_barrens()
{
new npc_gilthares();
new npc_taskmaster_fizzule();
new npc_twiggy_flathead();
- new npc_wizzlecrank_shredder();
}