diff options
author | Maciej Kasatkin <mk@realbadangel.pl> | 2012-09-13 09:14:29 +0200 |
---|---|---|
committer | Maciej Kasatkin <mk@realbadangel.pl> | 2012-09-13 09:14:29 +0200 |
commit | 80b5f39b63a68ca61113c4266fa56e3368763a33 (patch) | |
tree | 33c788a8ec9d814e72433c1e559c1360c788a019 /screwdriver.lua | |
parent | 14506c477ac69150fd37c80e1571e80fc0ce34fc (diff) |
Added NodeBreaker, Fixes to screwdrivers, added mesecons dep
Diffstat (limited to 'screwdriver.lua')
-rw-r--r-- | screwdriver.lua | 41 |
1 files changed, 25 insertions, 16 deletions
diff --git a/screwdriver.lua b/screwdriver.lua index d58d11a..0b81217 100644 --- a/screwdriver.lua +++ b/screwdriver.lua @@ -1,34 +1,43 @@ - minetest.register_tool("technic:screwdriver", { + minetest.register_tool("technic:screwdriver", { description = "Screwdriver", inventory_image = "technic_screwdriver.png", on_use = function(itemstack, user, pointed_thing) -- Must be pointing to facedir applicable node if pointed_thing.type~="node" then return end - local pos=minetest.get_pointed_thing_position(pointed_thing,above) - local node=minetest.env:get_node(pos) - local node_name=node.name - if node.param2==nil then return end - -- Get ready to set the param2 + local pos=minetest.get_pointed_thing_position(pointed_thing,above) + local node=minetest.env:get_node(pos) + local node_name=node.name + if minetest.registered_nodes[node_name].paramtype2 == "facedir" or minetest.registered_nodes[node_name].paramtype2 == "wallmounted" then + if node.param2==nil then return end + -- Get ready to set the param2 local n = node.param2 + if minetest.registered_nodes[node_name].paramtype2 == "facedir" then n = n+1 if n == 4 then n = 0 end + else + n = n+1 + if n == 6 then n = 0 end + end -- hacky_swap_node, unforunatly. local meta = minetest.env:get_meta(pos) local meta0 = meta:to_table() node.param2 = n - minetest.env:set_node(pos,node) + minetest.env:set_node(pos,node) meta = minetest.env:get_meta(pos) meta:from_table(meta0) - local item=itemstack:to_table() - local item_wear=tonumber((item["wear"])) - item_wear=item_wear+819 - if item_wear>65535 then itemstack:clear() return itemstack end - item["wear"]=tostring(item_wear) - itemstack:replace(item) - return itemstack - end, + local item=itemstack:to_table() + local item_wear=tonumber((item["wear"])) + item_wear=item_wear+819 + if item_wear>65535 then itemstack:clear() return itemstack end + item["wear"]=tostring(item_wear) + itemstack:replace(item) + return itemstack + else + return itemstack + end + end, }) - + minetest.register_craft({ output = "technic:screwdriver", recipe = { |