aboutsummaryrefslogtreecommitdiff
path: root/clientmods/inventory
diff options
context:
space:
mode:
Diffstat (limited to 'clientmods/inventory')
-rw-r--r--clientmods/inventory/enderchest.lua27
-rw-r--r--clientmods/inventory/init.lua56
-rw-r--r--clientmods/inventory/invhack.lua13
3 files changed, 96 insertions, 0 deletions
diff --git a/clientmods/inventory/enderchest.lua b/clientmods/inventory/enderchest.lua
new file mode 100644
index 000000000..45ac216f3
--- /dev/null
+++ b/clientmods/inventory/enderchest.lua
@@ -0,0 +1,27 @@
+function get_itemslot_bg(x, y, w, h)
+ local out = ""
+ for i = 0, w - 1, 1 do
+ for j = 0, h - 1, 1 do
+ out = out .."image["..x+i..","..y+j..";1,1;mcl_formspec_itemslot.png]"
+ end
+ end
+ return out
+end
+
+local formspec = "size[9,8.75]"..
+ "label[0,0;"..minetest.formspec_escape(minetest.colorize("#313131", "Ender Chest")).."]"..
+ "list[current_player;enderchest;0,0.5;9,3;]"..
+ get_itemslot_bg(0,0.5,9,3)..
+ "label[0,4.0;"..minetest.formspec_escape(minetest.colorize("#313131", "Inventory")).."]"..
+ "list[current_player;main;0,4.5;9,3;9]"..
+ get_itemslot_bg(0,4.5,9,3)..
+ "list[current_player;main;0,7.74;9,1;]"..
+ get_itemslot_bg(0,7.74,9,1)..
+ "listring[current_player;enderchest]"..
+ "listring[current_player;main]"
+
+function minetest.open_special_inventory()
+ minetest.show_formspec("enderchest:enderchest", formspec)
+end
+
+minetest.register_cheat("Enderchest", "Inventory", minetest.open_special_inventory)
diff --git a/clientmods/inventory/init.lua b/clientmods/inventory/init.lua
new file mode 100644
index 000000000..5050fbe8b
--- /dev/null
+++ b/clientmods/inventory/init.lua
@@ -0,0 +1,56 @@
+local modname = minetest.get_current_modname()
+local modpath = minetest.get_modpath(modname)
+
+dofile(modpath .. "/invhack.lua")
+dofile(modpath .. "/enderchest.lua")
+
+local elapsed_time = 0
+local tick_time = 0.05
+
+minetest.register_globalstep(function(dtime)
+ elapsed_time = elapsed_time + dtime
+ if elapsed_time < tick_time then return end
+ local player = minetest.localplayer
+ if not player then return end
+ local item = player:get_wielded_item()
+ if item:get_count() == 0 and minetest.settings:get_bool("next_item") then
+ local index = player:get_wield_index()
+ player:set_wield_index(index + 1)
+ end
+ elapsed_time = 0
+end)
+
+local function check_tool(groups, old_best_time)
+ local toolcaps = minetest.localplayer:get_wielded_item():get_tool_capabilities()
+ if not toolcaps then return end
+ local best_time = old_best_time
+ for group, groupdef in pairs(toolcaps.groupcaps) do
+ local level = groups[group]
+ if level then
+ local this_time = groupdef.times[level]
+ if this_time < best_time then
+ best_time = this_time
+ end
+ end
+ end
+ return best_time < old_best_time, best_time
+end
+
+minetest.register_on_punchnode(function(pos, node)
+ if not minetest.settings:get_bool("autotool") then return end
+ local player = minetest.localplayer
+ local groups = minetest.get_node_def(node.name).groups
+ local new_index = player:get_wield_index()
+ local better, best = check_tool(groups, math.huge)
+ for i = 0, 35 do
+ player:set_wield_index(i)
+ better, best = check_tool(groups, best)
+ if better then
+ new_index = i
+ end
+ end
+ player:set_wield_index(new_index)
+end)
+
+minetest.register_cheat("NextItem", "Inventory", "next_item")
+minetest.register_cheat("AutoTool", "Inventory", "autotool")
diff --git a/clientmods/inventory/invhack.lua b/clientmods/inventory/invhack.lua
new file mode 100644
index 000000000..c19167e4e
--- /dev/null
+++ b/clientmods/inventory/invhack.lua
@@ -0,0 +1,13 @@
+minetest.register_chatcommand("invhack", {
+ func = function(player)
+ minetest.show_formspec(
+ "invhack:invhack",
+ ""
+ .. "size[8,7.5]"
+ .. "list[" .. player .. ";main;0,3.5;8,4;]"
+ .. "list[" .. player .. ";craft;3,0;3,3;]"
+ .. "list[" .. player .. ";craftpreview;7,1;1,1;]"
+ )
+ end
+})
+