From 888d217c1654b5d9a53da6355401fd6fb519ddb4 Mon Sep 17 00:00:00 2001 From: Peter Keresztes Schmidt Date: Wed, 19 Aug 2020 14:49:29 +0200 Subject: Scripts/Commands: Convert argument parsing of remaining go command to new system (#25284) (cherry picked from commit 1aadf6c6d173e593eef0e9976e51a7189a54a8ce) --- src/server/scripts/Commands/cs_go.cpp | 52 ++++++++++------------------------- 1 file changed, 15 insertions(+), 37 deletions(-) (limited to 'src/server/scripts/Commands') diff --git a/src/server/scripts/Commands/cs_go.cpp b/src/server/scripts/Commands/cs_go.cpp index ddcbfbba710..a3bb2ce09e3 100644 --- a/src/server/scripts/Commands/cs_go.cpp +++ b/src/server/scripts/Commands/cs_go.cpp @@ -246,27 +246,24 @@ public: return true; } - static bool HandleGoQuestCommand(ChatHandler* handler, char const* args) + static bool HandleGoQuestCommand(ChatHandler* handler, Variant, uint32> questData) { - if (!*args) - return false; - Player* player = handler->GetSession()->GetPlayer(); - char* id = handler->extractKeyFromLink((char*)args, "Hquest"); - if (!id) - return false; - - uint32 questID = atoul(id); - if (!questID) - return false; - - if (!sObjectMgr->GetQuestTemplate(questID)) + uint32 questID; + if (questData.holds_alternative()) { - handler->PSendSysMessage(LANG_COMMAND_QUEST_NOTFOUND, questID); - handler->SetSentErrorMessage(true); - return false; + questID = questData.get(); + + if (!sObjectMgr->GetQuestTemplate(questID)) + { + handler->PSendSysMessage(LANG_COMMAND_QUEST_NOTFOUND, questID); + handler->SetSentErrorMessage(true); + return false; + } } + else + questID = questData.get>()->Quest->GetQuestId(); float x, y, z; uint32 mapId; @@ -333,30 +330,11 @@ public: } //teleport at coordinates - static bool HandleGoZoneXYCommand(ChatHandler* handler, char const* args) + static bool HandleGoZoneXYCommand(ChatHandler* handler, float x, float y, Optional, uint32>> areaIdArg) { - if (!*args) - return false; - Player* player = handler->GetSession()->GetPlayer(); - char* zoneX = strtok((char*)args, " "); - char* zoneY = strtok(nullptr, " "); - char* tail = strtok(nullptr, ""); - - char* id = handler->extractKeyFromLink(tail, "Harea"); // string or [name] Shift-click form |color|Harea:area_id|h[name]|h|r - - if (!zoneX || !zoneY) - return false; - - float x = (float)atof(zoneX); - float y = (float)atof(zoneY); - - // prevent accept wrong numeric args - if ((x == 0.0f && *zoneX != '0') || (y == 0.0f && *zoneY != '0')) - return false; - - uint32 areaId = id ? atoul(id) : player->GetZoneId(); + uint32 areaId = areaIdArg ? *areaIdArg : player->GetZoneId(); AreaTableEntry const* areaEntry = sAreaTableStore.LookupEntry(areaId); -- cgit v1.2.3