Add port to favorites if not 30000
Major modmgr overhaul Add missing formspec checkbox doc
This commit is contained in:
parent
868f35e27a
commit
baf5614880
@ -108,13 +108,15 @@ function gamemgr.handle_edit_game_buttons(fields)
|
|||||||
if fields["btn_add_mod_to_game"] ~= nil then
|
if fields["btn_add_mod_to_game"] ~= nil then
|
||||||
local modindex = engine.get_textlist_index("mods_available")
|
local modindex = engine.get_textlist_index("mods_available")
|
||||||
|
|
||||||
if modindex > 0 and
|
local mod = modmgr.get_global_mod(modindex)
|
||||||
modindex <= #modmgr.global_mods then
|
if mod ~= nil then
|
||||||
|
|
||||||
local sourcepath =
|
local sourcepath = mod.path
|
||||||
engine.get_modpath() .. DIR_DELIM .. modmgr.global_mods[modindex]
|
|
||||||
|
|
||||||
gamemgr.add_mod(current_game,sourcepath)
|
if not gamemgr.add_mod(current_game,sourcepath) then
|
||||||
|
gamedata.errormessage = "Gamemgr: Unable to copy mod: " ..
|
||||||
|
mod.name .. " to game: " .. current_game.id
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -128,8 +130,10 @@ function gamemgr.add_mod(gamespec,sourcepath)
|
|||||||
|
|
||||||
local modname = get_last_folder(sourcepath)
|
local modname = get_last_folder(sourcepath)
|
||||||
|
|
||||||
engine.copy_dir(sourcepath,gamespec.gamemods_path .. DIR_DELIM .. modname);
|
return engine.copy_dir(sourcepath,gamespec.gamemods_path .. DIR_DELIM .. modname);
|
||||||
end
|
end
|
||||||
|
|
||||||
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
@ -142,15 +146,9 @@ function gamemgr.delete_mod(gamespec,modindex)
|
|||||||
if modindex > 0 and
|
if modindex > 0 and
|
||||||
#game_mods >= modindex then
|
#game_mods >= modindex then
|
||||||
|
|
||||||
local modname = game_mods[modindex]
|
if game_mods[modindex].path:sub(0,gamespec.gamemods_path:len())
|
||||||
|
== gamespec.gamemods_path then
|
||||||
if modname:find("<MODPACK>") ~= nil then
|
engine.delete_dir(game_mods[modindex].path)
|
||||||
modname = modname:sub(0,modname:find("<") -2)
|
|
||||||
end
|
|
||||||
|
|
||||||
local modpath = gamespec.gamemods_path .. DIR_DELIM .. modname
|
|
||||||
if modpath:sub(0,gamespec.gamemods_path:len()) == gamespec.gamemods_path then
|
|
||||||
engine.delete_dir(modpath)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -170,7 +168,7 @@ function gamemgr.get_game_mods(gamespec)
|
|||||||
if retval ~= "" then
|
if retval ~= "" then
|
||||||
retval = retval..","
|
retval = retval..","
|
||||||
end
|
end
|
||||||
retval = retval .. game_mods[i]
|
retval = retval .. game_mods[i].name
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return retval
|
return retval
|
||||||
@ -250,7 +248,7 @@ function gamemgr.dialog_edit_game()
|
|||||||
|
|
||||||
retval = retval ..
|
retval = retval ..
|
||||||
"textlist[7,0.5;4.5,4.3;mods_available;"
|
"textlist[7,0.5;4.5,4.3;mods_available;"
|
||||||
.. modmgr.get_mods_list() .. ";0]"
|
.. modmgr.render_modlist() .. ";0]"
|
||||||
|
|
||||||
retval = retval ..
|
retval = retval ..
|
||||||
"button[0.55,4.95;4.7,0.5;btn_remove_mod_from_game;Remove selected mod]"
|
"button[0.55,4.95;4.7,0.5;btn_remove_mod_from_game;Remove selected mod]"
|
||||||
|
@ -2,6 +2,11 @@ os.setlocale("C", "numeric")
|
|||||||
|
|
||||||
local scriptpath = engine.get_scriptdir()
|
local scriptpath = engine.get_scriptdir()
|
||||||
|
|
||||||
|
mt_color_grey = "#AAAAAA"
|
||||||
|
mt_color_blue = "#0000DD"
|
||||||
|
mt_color_green = "#00DD00"
|
||||||
|
mt_color_dark_green = "#003300"
|
||||||
|
|
||||||
dofile(scriptpath .. DIR_DELIM .. "mainmenu_worldlist.lua")
|
dofile(scriptpath .. DIR_DELIM .. "mainmenu_worldlist.lua")
|
||||||
dofile(scriptpath .. DIR_DELIM .. "modmgr.lua")
|
dofile(scriptpath .. DIR_DELIM .. "modmgr.lua")
|
||||||
dofile(scriptpath .. DIR_DELIM .. "modstore.lua")
|
dofile(scriptpath .. DIR_DELIM .. "modstore.lua")
|
||||||
@ -29,6 +34,12 @@ function render_favourite(spec,render_details)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if spec.port ~= nil and
|
||||||
|
spec.port ~= 30000 then
|
||||||
|
|
||||||
|
text = text .. ":" .. spec.port
|
||||||
|
end
|
||||||
|
|
||||||
if not render_details then
|
if not render_details then
|
||||||
return text
|
return text
|
||||||
end
|
end
|
||||||
|
@ -5,12 +5,12 @@ filterlist = {}
|
|||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function filterlist.refresh(this)
|
function filterlist.refresh(this)
|
||||||
this.m_raw_list = this.m_raw_list_fct()
|
this.m_raw_list = this.m_raw_list_fct(this.m_fetch_param)
|
||||||
filterlist.process(this)
|
filterlist.process(this)
|
||||||
end
|
end
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function filterlist.create(raw_fct,compare_fct,uid_match_fct,filter_fct)
|
function filterlist.create(raw_fct,compare_fct,uid_match_fct,filter_fct,fetch_param)
|
||||||
|
|
||||||
assert((raw_fct ~= nil) and (type(raw_fct) == "function"))
|
assert((raw_fct ~= nil) and (type(raw_fct) == "function"))
|
||||||
assert((compare_fct ~= nil) and (type(compare_fct) == "function"))
|
assert((compare_fct ~= nil) and (type(compare_fct) == "function"))
|
||||||
@ -23,14 +23,13 @@ function filterlist.create(raw_fct,compare_fct,uid_match_fct,filter_fct)
|
|||||||
this.m_uid_match_fct = uid_match_fct
|
this.m_uid_match_fct = uid_match_fct
|
||||||
|
|
||||||
this.m_filtercriteria = nil
|
this.m_filtercriteria = nil
|
||||||
|
this.m_fetch_param = fetch_param
|
||||||
|
|
||||||
this.m_sortmode = "none"
|
this.m_sortmode = "none"
|
||||||
this.m_sort_list = {}
|
this.m_sort_list = {}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
this.m_processed_list = nil
|
this.m_processed_list = nil
|
||||||
this.m_raw_list = this.m_raw_list_fct()
|
this.m_raw_list = this.m_raw_list_fct(this.m_fetch_param)
|
||||||
|
|
||||||
filterlist.process(this)
|
filterlist.process(this)
|
||||||
|
|
||||||
@ -44,7 +43,8 @@ end
|
|||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function filterlist.set_filtercriteria(this,criteria)
|
function filterlist.set_filtercriteria(this,criteria)
|
||||||
if criteria == this.m_filtercriteria then
|
if criteria == this.m_filtercriteria and
|
||||||
|
type(criteria) ~= "table" then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
this.m_filtercriteria = criteria
|
this.m_filtercriteria = criteria
|
||||||
@ -139,8 +139,7 @@ function filterlist.process(this)
|
|||||||
|
|
||||||
this.m_processed_list = {}
|
this.m_processed_list = {}
|
||||||
|
|
||||||
for i,v in ipairs(this.m_raw_list) do
|
for k,v in pairs(this.m_raw_list) do
|
||||||
|
|
||||||
if this.m_filtercriteria == nil or
|
if this.m_filtercriteria == nil or
|
||||||
this.m_filter_fct(v,this.m_filtercriteria) then
|
this.m_filter_fct(v,this.m_filtercriteria) then
|
||||||
table.insert(this.m_processed_list,v)
|
table.insert(this.m_processed_list,v)
|
||||||
|
@ -16,27 +16,31 @@
|
|||||||
--51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
--51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function get_mods(path,retval,basefolder)
|
function get_mods(path,retval,modpack)
|
||||||
|
|
||||||
local mods = engine.get_dirlist(path,true)
|
local mods = engine.get_dirlist(path,true)
|
||||||
|
|
||||||
for i=1,#mods,1 do
|
for i=1,#mods,1 do
|
||||||
local filename = path .. DIR_DELIM .. mods[i] .. DIR_DELIM .. "modpack.txt"
|
local toadd = {}
|
||||||
local modpackfile,error = io.open(filename,"r")
|
local modpackfile = nil
|
||||||
|
|
||||||
local name = mods[i]
|
toadd.name = mods[i]
|
||||||
if basefolder ~= nil and
|
toadd.path = path .. DIR_DELIM .. mods[i] .. DIR_DELIM
|
||||||
basefolder ~= "" then
|
if modpack ~= nil and
|
||||||
name = basefolder .. DIR_DELIM .. mods[i]
|
modpack ~= "" then
|
||||||
|
toadd.modpack = modpack
|
||||||
|
else
|
||||||
|
local filename = path .. DIR_DELIM .. mods[i] .. DIR_DELIM .. "modpack.txt"
|
||||||
|
local error = nil
|
||||||
|
modpackfile,error = io.open(filename,"r")
|
||||||
end
|
end
|
||||||
|
|
||||||
if modpackfile ~= nil then
|
if modpackfile ~= nil then
|
||||||
modpackfile:close()
|
modpackfile:close()
|
||||||
table.insert(retval,name .. " <MODPACK>")
|
toadd.is_modpack = true
|
||||||
get_mods(path .. DIR_DELIM .. name,retval,name)
|
table.insert(retval,toadd)
|
||||||
|
get_mods(path .. DIR_DELIM .. mods[i],retval,mods[i])
|
||||||
else
|
else
|
||||||
|
table.insert(retval,toadd)
|
||||||
table.insert(retval,name)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -174,49 +178,6 @@ function modmgr.parse_dofile_line(modpath,line)
|
|||||||
return nil
|
return nil
|
||||||
end
|
end
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
|
||||||
function modmgr.update_global_mods()
|
|
||||||
local modpath = engine.get_modpath()
|
|
||||||
modmgr.global_mods = {}
|
|
||||||
if modpath ~= nil and
|
|
||||||
modpath ~= "" then
|
|
||||||
get_mods(modpath,modmgr.global_mods)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
|
||||||
function modmgr.get_mods_list()
|
|
||||||
local toadd = ""
|
|
||||||
|
|
||||||
modmgr.update_global_mods()
|
|
||||||
|
|
||||||
if modmgr.global_mods ~= nil then
|
|
||||||
for i=1,#modmgr.global_mods,1 do
|
|
||||||
if toadd ~= "" then
|
|
||||||
toadd = toadd..","
|
|
||||||
end
|
|
||||||
toadd = toadd .. modmgr.global_mods[i]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return toadd
|
|
||||||
end
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
|
||||||
function modmgr.mod_exists(basename)
|
|
||||||
modmgr.update_global_mods()
|
|
||||||
|
|
||||||
if modmgr.global_mods ~= nil then
|
|
||||||
for i=1,#modmgr.global_mods,1 do
|
|
||||||
if modmgr.global_mods[i] == basename then
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function modmgr.identify_modname(modpath,filename)
|
function modmgr.identify_modname(modpath,filename)
|
||||||
local testfile = io.open(modpath .. DIR_DELIM .. filename,"r")
|
local testfile = io.open(modpath .. DIR_DELIM .. filename,"r")
|
||||||
@ -258,6 +219,11 @@ end
|
|||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function modmgr.tab()
|
function modmgr.tab()
|
||||||
|
|
||||||
|
if modmgr.global_mods == nil then
|
||||||
|
modmgr.refresh_globals()
|
||||||
|
end
|
||||||
|
|
||||||
if modmgr.selected_mod == nil then
|
if modmgr.selected_mod == nil then
|
||||||
modmgr.selected_mod = 1
|
modmgr.selected_mod = 1
|
||||||
end
|
end
|
||||||
@ -266,28 +232,29 @@ function modmgr.tab()
|
|||||||
"vertlabel[0,-0.25;MODS]" ..
|
"vertlabel[0,-0.25;MODS]" ..
|
||||||
"label[0.8,-0.25;Installed Mods:]" ..
|
"label[0.8,-0.25;Installed Mods:]" ..
|
||||||
"textlist[0.75,0.25;4.5,4.3;modlist;" ..
|
"textlist[0.75,0.25;4.5,4.3;modlist;" ..
|
||||||
modmgr.get_mods_list() ..
|
modmgr.render_modlist(modmgr.global_mods) ..
|
||||||
";" .. modmgr.selected_mod .. "]"
|
";" .. modmgr.selected_mod .. "]"
|
||||||
|
|
||||||
retval = retval ..
|
retval = retval ..
|
||||||
"button[1,4.85;2,0.5;btn_mod_mgr_install_local;Install]" ..
|
"button[1,4.85;2,0.5;btn_mod_mgr_install_local;Install]" ..
|
||||||
"button[3,4.85;2,0.5;btn_mod_mgr_download;Download]"
|
"button[3,4.85;2,0.5;btn_mod_mgr_download;Download]"
|
||||||
|
|
||||||
if #modmgr.global_mods >= modmgr.selected_mod and
|
local selected_mod = nil
|
||||||
modmgr.global_mods[modmgr.selected_mod]:find("<MODPACK>") then
|
|
||||||
retval = retval .. "button[10,4.85;2,0.5;btn_mod_mgr_rename_modpack;Rename]"
|
if filterlist.size(modmgr.global_mods) >= modmgr.selected_mod then
|
||||||
|
selected_mod = filterlist.get_list(modmgr.global_mods)[modmgr.selected_mod]
|
||||||
end
|
end
|
||||||
|
|
||||||
if #modmgr.global_mods >= modmgr.selected_mod then
|
if selected_mod ~= nil then
|
||||||
local modpath = engine.get_modpath()
|
if selected_mod.is_modpack then
|
||||||
--show dependencys
|
retval = retval .. "button[10,4.85;2,0.5;btn_mod_mgr_rename_modpack;Rename]"
|
||||||
if modmgr.global_mods[modmgr.selected_mod]:find("<MODPACK>") == nil then
|
else
|
||||||
|
--show dependencies
|
||||||
retval = retval ..
|
retval = retval ..
|
||||||
"label[6,1.9;Depends:]" ..
|
"label[6,1.9;Depends:]" ..
|
||||||
"textlist[6,2.4;5.7,2;deplist;"
|
"textlist[6,2.4;5.7,2;deplist;"
|
||||||
|
|
||||||
toadd = modmgr.get_dependencys(modpath .. DIR_DELIM ..
|
toadd = modmgr.get_dependencies(selected_mod.path)
|
||||||
modmgr.global_mods[modmgr.selected_mod])
|
|
||||||
|
|
||||||
retval = retval .. toadd .. ";0;true,false]"
|
retval = retval .. toadd .. ";0;true,false]"
|
||||||
|
|
||||||
@ -302,13 +269,12 @@ end
|
|||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function modmgr.dialog_rename_modpack()
|
function modmgr.dialog_rename_modpack()
|
||||||
|
|
||||||
local modname = modmgr.global_mods[modmgr.selected_mod]
|
local mod = filterlist.get_list(modmgr.modlist)[modmgr.selected_mod]
|
||||||
modname = modname:sub(0,modname:find("<") -2)
|
|
||||||
|
|
||||||
local retval =
|
local retval =
|
||||||
"label[1.75,1;Rename Modpack:]"..
|
"label[1.75,1;Rename Modpack:]"..
|
||||||
"field[4.5,1.4;6,0.5;te_modpack_name;;" ..
|
"field[4.5,1.4;6,0.5;te_modpack_name;;" ..
|
||||||
modname ..
|
mod.name ..
|
||||||
"]" ..
|
"]" ..
|
||||||
"button[5,4.2;2.6,0.5;dlg_rename_modpack_confirm;Accept]" ..
|
"button[5,4.2;2.6,0.5;dlg_rename_modpack_confirm;Accept]" ..
|
||||||
"button[7.5,4.2;2.8,0.5;dlg_rename_modpack_cancel;Cancel]"
|
"button[7.5,4.2;2.8,0.5;dlg_rename_modpack_cancel;Cancel]"
|
||||||
@ -318,9 +284,6 @@ end
|
|||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function modmgr.precheck()
|
function modmgr.precheck()
|
||||||
if modmgr.global_mods == nil then
|
|
||||||
modmgr.update_global_mods()
|
|
||||||
end
|
|
||||||
|
|
||||||
if modmgr.world_config_selected_world == nil then
|
if modmgr.world_config_selected_world == nil then
|
||||||
modmgr.world_config_selected_world = 1
|
modmgr.world_config_selected_world = 1
|
||||||
@ -333,53 +296,61 @@ function modmgr.precheck()
|
|||||||
if modmgr.hide_gamemods == nil then
|
if modmgr.hide_gamemods == nil then
|
||||||
modmgr.hide_gamemods = true
|
modmgr.hide_gamemods = true
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
if modmgr.hide_modpackcontents == nil then
|
||||||
function modmgr.get_worldmod_idx()
|
modmgr.hide_modpackcontents = true
|
||||||
if not modmgr.hide_gamemods then
|
|
||||||
return modmgr.world_config_selected_mod - #modmgr.worldconfig.game_mods
|
|
||||||
else
|
|
||||||
return modmgr.world_config_selected_mod
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function modmgr.is_gamemod()
|
function modmgr.render_modlist(render_list)
|
||||||
if not modmgr.hide_gamemods then
|
|
||||||
if modmgr.world_config_selected_mod <= #modmgr.worldconfig.game_mods then
|
|
||||||
return true
|
|
||||||
else
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
else
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
|
||||||
function modmgr.render_worldmodlist()
|
|
||||||
local retval = ""
|
local retval = ""
|
||||||
|
|
||||||
for i=1,#modmgr.global_mods,1 do
|
if render_list == nil then
|
||||||
local parts = modmgr.global_mods[i]:split(DIR_DELIM)
|
if modmgr.global_mods == nil then
|
||||||
local shortname = parts[#parts]
|
modmgr.refresh_globals()
|
||||||
if modmgr.worldconfig.global_mods[shortname] then
|
end
|
||||||
retval = retval .. "#22F922" .. modmgr.global_mods[i] .. ","
|
render_list = modmgr.global_mods
|
||||||
|
end
|
||||||
|
|
||||||
|
local list = filterlist.get_list(render_list)
|
||||||
|
local last_modpack = nil
|
||||||
|
|
||||||
|
for i,v in ipairs(list) do
|
||||||
|
if retval ~= "" then
|
||||||
|
retval = retval ..","
|
||||||
|
end
|
||||||
|
|
||||||
|
if v.is_modpack then
|
||||||
|
local rawlist = filterlist.get_raw_list(render_list)
|
||||||
|
|
||||||
|
local all_enabled = true
|
||||||
|
for j=1,#rawlist,1 do
|
||||||
|
if rawlist[j].modpack == list[i].name and
|
||||||
|
rawlist[j].enabled ~= true then
|
||||||
|
all_enabled = false
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if all_enabled == false then
|
||||||
|
retval = retval .. mt_color_grey
|
||||||
else
|
else
|
||||||
retval = retval .. modmgr.global_mods[i] .. ","
|
retval = retval .. mt_color_dark_green
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return retval
|
if v.typ == "game_mod" then
|
||||||
end
|
retval = retval .. mt_color_blue
|
||||||
|
else
|
||||||
--------------------------------------------------------------------------------
|
if v.enabled then
|
||||||
function modmgr.render_gamemodlist()
|
retval = retval .. mt_color_green
|
||||||
local retval = ""
|
end
|
||||||
for i=1,#modmgr.worldconfig.game_mods,1 do
|
end
|
||||||
retval = retval ..
|
if v.modpack ~= nil then
|
||||||
"#0000FF" .. modmgr.worldconfig.game_mods[i] .. ","
|
retval = retval .. " "
|
||||||
|
end
|
||||||
|
retval = retval .. v.name
|
||||||
end
|
end
|
||||||
|
|
||||||
return retval
|
return retval
|
||||||
@ -389,82 +360,43 @@ end
|
|||||||
function modmgr.dialog_configure_world()
|
function modmgr.dialog_configure_world()
|
||||||
modmgr.precheck()
|
modmgr.precheck()
|
||||||
|
|
||||||
local modpack_selected = false
|
|
||||||
local gamemod_selected = modmgr.is_gamemod()
|
|
||||||
local modname = ""
|
|
||||||
local modfolder = ""
|
|
||||||
local shortname = ""
|
|
||||||
|
|
||||||
if not gamemod_selected then
|
|
||||||
local worldmodidx = modmgr.get_worldmod_idx()
|
|
||||||
modname = modmgr.global_mods[worldmodidx]
|
|
||||||
|
|
||||||
if modname ~= nil then
|
|
||||||
|
|
||||||
if modname:find("<MODPACK>") ~= nil then
|
|
||||||
modname = modname:sub(0,modname:find("<") -2)
|
|
||||||
modpack_selected = true
|
|
||||||
end
|
|
||||||
|
|
||||||
local parts = modmgr.global_mods[worldmodidx]:split(DIR_DELIM)
|
|
||||||
shortname = parts[#parts]
|
|
||||||
|
|
||||||
modfolder = engine.get_modpath() .. DIR_DELIM .. modname
|
|
||||||
else
|
|
||||||
modname = ""
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local worldspec = engine.get_worlds()[modmgr.world_config_selected_world]
|
local worldspec = engine.get_worlds()[modmgr.world_config_selected_world]
|
||||||
|
local mod = filterlist.get_list(modmgr.modlist)[modmgr.world_config_selected_mod]
|
||||||
|
|
||||||
local retval =
|
local retval =
|
||||||
"size[11,6.5]" ..
|
"size[11,6.5]" ..
|
||||||
"label[1.5,-0.25;World: " .. worldspec.name .. "]"
|
"label[1.5,-0.25;World: " .. worldspec.name .. "]"
|
||||||
|
|
||||||
if modmgr.hide_gamemods then
|
if modmgr.hide_gamemods then
|
||||||
retval = retval .. "checkbox[5.5,6.15;cb_hide_gamemods;Hide Game;true]"
|
retval = retval .. "checkbox[0,5.75;cb_hide_gamemods;Hide Game;true]"
|
||||||
else
|
else
|
||||||
retval = retval .. "checkbox[5.5,6.15;cb_hide_gamemods;Hide Game;false]"
|
retval = retval .. "checkbox[0,5.75;cb_hide_gamemods;Hide Game;false]"
|
||||||
end
|
|
||||||
retval = retval ..
|
|
||||||
"button[9.25,6.35;2,0.5;btn_config_world_save;Save]" ..
|
|
||||||
"button[7.4,6.35;2,0.5;btn_config_world_cancel;Cancel]" ..
|
|
||||||
"textlist[5.5,-0.25;5.5,6.5;world_config_modlist;"
|
|
||||||
|
|
||||||
|
|
||||||
if not modmgr.hide_gamemods then
|
|
||||||
retval = retval .. modmgr.render_gamemodlist()
|
|
||||||
end
|
end
|
||||||
|
|
||||||
retval = retval .. modmgr.render_worldmodlist()
|
if modmgr.hide_modpackcontents then
|
||||||
|
retval = retval .. "checkbox[2,5.75;cb_hide_mpcontent;Hide mp content;true]"
|
||||||
|
else
|
||||||
|
retval = retval .. "checkbox[2,5.75;cb_hide_mpcontent;Hide mp content;false]"
|
||||||
|
end
|
||||||
|
|
||||||
retval = retval .. ";" .. modmgr.world_config_selected_mod .."]"
|
if mod == nil then
|
||||||
|
mod = {name=""}
|
||||||
if not gamemod_selected then
|
end
|
||||||
retval = retval ..
|
retval = retval ..
|
||||||
"label[0,0.45;Mod:]" ..
|
"label[0,0.45;Mod:]" ..
|
||||||
"label[0.75,0.45;" .. modname .. "]" ..
|
"label[0.75,0.45;" .. mod.name .. "]" ..
|
||||||
"label[0,1.5;Depends:]" ..
|
"label[0,1;Depends:]" ..
|
||||||
"textlist[0,2;5,4.25;world_config_depends;" ..
|
"textlist[0,1.5;5,4.25;world_config_depends;" ..
|
||||||
modmgr.get_dependencys(modfolder) .. ";0]"
|
modmgr.get_dependencies(mod.path) .. ";0]" ..
|
||||||
|
"button[9.25,6.35;2,0.5;btn_config_world_save;Save]" ..
|
||||||
|
"button[7.4,6.35;2,0.5;btn_config_world_cancel;Cancel]" ..
|
||||||
|
"button[5.5,-0.125;5.75,0.5;btn_all_mods;Enable all Mods]" ..
|
||||||
|
"textlist[5.5,0.5;5.5,5.75;world_config_modlist;"
|
||||||
|
|
||||||
if modpack_selected then
|
|
||||||
retval = retval ..
|
|
||||||
"button[-0.05,1.05;2,0.5;btn_cfgw_enable_all;Enable All]" ..
|
|
||||||
"button[3.25,1.05;2,0.5;btn_cfgw_disable_all;Disable All]"
|
|
||||||
else
|
|
||||||
retval = retval ..
|
|
||||||
"checkbox[0,0.8;cb_mod_enabled;enabled;"
|
|
||||||
|
|
||||||
if modmgr.worldconfig.global_mods[shortname] then
|
retval = retval .. modmgr.render_modlist(modmgr.modlist)
|
||||||
retval = retval .. "true"
|
|
||||||
else
|
|
||||||
retval = retval .. "false"
|
|
||||||
end
|
|
||||||
|
|
||||||
retval = retval .. "]"
|
retval = retval .. ";" .. modmgr.world_config_selected_mod .."]"
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return retval
|
return retval
|
||||||
end
|
end
|
||||||
@ -494,13 +426,14 @@ function modmgr.handle_buttons(tab,fields)
|
|||||||
end
|
end
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function modmgr.get_dependencys(modfolder)
|
function modmgr.get_dependencies(modfolder)
|
||||||
|
local toadd = ""
|
||||||
|
if modfolder ~= nil then
|
||||||
local filename = modfolder ..
|
local filename = modfolder ..
|
||||||
DIR_DELIM .. "depends.txt"
|
DIR_DELIM .. "depends.txt"
|
||||||
|
|
||||||
local dependencyfile = io.open(filename,"r")
|
local dependencyfile = io.open(filename,"r")
|
||||||
|
|
||||||
local toadd = ""
|
|
||||||
if dependencyfile then
|
if dependencyfile then
|
||||||
local dependency = dependencyfile:read("*l")
|
local dependency = dependencyfile:read("*l")
|
||||||
while dependency do
|
while dependency do
|
||||||
@ -511,8 +444,7 @@ function modmgr.get_dependencys(modfolder)
|
|||||||
dependency = dependencyfile:read()
|
dependency = dependencyfile:read()
|
||||||
end
|
end
|
||||||
dependencyfile:close()
|
dependencyfile:close()
|
||||||
else
|
end
|
||||||
print("Modmgr:" .. filename .. " not found")
|
|
||||||
end
|
end
|
||||||
|
|
||||||
return toadd
|
return toadd
|
||||||
@ -666,15 +598,17 @@ function modmgr.installmod(modfilename,basename)
|
|||||||
end
|
end
|
||||||
|
|
||||||
engine.delete_dir(modpath)
|
engine.delete_dir(modpath)
|
||||||
|
|
||||||
|
modmgr.refresh_globals()
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function modmgr.handle_rename_modpack_buttons(fields)
|
function modmgr.handle_rename_modpack_buttons(fields)
|
||||||
local oldname = modmgr.global_mods[modmgr.selected_mod]
|
|
||||||
oldname = oldname:sub(0,oldname:find("<") -2)
|
|
||||||
|
|
||||||
if fields["dlg_rename_modpack_confirm"] ~= nil then
|
if fields["dlg_rename_modpack_confirm"] ~= nil then
|
||||||
local oldpath = engine.get_modpath() .. DIR_DELIM .. oldname
|
local mod = filterlist.get_list(modmgr.modlist)[modmgr.selected_mod]
|
||||||
|
local oldpath = engine.get_modpath() .. DIR_DELIM .. mod.name
|
||||||
local targetpath = engine.get_modpath() .. DIR_DELIM .. fields["te_modpack_name"]
|
local targetpath = engine.get_modpath() .. DIR_DELIM .. fields["te_modpack_name"]
|
||||||
engine.copy_dir(oldpath,targetpath,false)
|
engine.copy_dir(oldpath,targetpath,false)
|
||||||
end
|
end
|
||||||
@ -690,28 +624,67 @@ function modmgr.handle_configure_world_buttons(fields)
|
|||||||
if fields["world_config_modlist"] ~= nil then
|
if fields["world_config_modlist"] ~= nil then
|
||||||
local event = explode_textlist_event(fields["world_config_modlist"])
|
local event = explode_textlist_event(fields["world_config_modlist"])
|
||||||
modmgr.world_config_selected_mod = event.index
|
modmgr.world_config_selected_mod = event.index
|
||||||
|
|
||||||
|
if event.typ == "DCL" then
|
||||||
|
local mod = filterlist.get_list(modmgr.modlist)[event.index]
|
||||||
|
|
||||||
|
if mod.typ == "game_mod" then
|
||||||
|
return nil
|
||||||
end
|
end
|
||||||
|
|
||||||
if fields["cb_mod_enabled"] ~= nil then
|
if not mod.is_modpack then
|
||||||
local index = modmgr.get_worldmod_idx()
|
mod.enabled = not mod.enabled
|
||||||
local modname = modmgr.global_mods[index]
|
|
||||||
|
|
||||||
local parts = modmgr.global_mods[index]:split(DIR_DELIM)
|
|
||||||
local shortname = parts[#parts]
|
|
||||||
|
|
||||||
if fields["cb_mod_enabled"] == "true" then
|
|
||||||
modmgr.worldconfig.global_mods[shortname] = true
|
|
||||||
else
|
else
|
||||||
modmgr.worldconfig.global_mods[shortname] = false
|
local list = filterlist.get_raw_list(modmgr.modlist)
|
||||||
|
local toset = nil
|
||||||
|
|
||||||
|
for i=1,#list,1 do
|
||||||
|
if list[i].modpack == mod.name then
|
||||||
|
if toset == nil then
|
||||||
|
toset = not list[i].enabled
|
||||||
|
end
|
||||||
|
|
||||||
|
list[i].enabled = toset
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if fields["cb_hide_gamemods"] ~= nil then
|
if fields["cb_hide_gamemods"] ~= nil then
|
||||||
|
local current = filterlist.get_filtercriteria(modmgr.modlist)
|
||||||
|
|
||||||
|
if current == nil then
|
||||||
|
current = {}
|
||||||
|
end
|
||||||
|
|
||||||
if fields["cb_hide_gamemods"] == "true" then
|
if fields["cb_hide_gamemods"] == "true" then
|
||||||
|
current.hide_game = true
|
||||||
modmgr.hide_gamemods = true
|
modmgr.hide_gamemods = true
|
||||||
else
|
else
|
||||||
|
current.hide_game = false
|
||||||
modmgr.hide_gamemods = false
|
modmgr.hide_gamemods = false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
filterlist.set_filtercriteria(modmgr.modlist,current)
|
||||||
|
end
|
||||||
|
|
||||||
|
if fields["cb_hide_mpcontent"] ~= nil then
|
||||||
|
local current = filterlist.get_filtercriteria(modmgr.modlist)
|
||||||
|
|
||||||
|
if current == nil then
|
||||||
|
current = {}
|
||||||
|
end
|
||||||
|
|
||||||
|
if fields["cb_hide_mpcontent"] == "true" then
|
||||||
|
current.hide_modpackcontents = true
|
||||||
|
modmgr.hide_modpackcontents = true
|
||||||
|
else
|
||||||
|
current.hide_modpackcontents = false
|
||||||
|
modmgr.hide_modpackcontents = false
|
||||||
|
end
|
||||||
|
|
||||||
|
filterlist.set_filtercriteria(modmgr.modlist,current)
|
||||||
end
|
end
|
||||||
|
|
||||||
if fields["btn_config_world_save"] then
|
if fields["btn_config_world_save"] then
|
||||||
@ -724,17 +697,27 @@ function modmgr.handle_configure_world_buttons(fields)
|
|||||||
|
|
||||||
if worldfile then
|
if worldfile then
|
||||||
worldfile:write("gameid = " .. modmgr.worldconfig.id .. "\n")
|
worldfile:write("gameid = " .. modmgr.worldconfig.id .. "\n")
|
||||||
for key,value in pairs(modmgr.worldconfig.global_mods) do
|
|
||||||
if value then
|
local rawlist = filterlist.get_raw_list(modmgr.modlist)
|
||||||
worldfile:write("load_mod_" .. key .. " = true" .. "\n")
|
|
||||||
|
for i=1,#rawlist,1 do
|
||||||
|
|
||||||
|
if not rawlist[i].is_modpack and
|
||||||
|
rawlist[i].typ ~= "game_mod" then
|
||||||
|
if rawlist[i].enabled then
|
||||||
|
worldfile:write("load_mod_" .. rawlist[i].name .. " = true" .. "\n")
|
||||||
else
|
else
|
||||||
worldfile:write("load_mod_" .. key .. " = false" .. "\n")
|
worldfile:write("load_mod_" .. rawlist[i].name .. " = false" .. "\n")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
worldfile:close()
|
worldfile:close()
|
||||||
|
else
|
||||||
|
print("failed to open world config file")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
modmgr.modlist = nil
|
||||||
modmgr.worldconfig = nil
|
modmgr.worldconfig = nil
|
||||||
|
|
||||||
return {
|
return {
|
||||||
@ -755,60 +738,36 @@ function modmgr.handle_configure_world_buttons(fields)
|
|||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
if fields["btn_cfgw_enable_all"] then
|
if fields["btn_all_mods"] then
|
||||||
local worldmodidx = modmgr.get_worldmod_idx()
|
local list = filterlist.get_raw_list(modmgr.modlist)
|
||||||
modname = modmgr.global_mods[worldmodidx]
|
|
||||||
|
|
||||||
modname = modname:sub(0,modname:find("<") -2)
|
for i=1,#list,1 do
|
||||||
|
if list[i].typ ~= "game_mod" and
|
||||||
for i=1,#modmgr.global_mods,1 do
|
not list[i].is_modpack then
|
||||||
|
list[i].enabled = true
|
||||||
if modmgr.global_mods[i]:find("<MODPACK>") == nil then
|
|
||||||
local modpackpart = modmgr.global_mods[i]:sub(0,modname:len())
|
|
||||||
|
|
||||||
if modpackpart == modname then
|
|
||||||
local parts = modmgr.global_mods[i]:split(DIR_DELIM)
|
|
||||||
local shortname = parts[#parts]
|
|
||||||
modmgr.worldconfig.global_mods[shortname] = true
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if fields["btn_cfgw_disable_all"] then
|
|
||||||
local worldmodidx = modmgr.get_worldmod_idx()
|
|
||||||
modname = modmgr.global_mods[worldmodidx]
|
|
||||||
|
|
||||||
modname = modname:sub(0,modname:find("<") -2)
|
|
||||||
|
|
||||||
for i=1,#modmgr.global_mods,1 do
|
|
||||||
local modpackpart = modmgr.global_mods[i]:sub(0,modname:len())
|
|
||||||
|
|
||||||
if modpackpart == modname then
|
|
||||||
local parts = modmgr.global_mods[i]:split(DIR_DELIM)
|
|
||||||
local shortname = parts[#parts]
|
|
||||||
modmgr.worldconfig.global_mods[shortname] = nil
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
end
|
end
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function modmgr.handle_delete_mod_buttons(fields)
|
function modmgr.handle_delete_mod_buttons(fields)
|
||||||
local modname = modmgr.global_mods[modmgr.selected_mod]
|
local mod = filterlist.get_list(modmgr.global_mods)[modmgr.selected_mod]
|
||||||
|
|
||||||
if modname:find("<MODPACK>") ~= nil then
|
|
||||||
modname = modname:sub(0,modname:find("<") -2)
|
|
||||||
end
|
|
||||||
|
|
||||||
if fields["dlg_delete_mod_confirm"] ~= nil then
|
if fields["dlg_delete_mod_confirm"] ~= nil then
|
||||||
local oldpath = engine.get_modpath() .. DIR_DELIM .. modname
|
|
||||||
|
|
||||||
if oldpath ~= nil and
|
if mod.path ~= nil and
|
||||||
oldpath ~= "" and
|
mod.path ~= "" and
|
||||||
oldpath ~= engine.get_modpath() then
|
mod.path ~= engine.get_modpath() then
|
||||||
engine.delete_dir(oldpath)
|
if not engine.delete_dir(mod.path) then
|
||||||
|
gamedata.errormessage ="Modmgr: failed to delete >" .. mod.path .. "<"
|
||||||
|
end
|
||||||
|
modmgr.refresh_globals()
|
||||||
|
else
|
||||||
|
gamedata.errormessage ="Modmgr: invalid modpath >" .. mod.path .. "<"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -822,14 +781,10 @@ end
|
|||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function modmgr.dialog_delete_mod()
|
function modmgr.dialog_delete_mod()
|
||||||
|
|
||||||
local modname = modmgr.global_mods[modmgr.selected_mod]
|
local mod = filterlist.get_list(modmgr.global_mods)[modmgr.selected_mod]
|
||||||
|
|
||||||
if modname:find("<MODPACK>") ~= nil then
|
|
||||||
modname = modname:sub(0,modname:find("<") -2)
|
|
||||||
end
|
|
||||||
|
|
||||||
local retval =
|
local retval =
|
||||||
"field[1.75,1;10,3;;Are you sure you want to delete ".. modname .. "?;]"..
|
"field[1.75,1;10,3;;Are you sure you want to delete ".. mod.name .. "?;]"..
|
||||||
"button[4,4.2;1,0.5;dlg_delete_mod_confirm;Yes]" ..
|
"button[4,4.2;1,0.5;dlg_delete_mod_confirm;Yes]" ..
|
||||||
"button[6.5,4.2;3,0.5;dlg_delete_mod_cancel;No of course not!]"
|
"button[6.5,4.2;3,0.5;dlg_delete_mod_cancel;No of course not!]"
|
||||||
|
|
||||||
@ -837,8 +792,85 @@ function modmgr.dialog_delete_mod()
|
|||||||
end
|
end
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function modmgr.init_worldconfig()
|
function modmgr.preparemodlist(data)
|
||||||
|
local retval = {}
|
||||||
|
|
||||||
|
local global_mods = {}
|
||||||
|
local game_mods = {}
|
||||||
|
|
||||||
|
--read global mods
|
||||||
|
local modpath = engine.get_modpath()
|
||||||
|
|
||||||
|
if modpath ~= nil and
|
||||||
|
modpath ~= "" then
|
||||||
|
get_mods(modpath,global_mods)
|
||||||
|
end
|
||||||
|
|
||||||
|
for i=1,#global_mods,1 do
|
||||||
|
global_mods[i].typ = "global_mod"
|
||||||
|
table.insert(retval,global_mods[i])
|
||||||
|
end
|
||||||
|
|
||||||
|
--read game mods
|
||||||
|
if data.gameid ~= nil and
|
||||||
|
data.gameid ~= "" then
|
||||||
|
local gamemodpath = engine.get_gamepath() .. DIR_DELIM .. data.gameid .. DIR_DELIM .. "mods"
|
||||||
|
|
||||||
|
get_mods(gamemodpath,game_mods)
|
||||||
|
end
|
||||||
|
|
||||||
|
for i=1,#game_mods,1 do
|
||||||
|
game_mods[i].typ = "game_mod"
|
||||||
|
table.insert(retval,game_mods[i])
|
||||||
|
end
|
||||||
|
|
||||||
|
if data.worldpath == nil then
|
||||||
|
return retval
|
||||||
|
end
|
||||||
|
|
||||||
|
--read world mod configuration
|
||||||
|
local filename = data.worldpath ..
|
||||||
|
DIR_DELIM .. "world.mt"
|
||||||
|
|
||||||
|
local worldfile = io.open(filename,"r")
|
||||||
|
if worldfile then
|
||||||
|
local dependency = worldfile:read("*l")
|
||||||
|
while dependency do
|
||||||
|
local parts = dependency:split("=")
|
||||||
|
|
||||||
|
local key = parts[1]:trim()
|
||||||
|
|
||||||
|
if key ~= "gameid" then
|
||||||
|
local key = parts[1]:trim():sub(10)
|
||||||
|
local element = nil
|
||||||
|
for i=1,#retval,1 do
|
||||||
|
if retval[i].name == key then
|
||||||
|
element = retval[i]
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if element ~= nil then
|
||||||
|
if parts[2]:trim() == "true" then
|
||||||
|
element.enabled = true
|
||||||
|
else
|
||||||
|
element.enabled = false
|
||||||
|
end
|
||||||
|
else
|
||||||
|
print("Mod: " .. key .. " " .. dump(parts[2]) .. " but not found")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
dependency = worldfile:read("*l")
|
||||||
|
end
|
||||||
|
worldfile:close()
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
return retval
|
||||||
|
end
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
function modmgr.init_worldconfig()
|
||||||
|
modmgr.precheck()
|
||||||
local worldspec = engine.get_worlds()[modmgr.world_config_selected_world]
|
local worldspec = engine.get_worlds()[modmgr.world_config_selected_world]
|
||||||
|
|
||||||
if worldspec ~= nil then
|
if worldspec ~= nil then
|
||||||
@ -851,12 +883,66 @@ function modmgr.init_worldconfig()
|
|||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
modmgr.modlist = filterlist.create(
|
||||||
|
modmgr.preparemodlist, --refresh
|
||||||
|
modmgr.comparemod, --compare
|
||||||
|
function(element,uid) --uid match
|
||||||
|
if element.name == uid then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
function(element,criteria)
|
||||||
|
if criteria.hide_game and
|
||||||
|
element.typ == "game_mod" then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
if criteria.hide_modpackcontents and
|
||||||
|
element.modpack ~= nil then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
return true
|
||||||
|
end, --filter
|
||||||
|
{ worldpath= worldspec.path,
|
||||||
|
gameid = worldspec.gameid }
|
||||||
|
)
|
||||||
|
|
||||||
|
filterlist.set_filtercriteria(modmgr.modlist, {
|
||||||
|
hide_game=modmgr.hide_gamemods,
|
||||||
|
hide_modpackcontents= modmgr.hide_modpackcontents
|
||||||
|
})
|
||||||
|
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
function modmgr.comparemod(elem1,elem2)
|
||||||
|
if elem1 == nil or elem2 == nil then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
if elem1.name ~= elem2.name then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
if elem1.is_modpack ~= elem2.is_modpack then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
if elem1.typ ~= elem2.typ then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
if elem1.modpack ~= elem2.modpack then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
if elem1.path ~= elem2.path then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
function modmgr.gettab(name)
|
function modmgr.gettab(name)
|
||||||
local retval = ""
|
local retval = ""
|
||||||
@ -879,3 +965,46 @@ function modmgr.gettab(name)
|
|||||||
|
|
||||||
return retval
|
return retval
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
function modmgr.mod_exists(basename)
|
||||||
|
|
||||||
|
if modmgr.global_mods == nil then
|
||||||
|
modmgr.refresh_globals()
|
||||||
|
end
|
||||||
|
|
||||||
|
if filterlist.engine_index_by_uid(modmgr.global_mods,basename) > 0 then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
function modmgr.get_global_mod(idx)
|
||||||
|
|
||||||
|
if modmgr.global_mods == nil then
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
|
||||||
|
if idx < 1 or idx > filterlist.size(modmgr.global_mods) then
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
|
||||||
|
return filterlist.get_list(modmgr.global_mods)[idx]
|
||||||
|
end
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
function modmgr.refresh_globals()
|
||||||
|
modmgr.global_mods = filterlist.create(
|
||||||
|
modmgr.preparemodlist, --refresh
|
||||||
|
modmgr.comparemod, --compare
|
||||||
|
function(element,uid) --uid match
|
||||||
|
if element.name == uid then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
nil, --filter
|
||||||
|
{}
|
||||||
|
)
|
||||||
|
end
|
||||||
|
@ -997,6 +997,13 @@ dropdown[<X>,<Y>;<W>;<name>;<item 1>,<item 2>, ...,<item n>;<selected idx>]
|
|||||||
^ index of currently selected dropdown item
|
^ index of currently selected dropdown item
|
||||||
^ color in hexadecimal format RRGGBB
|
^ color in hexadecimal format RRGGBB
|
||||||
|
|
||||||
|
checkbox[<X>,<Y>;<name>;<label>;<selected>]
|
||||||
|
^ show a checkbox
|
||||||
|
^ x and y position of checkbox
|
||||||
|
^ name fieldname data is transfered to lua
|
||||||
|
^ label to be shown left of checkbox
|
||||||
|
^ selected (optional) true/false
|
||||||
|
|
||||||
Note: do NOT use a element name starting with "key_" those names are reserved to
|
Note: do NOT use a element name starting with "key_" those names are reserved to
|
||||||
pass key press events to formspec!
|
pass key press events to formspec!
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user