This commit is contained in:
Joachim Stolberg 2019-03-08 18:44:23 +01:00
parent c7ec85a24b
commit dc02a9f45b
3 changed files with 33 additions and 48 deletions

View File

@ -267,7 +267,8 @@ function techage.consumer.turn_power_on(pos, power_consumption)
local mem = tubelib2.get_mem(pos) local mem = tubelib2.get_mem(pos)
mem.power_consumption = power_consumption mem.power_consumption = power_consumption
-- 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 consumer 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

View File

@ -7,38 +7,33 @@ local M = minetest.get_meta
local MP = minetest.get_modpath("tubelib2") local MP = minetest.get_modpath("tubelib2")
local I,_ = dofile(MP.."/intllib.lua") local I,_ = dofile(MP.."/intllib.lua")
local POWER_CONSUMPTION = 2
local POWER_CONSUME = 4
local STANDBY_TICKS = 4 local STANDBY_TICKS = 4
local COUNTDOWN_TICKS = 4
local CYCLE_TIME = 4 local CYCLE_TIME = 4
local Cable = techage.ElectricCable
local consumer = techage.consumer
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_button[3,1.2;1,1;".. self:get_state_button_image(mem) ..";state_button;]".. "image_button[3,1.2;1,1;".. self:get_state_button_image(mem) ..";state_button;]"..
--"button[5.5,1.2;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) local function valid_power_dir(pos, mem, in_dir)
-- signal power consumption return mem.power_dir == in_dir
mem.power_consume = POWER_CONSUME
-- goto RUNNING or FAULT, depending on power supply
return mem.power_supply
end end
local function start_node(pos, mem, state) local function start_node(pos, mem, state)
techage.consumer_check_power_consumption(pos) consumer.turn_power_on(pos, POWER_CONSUMPTION)
end end
local function stop_node(pos, mem, state) local function stop_node(pos, mem, state)
mem.power_consume = 0 consumer.turn_power_on(pos, 0)
techage.consumer_check_power_consumption(pos)
end end
local State = techage.NodeStates:new({ local State = techage.NodeStates:new({
@ -47,37 +42,28 @@ local State = techage.NodeStates:new({
cycle_time = CYCLE_TIME, cycle_time = CYCLE_TIME,
standby_ticks = STANDBY_TICKS, standby_ticks = STANDBY_TICKS,
formspec_func = formspec, formspec_func = formspec,
can_start = can_start,
start_node = start_node, start_node = start_node,
stop_node = stop_node, stop_node = stop_node,
}) })
local function node_timer(pos, elapsed) local function lamp_turn_on_clbk(pos, in_dir, sum)
--print("node_timer")
local mem = tubelib2.get_mem(pos) local mem = tubelib2.get_mem(pos)
return State:is_active(mem)
end
-- To be able to check if power connection is on the
-- correct node side (mem.power_dir == in_dir)
local function valid_power_dir(pos, mem, in_dir)
--print("valid_power_dir", mem.power_dir, in_dir)
return true
end
local function turn_power_on(pos, in_dir, on)
local mem = tubelib2.get_mem(pos)
mem.power_supply = on
local state = State:get_state(mem) local state = State:get_state(mem)
if on and state == techage.FAULT then if sum > 0 and state == techage.FAULT then
State:stop(pos, mem) State:stop(pos, mem)
State:start(pos, mem) State:start(pos, mem)
elseif not on and state == techage.RUNNING then elseif sum <= 0 and state == techage.RUNNING then
State:fault(pos, mem) State:fault(pos, mem)
end end
end end
local function node_timer(pos, elapsed)
print("node_timer")
local mem = tubelib2.get_mem(pos)
return State:is_active(mem)
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
@ -102,32 +88,30 @@ minetest.register_node("techage:ele_consumer", {
'techage_electric_button.png', 'techage_electric_button.png',
'techage_electric_button.png', 'techage_electric_button.png',
'techage_electric_button.png', 'techage_electric_button.png',
'techage_electric_button.png', 'techage_electric_button.png^techage_electric_plug.png',
'techage_electric_button.png', 'techage_electric_button.png',
'techage_electric_button.png', 'techage_electric_button.png',
}, },
techage = { techage = {
power_consumption = techage.consumer_power_consumption, turn_on = lamp_turn_on_clbk,
power_network = techage.ElectricCable, read_power_consumption = consumer.read_power_consumption,
power_network = Cable,
power_side = "L", power_side = "L",
valid_power_dir = valid_power_dir, valid_power_dir = valid_power_dir,
turn_on = turn_power_on,
}, },
after_place_node = function(pos, placer) after_place_node = function(pos, placer)
local mem = techage.consumer_after_place_node(pos, placer) local mem = consumer.after_place_node(pos, placer)
mem.power_consume = 0
mem.power_supply = false
on_rightclick(pos)
State:node_init(pos, mem, "") State:node_init(pos, mem, "")
on_rightclick(pos)
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.consumer_after_dig_node(pos, oldnode) consumer.after_dig_node(pos, oldnode)
end, end,
after_tube_update = techage.consumer_after_tube_update, after_tube_update = consumer.after_tube_update,
on_timer = node_timer, on_timer = node_timer,
on_receive_fields = on_receive_fields, on_receive_fields = on_receive_fields,
on_rightclick = on_rightclick, on_rightclick = on_rightclick,
@ -147,19 +131,19 @@ minetest.register_node("techage:ele_consumer_on", {
'techage_electric_button.png', 'techage_electric_button.png',
}, },
techage = { techage = {
power_consumption = techage.consumer_power_consumption, turn_on = lamp_turn_on_clbk,
power_network = techage.ElectricCable, read_power_consumption = consumer.read_power_consumption,
power_network = Cable,
power_side = "L", power_side = "L",
valid_power_dir = valid_power_dir, valid_power_dir = valid_power_dir,
turn_on = turn_power_on,
}, },
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.consumer_after_dig_node(pos, oldnode) consumer.after_dig_node(pos, oldnode)
end, end,
after_tube_update = techage.consumer_after_tube_update, after_tube_update = consumer.after_tube_update,
on_timer = node_timer, on_timer = node_timer,
on_receive_fields = on_receive_fields, on_receive_fields = on_receive_fields,
on_rightclick = on_rightclick, on_rightclick = on_rightclick,

View File

@ -40,7 +40,6 @@ local State = techage.NodeStates:new({
cycle_time = CYCLE_TIME, cycle_time = CYCLE_TIME,
standby_ticks = STANDBY_TICKS, standby_ticks = STANDBY_TICKS,
formspec_func = formspec, formspec_func = formspec,
--can_start = can_start,
start_node = start_node, start_node = start_node,
stop_node = stop_node, stop_node = stop_node,
}) })
@ -59,6 +58,7 @@ local function turn_power_on(pos, in_dir, sum)
if State:is_active(mem) and sum <= 0 then if State:is_active(mem) and sum <= 0 then
State:fault(pos, mem) State:fault(pos, mem)
end end
M(pos):set_string("formspec", formspec(State, pos, mem))
end end
local function on_receive_fields(pos, formname, fields, player) local function on_receive_fields(pos, formname, fields, player)