From e46cf607a4da55fc77b6b2ea7fca53d69ec6e56b Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Sat, 30 Aug 2014 11:07:08 +0300 Subject: Remove additional parameters from processCharMapServer function. --- src/net/tmwa/charserverhandler.cpp | 29 ++++++++++++++++++++++++++++- src/net/tmwa/charserverhandler.h | 4 +++- 2 files changed, 31 insertions(+), 2 deletions(-) (limited to 'src/net/tmwa') diff --git a/src/net/tmwa/charserverhandler.cpp b/src/net/tmwa/charserverhandler.cpp index b8bdf4842..ae64dbf60 100644 --- a/src/net/tmwa/charserverhandler.cpp +++ b/src/net/tmwa/charserverhandler.cpp @@ -113,7 +113,7 @@ void CharServerHandler::handleMessage(Net::MessageIn &msg) break; case SMSG_CHANGE_MAP_SERVER: - processChangeMapServer(msg, mNetwork, mapServer); + processChangeMapServer(msg); break; default: @@ -387,4 +387,31 @@ void CharServerHandler::processCharMapInfo(Net::MessageIn &restrict msg) BLOCK_END("CharServerHandler::processCharMapInfo") } +void CharServerHandler::processChangeMapServer(Net::MessageIn &msg) +{ + Network *const network = mNetwork; + ServerInfo &server = mapServer; + BLOCK_START("CharServerHandler::processChangeMapServer") + GameHandler *const gh = static_cast(Net::getGameHandler()); + if (!gh || !network) + { + BLOCK_END("CharServerHandler::processChangeMapServer") + return; + } + gh->setMap(msg.readString(16)); + const int x = msg.readInt16(); + const int y = msg.readInt16(); + server.hostname = ipToString(msg.readInt32()); + server.port = msg.readInt16(); + + network->disconnect(); + client->setState(STATE_CHANGE_MAP); + if (localPlayer) + { + localPlayer->setTileCoords(x, y); + localPlayer->setMap(nullptr); + } + BLOCK_END("CharServerHandler::processChangeMapServer") +} + } // namespace TmwAthena diff --git a/src/net/tmwa/charserverhandler.h b/src/net/tmwa/charserverhandler.h index 8910b784c..062360800 100644 --- a/src/net/tmwa/charserverhandler.h +++ b/src/net/tmwa/charserverhandler.h @@ -59,7 +59,9 @@ class CharServerHandler final : public MessageHandler, void processCharLogin(Net::MessageIn &msg); - void processCharMapInfo(Net::MessageIn &restrict msg); + void processCharMapInfo(Net::MessageIn &msg); + + void processChangeMapServer(Net::MessageIn &msg); protected: void readPlayerData(Net::MessageIn &msg, -- cgit v1.2.3-70-g09d2