diff options
| author | thetaepsilon-gamedev <thetaepsilon-gamedev@noreply.users.github.com> | 2017-10-01 15:18:00 +0100 | 
|---|---|---|
| committer | thetaepsilon-gamedev <thetaepsilon-gamedev@noreply.users.github.com> | 2017-10-01 15:18:00 +0100 | 
| commit | f7b17197677ea3675eee6bc667370fe3e23ac099 (patch) | |
| tree | ce982d46436cefd1ae3db287e70eb66441ba817a /new_flow_logic/flowable_node_registry_install.lua | |
| parent | 3a1edac06ce193179b58ffcd055b492839d30018 (diff) | |
new flow logic: node registry: split registration functions into seperate file to allow ABM code to inspect tables
Diffstat (limited to 'new_flow_logic/flowable_node_registry_install.lua')
| -rw-r--r-- | new_flow_logic/flowable_node_registry_install.lua | 70 | 
1 files changed, 70 insertions, 0 deletions
| diff --git a/new_flow_logic/flowable_node_registry_install.lua b/new_flow_logic/flowable_node_registry_install.lua new file mode 100644 index 0000000..06d69fd --- /dev/null +++ b/new_flow_logic/flowable_node_registry_install.lua @@ -0,0 +1,70 @@ +-- flowable node registry: add entries and install ABMs if new flow logic is enabled +-- written 2017 by thetaepsilon + + + +-- use for hooking up ABMs as nodes are registered +local abmregister = pipeworks.flowlogic.abmregister + +-- registration functions +pipeworks.flowables.register = {} +local register = pipeworks.flowables.register + +-- some sanity checking for passed args, as this could potentially be made an external API eventually +local checkexists = function(nodename) +	if type(nodename) ~= "string" then error("pipeworks.flowables nodename must be a string!") end +	return pipeworks.flowables.list.all[nodename] +end + +local insertbase = function(nodename) +	if checkexists(nodename) then error("pipeworks.flowables duplicate registration!") end +	pipeworks.flowables.list.all[nodename] = true +	-- table.insert(pipeworks.flowables.list.nodenames, nodename) +end + +-- Register a node as a simple flowable. +-- Simple flowable nodes have no considerations for direction of flow; +-- A cluster of adjacent simple flowables will happily average out in any direction. +register.simple = function(nodename) +	insertbase(nodename) +	pipeworks.flowables.list.simple[nodename] = true +	table.insert(pipeworks.flowables.list.simple_nodenames, nodename) +	if pipeworks.enable_new_flow_logic then +		abmregister.balance(nodename) +	end +end + +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. +-- 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. +-- possible WISHME here: technic-driven high-pressure pumps +register.intake_simple = function(nodename, maxpressure) +	checkbase(nodename) +	pipeworks.flowables.inputs.list[nodename] = { maxpressure=maxpressure } +	table.insert(pipeworks.flowables.inputs.nodenames, nodename) +	if pipeworks.enable_new_flow_logic then +		abmregister.input(nodename, maxpressure, pipeworks.flowlogic.check_for_liquids_v2) +	end +end + +-- Register a node as an output. +-- Expects node to already be a flowable. +-- threshold and outputfn are currently as documented for register_abm_output() in abm_register.lua. +register.output = function(nodename, threshold, outputfn) +	checkbase(nodename) +	pipeworks.flowables.outputs.list[nodename] = { threshold=threshold, outputfn=outputfn } +	if pipeworks.enable_new_flow_logic then +		abmregister.output(nodename, threshold, outputfn) +	end +end + +-- TODOs here: +-- The spigot's output behaviour (and possibly the fountain) could be abstracted out into a "simple output" of sorts, +-- which tries to place water nodes around it. +-- possibly this could be given a helper function to determine which faces a node should try, +-- to allow things like rotation or other param values determining "direction" to be respected. | 
