--[[ TechAge ======= Copyright (C) 2019-2020 Joachim Stolberg AGPL v3 See LICENSE.txt for more information TA2 Power Generator ]]-- -- for lazy programmers local M = minetest.get_meta local S = techage.S local P2S = function(pos) if pos then return minetest.pos_to_string(pos) end end local S2P = minetest.string_to_pos local Cable = techage.ElectricCable local Axle = techage.Axle local power = techage.power local networks = techage.networks local CYCLE_TIME = 2 local PWR_PERF = 24 local function swap_node(pos, name) local node = techage.get_node_lvm(pos) if node.name == name then return end node.name = name minetest.swap_node(pos, node) end local function on_power(pos) local nvm = techage.get_nvm(pos) nvm.axle = nvm.axle or {} nvm.consumer_powered = true M(pos):set_string("infotext", S("TA2 Power Generator")) swap_node(pos, "techage:ta2_generator_on") nvm.ticks = 0 local outdir = M(pos):get_int("outdir") nvm.axle.curr_power = techage.power.needed_power(pos, Cable, outdir) end local function on_nopower(pos) local nvm = techage.get_nvm(pos) nvm.consumer_powered = false if (nvm.ticks or 0) < 4 then M(pos):set_string("infotext", S("TA2 Power Generator: Overload fault?\n(restart with right-click)")) end nvm.ticks = 0 end local function node_timer(pos, elapsed) local nvm = techage.get_nvm(pos) nvm.axle = nvm.axle or {} -- trigger network on consumer side nvm.ticks = (nvm.ticks or 0) + 1 if nvm.ticks % 2 then power.consumer_alive(pos, Axle, CYCLE_TIME) end -- handle generator side delayed if nvm.ticks > 3 then local outdir = M(pos):get_int("outdir") if nvm.consumer_powered and not nvm.running_as_generator then nvm.running_as_generator = true power.generator_start(pos, Cable, CYCLE_TIME, outdir, nvm.max_power) elseif not nvm.consumer_powered and nvm.running_as_generator then nvm.running_as_generator = false power.generator_stop(pos, Cable, outdir) end if nvm.running_as_generator then nvm.axle.curr_power = power.generator_alive(pos, Cable, CYCLE_TIME, outdir, PWR_PERF) + 1 else swap_node(pos, "techage:ta2_generator_off") end end return true end local function tubelib2_on_update2(pos, outdir, tlib2, node) local nvm = techage.get_nvm(pos) nvm.axle = nvm.axle or {} nvm.axle.curr_power = 1 power.update_network(pos, outdir, tlib2) end minetest.register_node("techage:ta2_generator_off", { description = S("TA2 Power Generator"), tiles = { -- up, down, right, left, back, front "techage_filling_ta2.png^techage_frame_ta2_top.png^techage_appl_arrow.png", "techage_filling_ta2.png^techage_frame_ta2.png", "techage_filling_ta2.png^techage_frame_ta2.png^techage_appl_hole_electric.png", "techage_filling_ta2.png^techage_axle_clutch.png^techage_frame_ta2.png", "techage_filling_ta2.png^techage_frame_ta2.png^techage_appl_generator_red.png", "techage_filling_ta2.png^techage_frame_ta2.png^techage_appl_generator_red.png^[transformFX]", }, paramtype2 = "facedir", groups = {cracky=2, crumbly=2, choppy=2}, on_rotate = screwdriver.disallow, is_ground_content = false, after_place_node = function(pos) local nvm = techage.get_nvm(pos) nvm.axle = nvm.axle or {} nvm.axle.curr_power = 1 nvm.consumer_powered = false nvm.running_as_generator = false M(pos):set_int("outdir", networks.side_to_outdir(pos, "R")) M(pos):set_int("leftdir", networks.side_to_outdir(pos, "L")) Cable:after_place_node(pos) Axle:after_place_node(pos) minetest.get_node_timer(pos):start(CYCLE_TIME) power.consumer_start(pos, Axle, CYCLE_TIME*2) M(pos):set_string("infotext", S("TA2 Power Generator")) end, on_rightclick = function(pos, node, clicker) local nvm = techage.get_nvm(pos) nvm.axle = nvm.axle or {} nvm.axle.curr_power = 1 M(pos):set_string("infotext", S("TA2 Power Generator")) end, after_dig_node = function(pos, oldnode) Cable:after_dig_node(pos) Axle:after_dig_node(pos) techage.del_mem(pos) end, tubelib2_on_update2 = tubelib2_on_update2, on_timer = node_timer, networks = { ele1 = { sides = {R = 1}, ntype = "gen1", nominal = PWR_PERF, }, axle = { sides = {L = 1}, ntype = "con1", on_power = on_power, on_nopower = on_nopower, }, } }) minetest.register_node("techage:ta2_generator_on", { description = S("TA2 Power Generator"), tiles = { -- up, down, right, left, back, front "techage_filling_ta2.png^techage_frame_ta2_top.png^techage_appl_arrow.png", "techage_filling_ta2.png^techage_frame_ta2.png", "techage_filling_ta2.png^techage_frame_ta2.png^techage_appl_hole_electric.png", { image = "techage_filling4_ta2.png^techage_axle_clutch4.png^techage_frame4_ta2.png", backface_culling = false, animation = { type = "vertical_frames", aspect_w = 32, aspect_h = 32, length = 0.6, }, }, { image = "techage_filling4_ta2.png^techage_appl_generator_red4.png^techage_frame4_ta2.png", backface_culling = false, animation = { type = "vertical_frames", aspect_w = 32, aspect_h = 32, length = 0.3, }, }, { image = "techage_filling4_ta2.png^techage_appl_generator_red4.png^[transformFX]^techage_frame4_ta2.png", backface_culling = false, animation = { type = "vertical_frames", aspect_w = 32, aspect_h = 32, length = 0.3, }, }, }, paramtype2 = "facedir", on_rotate = screwdriver.disallow, is_ground_content = false, drop = "", groups = {not_in_creative_inventory=1}, diggable = false, tubelib2_on_update2 = tubelib2_on_update2, on_timer = node_timer, networks = { ele1 = { sides = {R = 1}, ntype = "gen1", nominal = PWR_PERF, }, axle = { sides = {L = 1}, ntype = "con1", on_power = on_power, on_nopower = on_nopower, }, } }) techage.register_node({"techage:ta2_generator_off", "techage:ta2_generator_on"}, { on_node_load = function(pos, node) minetest.get_node_timer(pos):start(CYCLE_TIME) end, }) Cable:add_secondary_node_names({"techage:ta2_generator_off", "techage:ta2_generator_on"}) Axle:add_secondary_node_names({"techage:ta2_generator_off", "techage:ta2_generator_on"}) minetest.register_craft({ output = "techage:ta2_generator_off", recipe = { {"basic_materials:steel_bar", "dye:red", "default:wood"}, {'techage:axle', 'basic_materials:gear_steel', 'techage:electric_cableS'}, {"default:wood", "techage:iron_ingot", "basic_materials:steel_bar"}, }, })