diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/game.cpp | 16 | ||||
-rw-r--r-- | src/game.h | 4 | ||||
-rw-r--r-- | src/gui/char_select.cpp | 7 |
3 files changed, 11 insertions, 16 deletions
diff --git a/src/game.cpp b/src/game.cpp index ba860822..b3801bfd 100644 --- a/src/game.cpp +++ b/src/game.cpp @@ -71,7 +71,7 @@ extern Graphics *graphics; -char map_path[480]; +std::string map_path; std::string tradePartnerName; bool refresh_beings = false; @@ -272,12 +272,7 @@ void destroyGuiWindows() void do_init() { - std::string path(map_path); - std::string pathDir = path.substr(0, path.rfind(".")); - - // Try .tmx.gz map file - pathDir.insert(pathDir.size(), ".tmx.gz"); - Map *tiledMap = MapReader::readMap(pathDir); + Map *tiledMap = MapReader::readMap(map_path); if (!tiledMap) { @@ -1431,14 +1426,13 @@ void do_parse() case SMSG_PLAYER_WARP: { // Set new map path - strcpy(map_path, - std::string("maps/" + msg.readString(16)).c_str()); - strcpy(strrchr(map_path, '.') + 1, "tmx.gz"); + map_path = "maps/" + msg.readString(16); + map_path= map_path.substr(0, map_path.rfind(".")) + ".tmx.gz"; int x = msg.readShort(); int y = msg.readShort(); - logger->log("Warping to %s (%d, %d)", map_path, x, y); + logger->log("Warping to %s (%d, %d)", map_path.c_str(), x, y); Map *oldMap = tiledMap; tiledMap = MapReader::readMap(map_path); @@ -24,7 +24,7 @@ #ifndef _TMW_GAME_ #define _TMW_GAME_ -#include <string> +#include <iosfwd> #define SPEECH_TIME 80 #define SPEECH_MAX_TIME 100 @@ -32,7 +32,7 @@ #define LOCK 254 #define IDLE 255 -extern char map_path[480]; +extern std::string map_path; extern std::string tradePartnerName; extern int fps, frame, current_npc; extern volatile int tick_time; diff --git a/src/gui/char_select.cpp b/src/gui/char_select.cpp index 071708b8..862e659d 100644 --- a/src/gui/char_select.cpp +++ b/src/gui/char_select.cpp @@ -24,6 +24,7 @@ #include "char_select.h" #include <sstream> +#include <string> #include <SDL.h> #include <guichan/widgets/label.hpp> @@ -230,14 +231,14 @@ void CharSelectDialog::serverCharSelect() if (msg.getId() == 0x0071) { char_ID = msg.readLong(); - std::string mapPath = "maps/" + msg.readString(16); - strcpy(map_path, mapPath.c_str()); + map_path = "maps/" + msg.readString(16); + map_path= map_path.substr(0, map_path.rfind(".")) + ".tmx.gz"; map_address = msg.readLong(); map_port = msg.readShort(); player_info = char_info[0]; state = GAME; - logger->log("CharSelect: Map: %s", map_path); + logger->log("CharSelect: Map: %s", map_path.c_str()); logger->log("CharSelect: Server: %s:%d", iptostring(map_address), map_port); close_session(); |