techage/fusion_reactor/magnet.lua
2023-05-18 18:32:08 +02:00

272 lines
7.6 KiB
Lua

--[[
TechAge
=======
Copyright (C) 2019-2022 Joachim Stolberg
AGPL v3
See LICENSE.txt for more information
TA5 Fusion Reactor Magnet
]]--
-- for lazy programmers
local S2P = minetest.string_to_pos
local P2S = minetest.pos_to_string
local M = minetest.get_meta
local S = techage.S
local Cable = techage.ElectricCable
local Pipe = techage.GasPipe
local power = networks.power
local liquid = networks.liquid
local control = networks.control
local CAPACITY = 6
local SHELLBLOCKS = {"techage:ta5_fr_shell", "techage:ta5_fr_nucleus", "techage:ta5_magnet1", "techage:ta5_magnet2"}
minetest.register_node("techage:ta5_magnet1", {
description = S("TA5 Fusion Reactor Magnet 1"),
tiles = {
-- up, down, right, left, back, front
"techage_collider_magnet.png^techage_appl_hole_ta5_pipe1.png^techage_steel_tiles_top.png^[transformR180]",
"techage_collider_magnet.png^techage_appl_hole_ta5_pipe2.png^techage_steel_tiles_top.png",
"techage_collider_magnet.png^techage_steel_tiles_side.png",
"techage_collider_magnet.png^techage_steel_tiles_side.png^[transformR180]",
"techage_collider_magnet.png^techage_appl_hole_electric.png",
"techage_steel_tiles.png",
},
after_place_node = function(pos, placer, itemstack)
Pipe:after_place_node(pos)
Cable:after_place_node(pos)
end,
ta_rotate_node = function(pos, node, new_param2)
Pipe:after_dig_node(pos)
Cable:after_dig_node(pos)
minetest.swap_node(pos, {name = node.name, param2 = new_param2})
Pipe:after_place_node(pos)
Cable:after_place_node(pos)
end,
after_dig_node = function(pos, oldnode)
Pipe:after_dig_node(pos)
Cable:after_dig_node(pos)
techage.del_mem(pos)
end,
paramtype2 = "facedir",
groups = {choppy=2, cracky=2, crumbly=2},
is_ground_content = false,
sounds = default.node_sound_metal_defaults(),
})
minetest.register_node("techage:ta5_magnet2", {
description = S("TA5 Fusion Reactor Magnet 2"),
tiles = {
-- up, down, right, left, back, front
"techage_collider_magnet.png^techage_appl_hole_ta5_pipe1.png^techage_steel_tiles_top2.png^[transformR180]",
"techage_collider_magnet.png^techage_appl_hole_ta5_pipe2.png^techage_steel_tiles_top2.png^[transformR270]",
"techage_steel_tiles.png",
"techage_collider_magnet.png^techage_steel_tiles_side.png^[transformR180]",
"techage_collider_magnet.png^techage_steel_tiles_side.png",
"techage_steel_tiles.png",
},
after_place_node = function(pos, placer, itemstack)
Pipe:after_place_node(pos)
Cable:after_place_node(pos)
end,
ta_rotate_node = function(pos, node, new_param2)
Pipe:after_dig_node(pos)
Cable:after_dig_node(pos)
minetest.swap_node(pos, {name = node.name, param2 = new_param2})
Pipe:after_place_node(pos)
Cable:after_place_node(pos)
end,
after_dig_node = function(pos, oldnode)
Pipe:after_dig_node(pos)
Cable:after_dig_node(pos)
techage.del_mem(pos)
end,
paramtype2 = "facedir",
groups = {choppy=2, cracky=2, crumbly=2},
is_ground_content = false,
sounds = default.node_sound_metal_defaults(),
})
power.register_nodes({"techage:ta5_magnet1"}, Cable, "con", {"B"})
liquid.register_nodes({"techage:ta5_magnet1", "techage:ta5_magnet2"}, Pipe, "tank", {"U", "D"}, {
capa = CAPACITY,
peek = function(pos, indir)
local nvm = techage.get_nvm(pos)
return liquid.srv_peek(nvm)
end,
put = function(pos, indir, name, amount)
local nvm = techage.get_nvm(pos)
return liquid.srv_put(nvm, name, amount, CAPACITY)
end,
take = function(pos, indir, name, amount)
local nvm = techage.get_nvm(pos)
return liquid.srv_take(nvm, name, amount)
end,
untake = function(pos, indir, name, amount)
local nvm = techage.get_nvm(pos)
liquid.srv_put(nvm, name, amount, CAPACITY)
end,
})
local function check_plasma(pos, param2)
local pos1 = networks.get_relpos(pos, "F", param2)
local node = minetest.get_node(pos1) or {}
return node.name == "air"
end
local function swap_plasma(pos, name, param2)
local pos1 = networks.get_relpos(pos, "F", param2)
minetest.swap_node(pos1, {name = name, param2 = param2})
end
local function check_shell(pos, param2)
local pos1 = networks.get_relpos(pos, "D", param2)
local pos2 = networks.get_relpos(pos, "BU", param2)
local _,t = minetest.find_nodes_in_area(pos1, pos2, SHELLBLOCKS)
local cnt = 0
for k,v in pairs(t) do
cnt = cnt + v
end
return cnt == 6
end
local function check_nucleus(pos, param2)
local pos1 = networks.get_relpos(pos, "B", param2)
local node = minetest.get_node(pos1) or {}
if node.name == "techage:ta5_fr_nucleus" then
return pos1
end
end
local function on_receive(pos, tlib2, topic, payload)
--print("on_receive", topic)
local nvm = techage.get_nvm(pos)
if topic == "on" then
nvm.running = true
elseif topic == "off" then
nvm.running = false
end
end
local function rst_power(nvm)
nvm.power = 0
return true
end
local function inc_power(nvm)
nvm.power = nvm.power or 0
if nvm.power < 0 then nvm.power = 0 end
nvm.power = nvm.power + 1
return nvm.power <= 2
end
local function dec_power(nvm)
nvm.power = nvm.power or 0
if nvm.power > 0 then nvm.power = 0 end
nvm.power = nvm.power - 1
return nvm.power >= -2
end
local function on_request(pos, tlib2, topic)
local nvm = techage.get_nvm(pos)
nvm.liquid = nvm.liquid or {}
nvm.liquid.amount = nvm.liquid.amount or 0
if tlib2 == Cable then
if topic == "connect" then
return true
elseif topic == "inc_power" then
return inc_power(nvm)
elseif topic == "test_plasma" then
local node = minetest.get_node(pos) or {}
return check_plasma(pos, node.param2)
elseif topic == "test_shell" then
local node = minetest.get_node(pos) or {}
return check_shell(pos, node.param2)
elseif topic == "test_nucleus" then
local node = minetest.get_node(pos) or {}
return check_nucleus(pos, node.param2)
elseif topic == "no_gas" then
nvm.liquid.amount = 0
return true
end
else -- Pipe
if topic == "dec_power" then
return dec_power(nvm)
elseif topic == "test_pipe_blue" then
nvm.test_pipe = true
return true
elseif topic == "test_pipe_green" then
local res = nvm.test_pipe
nvm.test_pipe = false
return res
elseif topic == "test_gas_blue" then
nvm.has_gas = true
return nvm.liquid.amount == CAPACITY
elseif topic == "test_gas_green" then
local res = nvm.has_gas
nvm.has_gas = false
return res
end
end
if topic == "rst_power" then
return rst_power(nvm)
end
return false
end
control.register_nodes({"techage:ta5_magnet1", "techage:ta5_magnet2"}, {
on_receive = on_receive,
on_request = on_request,
}
)
minetest.register_craftitem("techage:ta5_magnet_blank", {
description = S("TA5 Fusion Reactor Magnet Blank"),
inventory_image = "techage_collider_magnet.png^techage_appl_hole_electric.png",
})
minetest.register_craftitem("techage:ta5_magnet_shield", {
description = S("TA5 Fusion Reactor Magnet Shield"),
inventory_image = "techage_steel_tiles.png",
})
techage.furnace.register_recipe({
output = "techage:ta5_magnet_shield 2",
recipe = {"default:steel_ingot", "techage:usmium_powder", "techage:graphite_powder"},
time = 2,
})
minetest.register_craft({
output = "techage:ta5_magnet_blank 2",
recipe = {
{'default:steel_ingot', 'techage:electric_cableS', 'techage:aluminum'},
{'techage:ta5_pipe1S', 'basic_materials:gold_wire', 'techage:ta5_pipe2S'},
{'techage:aluminum', 'dye:brown', 'default:steel_ingot'},
},
})
minetest.register_craft({
output = "techage:ta5_magnet1",
recipe = {
{'', 'techage:ta5_magnet_shield', 'techage:ta5_magnet_blank'},
{'', '', ''},
{'', '', ''},
},
})
minetest.register_craft({
output = "techage:ta5_magnet2",
recipe = {
{'', 'techage:ta5_magnet_shield', 'techage:ta5_magnet_blank'},
{'', '', 'techage:ta5_magnet_shield'},
{'', '', ''},
},
})