summaryrefslogtreecommitdiff
path: root/node_controllers.lua
diff options
context:
space:
mode:
authorFaceDeer <derksenmobile@gmail.com>2017-01-01 00:00:24 -0700
committerFaceDeer <derksenmobile@gmail.com>2017-01-01 00:00:24 -0700
commit6c7842d92cb8a02c871c7184954e25292bf2d4b8 (patch)
tree85017a0a75af346852cd498b3abc3ca994fd11cd /node_controllers.lua
parent68e0ca21c6ff335d1b27c3bebc796de56cb2a49b (diff)
Introduced a bug with builders in the last checkin
Dumb oversight, didn't notice lazy execution of "and" here.
Diffstat (limited to 'node_controllers.lua')
-rw-r--r--node_controllers.lua8
1 files changed, 6 insertions, 2 deletions
diff --git a/node_controllers.lua b/node_controllers.lua
index e3f8ccb..fe0752c 100644
--- a/node_controllers.lua
+++ b/node_controllers.lua
@@ -191,18 +191,22 @@ minetest.register_node("digtron:controller", {
end, pos
)
+ local strange_failure = false
-- execute_build on all digtron components that have one
for k, location in pairs(layout.builders) do
local target = minetest.get_node(location)
local targetdef = minetest.registered_nodes[target.name]
if targetdef.execute_build ~= nil then
--using the old location of the controller as fallback so that any leftovers land with the rest of the digger output. Not that there should be any.
- can_build = can_build and targetdef.execute_build(location, clicker, layout.inventories, layout.protected, nodes_dug, controlling_coordinate, oldpos)
+ if targetdef.execute_build(location, clicker, layout.inventories, layout.protected, nodes_dug, controlling_coordinate, oldpos) == false then
+ -- Don't interrupt the build cycle as a whole, we've already moved so might as well try to complete as much as possible.
+ strange_failure = true
+ end
else
minetest.log(string.format("%s has builder group but is missing execute_build method! This is an error in mod programming, file a bug.", targetdef.name))
end
end
- if can_build == false then
+ if strange_failure then
-- We weren't able to detect this build failure ahead of time, so make a big noise now. This is strange, shouldn't happen often.
minetest.sound_play("dingding", {gain=1.0, pos=pos})
minetest.sound_play("buzzer", {gain=0.5, pos=pos})