summaryrefslogtreecommitdiff
path: root/new_flow_logic/flowable_node_registry_install.lua
diff options
context:
space:
mode:
authorthetaepsilon-gamedev <thetaepsilon-gamedev@noreply.users.github.com>2017-10-07 18:07:55 +0100
committerthetaepsilon-gamedev <thetaepsilon-gamedev@noreply.users.github.com>2017-10-07 18:07:55 +0100
commitbe1a6d53aa94f812dc661b4b08c5d0e2ebf97623 (patch)
treee5ec97f620399cc5f0b7ef4ec8b2a36f14d2e41c /new_flow_logic/flowable_node_registry_install.lua
parent65b3448796815718275ed3c16af4865e5e005454 (diff)
new flow logic: flowable_node_registry_install.lua: factor out register.intake_simple into generic registration and helper wrapper
Diffstat (limited to 'new_flow_logic/flowable_node_registry_install.lua')
-rw-r--r--new_flow_logic/flowable_node_registry_install.lua32
1 files changed, 26 insertions, 6 deletions
diff --git a/new_flow_logic/flowable_node_registry_install.lua b/new_flow_logic/flowable_node_registry_install.lua
index aed6fbd..35dbe97 100644
--- a/new_flow_logic/flowable_node_registry_install.lua
+++ b/new_flow_logic/flowable_node_registry_install.lua
@@ -45,21 +45,41 @@ local checkbase = function(nodename)
if not checkexists(nodename) then error("pipeworks.flowables node doesn't exist as a flowable!") end
end
--- Register a node as a simple intake.
+local duplicateerr = function(kind, nodename) error(kind.." duplicate registration for "..nodename) end
+
+
+
+-- Registers a node as a fluid intake.
+-- intakefn is used to determine the water that can be taken in a node-specific way.
-- Expects node to be registered as a flowable (is present in flowables.list.all),
-- so that water can move out of it.
--- maxpressure is the maximum pipeline pressure that this node can drive.
+-- maxpressure is the maximum pipeline pressure that this node can drive;
+-- if the input's node exceeds this the callback is not run.
-- possible WISHME here: technic-driven high-pressure pumps
-register.intake_simple = function(nodename, maxpressure)
+register.intake = function(nodename, maxpressure, intakefn)
+ -- check for duplicate registration of this node
+ local list = pipeworks.flowables.inputs.list
checkbase(nodename)
- pipeworks.flowables.inputs.list[nodename] = { maxpressure=maxpressure }
+ if list[nodename] then duplicateerr("pipeworks.flowables.inputs", nodename) end
+ list[nodename] = { maxpressure=maxpressure, intakefn=intakefn }
table.insert(pipeworks.flowables.inputs.nodenames, nodename)
if pipeworks.toggles.pressure_logic then
- abmregister.input(nodename, maxpressure, pipeworks.flowlogic.check_for_liquids_v2)
+ abmregister.input(nodename, maxpressure, intakefn)
end
- regwarning("simple intake", nodename)
+ regwarning("intake", nodename)
end
+
+
+-- Register a node as a simple intake:
+-- tries to absorb water source nodes from it's surroundings.
+-- may exceed limit slightly due to needing to absorb whole nodes.
+register.intake_simple = function(nodename, maxpressure)
+ register.intake(nodename, maxpressure, pipeworks.flowlogic.check_for_liquids_v2)
+end
+
+
+
-- Register a node as an output.
-- Expects node to already be a flowable.
-- upper and lower thresholds have different meanings depending on whether finite liquid mode is in effect.