summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorthetaepsilon-gamedev <thetaepsilon-gamedev@noreply.users.github.com>2017-10-01 21:04:07 +0100
committerthetaepsilon-gamedev <thetaepsilon-gamedev@noreply.users.github.com>2017-10-01 21:04:07 +0100
commit667eeb7d095f12d5c7e560d161697878ea485433 (patch)
treeea448da7b324c451cbd5ea1dff108ea924ae810d
parentdc13ec619f7e49b0e75f845f8baa0559a8b11936 (diff)
new flow logic: abms.lua: generalise spigot output code to support arbitary neighbour lists
-rw-r--r--devices.lua5
-rw-r--r--new_flow_logic/abms.lua44
2 files changed, 19 insertions, 30 deletions
diff --git a/devices.lua b/devices.lua
index f4f2150..d12c84a 100644
--- a/devices.lua
+++ b/devices.lua
@@ -377,8 +377,9 @@ minetest.register_node(nodename_spigot_loaded, {
new_flow_logic_register.simple(nodename_spigot_empty)
new_flow_logic_register.simple(nodename_spigot_loaded)
local spigot_min = 1
-new_flow_logic_register.output(nodename_spigot_empty, spigot_min, pipeworks.flowlogic.helpers.output_spigot)
-new_flow_logic_register.output(nodename_spigot_loaded, spigot_min, pipeworks.flowlogic.helpers.output_spigot)
+local outputfn = pipeworks.flowlogic.helpers.make_neighbour_output({{x=0, y=-1, z=0}})
+new_flow_logic_register.output(nodename_spigot_empty, spigot_min, outputfn)
+new_flow_logic_register.output(nodename_spigot_loaded, spigot_min, outputfn)
diff --git a/new_flow_logic/abms.lua b/new_flow_logic/abms.lua
index afeb3b3..a07c390 100644
--- a/new_flow_logic/abms.lua
+++ b/new_flow_logic/abms.lua
@@ -111,19 +111,23 @@ end
--- flowlogic output helper for spigots
--- tries to place a water block in the world beneath the spigot.
--- threshold checking is assumed to be handled by the node registration;
--- see register_local_pipes.lua for the pipeworks default spigot.
-flowlogic.helpers.output_spigot = function(pos, node, currentpressure)
- local taken = 0
- local below = {x=pos.x, y=pos.y-1, z=pos.z}
- local name = minetest.get_node(below).name
- if (name == "air") or (name == "default:water_flowing") then
- minetest.set_node(below, {name="default:water_source"})
- taken = taken + 1
+-- flowlogic output helper implementation:
+-- outputs water by trying to place water nodes nearby in the world.
+-- neighbours is a list of node offsets to try placing water in.
+-- this is a constructor function, returning another function which satisfies the output helper requirements.
+flowlogic.helpers.make_neighbour_output = function(neighbours)
+ return function(pos, node, currentpressure)
+ local taken = 0
+ for _, offset in pairs(neighbours) do
+ local npos = vector.add(pos, offset)
+ local name = minetest.get_node(npos).name
+ if (name == "air") or (name == "default:water_flowing") then
+ minetest.swap_node(npos, {name="default:water_source"})
+ taken = taken + 1
+ end
+ end
+ return taken
end
- return taken
end
@@ -145,19 +149,3 @@ flowlogic.run_output = function(pos, node, threshold, outputfn)
meta:set_float(label_pressure, newpressure)
end
end
-
-
-
-flowlogic.run_spigot_output = function(pos, node)
- -- try to output a water source node if there's enough pressure and space below.
- local meta = minetest.get_meta(pos)
- local currentpressure = meta:get_float(label_pressure)
- if currentpressure > 1 then
- local below = {x=pos.x, y=pos.y-1, z=pos.z}
- local name = minetest.get_node(below).name
- if (name == "air") or (name == "default:water_flowing") then
- minetest.set_node(below, {name="default:water_source"})
- meta:set_float(label_pressure, currentpressure - 1)
- end
- end
-end