Fluid transfer! Works with melterns \(soon\)!
This commit is contained in:
parent
cc4da83761
commit
3ac8b48759
@ -8,7 +8,7 @@ A new *powerful* modpack for [Minetest](http://minetest.net)!
|
|||||||
### Universal Electric Power API
|
### Universal Electric Power API
|
||||||
How is this any different from technic I hear you asking? Well, first of all, I have eliminated the concept of "tiers" in the **technic** sense, as all types of machines will now be accepting any conduit. Machines can be upgraded for speed and efficiency.
|
How is this any different from technic I hear you asking? Well, first of all, I have eliminated the concept of "tiers" in the **technic** sense, as all types of machines will now be accepting any conduit. Machines can be upgraded for speed and efficiency.
|
||||||
|
|
||||||
### (Planned) Universal Fluid Transfer API
|
### Universal Fluid Transfer API
|
||||||
Exactly what it sounds like. Pipeworks failed to do this.
|
Exactly what it sounds like. Pipeworks failed to do this.
|
||||||
|
|
||||||
### (Planned) Universal Item Transfer API
|
### (Planned) Universal Item Transfer API
|
||||||
|
@ -0,0 +1,156 @@
|
|||||||
|
-- This API is compatible with fluidity.
|
||||||
|
local fluidmod = minetest.get_modpath("fluidity") ~= nil
|
||||||
|
|
||||||
|
local function node_data(pos)
|
||||||
|
local node = minetest.get_node(pos)
|
||||||
|
local nodedef = minetest.registered_nodes[node.name]
|
||||||
|
return node, nodedef
|
||||||
|
end
|
||||||
|
|
||||||
|
function elefluid.get_node_buffers(pos)
|
||||||
|
local node, nodedef = node_data(pos)
|
||||||
|
if not nodedef['ele_fluid_container'] and not ele.helpers.get_item_group(node.name, "fluidity_tank") then
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
|
||||||
|
if fluidmod and ele.helpers.get_item_group(node.name, "fluidity_tank") then
|
||||||
|
return {fluidity = {}}
|
||||||
|
end
|
||||||
|
|
||||||
|
return nodedef['ele_fluid_container']
|
||||||
|
end
|
||||||
|
|
||||||
|
function elefluid.get_buffer_data(pos, buffer)
|
||||||
|
local node, nodedef = node_data(pos)
|
||||||
|
local buffers = elefluid.get_node_buffers(pos)
|
||||||
|
|
||||||
|
if not buffers[buffer] then
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local fluid = meta:get_string(buffer .. "_fluid")
|
||||||
|
local amount = meta:get_string(buffer .. "_fluid_storage")
|
||||||
|
local capacity = buffers[buffer].capacity
|
||||||
|
local accepts = buffers[buffer].accepts
|
||||||
|
|
||||||
|
-- Fluidity tanks compatibility
|
||||||
|
if buffer == "fluidity" then
|
||||||
|
local ffluid, fluidcount, fcapacity, fbasetank, fmod = fluidity.tanks.get_tank_at(pos)
|
||||||
|
|
||||||
|
fluid = ffluid
|
||||||
|
amount = fluidcount
|
||||||
|
accepts = true
|
||||||
|
capacity = fcapacity
|
||||||
|
end
|
||||||
|
|
||||||
|
return {
|
||||||
|
fluid = fluid,
|
||||||
|
amount = amount,
|
||||||
|
accepts = accepts,
|
||||||
|
capacity = capacity,
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
function elefluid.buffer_accepts_fluid(pos, buffer, fluid)
|
||||||
|
local bfdata = elefluid.get_buffer_data(pos, buffer)
|
||||||
|
if not bfdata then return false end
|
||||||
|
|
||||||
|
if bfdata.accepts == true or bfdata.accepts == fluid then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
if type(bfdata.accepts) ~= "table" then
|
||||||
|
bfdata.accepts = { bfdata.accepts }
|
||||||
|
end
|
||||||
|
|
||||||
|
for _,pf in pairs(bfdata.accepts) do
|
||||||
|
if pf == fluid then
|
||||||
|
return true
|
||||||
|
elseif pf:match("^group") and ele.helpers.get_item_group(fluid, pf) then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
function elefluid.can_insert_into_buffer(pos, buffer, fluid, count)
|
||||||
|
local bfdata = elefluid.get_buffer_data(pos, buffer)
|
||||||
|
if not bfdata then return nil end
|
||||||
|
if bfdata.fluid ~= fluid and bfdata.fluid ~= "" then return nil end
|
||||||
|
|
||||||
|
local can_put = 0
|
||||||
|
if bfdata.amount + count > bfdata.capacity then
|
||||||
|
can_put = bfdata.capacity - bfdata.amount
|
||||||
|
else
|
||||||
|
can_put = count
|
||||||
|
end
|
||||||
|
|
||||||
|
return can_put
|
||||||
|
end
|
||||||
|
|
||||||
|
function elefluid.insert_into_buffer(pos, buffer, fluid, count)
|
||||||
|
local bfdata = elefluid.get_buffer_data(pos, buffer)
|
||||||
|
if not bfdata then return nil end
|
||||||
|
if bfdata.fluid ~= fluid and bfdata.fluid ~= "" then return nil end
|
||||||
|
|
||||||
|
local can_put = elefluid.can_insert_into_buffer(pos, buffer, fluid, count)
|
||||||
|
|
||||||
|
if can_put == 0 then return count end
|
||||||
|
|
||||||
|
if buffer == "fluidity" then
|
||||||
|
return fluidity.tanks.fill_tank_at(pos, fluid, count, true)
|
||||||
|
end
|
||||||
|
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
meta:set_int(buffer .. "_fluid_storage", bfdata.amount + can_put)
|
||||||
|
meta:set_string(buffer .. "_fluid", fluid)
|
||||||
|
|
||||||
|
return 0
|
||||||
|
end
|
||||||
|
|
||||||
|
function elefluid.can_take_from_buffer(pos, buffer, count)
|
||||||
|
local bfdata = elefluid.get_buffer_data(pos, buffer)
|
||||||
|
if not bfdata then return nil end
|
||||||
|
|
||||||
|
local amount = bfdata.amount
|
||||||
|
local take_count = 0
|
||||||
|
|
||||||
|
if amount < count then
|
||||||
|
take_count = amount
|
||||||
|
else
|
||||||
|
take_count = count
|
||||||
|
end
|
||||||
|
|
||||||
|
return take_count
|
||||||
|
end
|
||||||
|
|
||||||
|
function elefluid.take_from_buffer(pos, buffer, count)
|
||||||
|
local bfdata = elefluid.get_buffer_data(pos, buffer)
|
||||||
|
if not bfdata then return nil end
|
||||||
|
|
||||||
|
local fluid = bfdata.fluid
|
||||||
|
local amount = bfdata.amount
|
||||||
|
|
||||||
|
local take_count = elefluid.can_take_from_buffer(pos, buffer, count)
|
||||||
|
|
||||||
|
if buffer == "fluidity" then
|
||||||
|
local fname, cf = fluidity.tanks.take_from_tank_at(pos, count, true)
|
||||||
|
if cf then
|
||||||
|
count = count - cf
|
||||||
|
end
|
||||||
|
return fname, count
|
||||||
|
end
|
||||||
|
|
||||||
|
local new_storage = amount - take_count
|
||||||
|
if new_storage == 0 then
|
||||||
|
fluid = ""
|
||||||
|
end
|
||||||
|
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
meta:set_int(buffer .. "_fluid_storage", new_storage)
|
||||||
|
meta:set_string(buffer .. "_fluid", fluid)
|
||||||
|
|
||||||
|
return fluid, take_count
|
||||||
|
end
|
@ -3,8 +3,6 @@
|
|||||||
-- Network cache
|
-- Network cache
|
||||||
elefluid.graphcache = {nodes = {}}
|
elefluid.graphcache = {nodes = {}}
|
||||||
|
|
||||||
local fluidmod = minetest.get_modpath("fluidity") ~= nil
|
|
||||||
|
|
||||||
---------------------
|
---------------------
|
||||||
-- Graph Functions --
|
-- Graph Functions --
|
||||||
---------------------
|
---------------------
|
||||||
@ -41,7 +39,8 @@ local function check_node(targets, all_nodes, pos, p_pos, pnodeid, queue)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
if not ele.helpers.get_item_group(node.name, "ele_fluid_container") then
|
if not ele.helpers.get_item_group(node.name, "ele_fluid_container") and
|
||||||
|
not ele.helpers.get_item_group(node.name, "fluidity_tank") then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -87,7 +86,8 @@ local function fluid_targets(p_pos, positions)
|
|||||||
local node = minetest.get_node(pos)
|
local node = minetest.get_node(pos)
|
||||||
if node and ele.helpers.get_item_group(node.name, "elefluid_transport") then
|
if node and ele.helpers.get_item_group(node.name, "elefluid_transport") then
|
||||||
add_duct_node(all_nodes, pos, pnodeid, queue)
|
add_duct_node(all_nodes, pos, pnodeid, queue)
|
||||||
elseif node and ele.helpers.get_item_group(node.name, "ele_fluid_container") then
|
elseif node and (ele.helpers.get_item_group(node.name, "ele_fluid_container") or
|
||||||
|
ele.helpers.get_item_group(node.name, "fluidity_tank")) then
|
||||||
queue = {p_pos}
|
queue = {p_pos}
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -178,13 +178,14 @@ minetest.register_abm({
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- Make sure source node is a registered fluid container
|
-- Make sure source node is a registered fluid container
|
||||||
if not ele.helpers.get_item_group(srcnode.name, "ele_fluid_container") then
|
if not ele.helpers.get_item_group(srcnode.name, "ele_fluid_container") and
|
||||||
|
not ele.helpers.get_item_group(srcnode.name, "fluidity_tank") then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local srcmeta = minetest.get_meta(srcpos)
|
local srcmeta = minetest.get_meta(srcpos)
|
||||||
local srcdef = minetest.registered_nodes[srcnode.name]
|
local srcdef = minetest.registered_nodes[srcnode.name]
|
||||||
local buffers = srcdef['ele_fluid_buffers']
|
local buffers = elefluid.get_node_buffers(srcpos)
|
||||||
if not buffers then return nil end
|
if not buffers then return nil end
|
||||||
|
|
||||||
local pcapability = ele.helpers.get_node_property(meta, pos, "fluid_pump_capacity")
|
local pcapability = ele.helpers.get_node_property(meta, pos, "fluid_pump_capacity")
|
||||||
@ -192,64 +193,28 @@ minetest.register_abm({
|
|||||||
-- Transfer some fluid here
|
-- Transfer some fluid here
|
||||||
for _,pos in pairs(targets) do
|
for _,pos in pairs(targets) do
|
||||||
if not vector.equals(pos, srcpos) then
|
if not vector.equals(pos, srcpos) then
|
||||||
local nm = minetest.get_meta(pos)
|
local pp = elefluid.get_node_buffers(pos)
|
||||||
local nd = minetest.get_node(pos)
|
|
||||||
local nc = minetest.registered_nodes[nd.name]
|
|
||||||
local pp = nc['ele_fluid_buffers']
|
|
||||||
|
|
||||||
local changed = false
|
local changed = false
|
||||||
|
|
||||||
if pp ~= nil then
|
if pp ~= nil then
|
||||||
for name, data in pairs(pp) do
|
for name in pairs(pp) do
|
||||||
for bname, buf in pairs(buffers) do
|
for bname in pairs(buffers) do
|
||||||
local target_fluid = nm:get_string(name.."_fluid")
|
local buffer_data = elefluid.get_buffer_data(srcpos, bname)
|
||||||
local buffer_fluid = srcmeta:get_string(bname.."_fluid")
|
local target_data = elefluid.get_buffer_data(pos, name)
|
||||||
|
|
||||||
local target_count = nm:get_int(name.."_fluid_storage")
|
if (target_data.fluid == buffer_data.fluid or target_data.fluid == "") and
|
||||||
local buffer_count = srcmeta:get_int(bname.."_fluid_storage")
|
buffer_data.fluid ~= "" and buffer_data.amount > 0 and
|
||||||
|
elefluid.buffer_accepts_fluid(pos, name, buffer_data.fluid) then
|
||||||
|
|
||||||
local apply = false
|
if elefluid.can_insert_into_buffer(pos, name, buffer_data.fluid, pcapability) > 0 then
|
||||||
|
local res_f, count = elefluid.take_from_buffer(srcpos, bname, pcapability)
|
||||||
if (target_fluid == buffer_fluid or target_fluid == "") and buffer_fluid ~= "" and buffer_count > 0 and
|
if count > 0 then
|
||||||
(data.accepts == true or data.accepts == buffer_fluid) then
|
elefluid.insert_into_buffer(pos, name, res_f, count)
|
||||||
local can_transfer_amnt = 0
|
changed = true
|
||||||
if buffer_count > pcapability then
|
|
||||||
can_transfer_amnt = pcapability
|
|
||||||
else
|
|
||||||
can_transfer_amnt = buffer_count
|
|
||||||
end
|
|
||||||
|
|
||||||
if can_transfer_amnt > 0 then
|
|
||||||
local can_accept_amnt = 0
|
|
||||||
if target_count + can_transfer_amnt > data.capacity then
|
|
||||||
can_accept_amnt = data.capacity - target_count
|
|
||||||
else
|
|
||||||
can_accept_amnt = can_transfer_amnt
|
|
||||||
end
|
|
||||||
|
|
||||||
if can_accept_amnt > 0 then
|
|
||||||
target_count = target_count + can_accept_amnt
|
|
||||||
target_fluid = buffer_fluid
|
|
||||||
buffer_count = buffer_count - can_accept_amnt
|
|
||||||
|
|
||||||
if buffer_count == 0 then
|
|
||||||
buffer_fluid = ""
|
|
||||||
end
|
|
||||||
|
|
||||||
apply = true
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if apply then
|
|
||||||
nm:set_string(name.."_fluid", target_fluid)
|
|
||||||
srcmeta:set_string(bname.."_fluid", buffer_fluid)
|
|
||||||
|
|
||||||
nm:set_int(name.."_fluid_storage", target_count)
|
|
||||||
srcmeta:set_string(bname.."_fluid_storage", buffer_count)
|
|
||||||
|
|
||||||
changed = true
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -277,7 +242,8 @@ local function check_connections(pos)
|
|||||||
local name = minetest.get_node(connected_pos).name
|
local name = minetest.get_node(connected_pos).name
|
||||||
if ele.helpers.get_item_group(name, "elefluid_transport") or
|
if ele.helpers.get_item_group(name, "elefluid_transport") or
|
||||||
ele.helpers.get_item_group(name, "ele_fluid_container") or
|
ele.helpers.get_item_group(name, "ele_fluid_container") or
|
||||||
ele.helpers.get_item_group(name, "elefluid_transport_source") then
|
ele.helpers.get_item_group(name, "elefluid_transport_source") or
|
||||||
|
ele.helpers.get_item_group(name, "fluidity_tank") then
|
||||||
table.insert(connections, connected_pos)
|
table.insert(connections, connected_pos)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -318,7 +284,8 @@ function elefluid.clear_networks(pos)
|
|||||||
table.insert(network.all_nodes, pos)
|
table.insert(network.all_nodes, pos)
|
||||||
end
|
end
|
||||||
|
|
||||||
if ele.helpers.get_item_group(name, "ele_fluid_container") then
|
if ele.helpers.get_item_group(name, "ele_fluid_container") or
|
||||||
|
ele.helpers.get_item_group(name, "fluidity_tank") then
|
||||||
meta:set_string("ele_network", network_id)
|
meta:set_string("ele_network", network_id)
|
||||||
table.insert(network.targets, pos)
|
table.insert(network.targets, pos)
|
||||||
end
|
end
|
||||||
|
@ -82,6 +82,7 @@ function elefluid.register_transfer_duct(nodename, nodedef)
|
|||||||
"group:elefluid_transport",
|
"group:elefluid_transport",
|
||||||
"group:elefluid_transport_source",
|
"group:elefluid_transport_source",
|
||||||
"group:ele_fluid_container",
|
"group:ele_fluid_container",
|
||||||
|
"group:fluidity_tank"
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user