]> git.lizzy.rs Git - dragonfireclient.git/blobdiff - src/emerge.cpp
Add replacements to schematics
[dragonfireclient.git] / src / emerge.cpp
index 2a5e84f67c8ca1d9a9fc2933083c03d6f0c96690..f97763718eacebb79d86f3653de7494c9b25a7a4 100644 (file)
@@ -32,8 +32,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
 #include "mapblock.h"
 #include "serverobject.h"
 #include "settings.h"
-#include "script.h"
-#include "scriptapi.h"
+#include "cpp_api/scriptapi.h"
 #include "profiler.h"
 #include "log.h"
 #include "nodedef.h"
@@ -43,6 +42,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
 #include "mapgen_v7.h"
 #include "mapgen_indev.h"
 #include "mapgen_singlenode.h"
+#include "mapgen_math.h"
 
 
 /////////////////////////////// Emerge Manager ////////////////////////////////
@@ -50,14 +50,19 @@ with this program; if not, write to the Free Software Foundation, Inc.,
 EmergeManager::EmergeManager(IGameDef *gamedef) {
        //register built-in mapgens
        registerMapgen("v6", new MapgenFactoryV6());
-       //registerMapgen("v7", new MapgenFactoryV7());
+       registerMapgen("v7", new MapgenFactoryV7());
        registerMapgen("indev", new MapgenFactoryIndev());
        registerMapgen("singlenode", new MapgenFactorySinglenode());
+       registerMapgen("math", new MapgenFactoryMath());
 
        this->ndef     = gamedef->getNodeDefManager();
        this->biomedef = new BiomeDefManager();
        this->params   = NULL;
        
+       this->luaoverride_params          = NULL;
+       this->luaoverride_params_modified = 0;
+       this->luaoverride_flagmask        = 0;
+       
        mapgen_debug_info = g_settings->getBool("enable_mapgen_debug_info");
 
        queuemutex.Init();
@@ -96,9 +101,24 @@ EmergeManager::~EmergeManager() {
                delete emergethread[i];
                delete mapgen[i];
        }
+       emergethread.clear();
+       mapgen.clear();
+
+       for (unsigned int i = 0; i < ores.size(); i++)
+               delete ores[i];
+       ores.clear();
+
+       for (unsigned int i = 0; i < decorations.size(); i++)
+               delete decorations[i];
+       decorations.clear();
        
+       for (std::map<std::string, MapgenFactory *>::iterator iter = mglist.begin();
+                       iter != mglist.end(); iter ++) {
+               delete iter->second;
+       }
+       mglist.clear();
+
        delete biomedef;
-       delete params;
 }
 
 
@@ -108,10 +128,39 @@ void EmergeManager::initMapgens(MapgenParams *mgparams) {
        if (mapgen.size())
                return;
        
+       // Resolve names of nodes for things that were registered
+       // (at this point, the registration period is over)
        biomedef->resolveNodeNames(ndef);
        
+       for (size_t i = 0; i != ores.size(); i++)
+               ores[i]->resolveNodeNames(ndef);
+               
+       for (size_t i = 0; i != decorations.size(); i++)
+               decorations[i]->resolveNodeNames(ndef);
+       
+       // Apply mapgen parameter overrides from Lua
+       if (luaoverride_params) {
+               if (luaoverride_params_modified & MGPARAMS_SET_MGNAME)
+                       mgparams->mg_name = luaoverride_params->mg_name;
+               
+               if (luaoverride_params_modified & MGPARAMS_SET_SEED)
+                       mgparams->seed = luaoverride_params->seed;
+               
+               if (luaoverride_params_modified & MGPARAMS_SET_WATER_LEVEL)
+                       mgparams->water_level = luaoverride_params->water_level;
+               
+               if (luaoverride_params_modified & MGPARAMS_SET_FLAGS) {
+                       mgparams->flags &= ~luaoverride_flagmask;
+                       mgparams->flags |= luaoverride_params->flags;
+               }
+               
+               delete luaoverride_params;
+               luaoverride_params = NULL;
+       }
+       
+       // Create the mapgens
        this->params = mgparams;
-       for (unsigned int i = 0; i != emergethread.size(); i++) {
+       for (size_t i = 0; i != emergethread.size(); i++) {
                mg = createMapgen(params->mg_name, 0, params);
                if (!mg) {
                        infostream << "EmergeManager: falling back to mapgen v6" << std::endl;
@@ -124,6 +173,16 @@ void EmergeManager::initMapgens(MapgenParams *mgparams) {
 }
 
 
+Mapgen *EmergeManager::getCurrentMapgen() {
+       for (unsigned int i = 0; i != emergethread.size(); i++) {
+               if (emergethread[i]->IsSameThread())
+                       return emergethread[i]->mapgen;
+       }
+       
+       return NULL;
+}
+
+
 bool EmergeManager::enqueueBlockEmerge(u16 peer_id, v3s16 p, bool allow_generate) {
        std::map<v3s16, BlockEmergeData *>::const_iterator iter;
        BlockEmergeData *bedata;
@@ -243,6 +302,8 @@ MapgenParams *EmergeManager::createMapgenParams(std::string mgname) {
 MapgenParams *EmergeManager::getParamsFromSettings(Settings *settings) {
        std::string mg_name = settings->get("mg_name");
        MapgenParams *mgparams = createMapgenParams(mg_name);
+       if (!mgparams)
+               return NULL;
        
        mgparams->mg_name     = mg_name;
        mgparams->seed        = settings->getU64(settings == g_settings ? "fixed_map_seed" : "seed");
@@ -336,7 +397,7 @@ bool EmergeThread::getBlockOrStartGen(v3s16 p, MapBlock **b,
 
 void *EmergeThread::Thread() {
        ThreadStarted();
-       log_register_thread("EmergeThread" + id);
+       log_register_thread("EmergeThread" + itos(id));
        DSTACK(__FUNCTION_NAME);
        BEGIN_DEBUG_EXCEPTION_HANDLER
 
@@ -405,7 +466,7 @@ void *EmergeThread::Thread() {
                                                ign(&m_server->m_ignore_map_edit_events_area,
                                                VoxelArea(minp, maxp));
                                        {  // takes about 90ms with -O1 on an e3-1230v2
-                                               scriptapi_environment_on_generated(m_server->m_lua,
+                                               SERVER_TO_SA(m_server)->environment_OnGenerated(
                                                                minp, maxp, emerge->getBlockSeed(minp));
                                        }
 
@@ -427,6 +488,14 @@ void *EmergeThread::Thread() {
                if (block)
                        modified_blocks[p] = block;
 
+               // Update weather data in mapblock
+               for(std::map<v3s16, MapBlock *>::iterator
+                       i = modified_blocks.begin();
+                       i != modified_blocks.end(); ++i) {
+                       map->getHeat(m_server->m_env, MAP_BLOCKSIZE*i->first ,i->second);
+                       map->getHumidity(m_server->m_env, MAP_BLOCKSIZE*i->first, i->second);
+               }
+
                // Set the modified blocks unsent for all the clients
                for (std::map<u16, RemoteClient*>::iterator
                         i = m_server->m_clients.begin();