summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorthetaepsilon-gamedev <thetaepsilon-gamedev@noreply.users.github.com>2017-10-16 23:27:04 +0100
committerthetaepsilon-gamedev <thetaepsilon-gamedev@noreply.users.github.com>2017-10-16 23:27:04 +0100
commitfd978204dd5c72d350ba0d31ec43c628c46599f3 (patch)
tree8d602597e4c947b2a4dfbb3ccb05ac37f3f72f6c
parente41167813ba15344e56a291f2cc03706cb62590e (diff)
new flow logic: abms.lua: use directional callback function for direcional nodes to obtain neighbour list
-rw-r--r--new_flow_logic/abms.lua17
1 files changed, 17 insertions, 0 deletions
diff --git a/new_flow_logic/abms.lua b/new_flow_logic/abms.lua
index 0b0b799..e5e2e6e 100644
--- a/new_flow_logic/abms.lua
+++ b/new_flow_logic/abms.lua
@@ -23,6 +23,16 @@ local make_coords_offsets = function(pos, include_base)
return coords
end
+-- create positions from list of offsets
+-- see in use of directional flow logic below
+local apply_coords_offsets = function(pos, offsets)
+ local result = {}
+ for index, offset in ipairs(offsets) do
+ table.insert(result, vector.add(pos, offset))
+ end
+ return result
+end
+
-- local debuglog = function(msg) print("## "..msg) end
@@ -138,6 +148,13 @@ flowlogic.balance_pressure = function(pos, node, currentpressure)
local candidates = {}
if pipeworks.flowables.list.simple[node.name] then
candidates = make_coords_offsets(pos, false)
+ else
+ -- directional flowables: call the callback to get the list
+ local directional = pipeworks.flowables.list.directional[node.name]
+ if directional then
+ local offsets = directional.neighbourfn(node)
+ candidates = apply_coords_offsets(pos, offsets)
+ end
end
-- then handle neighbours, but if not a pressure node don't consider them at all