diff options
author | Ezhh <owlecho@live.com> | 2017-12-16 16:02:08 +0000 |
---|---|---|
committer | SmallJoker <SmallJoker@users.noreply.github.com> | 2017-12-16 17:02:08 +0100 |
commit | 649eef9e4fe4ef6a59ca9f59c900c6e0900cfb3a (patch) | |
tree | b600d8811b5a79ba509461665b418da42552e353 /builtin | |
parent | 770eb09adcca5e8d7b1d3b441a130fb9338759e2 (diff) | |
download | minetest-649eef9e4fe4ef6a59ca9f59c900c6e0900cfb3a.tar.gz minetest-649eef9e4fe4ef6a59ca9f59c900c6e0900cfb3a.tar.bz2 minetest-649eef9e4fe4ef6a59ca9f59c900c6e0900cfb3a.zip |
Give subgames the ability to disallow specific mapgens (#6792)
Diffstat (limited to 'builtin')
-rw-r--r-- | builtin/common/misc_helpers.lua | 2 | ||||
-rw-r--r-- | builtin/mainmenu/dlg_create_world.lua | 48 |
2 files changed, 36 insertions, 14 deletions
diff --git a/builtin/common/misc_helpers.lua b/builtin/common/misc_helpers.lua index 01237f265..baa9be268 100644 --- a/builtin/common/misc_helpers.lua +++ b/builtin/common/misc_helpers.lua @@ -551,7 +551,7 @@ end -------------------------------------------------------------------------------- if INIT == "mainmenu" then function core.get_game(index) - local games = game.get_games() + local games = core.get_games() if index > 0 and index <= #games then return games[index] diff --git a/builtin/mainmenu/dlg_create_world.lua b/builtin/mainmenu/dlg_create_world.lua index 4e88ccc48..380f0654f 100644 --- a/builtin/mainmenu/dlg_create_world.lua +++ b/builtin/mainmenu/dlg_create_world.lua @@ -15,11 +15,39 @@ --with this program; if not, write to the Free Software Foundation, Inc., --51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. +local worldname = "" + local function create_world_formspec(dialogdata) local mapgens = core.get_mapgen_names() local current_seed = core.settings:get("fixed_map_seed") or "" local current_mg = core.settings:get("mg_name") + local gameid = core.settings:get("menu_last_game") + + local game, gameidx = nil , 0 + if gameid ~= nil then + game, gameidx = gamemgr.find_by_gameid(gameid) + + if gameidx == nil then + gameidx = 0 + end + end + + local gamepath = core.get_game(gameidx).path + local gameconfig = Settings(gamepath.."/game.conf") + + local disallowed_mapgens = (gameconfig:get("disallowed_mapgens") or ""):split() + for key, value in pairs(disallowed_mapgens) do + disallowed_mapgens[key] = value:trim() + end + + if disallowed_mapgens then + for i = #mapgens, 1, -1 do + if table.indexof(disallowed_mapgens, mapgens[i]) > 0 then + table.remove(mapgens, i) + end + end + end local mglist = "" local selindex = 1 @@ -32,23 +60,12 @@ local function create_world_formspec(dialogdata) mglist = mglist .. v .. "," end mglist = mglist:sub(1, -2) - - local gameid = core.settings:get("menu_last_game") - - local game, gameidx = nil , 0 - if gameid ~= nil then - game, gameidx = gamemgr.find_by_gameid(gameid) - - if gameidx == nil then - gameidx = 0 - end - end current_seed = core.formspec_escape(current_seed) local retval = "size[11.5,6.5,true]" .. "label[2,0;" .. fgettext("World name") .. "]".. - "field[4.5,0.4;6,0.5;te_world_name;;]" .. + "field[4.5,0.4;6,0.5;te_world_name;;" .. minetest.formspec_escape(worldname) .. "]" .. "label[2,1;" .. fgettext("Seed") .. "]".. "field[4.5,1.4;6,0.5;te_seed;;".. current_seed .. "]" .. @@ -121,10 +138,14 @@ local function create_world_buttonhandler(this, fields) return true end + worldname = fields.te_world_name + if fields["games"] then + local gameindex = core.get_textlist_index("games") + core.settings:set("menu_last_game", gamemgr.games[gameindex].id) return true end - + if fields["world_create_cancel"] then this:delete() return true @@ -135,6 +156,7 @@ end function create_create_world_dlg(update_worldlistfilter) + worldname = "" local retval = dialog_create("sp_create_world", create_world_formspec, create_world_buttonhandler, |