Work Table : convert repairing ABM to node timer

This commit is contained in:
Jean-Patrick Guerrero 2016-02-10 12:31:24 +01:00
parent 316af94a51
commit be813edc39

View File

@ -263,6 +263,26 @@ function worktable.dig(pos)
inv:is_empty("tool") and inv:is_empty("storage") inv:is_empty("tool") and inv:is_empty("storage")
end end
function worktable.timer(pos)
local timer = minetest.get_node_timer(pos)
local inv = minetest.get_meta(pos):get_inventory()
local tool = inv:get_stack("tool", 1)
local hammer = inv:get_stack("hammer", 1)
if tool:is_empty() or hammer:is_empty() or tool:get_wear() == 0 then
timer:stop() return
end
-- Tool's wearing range: 0-65535 | 0 = new condition.
tool:add_wear(-500)
hammer:add_wear(700)
inv:set_stack("tool", 1, tool)
inv:set_stack("hammer", 1, hammer)
return true
end
function worktable.put(_, listname, _, stack) function worktable.put(_, listname, _, stack)
local stackname = stack:get_name() local stackname = stack:get_name()
if (listname == "tool" and stack:get_wear() > 0 and if (listname == "tool" and stack:get_wear() > 0 and
@ -296,6 +316,9 @@ function worktable.on_put(pos, listname, _, stack)
worktable:get_output(inv, input, stack:get_name()) worktable:get_output(inv, input, stack:get_name())
elseif listname == "trash" then elseif listname == "trash" then
inv:set_list("trash", {}) inv:set_list("trash", {})
elseif listname == "tool" or listname == "hammer" then
local timer = minetest.get_node_timer(pos)
timer:start(1.0)
end end
end end
@ -330,6 +353,7 @@ xdecor.register("worktable", {
}, },
on_rotate = screwdriver.rotate_simple, on_rotate = screwdriver.rotate_simple,
can_dig = worktable.dig, can_dig = worktable.dig,
on_timer = worktable.timer,
on_construct = worktable.construct, on_construct = worktable.construct,
on_receive_fields = worktable.fields, on_receive_fields = worktable.fields,
on_metadata_inventory_put = worktable.on_put, on_metadata_inventory_put = worktable.on_put,
@ -384,16 +408,17 @@ for node in pairs(minetest.registered_nodes) do
end end
local T = { local T = {
{"nanoslab", nil, 2}, {"nanoslab", nil, 2 },
{"micropanel", nil, 3}, {"micropanel", nil, 3 },
{"cube", nil, 6}, {"cube", nil, 6 },
{"cube", "panel", 9}, {"cube", "panel", 9 },
{"cube", "outerstair", 11}, {"cube", "outerstair", 11 },
{"cube", "halfstair", 7}, {"cube", "halfstair", 7 },
{"cube", "innerstair", nil}, {"cube", "innerstair", nil},
{"panel", nil, 7}, {"panel", nil, 7 },
{"panel", "outerstair", 12}, {"panel", "cube", 9 },
{"halfstair", nil, 11}, {"panel", "outerstair", 12 },
{"halfstair", nil, 11 },
{"halfstair", "outerstair", nil} {"halfstair", "outerstair", nil}
} }
@ -432,20 +457,3 @@ for node in pairs(minetest.registered_nodes) do
end end
end end
minetest.register_abm({
nodenames = {"xdecor:worktable"},
interval = 3, chance = 1,
action = function(pos)
local inv = minetest.get_meta(pos):get_inventory()
local tool, hammer = inv:get_stack("tool", 1), inv:get_stack("hammer", 1)
if tool:is_empty() or hammer:is_empty() or tool:get_wear() == 0 then return end
-- Wear : 0-65535 | 0 = new condition.
tool:add_wear(-500)
hammer:add_wear(700)
inv:set_stack("tool", 1, tool)
inv:set_stack("hammer", 1, hammer)
end
})