From 8062f079b8203767eb9457502f68541d1132a0c9 Mon Sep 17 00:00:00 2001 From: Joachim Stolberg Date: Fri, 16 Aug 2019 11:13:30 +0200 Subject: [PATCH] power distribution changed --- .test/sink.lua | 4 +++- iron_age/coalburner.lua | 3 ++- iron_age/gravelsieve.lua | 3 +++ power/power.lua | 41 ++++++++++++++++++++-------------------- power/power2.lua | 5 +++-- power/powerswitch.lua | 2 ++ 6 files changed, 34 insertions(+), 24 deletions(-) diff --git a/.test/sink.lua b/.test/sink.lua index f784ea7..ce61e24 100644 --- a/.test/sink.lua +++ b/.test/sink.lua @@ -44,12 +44,14 @@ local function on_rightclick(pos, node, clicker) local mem = tubelib2.get_mem(pos) if not mem.running and power.power_available(pos, mem, PWR_NEEDED) then mem.running = true - swap_node(pos, "techage:sink_on") + print("turn on") + --swap_node(pos, "techage:sink_on") power.consumer_start(pos, mem, CYCLE_TIME, PWR_NEEDED) minetest.get_node_timer(pos):start(CYCLE_TIME) M(pos):set_string("infotext", "on") else mem.running = false + print("turn off") swap_node(pos, "techage:sink") power.consumer_stop(pos, mem) minetest.get_node_timer(pos):stop() diff --git a/iron_age/coalburner.lua b/iron_age/coalburner.lua index f8c099c..93eb48f 100644 --- a/iron_age/coalburner.lua +++ b/iron_age/coalburner.lua @@ -85,7 +85,7 @@ local function flame(pos, height, heat, first_time) pos = {x=pos.x, y=pos.y+1, z=pos.z} idx = math.min(idx, 12) local node = minetest.get_node(pos) - if node.name == "techage:meltingpot_active" then + if node.name == "techage:meltingpot_active" or node.name == "ignore" then return end if node.name == "techage:meltingpot" then @@ -129,6 +129,7 @@ for idx,ratio in ipairs(lRatio) do end end, + drawtype = "glasslike", use_texture_alpha = true, inventory_image = "techage_flame.png", paramtype = "light", diff --git a/iron_age/gravelsieve.lua b/iron_age/gravelsieve.lua index d01d321..f2738f8 100644 --- a/iron_age/gravelsieve.lua +++ b/iron_age/gravelsieve.lua @@ -44,6 +44,9 @@ local function keep_running(pos, elapsed) dst, src = get_random_basalt_ore(), ItemStack("techage:basalt_gravel") elseif inv:contains_item("src", ItemStack("default:gravel")) then dst, src = get_random_gravel_ore(), ItemStack("default:gravel") + elseif not inv:is_empty("src") then + src = inv:get_stack("src", 1):take_item(1) + dst = src else return false end diff --git a/power/power.lua b/power/power.lua index 0e69a73..3e13152 100644 --- a/power/power.lua +++ b/power/power.lua @@ -53,8 +53,8 @@ local function accounting(pos, mem) mem.mst_supply2 = min(mem.mst_demand1 - mem.mst_supply1, mem.mst_available2) mem.mst_demand2 = min(mem.mst_supply1 - mem.mst_demand1, mem.mst_available1) mem.mst_reserve = (mem.mst_available1 + mem.mst_available2) - mem.mst_needed1 - --print("needed = "..mem.mst_needed1.."/"..mem.mst_needed2..", available = "..mem.mst_available1.."/"..mem.mst_available2) - --print("supply = "..mem.mst_supply1.."/"..mem.mst_supply2..", demand = "..mem.mst_demand1.."/"..mem.mst_demand2..", reserve = "..mem.mst_reserve) + print("needed = "..mem.mst_needed1.."/"..mem.mst_needed2..", available = "..mem.mst_available1.."/"..mem.mst_available2) + print("supply = "..mem.mst_supply1.."/"..mem.mst_supply2..", demand = "..mem.mst_demand1.."/"..mem.mst_demand2..", reserve = "..mem.mst_reserve) end local function connection_walk(pos, clbk) @@ -77,7 +77,6 @@ local function consumer_turn_off(pos, mem) if pwr and pwr.on_nopower then pwr.on_nopower(pos, mem) end - mem.pwr_node_alive_cnt = 0 mem.pwr_state = NOPOWER end @@ -88,6 +87,8 @@ local function consumer_turn_on(pos, mem) pwr.on_power(pos, mem) end mem.pwr_state = RUNNING + -- to avoid consumer starvation + mem.pwr_node_alive_cnt = (mem.pwr_cycle_time or 2)/2 + 1 end -- determine one "generating" node as master (largest hash number) @@ -138,7 +139,7 @@ end local function handle_consumer(mst_mem, mem, pos, power_needed) print("handle_consumer", mem.pwr_state) if mem.pwr_state == NOPOWER then - --print("power_needed", power_needed,"mst_mem.demand1", mst_mem.mst_demand1) + print("power_needed", power_needed,"mst_mem.demand1", mst_mem.mst_demand1) -- for next cycle mst_mem.mst_needed1 = mst_mem.mst_needed1 + power_needed -- current cycle @@ -147,6 +148,7 @@ local function handle_consumer(mst_mem, mem, pos, power_needed) consumer_turn_on(pos, mem) end elseif mem.pwr_state == RUNNING then + print("power_needed", power_needed,"mst_mem.demand1", mst_mem.mst_demand1) -- for next cycle mst_mem.mst_needed1 = mst_mem.mst_needed1 + power_needed -- current cycle @@ -180,13 +182,13 @@ local function handle_secondary(mst_mem, mem, pos, provides, needed) end -local function trigger_nodes(mst_pos, mst_mem) +local function trigger_nodes(mst_pos, mst_mem, dec) Route = {} pos_already_reached(mst_pos) connection_walk(mst_pos, function(pos, mem) - mem.pwr_node_alive_cnt = (mem.pwr_node_alive_cnt or 1) - 1 + mem.pwr_node_alive_cnt = (mem.pwr_node_alive_cnt or 1) - dec mem.pwr_power_provided_cnt = 2 - --print("trigger_nodes", mem.pwr_node_alive_cnt, mem.pwr_available2 or mem.pwr_available or mem.pwr_needed) + print("trigger_nodes", minetest.get_node(pos).name, mem.pwr_node_alive_cnt, mem.pwr_available2 or mem.pwr_available or mem.pwr_needed) if mem.pwr_node_alive_cnt >= 0 then if mem.pwr_available then handle_generator(mst_mem, mem, pos, mem.pwr_available) @@ -209,21 +211,21 @@ local function determine_new_master(pos, mem) tubelib2.get_mem(mpos).pwr_is_master = true elseif was_master then -- no master any more -- delete data - local mmem = tubelib2.get_mem(mpos) - mmem.mst_supply1 = 0 - mmem.mst_supply2 = 0 - mmem.mst_reserve = 0 + mem.mst_supply1 = 0 + mem.mst_supply2 = 0 + mem.mst_reserve = 0 end - return was_master or mem.pwr_is_master + return was_master or mem.pwr_is_master or not mpos end -- called from master position -local function power_distribution(pos, mem) +local function power_distribution(pos, mem, dec) + print("power_distribution") mem.mst_needed1 = 0 mem.mst_needed2 = 0 mem.mst_available1 = 0 mem.mst_available2 = 0 - trigger_nodes(pos, mem) + trigger_nodes(pos, mem, dec or 0) accounting(pos, mem) end @@ -267,7 +269,7 @@ end function techage.power.generator_alive(pos, mem) mem.pwr_node_alive_cnt = 2 if mem.pwr_is_master then - power_distribution(pos, mem) + power_distribution(pos, mem, 1) end return mem.pwr_provided end @@ -277,10 +279,9 @@ end -- function techage.power.consumer_alive(pos, mem) print("consumer_alive", mem.pwr_power_provided_cnt) + mem.pwr_node_alive_cnt = (mem.pwr_cycle_time or 2)/2 + 1 mem.pwr_power_provided_cnt = (mem.pwr_power_provided_cnt or 0) - (mem.pwr_cycle_time or 2)/2 - if mem.pwr_power_provided_cnt >= 0 then - mem.pwr_node_alive_cnt = (mem.pwr_cycle_time or 2)/2 + 1 - else + if mem.pwr_power_provided_cnt < 0 and mem.pwr_state == RUNNING then consumer_turn_off(pos, mem) end end @@ -365,7 +366,7 @@ function techage.power.secondary_alive(pos, mem, capa_curr, capa_max) mem.pwr_node_alive_cnt = 2 if mem.pwr_is_master then --print("secondary_alive is master") - power_distribution(pos, mem) + power_distribution(pos, mem, 1) end - return mem.pwr_provided + return mem.pwr_provided or 0 end \ No newline at end of file diff --git a/power/power2.lua b/power/power2.lua index a95952e..d10cd27 100644 --- a/power/power2.lua +++ b/power/power2.lua @@ -198,6 +198,7 @@ end -- Used to turn on/off the power by means of a power switch function techage.power.power_cut(pos, dir, cable, cut) + print("power_cut") local npos = vector.add(pos, tubelib2.Dir6dToVector[dir or 0]) local node = minetest.get_node(npos) @@ -213,12 +214,12 @@ function techage.power.power_cut(pos, dir, cable, cut) mem.interrupted_dirs = {true, true, true, true, true, true} for dir,_ in pairs(mem.connections) do mem.interrupted_dirs[dir] = false - techage.power.network_changed(pos, mem) + techage.power.network_changed(npos, mem) mem.interrupted_dirs[dir] = true end else mem.interrupted_dirs = {} - techage.power.network_changed(pos, mem) + techage.power.network_changed(npos, mem) end end diff --git a/power/powerswitch.lua b/power/powerswitch.lua index 7ab39f4..8a7e13a 100644 --- a/power/powerswitch.lua +++ b/power/powerswitch.lua @@ -35,6 +35,7 @@ local function switch_on(pos, node, clicker) if clicker and minetest.is_protected(pos, clicker:get_player_name()) then return end + print("switch_on") node.name = "techage:powerswitch_on" minetest.swap_node(pos, node) minetest.sound_play("techage_button", { @@ -50,6 +51,7 @@ local function switch_off(pos, node, clicker) if clicker and minetest.is_protected(pos, clicker:get_player_name()) then return end + print("switch_off") node.name = "techage:powerswitch" minetest.swap_node(pos, node) minetest.get_node_timer(pos):stop()