From: Matthew I Date: Thu, 30 Aug 2012 19:41:48 +0000 (-0400) Subject: Prevent world creation if the world already exists X-Git-Url: http://81.2.79.47:8989/gitweb/?a=commitdiff_plain;h=c8895dd43b098d635ec0ae55fbbbfe5d1fe8bef9;p=zefram%2Fminetest%2Fminetest_engine.git Prevent world creation if the world already exists --- diff --git a/src/guiMainMenu.cpp b/src/guiMainMenu.cpp index 4ceecbb5..5e0a3c38 100644 --- a/src/guiMainMenu.cpp +++ b/src/guiMainMenu.cpp @@ -48,10 +48,23 @@ struct CreateWorldDestMainMenu : public CreateWorldDest {} void accepted(std::wstring name, std::string gameid) { - if(!string_allowed_blacklist(wide_to_narrow(name), WORLDNAME_BLACKLISTED_CHARS)) + std::string name_narrow = wide_to_narrow(name); + if(!string_allowed_blacklist(name_narrow, WORLDNAME_BLACKLISTED_CHARS)) + { m_menu->displayMessageMenu(wgettext("Cannot create world: Name contains invalid characters")); - else - m_menu->createNewWorld(name, gameid); + return; + } + std::vector worlds = getAvailableWorlds(); + for(std::vector::iterator i = worlds.begin(); + i != worlds.end(); i++) + { + if((*i).name == name_narrow) + { + m_menu->displayMessageMenu(wgettext("Cannot create world: A world by this name already exists")); + return; + } + } + m_menu->createNewWorld(name, gameid); } GUIMainMenu *m_menu; }; @@ -936,4 +949,4 @@ int GUIMainMenu::getTab() void GUIMainMenu::displayMessageMenu(std::wstring msg) { (new GUIMessageMenu(env, parent, -1, menumgr, msg))->drop(); -} \ No newline at end of file +}