new flow logic: abm_register.lua: add extra safeguarding for conditional activation of new flow logic

This commit is contained in:
thetaepsilon-gamedev 2017-10-08 19:11:58 +01:00
parent 084174123d
commit 72f793e2b3

View File

@ -1,23 +1,16 @@
-- register new flow logic ABMs -- register new flow logic ABMs
-- written 2017 by thetaepsilon -- written 2017 by thetaepsilon
local register = {} local register = {}
pipeworks.flowlogic.abmregister = register pipeworks.flowlogic.abmregister = register
local flowlogic = pipeworks.flowlogic local flowlogic = pipeworks.flowlogic
-- A possible DRY violation here...
-- DISCUSS: should it be possible later on to raise the the rate of ABMs, or lower the chance?
-- Currently all the intervals and chances are hardcoded below.
-- register node list for the main logic function. -- register node list for the main logic function.
-- see flowlogic.run() in abms.lua. -- see flowlogic.run() in abms.lua.
local register_flowlogic_abm = function(nodename) local register_flowlogic_abm = function(nodename)
if pipeworks.toggles.pressure_logic then
minetest.register_abm({ minetest.register_abm({
nodenames = { nodename }, nodenames = { nodename },
interval = 1, interval = 1,
@ -26,5 +19,8 @@ local register_flowlogic_abm = function(nodename)
flowlogic.run(pos, node) flowlogic.run(pos, node)
end end
}) })
else
minetest.log("warning", "pipeworks pressure_logic not enabled but register.flowlogic() requested")
end
end end
register.flowlogic = register_flowlogic_abm register.flowlogic = register_flowlogic_abm