diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/script/lua_api/l_mapgen.cpp | 33 | ||||
-rw-r--r-- | src/script/lua_api/l_mapgen.h | 4 |
2 files changed, 12 insertions, 25 deletions
diff --git a/src/script/lua_api/l_mapgen.cpp b/src/script/lua_api/l_mapgen.cpp index 78cf389e0..0e3d219a4 100644 --- a/src/script/lua_api/l_mapgen.cpp +++ b/src/script/lua_api/l_mapgen.cpp @@ -262,32 +262,19 @@ int ModApiMapgen::l_set_mapgen_params(lua_State *L) return 0; } -// set_noiseparam_defaults({np1={noise params}, ...}) -// set default values for noise parameters if not present in global settings -int ModApiMapgen::l_set_noiseparam_defaults(lua_State *L) +// set_noiseparams(name, noiseparams, set_default) +// set global config values for noise parameters +int ModApiMapgen::l_set_noiseparams(lua_State *L) { - NoiseParams np; - std::string val, name; + const char *name = luaL_checkstring(L, 1); - if (!lua_istable(L, 1)) + NoiseParams np; + if (!read_noiseparams(L, 2, &np)) return 0; - lua_pushnil(L); - while (lua_next(L, 1)) { - if (read_noiseparams(L, -1, &np)) { - /// TODO(hmmmm): Update this for newer noiseparam formats - /// Right now this is safe because serializeStructToString() won't - /// touch memory outside of what the format string specifies - if (!serializeStructToString(&val, NOISEPARAMS_FMT_STR, &np)) - continue; - if (!lua_isstring(L, -2)) - continue; - - name = lua_tostring(L, -2); - g_settings->setDefault(name, val); - } - lua_pop(L, 1); - } + bool set_default = lua_isboolean(L, 3) ? lua_toboolean(L, 3) : true; + + g_settings->setNoiseParams(name, np, set_default); return 0; } @@ -682,7 +669,7 @@ void ModApiMapgen::Initialize(lua_State *L, int top) API_FCT(get_mapgen_object); API_FCT(set_mapgen_params); - API_FCT(set_noiseparam_defaults); + API_FCT(set_noiseparams); API_FCT(set_gen_notify); API_FCT(register_biome); diff --git a/src/script/lua_api/l_mapgen.h b/src/script/lua_api/l_mapgen.h index d76190f27..72bf1f59b 100644 --- a/src/script/lua_api/l_mapgen.h +++ b/src/script/lua_api/l_mapgen.h @@ -37,8 +37,8 @@ private: // set mapgen parameters static int l_set_mapgen_params(lua_State *L); - // set_noiseparam_defaults({np1={noise params}, ...}) - static int l_set_noiseparam_defaults(lua_State *L); + // set_noiseparam_defaults(name, noiseparams, set_default) + static int l_set_noiseparams(lua_State *L); // set_gen_notify(flagstring) static int l_set_gen_notify(lua_State *L); |