forked from mtcontrib/pipeworks
new flow logic: abms.lua: remove intake limit coercion causing water to be vanished
This commit is contained in:
parent
9abdeb3d62
commit
dc13ec619f
@ -29,6 +29,8 @@ end
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
--local formatvec = function(vec) local sep="," return "("..tostring(vec.x)..sep..tostring(vec.y)..sep..tostring(vec.z)..")" end
|
||||||
|
|
||||||
-- new version of liquid check
|
-- new version of liquid check
|
||||||
-- accepts a limit parameter to only delete water blocks that the receptacle can accept,
|
-- accepts a limit parameter to only delete water blocks that the receptacle can accept,
|
||||||
-- and returns it so that the receptacle can update it's pressure values.
|
-- and returns it so that the receptacle can update it's pressure values.
|
||||||
@ -43,14 +45,13 @@ local check_for_liquids_v2 = function(pos, limit)
|
|||||||
total = total + 1
|
total = total + 1
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
--pipeworks.logger("check_for_liquids_v2@"..formatvec(pos).." total "..total)
|
||||||
return total
|
return total
|
||||||
end
|
end
|
||||||
flowlogic.check_for_liquids_v2 = check_for_liquids_v2
|
flowlogic.check_for_liquids_v2 = check_for_liquids_v2
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--local formatvec = function(vec) local sep="," return "("..tostring(vec.x)..sep..tostring(vec.y)..sep..tostring(vec.z)..")" end
|
|
||||||
|
|
||||||
local label_pressure = "pipeworks.water_pressure"
|
local label_pressure = "pipeworks.water_pressure"
|
||||||
flowlogic.balance_pressure = function(pos, node)
|
flowlogic.balance_pressure = function(pos, node)
|
||||||
-- debuglog("balance_pressure() "..node.name.." at "..pos.x.." "..pos.y.." "..pos.z)
|
-- debuglog("balance_pressure() "..node.name.." at "..pos.x.." "..pos.y.." "..pos.z)
|
||||||
@ -100,8 +101,8 @@ flowlogic.run_input = function(pos, node, maxpressure, intakefn)
|
|||||||
if intake_limit <= 0 then return end
|
if intake_limit <= 0 then return end
|
||||||
|
|
||||||
local actual_intake = intakefn(pos, intake_limit)
|
local actual_intake = intakefn(pos, intake_limit)
|
||||||
|
--pipeworks.logger("run_input@"..formatvec(pos).." oldpressure "..currentpressure.." intake_limit "..intake_limit.." actual_intake "..actual_intake)
|
||||||
if actual_intake <= 0 then return end
|
if actual_intake <= 0 then return end
|
||||||
if actual_intake >= intake_limit then actual_intake = intake_limit end
|
|
||||||
|
|
||||||
local newpressure = actual_intake + currentpressure
|
local newpressure = actual_intake + currentpressure
|
||||||
-- debuglog("oldpressure "..currentpressure.." intake_limit "..intake_limit.." actual_intake "..actual_intake.." newpressure "..newpressure)
|
-- debuglog("oldpressure "..currentpressure.." intake_limit "..intake_limit.." actual_intake "..actual_intake.." newpressure "..newpressure)
|
||||||
|
Loading…
Reference in New Issue
Block a user