2019-05-01 13:20:09 +02:00
|
|
|
--- Microexpansion network
|
|
|
|
-- @type network
|
|
|
|
-- @field #table controller_pos the position of the controller
|
|
|
|
-- @field #number power_load the power currently provided to the network
|
|
|
|
-- @field #number power_storage the power that can be stored for the next tick
|
|
|
|
local network = {
|
|
|
|
power_load = 0,
|
2019-05-07 17:49:26 +02:00
|
|
|
power_storage = 0
|
2019-05-01 13:20:09 +02:00
|
|
|
}
|
|
|
|
microexpansion.network = network
|
|
|
|
|
|
|
|
--- construct a new network
|
|
|
|
-- @function [parent=#network] new
|
|
|
|
-- @param #table o the object to become a network or nil
|
2019-05-07 17:49:26 +02:00
|
|
|
-- @return #table the new network object
|
2019-05-01 13:20:09 +02:00
|
|
|
function network:new(o)
|
2019-05-07 17:49:26 +02:00
|
|
|
return setmetatable(o or {}, {__index = self})
|
2019-05-01 13:20:09 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
--- check if a node can be connected
|
|
|
|
-- @function [parent=#network] can_connect
|
|
|
|
-- @param #table pos the position of the node to be checked
|
|
|
|
-- @return #boolean whether this node has the group me_connect
|
|
|
|
function network.can_connect(pos)
|
2019-05-04 13:53:49 +02:00
|
|
|
local node = microexpansion.get_node(pos)
|
2019-05-01 13:20:09 +02:00
|
|
|
return minetest.get_item_group(node.name, "me_connect") > 0
|
|
|
|
end
|
|
|
|
|
|
|
|
--- get all adjacent connected nodes
|
|
|
|
-- @function [parent=#network] adjacent_connected_nodes
|
|
|
|
-- @param #table pos the position of the base node
|
|
|
|
-- @param #boolean include_ctrl whether to check for the controller
|
|
|
|
-- @return #table all nodes that have the group me_connect
|
|
|
|
function network.adjacent_connected_nodes(pos, include_ctrl)
|
|
|
|
local adjacent = {
|
|
|
|
{x=pos.x+1, y=pos.y, z=pos.z},
|
|
|
|
{x=pos.x-1, y=pos.y, z=pos.z},
|
|
|
|
{x=pos.x, y=pos.y+1, z=pos.z},
|
|
|
|
{x=pos.x, y=pos.y-1, z=pos.z},
|
|
|
|
{x=pos.x, y=pos.y, z=pos.z+1},
|
|
|
|
{x=pos.x, y=pos.y, z=pos.z-1},
|
|
|
|
}
|
|
|
|
|
|
|
|
local nodes = {}
|
|
|
|
|
2019-05-18 07:37:46 +02:00
|
|
|
for _,apos in pairs(adjacent) do
|
|
|
|
if network.can_connect(apos) then
|
2019-05-01 13:20:09 +02:00
|
|
|
if include_ctrl == false then
|
2019-05-18 07:37:46 +02:00
|
|
|
if not microexpansion.get_node(apos).name == "microexpansion:ctrl" then
|
|
|
|
table.insert(nodes, apos)
|
2019-05-01 13:20:09 +02:00
|
|
|
end
|
|
|
|
else
|
2019-05-18 07:37:46 +02:00
|
|
|
table.insert(nodes, apos)
|
2019-05-01 13:20:09 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
return nodes
|
|
|
|
end
|
|
|
|
|
|
|
|
--- provide power to the network
|
|
|
|
-- @function [parent=#network] provide
|
|
|
|
-- @param #number power the amount of power provided
|
|
|
|
function network:provide(power)
|
|
|
|
self.power_load = self.power_load + power
|
|
|
|
end
|
|
|
|
|
|
|
|
--- demand power from the network
|
|
|
|
-- @function [parent=#network] demand
|
|
|
|
-- @param #number power the amount of power demanded
|
|
|
|
-- @return #boolean whether the power was provided
|
|
|
|
function network:demand(power)
|
|
|
|
if self.power_load - power < 0 then
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
self.power_load = self.power_load - power
|
|
|
|
return true
|
|
|
|
end
|
|
|
|
|
|
|
|
--- add power capacity to the network
|
|
|
|
-- @function [parent=#network] add_power_capacity
|
|
|
|
-- @param #number power the amount of power that can be stored
|
|
|
|
function network:add_power_capacity(power)
|
|
|
|
self.power_storage = self.power_storage + power
|
|
|
|
end
|
|
|
|
|
|
|
|
--- add power capacity to the network
|
|
|
|
-- @function [parent=#network] add_power_capacity
|
|
|
|
-- @param #number power the amount of power that can't be stored anymore
|
|
|
|
function network:remove_power_capacity(power)
|
|
|
|
self.power_storage = self.power_storage - power
|
|
|
|
if self.power_storage < 0 then
|
|
|
|
minetest.log("warning","[Microexpansion] power storage of network "..self.." dropped below zero")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
--- remove overload
|
|
|
|
-- to be called by the controller every turn
|
|
|
|
-- @function [parent=#network] remove_overload
|
|
|
|
function network:remove_overload()
|
|
|
|
self.power_load = math.min(self.power_load, self.power_storage)
|
|
|
|
end
|
2019-05-07 17:49:26 +02:00
|
|
|
|
|
|
|
--- get a drives item capacity
|
|
|
|
-- @function get_drive_capacity
|
|
|
|
-- @param #table pos the position of the drive
|
|
|
|
-- @return #number the number of items that can be stored in the drive
|
|
|
|
local function get_drive_capacity(pos)
|
|
|
|
local cap = 0
|
|
|
|
local meta = minetest.get_meta(pos)
|
|
|
|
local inv = meta:get_inventory()
|
|
|
|
for i = 1, inv:get_size("main") do
|
|
|
|
cap = cap + microexpansion.get_cell_size(inv:get_stack("main", i):get_name())
|
|
|
|
end
|
|
|
|
return cap
|
|
|
|
end
|
|
|
|
|
|
|
|
--- get the item capacity of a network
|
|
|
|
-- @function [parent=#network] get_item_capacity
|
|
|
|
-- @return #number the total number of items that can be stored in the network
|
|
|
|
function network:get_item_capacity()
|
|
|
|
local cap = 0
|
|
|
|
for npos in microexpansion.connected_nodes(self.controller_pos) do
|
|
|
|
if microexpansion.get_node(npos).name == "microexpansion:drive" then
|
|
|
|
cap = cap + get_drive_capacity(npos)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return cap
|
|
|
|
end
|