forked from mtcontrib/pipeworks
new_flow_logic/flowable_node_registry.lua: integrate existing ABM registration from register_local_pipes.lua
This commit is contained in:
parent
31741e33e2
commit
ec9cf1df50
@ -1,6 +1,9 @@
|
|||||||
-- registration code for nodes under new flow logic
|
-- registration code for nodes under new flow logic
|
||||||
-- written 2017 by thetaepsilon
|
-- written 2017 by thetaepsilon
|
||||||
|
|
||||||
|
-- use for hooking up ABMs as nodes are registered
|
||||||
|
local abmregister = pipeworks.flowlogic.abmregister
|
||||||
|
|
||||||
pipeworks.flowables = {}
|
pipeworks.flowables = {}
|
||||||
pipeworks.flowables.list = {}
|
pipeworks.flowables.list = {}
|
||||||
pipeworks.flowables.list.all = {}
|
pipeworks.flowables.list.all = {}
|
||||||
@ -34,12 +37,13 @@ end
|
|||||||
-- Register a node as a simple flowable.
|
-- Register a node as a simple flowable.
|
||||||
-- Simple flowable nodes have no considerations for direction of flow;
|
-- Simple flowable nodes have no considerations for direction of flow;
|
||||||
-- A cluster of adjacent simple flowables will happily average out in any direction.
|
-- A cluster of adjacent simple flowables will happily average out in any direction.
|
||||||
-- This does *not* register the ABM, as that is done in register_flow_logic.lua;
|
|
||||||
-- this is so that the new flow logic can remain optional during development.
|
|
||||||
register.simple = function(nodename)
|
register.simple = function(nodename)
|
||||||
insertbase(nodename)
|
insertbase(nodename)
|
||||||
pipeworks.flowables.list.simple[nodename] = true
|
pipeworks.flowables.list.simple[nodename] = true
|
||||||
table.insert(pipeworks.flowables.list.simple_nodenames, nodename)
|
table.insert(pipeworks.flowables.list.simple_nodenames, nodename)
|
||||||
|
if pipeworks.enable_new_flow_logic then
|
||||||
|
abmregister.balance(nodename)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local checkbase = function(nodename)
|
local checkbase = function(nodename)
|
||||||
@ -56,4 +60,7 @@ register.intake_simple = function(nodename, maxpressure)
|
|||||||
checkbase(nodename)
|
checkbase(nodename)
|
||||||
pipeworks.flowables.inputs.list[nodename] = { maxpressure=maxpressure }
|
pipeworks.flowables.inputs.list[nodename] = { maxpressure=maxpressure }
|
||||||
table.insert(pipeworks.flowables.inputs.nodenames, nodename)
|
table.insert(pipeworks.flowables.inputs.nodenames, nodename)
|
||||||
|
if pipeworks.enable_new_flow_logic then
|
||||||
|
abmregister.input(nodename, maxpressure)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
@ -16,7 +16,6 @@ local pipes_full_nodenames = pipeworks.pipes_full_nodenames
|
|||||||
local pipes_empty_nodenames = pipeworks.pipes_empty_nodenames
|
local pipes_empty_nodenames = pipeworks.pipes_empty_nodenames
|
||||||
|
|
||||||
local register = pipeworks.flowables.register
|
local register = pipeworks.flowables.register
|
||||||
local abmregister = pipeworks.flowlogic.abmregister
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -42,12 +41,7 @@ if pipeworks.enable_pipes then
|
|||||||
register.simple(pump_on)
|
register.simple(pump_on)
|
||||||
register.simple(spigot_on)
|
register.simple(spigot_on)
|
||||||
register.simple(spigot_off)
|
register.simple(spigot_off)
|
||||||
abmregister.balance(pump_off)
|
|
||||||
abmregister.balance(pump_on)
|
|
||||||
abmregister.balance(spigot_on)
|
|
||||||
abmregister.balance(spigot_off)
|
|
||||||
|
|
||||||
register.intake_simple(pump_on, thresholds.pump_pressure)
|
register.intake_simple(pump_on, thresholds.pump_pressure)
|
||||||
abmregister.input(pump_on, thresholds.pump_pressure)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user