aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/emerge.cpp5
-rw-r--r--src/subgame.cpp37
2 files changed, 34 insertions, 8 deletions
diff --git a/src/emerge.cpp b/src/emerge.cpp
index e81793ff8..2926b0c0b 100644
--- a/src/emerge.cpp
+++ b/src/emerge.cpp
@@ -380,8 +380,11 @@ void EmergeManager::loadParamsFromSettings(Settings *settings)
delete params.sparams;
params.sparams = createMapgenParams(params.mg_name);
- if (params.sparams)
+
+ if (params.sparams) {
+ params.sparams->readParams(g_settings);
params.sparams->readParams(settings);
+ }
}
diff --git a/src/subgame.cpp b/src/subgame.cpp
index 94d9be181..fd2679eae 100644
--- a/src/subgame.cpp
+++ b/src/subgame.cpp
@@ -21,6 +21,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "porting.h"
#include "filesys.h"
#include "settings.h"
+#include "main.h"
#include "log.h"
#include "strfnd.h"
#ifndef SERVER
@@ -265,15 +266,37 @@ std::vector<WorldSpec> getAvailableWorlds()
bool initializeWorld(const std::string &path, const std::string &gameid)
{
- infostream<<"Initializing world at "<<path<<std::endl;
+ infostream << "Initializing world at " << path << std::endl;
+
+ fs::CreateAllDirs(path);
+
// Create world.mt if does not already exist
- std::string worldmt_path = path + DIR_DELIM + "world.mt";
- if(!fs::PathExists(worldmt_path)){
- infostream<<"Creating world.mt ("<<worldmt_path<<")"<<std::endl;
- fs::CreateAllDirs(path);
+ std::string worldmt_path = path + DIR_DELIM "world.mt";
+ if (!fs::PathExists(worldmt_path)) {
+ std::ostringstream ss(std::ios_base::binary);
+ ss << "gameid = " << gameid << "\nbackend = sqlite3\n";
+ if (!fs::safeWriteToFile(worldmt_path, ss.str()))
+ return false;
+
+ infostream << "Wrote world.mt (" << worldmt_path << ")" << std::endl;
+ }
+
+ // Create map_meta.txt if does not already exist
+ std::string mapmeta_path = path + DIR_DELIM "map_meta.txt";
+ if (!fs::PathExists(mapmeta_path)) {
std::ostringstream ss(std::ios_base::binary);
- ss<<"gameid = "<<gameid<< "\nbackend = sqlite3\n";
- fs::safeWriteToFile(worldmt_path, ss.str());
+ ss
+ << "mg_name = " << g_settings->get("mg_name")
+ << "\nseed = " << g_settings->get("fixed_map_seed")
+ << "\nchunksize = " << g_settings->get("chunksize")
+ << "\nwater_level = " << g_settings->get("water_level")
+ << "\nmg_flags = " << g_settings->get("mg_flags")
+ << "\n[end_of_params]\n";
+ if (!fs::safeWriteToFile(mapmeta_path, ss.str()))
+ return false;
+
+ infostream << "Wrote map_meta.txt (" << mapmeta_path << ")" << std::endl;
}
+
return true;
}