Mainmenu: Fix issues while trying to enable all mods (#5770)
authorSmallJoker <SmallJoker@users.noreply.github.com>
Fri, 19 May 2017 05:45:47 +0000 (07:45 +0200)
committerLoïc Blot <nerzhul@users.noreply.github.com>
Fri, 19 May 2017 05:45:47 +0000 (07:45 +0200)
builtin/mainmenu/dlg_config_world.lua
builtin/mainmenu/modmgr.lua
src/client.cpp
src/server.cpp
src/serverenvironment.cpp

index 3e5ba16eb96b87f2400586bfb2da1fa72a40f304..fcedadea886347e1bfc444200faada55ce2463ba 100644 (file)
@@ -49,7 +49,7 @@ local function get_formspec(data)
                "button[3.25,7;2.5,0.5;btn_config_world_save;" .. fgettext("Save") .. "]" ..
                "button[5.75,7;2.5,0.5;btn_config_world_cancel;" .. fgettext("Cancel") .. "]"
 
-       if mod and mod.name ~= "" and mod.typ ~= "game_mod" then
+       if mod and mod.name ~= "" and not mod.is_game_content then
                if mod.is_modpack then
                        local rawlist = data.list:get_raw_list()
 
@@ -97,7 +97,7 @@ end
 local function enable_mod(this, toset)
        local mod = this.data.list:get_list()[this.data.selected_mod]
 
-       if mod.typ == "game_mod" then
+       if mod.is_game_content then
                -- game mods can't be enabled or disabled
        elseif not mod.is_modpack then
                if toset == nil then
@@ -162,7 +162,7 @@ local function handle_buttons(this, fields)
                local i,mod
                for i,mod in ipairs(rawlist) do
                        if not mod.is_modpack and
-                                       mod.typ ~= "game_mod" then
+                                       not mod.is_game_content then
                                if modname_valid(mod.name) then
                                        worldfile:set("load_mod_"..mod.name, tostring(mod.enabled))
                                else
@@ -198,7 +198,8 @@ local function handle_buttons(this, fields)
                local list = this.data.list:get_raw_list()
 
                for i = 1, #list do
-                       if list[i].typ ~= "game_mod" and not list[i].is_modpack then
+                       if not list[i].is_game_content
+                                       and not list[i].is_modpack then
                                list[i].enabled = true
                        end
                end
@@ -210,7 +211,8 @@ local function handle_buttons(this, fields)
                local list = this.data.list:get_raw_list()
 
                for i = 1, #list do
-                       if list[i].typ ~= "game_mod" and not list[i].is_modpack then
+                       if not list[i].is_game_content
+                                       and not list[i].is_modpack then
                                list[i].enabled = false
                        end
                end
@@ -252,16 +254,16 @@ function create_configure_world_dlg(worldidx)
                                                return true
                                        end
                                end,
-                               function(element,criteria)
+                               function(element, criteria)
                                        if criteria.hide_game and
-                                               element.typ == "game_mod" then
-                                                       return false
+                                                       element.is_game_content then
+                                               return false
                                        end
 
                                        if criteria.hide_modpackcontents and
-                                               element.modpack ~= nil then
-                                                       return false
-                                               end
+                                                       element.modpack ~= nil then
+                                               return false
+                                       end
                                        return true
                                end, --filter
                                { worldpath= dlg.data.worldspec.path,
index 14d29272e7015f364a7ce829276dac9c4894812b..dee0489823425d1133ab5b63b0efe70ab15ba6a7 100644 (file)
@@ -252,7 +252,7 @@ function modmgr.render_modlist(render_list)
                                        break
                                end
                        end
-               elseif v.typ == "game_mod" or v.typ == "game" then
+               elseif v.is_game_content then
                        color = mt_color_blue
                elseif v.enabled then
                        color = mt_color_green
@@ -417,12 +417,14 @@ function modmgr.preparemodlist(data)
                -- Add title
                retval[#retval + 1] = {
                        typ = "game",
+                       is_game_content = true,
                        name = fgettext("Subgame Mods")
                }
        end
 
        for i=1,#game_mods,1 do
                game_mods[i].typ = "game_mod"
+               game_mods[i].is_game_content = true
                retval[#retval + 1] = game_mods[i]
        end
 
index 6ab4002a5e77c69443bd408f9fd6dc628e70489a..5f2d2d9d23554b17f4fa06a682c1aea8a30c9a42 100644 (file)
@@ -171,7 +171,7 @@ void Client::initMods()
                if (!string_allowed(mod.name, MODNAME_ALLOWED_CHARS)) {
                        throw ModError("Error loading mod \"" + mod.name +
                                "\": Mod name does not follow naming conventions: "
-                                       "Only chararacters [a-z0-9_] are allowed.");
+                                       "Only characters [a-z0-9_] are allowed.");
                }
                std::string script_path = mod.path + DIR_DELIM + "init.lua";
                infostream << "  [" << padStringRight(mod.name, 12) << "] [\""
index 5400dd5951384cb6142c33866a223903a837aa70..6889451d9f623ddf2f4ff946cec0719e84d7e1a1 100644 (file)
@@ -283,7 +283,7 @@ Server::Server(
                if (!string_allowed(mod.name, MODNAME_ALLOWED_CHARS)) {
                        throw ModError("Error loading mod \"" + mod.name +
                                "\": Mod name does not follow naming conventions: "
-                               "Only chararacters [a-z0-9_] are allowed.");
+                               "Only characters [a-z0-9_] are allowed.");
                }
                std::string script_path = mod.path + DIR_DELIM + "init.lua";
                infostream << "  [" << padStringRight(mod.name, 12) << "] [\""
index 4d2c87a4dfceb8297433580f5bb4941dc31b6dfb..892c6c55bec31ccca596efb2b0944504ad10ed05 100644 (file)
@@ -141,7 +141,7 @@ void LBMManager::addLBMDef(LoadingBlockModifierDef *lbm_def)
        if (!string_allowed(lbm_def->name, LBM_NAME_ALLOWED_CHARS)) {
                throw ModError("Error adding LBM \"" + lbm_def->name +
                        "\": Does not follow naming conventions: "
-                               "Only chararacters [a-z0-9_:] are allowed.");
+                               "Only characters [a-z0-9_:] are allowed.");
        }
 
        m_lbm_defs[lbm_def->name] = lbm_def;