-local rope_sbox = {
- type = "fixed",
- fixed = {-0.15, -0.5, -0.15, 0.15, 0.5, 0.15}
-}
+local rope = {}
-- Code by Mirko K. (modified by Temperest, Wulfsdad and kilbith) (License: GPL).
minetest.register_on_punchnode(function(pos, oldnode, digger)
if oldnode.name == "xdecor:rope" then
- remove_rope(pos, oldnode, digger, "xdecor:rope")
+ rope:remove(pos, oldnode, digger, "xdecor:rope")
end
end)
-local function place_rope(itemstack, placer, pointed_thing)
+function rope.place(itemstack, _, pointed_thing)
if pointed_thing.type == "node" then
local under = pointed_thing.under
local above = pointed_thing.above
return itemstack
end
-function remove_rope(pos, oldnode, digger, rope_name)
+function rope:remove(pos, oldnode, digger, rope_name)
local num = 0
local below = {x=pos.x, y=pos.y, z=pos.z}
local digger_inv = digger:get_inventory()
below.y = below.y - 1
num = num + 1
end
- if num ~= 0 then
- digger_inv:add_item("main", rope_name.." "..num)
- end
+ if num == 0 then return end
+ digger_inv:add_item("main", rope_name.." "..num)
return true
end
walkable = false,
climbable = true,
groups = {dig_immediate=3, flammable=3},
- selection_box = rope_sbox,
tiles = {"xdecor_rope.png"},
inventory_image = "xdecor_rope_inv.png",
wield_image = "xdecor_rope_inv.png",
- on_place = place_rope
+ selection_box = xdecor.pixelbox(8, {{3, 0, 3, 2, 8, 2}}),
+ on_place = rope.place
})