2020-01-26 01:22:06 +03:00
|
|
|
--[[
|
|
|
|
|
|
|
|
TechAge
|
|
|
|
=======
|
|
|
|
|
|
|
|
Copyright (C) 2019-2020 Joachim Stolberg
|
|
|
|
|
|
|
|
GPL v3
|
|
|
|
See LICENSE.txt for more information
|
|
|
|
|
|
|
|
TA3 Power Terminal
|
|
|
|
|
|
|
|
]]--
|
|
|
|
|
|
|
|
-- for lazy programmers
|
|
|
|
local S2P = minetest.string_to_pos
|
|
|
|
local P2S = function(pos) if pos then return minetest.pos_to_string(pos) end end
|
|
|
|
local M = minetest.get_meta
|
|
|
|
local N = function(pos) return minetest.get_node(pos).name end
|
|
|
|
local S = techage.S
|
|
|
|
|
|
|
|
local CYCLE_TIME = 2
|
|
|
|
|
|
|
|
local Cable = techage.ElectricCable
|
|
|
|
local power = techage.power
|
|
|
|
local networks = techage.networks
|
|
|
|
local STOPPED = techage.power.STOPPED
|
|
|
|
local NOPOWER = techage.power.NOPOWER
|
|
|
|
local RUNNING = techage.power.RUNNING
|
|
|
|
|
|
|
|
local function generator_data(gen_tbl)
|
|
|
|
local tbl = {
|
|
|
|
pow_all=0, pow_on=0, pow_act=0, pow_used=0,
|
|
|
|
num_on=0, num_act=0, num_used=0
|
|
|
|
}
|
|
|
|
for i,gen in ipairs(gen_tbl or {}) do
|
|
|
|
local nvm = techage.get_nvm(gen.pos)
|
|
|
|
tbl.pow_all = tbl.pow_all + (gen.nominal or 0)
|
2020-01-26 22:15:40 +03:00
|
|
|
if nvm.ele1 and nvm.ele1.gstate and nvm.ele1.gstate ~= STOPPED then
|
2020-01-26 01:22:06 +03:00
|
|
|
tbl.num_on = tbl.num_on + 1
|
|
|
|
tbl.pow_on = tbl.pow_on + (gen.nominal or 0)
|
2020-01-26 22:15:40 +03:00
|
|
|
if (nvm.ele1.galive or 0) > 0 then
|
2020-01-26 01:22:06 +03:00
|
|
|
tbl.num_act = tbl.num_act + 1
|
|
|
|
tbl.pow_act = tbl.pow_act + (gen.nominal or 0)
|
2020-01-26 22:15:40 +03:00
|
|
|
if (nvm.ele1.given or 0) > 0 then
|
2020-01-26 01:22:06 +03:00
|
|
|
tbl.num_used = tbl.num_used + 1
|
2020-01-26 22:15:40 +03:00
|
|
|
tbl.pow_used = tbl.pow_used + (nvm.ele1.given or 0)
|
2020-01-26 01:22:06 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
tbl.num_all = #(gen_tbl or {})
|
|
|
|
return tbl
|
|
|
|
end
|
|
|
|
|
|
|
|
local function consumer_data(con_tbl)
|
|
|
|
local tbl = {
|
|
|
|
pow_all=0, pow_on=0, pow_act=0, pow_used=0,
|
|
|
|
num_on=0, num_act=0, num_used=0
|
|
|
|
}
|
|
|
|
for i,gen in ipairs(con_tbl or {}) do
|
|
|
|
local nvm = techage.get_nvm(gen.pos)
|
|
|
|
tbl.pow_all = tbl.pow_all + (gen.nominal or 0)
|
2020-01-26 22:15:40 +03:00
|
|
|
if nvm.ele1 and nvm.ele1.cstate and nvm.ele1.cstate ~= STOPPED then
|
2020-01-26 01:22:06 +03:00
|
|
|
tbl.num_on = tbl.num_on + 1
|
|
|
|
tbl.pow_on = tbl.pow_on + (gen.nominal or 0)
|
2020-01-26 22:15:40 +03:00
|
|
|
if (nvm.ele1.calive or 0) > 0 then
|
2020-01-26 01:22:06 +03:00
|
|
|
tbl.num_act = tbl.num_act + 1
|
|
|
|
tbl.pow_act = tbl.pow_act + (gen.nominal or 0)
|
2020-01-26 22:15:40 +03:00
|
|
|
if (nvm.ele1.taken or 0) > 0 then
|
2020-01-26 01:22:06 +03:00
|
|
|
tbl.num_used = tbl.num_used + 1
|
2020-01-26 22:15:40 +03:00
|
|
|
tbl.pow_used = tbl.pow_used + (nvm.ele1.taken or 0)
|
2020-01-26 01:22:06 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
tbl.num_all = #(con_tbl or {})
|
|
|
|
return tbl
|
|
|
|
end
|
|
|
|
|
|
|
|
local function calc_network_data(pos, nvm)
|
2020-01-26 22:15:40 +03:00
|
|
|
local netw = techage.networks.has_network("ele1", nvm.ele1 and nvm.ele1.netID) or {}
|
2020-01-26 01:22:06 +03:00
|
|
|
local gen1 = generator_data(netw.gen1)
|
|
|
|
local gen2 = generator_data(netw.gen2)
|
|
|
|
local con1 = consumer_data(netw.con1)
|
|
|
|
local con2 = consumer_data(netw.con2)
|
|
|
|
|
|
|
|
return netw, gen1, gen2, con1, con2
|
|
|
|
end
|
|
|
|
|
|
|
|
local function column(x,y, data)
|
|
|
|
return
|
|
|
|
"label["..x..","..(y+0.0)..";"..data.num_all.. " ("..data.pow_all.." ku)]"..
|
|
|
|
"label["..x..","..(y+0.5)..";"..data.num_on.. " ("..data.pow_on.." ku)]"..
|
|
|
|
"label["..x..","..(y+1.0)..";"..data.num_act.. " ("..data.pow_act.." ku)]"..
|
|
|
|
"label["..x..","..(y+1.5)..";"..data.num_used.." ("..data.pow_used.." ku)]"
|
|
|
|
end
|
|
|
|
|
|
|
|
local function get_state(netw, gen1, gen2, con1, con2)
|
|
|
|
local num_nodes = gen1.num_all + gen2.num_all + con1.num_all +
|
|
|
|
con2.num_all + (#(netw.junc or {})) + (#(netw.term or {}))
|
|
|
|
local nload = (gen1.pow_act + gen2.pow_act) / con1.pow_act
|
|
|
|
local state = S("Number of all nodes")..": ".. num_nodes
|
|
|
|
if not netw.gen1 and not netw.gen2 then
|
|
|
|
state = S("No network or active generator available!")
|
|
|
|
elseif num_nodes > (techage.ELE1_MAX_CABLE_LENGHT - 50) then
|
|
|
|
state = string.format(S("With %u of a maximum of %u blocks you are almost at the limit!"),
|
|
|
|
num_nodes, techage.ELE1_MAX_CABLE_LENGHT)
|
|
|
|
elseif nload <= 1.0 then
|
|
|
|
state = S("The network is overloaded!")
|
|
|
|
elseif nload < 1.2 then
|
|
|
|
state = S("The network load is almost at the limit!")
|
|
|
|
end
|
|
|
|
return state
|
|
|
|
end
|
|
|
|
|
|
|
|
local function formspec(pos, nvm)
|
|
|
|
local netw, gen1, gen2, con1, con2 = calc_network_data(pos, nvm)
|
|
|
|
netw.prop = ((netw.prop or 0) + 1) % 2
|
|
|
|
local star = netw.prop == 1 and "*" or ""
|
|
|
|
local state = get_state(netw, gen1, gen2, con1, con2)
|
|
|
|
|
|
|
|
return "size[10,7]"..
|
|
|
|
default.gui_bg..
|
|
|
|
default.gui_bg_img..
|
|
|
|
default.gui_slots..
|
|
|
|
"box[0,-0.1;9.8,0.5;#c6e8ff]"..
|
|
|
|
"label[4,-0.1;"..minetest.colorize( "#000000", S("Network Data")).."]"..
|
|
|
|
"label[9.5,-0.1;"..minetest.colorize( "#000000", star).."]"..
|
|
|
|
power.formspec_label_bar(0, 0.7, S("Genera. 1"), gen1.pow_act, gen1.pow_used)..
|
|
|
|
power.formspec_label_bar(2.5, 0.7, S("Genera. 2"), gen2.pow_act, gen2.pow_used)..
|
|
|
|
power.formspec_label_bar(5, 0.7, S("Consum. 2"), con2.pow_act, con2.pow_used)..
|
|
|
|
power.formspec_label_bar(7.5, 0.7, S("Consum. 1"), con1.pow_act, con1.pow_used)..
|
|
|
|
"box[0,4.3;9.8,0.4;#c6e8ff]"..
|
|
|
|
"box[0,4.85;9.8,0.4;#395c74]"..
|
|
|
|
"box[0,5.35;9.8,0.4;#395c74]"..
|
|
|
|
"box[0,5.85;9.8,0.4;#395c74]"..
|
|
|
|
"box[0,6.35;9.8,0.4;#395c74]"..
|
|
|
|
"label[2,4.3;"..minetest.colorize( "#000000", S("Genera. 1")).."]"..
|
|
|
|
"label[4,4.3;"..minetest.colorize( "#000000", S("Genera. 2")).."]"..
|
|
|
|
"label[6,4.3;"..minetest.colorize( "#000000", S("Consum. 2")).."]"..
|
|
|
|
"label[8,4.3;"..minetest.colorize( "#000000", S("Consum. 1")).."]"..
|
|
|
|
"label[0.1,4.8;"..S("All nodes:").."]"..
|
|
|
|
"label[0.1,5.3;"..S("Turned on:").."]"..
|
|
|
|
"label[0.1,5.8;"..S("Active:").."]"..
|
|
|
|
"label[0.1,6.3;"..S("In use:").."]"..
|
|
|
|
"box[0,6.95;9.8,0.4;#000000]"..
|
|
|
|
"label[0.1,6.9;"..state.."]"..
|
|
|
|
column(2, 4.8, gen1)..
|
|
|
|
column(4, 4.8, gen2)..
|
|
|
|
column(6, 4.8, con2)..
|
|
|
|
column(8, 4.8, con1)
|
|
|
|
end
|
|
|
|
|
|
|
|
minetest.register_node("techage:power_terminal", {
|
|
|
|
description = S("TA3 Power Terminal"),
|
|
|
|
inventory_image = "techage_power_terminal_front.png",
|
|
|
|
tiles = {
|
|
|
|
"techage_power_terminal_top.png",
|
|
|
|
"techage_power_terminal_top.png",
|
|
|
|
"techage_power_terminal_side.png",
|
|
|
|
"techage_power_terminal_side.png",
|
|
|
|
"techage_power_terminal_back.png",
|
|
|
|
"techage_power_terminal_front.png",
|
|
|
|
},
|
|
|
|
drawtype = "nodebox",
|
|
|
|
node_box = {
|
|
|
|
type = "fixed",
|
|
|
|
fixed = {
|
|
|
|
{ -8/16, -8/16, 0/16, 8/16, 8/16, 8/16},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
after_place_node = function(pos)
|
|
|
|
local nvm = techage.get_nvm(pos)
|
|
|
|
M(pos):set_int("outdir", networks.side_to_outdir(pos, "B"))
|
|
|
|
Cable:after_place_node(pos)
|
|
|
|
M(pos):set_string("formspec", formspec(pos, nvm))
|
|
|
|
end,
|
|
|
|
after_dig_node = function(pos)
|
|
|
|
Cable:after_dig_node(pos)
|
|
|
|
techage.del_mem(pos)
|
|
|
|
end,
|
|
|
|
tubelib2_on_update2 = function(pos, outdir, tlib2, node)
|
|
|
|
power.update_network(pos, outdir, tlib2)
|
|
|
|
end,
|
|
|
|
on_rightclick = function(pos, node, clicker)
|
|
|
|
techage.set_activeformspec(pos, clicker)
|
|
|
|
minetest.get_node_timer(pos):start(CYCLE_TIME)
|
|
|
|
local nvm = techage.get_nvm(pos)
|
|
|
|
M(pos):set_string("formspec", formspec(pos, nvm))
|
|
|
|
end,
|
|
|
|
on_timer = function(pos, elapsed)
|
|
|
|
local nvm = techage.get_nvm(pos)
|
|
|
|
if techage.is_activeformspec(pos) then
|
|
|
|
M(pos):set_string("formspec", formspec(pos, nvm))
|
|
|
|
end
|
|
|
|
return true
|
|
|
|
end,
|
|
|
|
|
|
|
|
networks = {
|
|
|
|
ele1 = {
|
|
|
|
sides = {B = 1}, -- Cable connection side
|
|
|
|
ntype = "term",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
paramtype2 = "facedir",
|
|
|
|
paramtype = "light",
|
|
|
|
on_rotate = screwdriver.disallow,
|
|
|
|
sunlight_propagates = true,
|
|
|
|
is_ground_content = false,
|
|
|
|
groups = {cracky = 1, level = 2},
|
|
|
|
sounds = default.node_sound_metal_defaults(),
|
|
|
|
})
|
|
|
|
|
|
|
|
Cable:add_secondary_node_names({"techage:power_terminal"})
|
|
|
|
|