forked from mtcontrib/pipeworks
new flow logic: flowable_node_registry_install.lua: add cleanupfn argument to register.output()
This commit is contained in:
parent
187e755aa5
commit
453a114cd0
@ -86,12 +86,17 @@ end
|
|||||||
-- the upper and lower difference acts as a hysteresis to try and avoid "gaps" in the flow.
|
-- the upper and lower difference acts as a hysteresis to try and avoid "gaps" in the flow.
|
||||||
-- if finite mode is on, upper is ignored and lower is used to determine whether to run outputfn;
|
-- if finite mode is on, upper is ignored and lower is used to determine whether to run outputfn;
|
||||||
-- cleanupfn is ignored in this mode as finite mode assumes something causes water to move itself.
|
-- cleanupfn is ignored in this mode as finite mode assumes something causes water to move itself.
|
||||||
register.output = function(nodename, upper, lower, outputfn)
|
register.output = function(nodename, upper, lower, outputfn, cleanupfn)
|
||||||
if pipeworks.flowables.outputs.list[nodename] then
|
if pipeworks.flowables.outputs.list[nodename] then
|
||||||
error("pipeworks.flowables.outputs duplicate registration!")
|
error("pipeworks.flowables.outputs duplicate registration!")
|
||||||
end
|
end
|
||||||
checkbase(nodename)
|
checkbase(nodename)
|
||||||
pipeworks.flowables.outputs.list[nodename] = { upper=upper, lower=lower, outputfn=outputfn }
|
pipeworks.flowables.outputs.list[nodename] = {
|
||||||
|
upper=upper,
|
||||||
|
lower=lower,
|
||||||
|
outputfn=outputfn,
|
||||||
|
cleanupfn=cleanupfn,
|
||||||
|
}
|
||||||
-- output ABM now part of main flow logic ABM to preserve ordering.
|
-- output ABM now part of main flow logic ABM to preserve ordering.
|
||||||
-- note that because outputs have to be a flowable first
|
-- note that because outputs have to be a flowable first
|
||||||
-- (and the installation of the flow logic ABM is conditional),
|
-- (and the installation of the flow logic ABM is conditional),
|
||||||
@ -112,5 +117,6 @@ end
|
|||||||
-- but only drains pressure when water source nodes are actually placed.
|
-- but only drains pressure when water source nodes are actually placed.
|
||||||
register.output_simple = function(nodename, upper, lower, neighbours)
|
register.output_simple = function(nodename, upper, lower, neighbours)
|
||||||
local outputfn = pipeworks.flowlogic.helpers.make_neighbour_output_fixed(neighbours)
|
local outputfn = pipeworks.flowlogic.helpers.make_neighbour_output_fixed(neighbours)
|
||||||
register.output(nodename, upper, lower, outputfn)
|
local cleanupfn = pipeworks.flowlogic.helpers.make_neighbour_cleanup_fixed(neighbours)
|
||||||
|
register.output(nodename, upper, lower, outputfn, cleanupfn)
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user