bugfixes
This commit is contained in:
parent
dc97727ae1
commit
c7ec85a24b
@ -179,7 +179,8 @@ function techage.generator.turn_power_on(pos, power_capacity)
|
|||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
mem.power_capacity = power_capacity
|
mem.power_capacity = power_capacity
|
||||||
-- Starts the overall power consumption and depending on that turns all nodes on/off
|
-- Starts the overall power consumption and depending on that turns all nodes on/off
|
||||||
start_network_power_consumption(pos, mem.power_dir)
|
-- To be called delayed, so that the generator state machine can be handled before
|
||||||
|
minetest.after(0.2, start_network_power_consumption, pos, mem.power_dir)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Power network callback function
|
-- Power network callback function
|
||||||
@ -197,8 +198,8 @@ function techage.generator.after_dig_node(pos, oldnode)
|
|||||||
tubelib2.del_mem(pos)
|
tubelib2.del_mem(pos)
|
||||||
end
|
end
|
||||||
|
|
||||||
function techage.generator.formspec_level(mem)
|
function techage.generator.formspec_level(mem, sum)
|
||||||
local percent = ((mem.power_result or 0) * 100) / (mem.power_produce or 1)
|
local percent = ((sum or 0) * 100) / (mem.power_capacity or 1)
|
||||||
return "techage_form_level_bg.png^[lowpart:"..percent..":techage_form_level_fg.png]"
|
return "techage_form_level_bg.png^[lowpart:"..percent..":techage_form_level_fg.png]"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -10,82 +10,57 @@ local I,_ = dofile(MP.."/intllib.lua")
|
|||||||
local STANDBY_TICKS = 4
|
local STANDBY_TICKS = 4
|
||||||
local COUNTDOWN_TICKS = 4
|
local COUNTDOWN_TICKS = 4
|
||||||
local CYCLE_TIME = 16
|
local CYCLE_TIME = 16
|
||||||
|
local POWER_CAPACITY = 8
|
||||||
|
|
||||||
|
local Cable = techage.ElectricCable
|
||||||
|
local generator = techage.generator
|
||||||
|
|
||||||
local function formspec(self, pos, mem)
|
local function formspec(self, pos, mem)
|
||||||
return "size[8,7]"..
|
return "size[8,7]"..
|
||||||
default.gui_bg..
|
default.gui_bg..
|
||||||
default.gui_bg_img..
|
default.gui_bg_img..
|
||||||
default.gui_slots..
|
default.gui_slots..
|
||||||
"image[2,0.5;1,2;"..techage.generator_formspec_level(mem)..
|
"image[6,0.5;1,2;"..generator.formspec_level(mem, mem.power_result)..
|
||||||
"image_button[3,1.2;1,1;".. self:get_state_button_image(mem) ..";state_button;]"..
|
"image_button[5,1;1,1;".. self:get_state_button_image(mem) ..";state_button;]"..
|
||||||
"button[5.5,1.2;1.8,1;update;"..I("Update").."]"..
|
"button[2.5,1;1.8,1;update;"..I("Update").."]"..
|
||||||
"list[current_player;main;0,3;8,4;]"..
|
"list[current_player;main;0,3;8,4;]"..
|
||||||
default.get_hotbar_bg(0, 3)
|
default.get_hotbar_bg(0, 3)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function can_start(pos, mem, state)
|
|
||||||
print("can_start")
|
|
||||||
local sum = techage.calc_power_consumption(pos, mem, 8)
|
|
||||||
print("sum", sum)
|
|
||||||
if sum > 0 then
|
|
||||||
M(pos):set_string("infotext", "On:"..sum.." / "..8)
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
|
|
||||||
local function start_node(pos, mem, state)
|
local function start_node(pos, mem, state)
|
||||||
print("start_node")
|
generator.turn_power_on(pos, POWER_CAPACITY)
|
||||||
techage.generator_on(pos, mem)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function stop_node(pos, mem, state)
|
local function stop_node(pos, mem, state)
|
||||||
techage.generator_off(pos, mem)
|
generator.turn_power_on(pos, 0)
|
||||||
M(pos):set_string("infotext", "Off")
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local State = techage.NodeStates:new({
|
local State = techage.NodeStates:new({
|
||||||
node_name_passive = "techage:generator",
|
node_name_passive = "techage:generator",
|
||||||
cycle_time = CYCLE_TIME,
|
cycle_time = CYCLE_TIME,
|
||||||
standby_ticks = STANDBY_TICKS,
|
standby_ticks = STANDBY_TICKS,
|
||||||
has_item_meter = true,
|
|
||||||
aging_factor = 10,
|
|
||||||
formspec_func = formspec,
|
formspec_func = formspec,
|
||||||
can_start = can_start,
|
--can_start = can_start,
|
||||||
start_node = start_node,
|
start_node = start_node,
|
||||||
stop_node = stop_node,
|
stop_node = stop_node,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
local function distibuting(pos, mem)
|
|
||||||
local sum = techage.calc_power_consumption(pos, mem, 8)
|
|
||||||
if sum > 0 then
|
|
||||||
State:keep_running(pos, mem, COUNTDOWN_TICKS)
|
|
||||||
else
|
|
||||||
State:fault(pos, mem)
|
|
||||||
end
|
|
||||||
M(pos):set_string("infotext", "On:"..sum.." / "..8)
|
|
||||||
end
|
|
||||||
|
|
||||||
local function node_timer(pos, elapsed)
|
local function node_timer(pos, elapsed)
|
||||||
--print("node_timer")
|
print("node_timer")
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
distibuting(pos, mem)
|
|
||||||
return State:is_active(mem)
|
return State:is_active(mem)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function valid_power_dir(pos, mem, in_dir)
|
local function turn_power_on(pos, in_dir, sum)
|
||||||
return mem.power_dir == in_dir
|
|
||||||
end
|
|
||||||
|
|
||||||
local function turn_power_on(pos, in_dir, on)
|
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
if State:is_active(mem) and not on then
|
-- store result for formspec
|
||||||
|
mem.power_result = sum
|
||||||
|
if State:is_active(mem) and sum <= 0 then
|
||||||
State:fault(pos, mem)
|
State:fault(pos, mem)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
local function on_receive_fields(pos, formname, fields, player)
|
local function on_receive_fields(pos, formname, fields, player)
|
||||||
if minetest.is_protected(pos, player:get_player_name()) then
|
if minetest.is_protected(pos, player:get_player_name()) then
|
||||||
return
|
return
|
||||||
@ -120,26 +95,22 @@ minetest.register_node("techage:generator", {
|
|||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
|
|
||||||
techage = {
|
techage = {
|
||||||
power_consumption = techage.generator_power_consumption,
|
|
||||||
power_network = techage.ElectricCable,
|
|
||||||
power_consume = 0,
|
|
||||||
valid_power_dir = valid_power_dir,
|
|
||||||
turn_on = turn_power_on,
|
turn_on = turn_power_on,
|
||||||
|
read_power_consumption = generator.read_power_consumption,
|
||||||
|
power_network = Cable,
|
||||||
},
|
},
|
||||||
|
|
||||||
after_place_node = function(pos, placer)
|
after_place_node = function(pos, placer)
|
||||||
local mem = techage.generator_after_place_node(pos)
|
local mem = generator.after_place_node(pos)
|
||||||
State:node_init(pos, mem, "")
|
State:node_init(pos, mem, "")
|
||||||
end,
|
end,
|
||||||
|
|
||||||
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
||||||
State:after_dig_node(pos, oldnode, oldmetadata, digger)
|
State:after_dig_node(pos, oldnode, oldmetadata, digger)
|
||||||
techage.generator_after_dig_node(pos, oldnode)
|
generator.after_dig_node(pos, oldnode)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
after_tube_update = techage.generator_after_tube_update,
|
after_tube_update = generator.after_tube_update,
|
||||||
on_destruct = techage.generator_on_destruct,
|
|
||||||
on_timer = node_timer,
|
|
||||||
on_receive_fields = on_receive_fields,
|
on_receive_fields = on_receive_fields,
|
||||||
on_rightclick = on_rightclick,
|
on_rightclick = on_rightclick,
|
||||||
})
|
})
|
||||||
|
@ -37,18 +37,14 @@ end
|
|||||||
local function lamp_on_rightclick(pos, node, clicker)
|
local function lamp_on_rightclick(pos, node, clicker)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
if not mem.running then
|
if not mem.running then
|
||||||
-- Note the order!!!
|
|
||||||
swap_node(pos, "techage:lamp_on")
|
swap_node(pos, "techage:lamp_on")
|
||||||
mem.running = true
|
mem.running = true
|
||||||
M(pos):set_string("infotext", "On")
|
M(pos):set_string("infotext", "On")
|
||||||
-- last command!!!
|
|
||||||
consumer.turn_power_on(pos, POWER_CONSUMPTION)
|
consumer.turn_power_on(pos, POWER_CONSUMPTION)
|
||||||
else
|
else
|
||||||
-- Note the order!!!
|
|
||||||
swap_node(pos, "techage:lamp")
|
swap_node(pos, "techage:lamp")
|
||||||
mem.running = false
|
mem.running = false
|
||||||
M(pos):set_string("infotext", "Off")
|
M(pos):set_string("infotext", "Off")
|
||||||
-- last command!!!
|
|
||||||
consumer.turn_power_on(pos, 0)
|
consumer.turn_power_on(pos, 0)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -129,13 +125,10 @@ end
|
|||||||
local function generator_on_rightclick(pos, node, clicker)
|
local function generator_on_rightclick(pos, node, clicker)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
if not mem.running then
|
if not mem.running then
|
||||||
-- Note the order!!!
|
|
||||||
mem.running = true
|
mem.running = true
|
||||||
M(pos):set_string("infotext", "On")
|
M(pos):set_string("infotext", "On")
|
||||||
-- last command!!!
|
|
||||||
generator.turn_power_on(pos, POWER_CAPACITY)
|
generator.turn_power_on(pos, POWER_CAPACITY)
|
||||||
else
|
else
|
||||||
-- Note the order!!!
|
|
||||||
generator.turn_power_on(pos, 0)
|
generator.turn_power_on(pos, 0)
|
||||||
mem.running = false
|
mem.running = false
|
||||||
M(pos):set_string("infotext", "Off")
|
M(pos):set_string("infotext", "Off")
|
||||||
|
4
init.lua
4
init.lua
@ -30,8 +30,8 @@ dofile(MP.."/basis/junction.lua") -- network junction box
|
|||||||
|
|
||||||
dofile(MP.."/electric/electric_cable.lua")
|
dofile(MP.."/electric/electric_cable.lua")
|
||||||
dofile(MP.."/electric/test.lua")
|
dofile(MP.."/electric/test.lua")
|
||||||
--dofile(MP.."/electric/generator.lua")
|
dofile(MP.."/electric/generator.lua")
|
||||||
--dofile(MP.."/electric/consumer.lua")
|
dofile(MP.."/electric/consumer.lua")
|
||||||
|
|
||||||
|
|
||||||
--dofile(MP.."/fermenter/biogas_pipe.lua")
|
--dofile(MP.."/fermenter/biogas_pipe.lua")
|
||||||
|
Loading…
Reference in New Issue
Block a user