diff options
author | Vanessa Ezekowitz <vanessaezekowitz@gmail.com> | 2017-03-17 11:04:59 -0400 |
---|---|---|
committer | Vanessa Ezekowitz <vanessaezekowitz@gmail.com> | 2017-03-17 11:04:59 -0400 |
commit | 64b2611d8adbbc07bb92315eca9d71b74ea51756 (patch) | |
tree | 124e48b2d6b6de84e7d158f34d3d053f0e10be47 | |
parent | 1bfc2d4e5b19b643190c4996b458eb3d63f8152c (diff) |
prevent being able to place "loaded" and "on" items
(forces them to "empty" and "off")
-rw-r--r-- | devices.lua | 24 | ||||
-rw-r--r-- | pipes.lua | 1 |
2 files changed, 6 insertions, 19 deletions
diff --git a/devices.lua b/devices.lua index b64fe5e..4b7f574 100644 --- a/devices.lua +++ b/devices.lua @@ -65,7 +65,9 @@ function pipeworks.rotate_on_place(itemstack, placer, pointed_thing) if minetest.registered_nodes[minetest.get_node(pos1).name] and not minetest.registered_nodes[minetest.get_node(pos1).name]["buildable_to"] then return end - local placednode = itemstack:get_name() + local placednode = string.gsub(itemstack:get_name(), "_loaded", "_empty") + placednode = string.gsub(placednode, "_on", "_off") + minetest.add_node(pos1, {name = placednode, param2 = fdir }) pipeworks.scan_for_pipe_objects(pos1) @@ -179,9 +181,6 @@ for s in ipairs(states) do sounds = default.node_sound_wood_defaults(), walkable = true, on_place = pipeworks.rotate_on_place, - after_place_node = function(pos) - pipeworks.scan_for_pipe_objects(pos) - end, after_dig_node = function(pos) pipeworks.scan_for_pipe_objects(pos) end, @@ -222,9 +221,6 @@ minetest.register_node("pipeworks:valve_on_loaded", { sounds = default.node_sound_wood_defaults(), walkable = true, on_place = pipeworks.rotate_on_place, - after_place_node = function(pos) - pipeworks.scan_for_pipe_objects(pos) - end, after_dig_node = function(pos) pipeworks.scan_for_pipe_objects(pos) end, @@ -323,6 +319,7 @@ minetest.register_node("pipeworks:spigot_pouring", { sounds = default.node_sound_wood_defaults(), walkable = true, after_place_node = function(pos) + minetest.set_node(pos, { name = "pipeworks:spigot", param2 = minetest.get_node(pos).param2 }) pipeworks.scan_for_pipe_objects(pos) end, after_dig_node = function(pos) @@ -362,9 +359,6 @@ minetest.register_node("pipeworks:entry_panel_empty", { sounds = default.node_sound_wood_defaults(), walkable = true, on_place = pipeworks.rotate_on_place, - after_place_node = function(pos) - pipeworks.scan_for_pipe_objects(pos) - end, after_dig_node = function(pos) pipeworks.scan_for_pipe_objects(pos) end, @@ -384,9 +378,6 @@ minetest.register_node("pipeworks:entry_panel_loaded", { sounds = default.node_sound_wood_defaults(), walkable = true, on_place = pipeworks.rotate_on_place, - after_place_node = function(pos) - pipeworks.scan_for_pipe_objects(pos) - end, after_dig_node = function(pos) pipeworks.scan_for_pipe_objects(pos) end, @@ -408,9 +399,6 @@ minetest.register_node("pipeworks:flow_sensor_empty", { sounds = default.node_sound_wood_defaults(), walkable = true, on_place = pipeworks.rotate_on_place, - after_place_node = function(pos) - pipeworks.scan_for_pipe_objects(pos) - end, after_dig_node = function(pos) pipeworks.scan_for_pipe_objects(pos) end, @@ -449,9 +437,6 @@ minetest.register_node("pipeworks:flow_sensor_loaded", { sounds = default.node_sound_wood_defaults(), walkable = true, on_place = pipeworks.rotate_on_place, - after_place_node = function(pos) - pipeworks.scan_for_pipe_objects(pos) - end, after_dig_node = function(pos) pipeworks.scan_for_pipe_objects(pos) end, @@ -592,6 +577,7 @@ minetest.register_node("pipeworks:fountainhead_pouring", { sounds = default.node_sound_wood_defaults(), walkable = true, after_place_node = function(pos) + minetest.set_node(pos, { name = "pipeworks:fountainhead", param2 = minetest.get_node(pos).param2 }) pipeworks.scan_for_pipe_objects(pos) end, after_dig_node = function(pos) @@ -107,6 +107,7 @@ for index, connects in ipairs(cconnects) do walkable = true, drop = "pipeworks:pipe_1_empty", after_place_node = function(pos) + minetest.set_node(pos, { name = "pipeworks:pipe_"..index.."_empty" }) pipeworks.scan_for_pipe_objects(pos) end, after_dig_node = function(pos) |