reactor and doser activated
This commit is contained in:
parent
406b5ad6a5
commit
0a27fb122c
@ -42,10 +42,8 @@ local function on_rightclick(pos, node, clicker)
|
|||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
if not mem.running and power.power_available(pos, mem, PWR_NEEDED) then
|
if not mem.running and power.power_available(pos, mem, PWR_NEEDED) then
|
||||||
mem.running = true
|
mem.running = true
|
||||||
--swap_node(pos, "techage:sink_on")
|
|
||||||
power.consumer_start(pos, mem, CYCLE_TIME, PWR_NEEDED)
|
power.consumer_start(pos, mem, CYCLE_TIME, PWR_NEEDED)
|
||||||
minetest.get_node_timer(pos):start(CYCLE_TIME)
|
M(pos):set_string("infotext", "...")
|
||||||
M(pos):set_string("infotext", "on")
|
|
||||||
else
|
else
|
||||||
mem.running = false
|
mem.running = false
|
||||||
swap_node(pos, "techage:sink")
|
swap_node(pos, "techage:sink")
|
||||||
|
@ -21,10 +21,9 @@ local recipes = techage.recipes
|
|||||||
|
|
||||||
local Liquids = {} -- {hash(pos) = {name = outdir},...}
|
local Liquids = {} -- {hash(pos) = {name = outdir},...}
|
||||||
|
|
||||||
local STANDBY_TICKS = 0
|
local STANDBY_TICKS = 4
|
||||||
local COUNTDOWN_TICKS = 6
|
local COUNTDOWN_TICKS = 4
|
||||||
local CYCLE_TIME = 2
|
local CYCLE_TIME = 4
|
||||||
local POWER_NEED = 10
|
|
||||||
|
|
||||||
local function formspec(self, pos, mem)
|
local function formspec(self, pos, mem)
|
||||||
return "size[8,7]"..
|
return "size[8,7]"..
|
||||||
@ -73,20 +72,24 @@ end
|
|||||||
|
|
||||||
local function can_start(pos, mem, state)
|
local function can_start(pos, mem, state)
|
||||||
-- check reactor
|
-- check reactor
|
||||||
local res = reactor_cmnd(pos, "can_start")
|
local res = reactor_cmnd(pos, "check")
|
||||||
if not res then
|
if not res then
|
||||||
return S("reactor defect")
|
return S("reactor defect")
|
||||||
end
|
end
|
||||||
|
res = reactor_cmnd(pos, "can_start")
|
||||||
|
if not res then
|
||||||
|
return S("reactor defect or no power")
|
||||||
|
end
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
local function start_node(pos, mem, state)
|
local function start_node(pos, mem, state)
|
||||||
reactor_cmnd(pos, "start", {cycle_time = CYCLE_TIME, pwr_needed = POWER_NEED})
|
reactor_cmnd(pos, "start")
|
||||||
mem.running = true
|
mem.running = true
|
||||||
end
|
end
|
||||||
|
|
||||||
local function stop_node(pos, mem, state)
|
local function stop_node(pos, mem, state)
|
||||||
reactor_cmnd(pos, "stop", nil)
|
reactor_cmnd(pos, "stop")
|
||||||
mem.running = false
|
mem.running = false
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -108,35 +111,43 @@ end
|
|||||||
|
|
||||||
local function dosing(pos, mem, elapsed)
|
local function dosing(pos, mem, elapsed)
|
||||||
-- trigger reactor (power)
|
-- trigger reactor (power)
|
||||||
if not reactor_cmnd(pos, "power", POWER_NEED) then
|
if not reactor_cmnd(pos, "power") then
|
||||||
State:nopower(pos, mem, S("reactor has no power"))
|
if not mem.techage_countdown or mem.techage_countdown < 2 then
|
||||||
|
State:nopower(pos, mem, S("reactor has no power"))
|
||||||
|
end
|
||||||
|
State:idle(pos, mem)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
-- available liquids
|
-- -- available liquids
|
||||||
local liquids = get_liquids(pos)
|
-- local liquids = get_liquids(pos)
|
||||||
local recipe = recipes.get(mem, "ta4_doser")
|
-- local recipe = recipes.get(mem, "ta4_doser")
|
||||||
if not liquids or not recipe then return end
|
-- if not liquids or not recipe then return end
|
||||||
-- inputs
|
-- -- inputs
|
||||||
for _,item in pairs(recipe.input) do
|
-- for _,item in pairs(recipe.input) do
|
||||||
if item.name ~= "" then
|
-- if item.name ~= "" then
|
||||||
print("dosing", item.name, dump(liquids))
|
-- print("dosing", item.name, dump(liquids))
|
||||||
local outdir = liquids[item.name]
|
-- local outdir = liquids[item.name]
|
||||||
if not outdir then
|
-- if not outdir then
|
||||||
State:fault(pos, mem, S("input missing"))
|
-- State:fault(pos, mem, S("input missing"))
|
||||||
return
|
-- return
|
||||||
end
|
-- end
|
||||||
if liquid.take(pos, outdir, item.name, item.num) < item.num then
|
-- if liquid.take(pos, outdir, item.name, item.num) < item.num then
|
||||||
State:fault(pos, mem, S("input missing"))
|
-- State:fault(pos, mem, S("input missing"))
|
||||||
return
|
-- return
|
||||||
end
|
-- end
|
||||||
end
|
-- end
|
||||||
end
|
-- end
|
||||||
-- output
|
-- output
|
||||||
if not reactor_cmnd(pos, "output", recipe.output.name) then
|
--if not reactor_cmnd(pos, "output", recipe.output.name) then
|
||||||
|
local leftover
|
||||||
|
leftover = reactor_cmnd(pos, "output", {name = "techage:gasoline", amount = 1, player_name = "singleplayer"})
|
||||||
|
if not leftover or leftover > 0 then
|
||||||
State:fault(pos, mem, S("output blocked"))
|
State:fault(pos, mem, S("output blocked"))
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
if not reactor_cmnd(pos, "waste", recipe.waste.name) then
|
--if not reactor_cmnd(pos, "waste", recipe.waste.name) then
|
||||||
|
leftover = reactor_cmnd(pos, "waste", {name = "techage:bitumen", amount = 1, player_name = "singleplayer"})
|
||||||
|
if not leftover or leftover > 0 then
|
||||||
State:fault(pos, mem, S("output blocked"))
|
State:fault(pos, mem, S("output blocked"))
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
@ -13,100 +13,13 @@
|
|||||||
]]--
|
]]--
|
||||||
|
|
||||||
local S = techage.S
|
local S = techage.S
|
||||||
|
local M = minetest.get_meta
|
||||||
local Cable = techage.ElectricCable
|
local Cable = techage.ElectricCable
|
||||||
local power = techage.power
|
local power = techage.power
|
||||||
local Pipe = techage.LiquidPipe
|
local Pipe = techage.LiquidPipe
|
||||||
local networks = techage.networks
|
local networks = techage.networks
|
||||||
local liquid = techage.liquid
|
local liquid = techage.liquid
|
||||||
|
|
||||||
-- pos of the reactor stand
|
|
||||||
local function on_power(pos, mem)
|
|
||||||
mem.running = true
|
|
||||||
end
|
|
||||||
|
|
||||||
local function on_nopower(pos, mem)
|
|
||||||
mem.running = false
|
|
||||||
end
|
|
||||||
|
|
||||||
minetest.register_node("techage:ta4_reactor", {
|
|
||||||
description = S("TA4 Reactor"),
|
|
||||||
tiles = {"techage_reactor_side.png"},
|
|
||||||
drawtype = "mesh",
|
|
||||||
mesh = "techage_cylinder_12h.obj",
|
|
||||||
selection_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {-1/2, -23/32, -1/2, 1/2, 32/32, 1/2},
|
|
||||||
},
|
|
||||||
collision_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {-1/2, -23/32, -1/2, 1/2, 32/32, 1/2},
|
|
||||||
},
|
|
||||||
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
on_rotate = screwdriver.disallow,
|
|
||||||
groups = {cracky=2},
|
|
||||||
is_ground_content = false,
|
|
||||||
sounds = default.node_sound_metal_defaults(),
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("techage:ta4_reactor_stand", {
|
|
||||||
description = S("TA4 Reactor"),
|
|
||||||
tiles = {
|
|
||||||
-- up, down, right, left, back, front
|
|
||||||
"techage_reactor_stand_top.png^[transformR90",
|
|
||||||
"techage_reactor_stand_bottom.png^[transformFY^[transformR270",
|
|
||||||
"techage_reactor_stand_front.png",
|
|
||||||
"techage_reactor_stand_back.png",
|
|
||||||
"techage_reactor_stand_side.png^[transformFX",
|
|
||||||
"techage_reactor_stand_side.png",
|
|
||||||
},
|
|
||||||
drawtype = "nodebox",
|
|
||||||
node_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{ -8/16, 2/16, -8/16, 8/16, 4/16, 8/16 },
|
|
||||||
|
|
||||||
{ -8/16, -8/16, -8/16, -6/16, 8/16, -6/16 },
|
|
||||||
{ 6/16, -8/16, -8/16, 8/16, 8/16, -6/16 },
|
|
||||||
{ -8/16, -8/16, 6/16, -6/16, 8/16, 8/16 },
|
|
||||||
{ 6/16, -8/16, 6/16, 8/16, 8/16, 8/16 },
|
|
||||||
|
|
||||||
{-1/8, -4/8, -1/8, 1/8, 4/8, 1/8},
|
|
||||||
|
|
||||||
{-4/8, -1/8, -1/8, 4/8, 1/8, 1/8},
|
|
||||||
-- {-3/8, -1/8, -4/8, 3/8, 1/8, -3/8},
|
|
||||||
{-4/8, -1/8, -3/8, -3/8, 1/8, 3/8},
|
|
||||||
|
|
||||||
-- {-3/8, -1/8, 3/8, 3/8, 1/8, 4/8},
|
|
||||||
{ 3/8, -1/8, -3/8, 4/8, 1/8, 3/8},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
selection_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {-1/2, -1/2, -1/2, 1/2, 1/2, 1/2},
|
|
||||||
},
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
on_rotate = screwdriver.disallow,
|
|
||||||
groups = {cracky=2},
|
|
||||||
is_ground_content = false,
|
|
||||||
sounds = default.node_sound_metal_defaults(),
|
|
||||||
|
|
||||||
networks = {
|
|
||||||
pipe = {
|
|
||||||
sides = {R=1}, -- Pipe connection sides
|
|
||||||
ntype = "pump",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
})
|
|
||||||
|
|
||||||
-- for electrical connections
|
|
||||||
techage.power.register_node({"techage:ta4_reactor_stand"}, {
|
|
||||||
conn_sides = {"L"},
|
|
||||||
power_network = Cable,
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("techage:ta4_reactor_fillerpipe", {
|
minetest.register_node("techage:ta4_reactor_fillerpipe", {
|
||||||
description = S("TA4 Reactor Filler Pipe"),
|
description = S("TA4 Reactor Filler Pipe"),
|
||||||
tiles = {
|
tiles = {
|
||||||
@ -130,7 +43,6 @@ minetest.register_node("techage:ta4_reactor_fillerpipe", {
|
|||||||
},
|
},
|
||||||
after_place_node = function(pos)
|
after_place_node = function(pos)
|
||||||
local pos1 = {x = pos.x, y = pos.y-1, z = pos.z}
|
local pos1 = {x = pos.x, y = pos.y-1, z = pos.z}
|
||||||
print(minetest.get_node(pos1).name)
|
|
||||||
if minetest.get_node(pos1).name == "air" then
|
if minetest.get_node(pos1).name == "air" then
|
||||||
local node = minetest.get_node(pos)
|
local node = minetest.get_node(pos)
|
||||||
minetest.remove_node(pos)
|
minetest.remove_node(pos)
|
||||||
@ -161,70 +73,63 @@ minetest.register_node("techage:ta4_reactor_fillerpipe", {
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
|
local function stand_cmnd(pos, cmnd, payload)
|
||||||
|
return techage.transfer(
|
||||||
|
{x = pos.x, y = pos.y-1, z = pos.z},
|
||||||
|
5, -- outdir
|
||||||
|
cmnd, -- topic
|
||||||
|
payload, -- payload
|
||||||
|
nil, -- network
|
||||||
|
{"techage:ta4_reactor_stand"})
|
||||||
|
end
|
||||||
|
|
||||||
|
local function base_waste(pos, payload)
|
||||||
|
local pos2 = {x = pos.x, y = pos.y-3, z = pos.z}
|
||||||
|
local outdir = M(pos2):get_int("outdir")
|
||||||
|
return liquid.put(pos2, outdir, payload.name, payload.amount, payload.player_name)
|
||||||
|
end
|
||||||
|
|
||||||
-- controlled by the doser
|
-- controlled by the doser
|
||||||
techage.register_node({"techage:ta4_reactor_fillerpipe"}, {
|
techage.register_node({"techage:ta4_reactor_fillerpipe"}, {
|
||||||
on_transfer = function(pos, in_dir, topic, payload)
|
on_transfer = function(pos, in_dir, topic, payload)
|
||||||
-- pos of the reactor stand
|
if topic == "check" then
|
||||||
local pos2 = {x = pos.x, y = pos.y-2, z = pos.z}
|
local pos2,node = Pipe:get_node(pos, 5)
|
||||||
local mem = tubelib2.get_mem(pos2)
|
if not node or node.name ~= "techage:ta4_reactor" then
|
||||||
if topic == "power" then
|
return false
|
||||||
power.consumer_alive(pos2, mem)
|
end
|
||||||
return mem.running
|
pos2,node = Pipe:get_node(pos2, 5)
|
||||||
elseif topic == "can_start" then
|
if not node or node.name ~= "techage:ta4_reactor_stand" then
|
||||||
local pos1 = {x = pos.x, y = pos.y-1, z = pos.z}
|
return false
|
||||||
if minetest.get_node(pos1).name ~= "techage:ta4_reactor" then return false end
|
end
|
||||||
if minetest.get_node(pos2).name ~= "techage:ta4_reactor_stand" then return false end
|
|
||||||
return true
|
|
||||||
elseif topic == "start" and payload then
|
|
||||||
mem.running = true
|
|
||||||
power.consumer_start(pos2, mem, payload.cycle_time or 0, payload.pwr_needed or 0)
|
|
||||||
return true
|
|
||||||
elseif topic == "stop" then
|
|
||||||
mem.running = false
|
|
||||||
power.consumer_stop(pos2, mem)
|
|
||||||
return true
|
return true
|
||||||
|
elseif topic == "waste" then
|
||||||
|
return base_waste(pos, payload or {})
|
||||||
|
else
|
||||||
|
return stand_cmnd(pos, topic, payload or {})
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_node("techage:ta4_reactor_base", {
|
minetest.register_node("techage:ta4_reactor", {
|
||||||
description = S("TA4 Reactor Base"),
|
description = S("TA4 Reactor"),
|
||||||
tiles = {
|
tiles = {"techage_reactor_side.png"},
|
||||||
-- up, down, right, left, back, front
|
drawtype = "mesh",
|
||||||
"techage_concrete.png^techage_appl_arrowXL.png^techage_appl_hole_pipe.png^[transformR270",
|
mesh = "techage_cylinder_12h.obj",
|
||||||
"techage_concrete.png",
|
selection_box = {
|
||||||
"techage_concrete.png^techage_appl_hole_pipe.png",
|
type = "fixed",
|
||||||
"techage_concrete.png",
|
fixed = {-1/2, -23/32, -1/2, 1/2, 32/32, 1/2},
|
||||||
"techage_concrete.png",
|
|
||||||
"techage_concrete.png",
|
|
||||||
},
|
},
|
||||||
|
collision_box = {
|
||||||
after_place_node = function(pos, placer)
|
type = "fixed",
|
||||||
Pipe:after_place_node(pos)
|
fixed = {-1/2, -23/32, -1/2, 1/2, 32/32, 1/2},
|
||||||
end,
|
},
|
||||||
tubelib2_on_update2 = function(pos, dir, tlib2, node)
|
|
||||||
liquid.update_network(pos)
|
paramtype = "light",
|
||||||
end,
|
|
||||||
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
|
||||||
Pipe:after_dig_node(pos)
|
|
||||||
end,
|
|
||||||
|
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
on_rotate = screwdriver.disallow,
|
on_rotate = screwdriver.disallow,
|
||||||
groups = {cracky=2},
|
groups = {cracky=2},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
sounds = default.node_sound_stone_defaults(),
|
sounds = default.node_sound_metal_defaults(),
|
||||||
|
|
||||||
networks = {
|
|
||||||
pipe = {
|
|
||||||
sides = {R=1}, -- Pipe connection sides
|
|
||||||
ntype = "pump",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
})
|
})
|
||||||
|
|
||||||
Pipe:add_secondary_node_names({
|
Pipe:add_secondary_node_names({"techage:ta4_reactor_fillerpipe"})
|
||||||
"techage:ta4_reactor_base",
|
|
||||||
"techage:ta4_reactor_fillerpipe",
|
|
||||||
"techage:ta4_reactor_stand",
|
|
||||||
})
|
|
||||||
|
201
chemistry/ta4_stand.lua
Normal file
201
chemistry/ta4_stand.lua
Normal file
@ -0,0 +1,201 @@
|
|||||||
|
--[[
|
||||||
|
|
||||||
|
TechAge
|
||||||
|
=======
|
||||||
|
|
||||||
|
Copyright (C) 2019 Joachim Stolberg
|
||||||
|
|
||||||
|
GPL v3
|
||||||
|
See LICENSE.txt for more information
|
||||||
|
|
||||||
|
TA4 Reactor Stand and Base
|
||||||
|
|
||||||
|
]]--
|
||||||
|
|
||||||
|
local S = techage.S
|
||||||
|
local M = minetest.get_meta
|
||||||
|
local Cable = techage.ElectricCable
|
||||||
|
local power = techage.power
|
||||||
|
local Pipe = techage.LiquidPipe
|
||||||
|
local networks = techage.networks
|
||||||
|
local liquid = techage.liquid
|
||||||
|
|
||||||
|
local PWR_NEEDED = 8
|
||||||
|
local CYCLE_TIME = 4
|
||||||
|
|
||||||
|
local function on_power(pos, mem)
|
||||||
|
if mem.running then
|
||||||
|
minetest.get_node_timer(pos):start(CYCLE_TIME)
|
||||||
|
M(pos):set_string("infotext", S("on"))
|
||||||
|
mem.has_power = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function on_nopower(pos, mem)
|
||||||
|
M(pos):set_string("infotext", S("no power"))
|
||||||
|
mem.has_power = false
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_node("techage:ta4_reactor_stand", {
|
||||||
|
description = S("TA4 Reactor"),
|
||||||
|
tiles = {
|
||||||
|
-- up, down, right, left, back, front
|
||||||
|
"techage_reactor_stand_top.png^[transformR90",
|
||||||
|
"techage_reactor_stand_bottom.png^[transformFY^[transformR270",
|
||||||
|
"techage_reactor_stand_front.png",
|
||||||
|
"techage_reactor_stand_back.png",
|
||||||
|
"techage_reactor_stand_side.png^[transformFX",
|
||||||
|
"techage_reactor_stand_side.png",
|
||||||
|
},
|
||||||
|
drawtype = "nodebox",
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{ -8/16, 2/16, -8/16, 8/16, 4/16, 8/16 },
|
||||||
|
|
||||||
|
{ -8/16, -8/16, -8/16, -6/16, 8/16, -6/16 },
|
||||||
|
{ 6/16, -8/16, -8/16, 8/16, 8/16, -6/16 },
|
||||||
|
{ -8/16, -8/16, 6/16, -6/16, 8/16, 8/16 },
|
||||||
|
{ 6/16, -8/16, 6/16, 8/16, 8/16, 8/16 },
|
||||||
|
|
||||||
|
{-1/8, -4/8, -1/8, 1/8, 4/8, 1/8},
|
||||||
|
{-4/8, -1/8, -1/8, 4/8, 1/8, 1/8},
|
||||||
|
{-4/8, -1/8, -3/8, -3/8, 1/8, 3/8},
|
||||||
|
{ 3/8, -1/8, -3/8, 4/8, 1/8, 3/8},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
selection_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {-1/2, -1/2, -1/2, 1/2, 1/2, 1/2},
|
||||||
|
},
|
||||||
|
|
||||||
|
after_place_node = function(pos, placer)
|
||||||
|
local mem = tubelib2.init_mem(pos)
|
||||||
|
techage.power.after_place_node(pos)
|
||||||
|
M(pos):set_string("infotext", S("off"))
|
||||||
|
M(pos):set_int("outdir", networks.side_to_outdir(pos, "R"))
|
||||||
|
Pipe:after_place_node(pos)
|
||||||
|
end,
|
||||||
|
tubelib2_on_update2 = function(pos, dir, tlib2, node)
|
||||||
|
liquid.update_network(pos)
|
||||||
|
end,
|
||||||
|
after_tube_update = function(node, pos, out_dir, peer_pos, peer_in_dir)
|
||||||
|
techage.power.after_tube_update2(node, pos, out_dir, peer_pos, peer_in_dir)
|
||||||
|
end,
|
||||||
|
on_timer = function(pos, elapsed)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
power.consumer_alive(pos, mem)
|
||||||
|
return mem.running
|
||||||
|
end,
|
||||||
|
on_rightclick = function(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
|
||||||
|
power.consumer_start(pos, mem, CYCLE_TIME, PWR_NEEDED)
|
||||||
|
M(pos):set_string("infotext", "...")
|
||||||
|
else
|
||||||
|
mem.running = false
|
||||||
|
power.consumer_stop(pos, mem)
|
||||||
|
minetest.get_node_timer(pos):stop()
|
||||||
|
M(pos):set_string("infotext", S("off"))
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
after_dig_node = function(pos, oldnode)
|
||||||
|
techage.power.after_dig_node(pos, oldnode)
|
||||||
|
Pipe:after_dig_node(pos)
|
||||||
|
tubelib2.del_mem(pos)
|
||||||
|
end,
|
||||||
|
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
on_rotate = screwdriver.disallow,
|
||||||
|
groups = {cracky=2},
|
||||||
|
is_ground_content = false,
|
||||||
|
sounds = default.node_sound_metal_defaults(),
|
||||||
|
-- Pipe connection
|
||||||
|
networks = {
|
||||||
|
pipe = {
|
||||||
|
sides = {R=1},
|
||||||
|
ntype = "pump",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
-- for electrical connections
|
||||||
|
techage.power.enrich_node({"techage:ta4_reactor_stand"}, {
|
||||||
|
conn_sides = {"L"},
|
||||||
|
power_network = Cable,
|
||||||
|
on_power = on_power,
|
||||||
|
on_nopower = on_nopower,
|
||||||
|
})
|
||||||
|
|
||||||
|
-- controlled by the fillerpipe
|
||||||
|
techage.register_node({"techage:ta4_reactor_stand"}, {
|
||||||
|
on_transfer = function(pos, in_dir, topic, payload)
|
||||||
|
print(topic, payload)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
if topic == "power" then
|
||||||
|
return mem.has_power
|
||||||
|
elseif topic == "output" then
|
||||||
|
local outdir = M(pos):get_int("outdir")
|
||||||
|
return liquid.put(pos, outdir, payload.name, payload.amount, payload.player_name)
|
||||||
|
elseif topic == "can_start" then
|
||||||
|
return power.power_available(pos, mem, 0)
|
||||||
|
elseif topic == "start" and payload then
|
||||||
|
mem.running = true
|
||||||
|
mem.has_power = false
|
||||||
|
power.consumer_start(pos, mem, CYCLE_TIME, PWR_NEEDED)
|
||||||
|
M(pos):set_string("infotext", "...")
|
||||||
|
return true
|
||||||
|
elseif topic == "stop" then
|
||||||
|
mem.running = false
|
||||||
|
mem.has_power = false
|
||||||
|
power.consumer_stop(pos, mem)
|
||||||
|
minetest.get_node_timer(pos):stop()
|
||||||
|
M(pos):set_string("infotext", S("off"))
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_node("techage:ta4_reactor_base", {
|
||||||
|
description = S("TA4 Reactor Base"),
|
||||||
|
tiles = {
|
||||||
|
-- up, down, right, left, back, front
|
||||||
|
"techage_concrete.png^techage_appl_arrowXL.png^techage_appl_hole_pipe.png^[transformR270",
|
||||||
|
"techage_concrete.png",
|
||||||
|
"techage_concrete.png^techage_appl_hole_pipe.png",
|
||||||
|
"techage_concrete.png",
|
||||||
|
"techage_concrete.png",
|
||||||
|
"techage_concrete.png",
|
||||||
|
},
|
||||||
|
|
||||||
|
after_place_node = function(pos, placer)
|
||||||
|
M(pos):set_int("outdir", networks.side_to_outdir(pos, "R"))
|
||||||
|
Pipe:after_place_node(pos)
|
||||||
|
end,
|
||||||
|
tubelib2_on_update2 = function(pos, dir, tlib2, node)
|
||||||
|
liquid.update_network(pos)
|
||||||
|
end,
|
||||||
|
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
||||||
|
Pipe:after_dig_node(pos)
|
||||||
|
end,
|
||||||
|
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
on_rotate = screwdriver.disallow,
|
||||||
|
groups = {cracky=2},
|
||||||
|
is_ground_content = false,
|
||||||
|
sounds = default.node_sound_stone_defaults(),
|
||||||
|
|
||||||
|
networks = {
|
||||||
|
pipe = {
|
||||||
|
sides = {R=1}, -- Pipe connection sides
|
||||||
|
ntype = "pump",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
Pipe:add_secondary_node_names({
|
||||||
|
"techage:ta4_reactor_base",
|
||||||
|
"techage:ta4_reactor_stand",
|
||||||
|
})
|
@ -37,14 +37,23 @@ local function swap_node(pos, name)
|
|||||||
minetest.swap_node(pos, node)
|
minetest.swap_node(pos, node)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function play_sound(pos)
|
|
||||||
|
local function node_timer(pos)
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
if mem.running then
|
if mem.running then
|
||||||
mem.handle = minetest.sound_play("techage_turbine", {
|
mem.handle = minetest.sound_play("techage_turbine", {
|
||||||
pos = pos,
|
pos = pos,
|
||||||
gain = 1,
|
gain = 1,
|
||||||
max_hear_distance = 15})
|
max_hear_distance = 15})
|
||||||
minetest.after(2, play_sound, pos)
|
end
|
||||||
|
return mem.running
|
||||||
|
end
|
||||||
|
|
||||||
|
local function play_sound(pos)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
if mem.running then
|
||||||
|
node_timer(pos)
|
||||||
|
minetest.get_node_timer(pos):start(2)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -53,6 +62,7 @@ local function stop_sound(pos)
|
|||||||
if mem.running and mem.handle then
|
if mem.running and mem.handle then
|
||||||
minetest.sound_stop(mem.handle)
|
minetest.sound_stop(mem.handle)
|
||||||
mem.handle = nil
|
mem.handle = nil
|
||||||
|
minetest.get_node_timer(pos):stop(2)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -102,6 +112,7 @@ minetest.register_node("techage:turbine_on", {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
on_timer = node_timer,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
groups = {not_in_creative_inventory=1},
|
groups = {not_in_creative_inventory=1},
|
||||||
diggable = false,
|
diggable = false,
|
||||||
|
7
init.lua
7
init.lua
@ -195,7 +195,7 @@ else
|
|||||||
|
|
||||||
-- Test
|
-- Test
|
||||||
dofile(MP.."/recipe_checker.lua")
|
dofile(MP.."/recipe_checker.lua")
|
||||||
--dofile(MP.."/.test/sink.lua")
|
dofile(MP.."/.test/sink.lua")
|
||||||
dofile(MP.."/.test/source.lua")
|
dofile(MP.."/.test/source.lua")
|
||||||
--dofile(MP.."/.test/akku.lua")
|
--dofile(MP.."/.test/akku.lua")
|
||||||
--dofile(MP.."/.test/switch.lua")
|
--dofile(MP.."/.test/switch.lua")
|
||||||
@ -219,8 +219,9 @@ else
|
|||||||
dofile(MP.."/energy_storage/nodes.lua")
|
dofile(MP.."/energy_storage/nodes.lua")
|
||||||
|
|
||||||
-- Chemistry
|
-- Chemistry
|
||||||
--dofile(MP.."/chemistry/ta4_reactor.lua")
|
dofile(MP.."/chemistry/ta4_reactor.lua")
|
||||||
--dofile(MP.."/chemistry/ta4_doser.lua")
|
dofile(MP.."/chemistry/ta4_stand.lua")
|
||||||
|
dofile(MP.."/chemistry/ta4_doser.lua")
|
||||||
|
|
||||||
-- Hydrogen
|
-- Hydrogen
|
||||||
dofile(MP.."/hydrogen/hydrogen.lua")
|
dofile(MP.."/hydrogen/hydrogen.lua")
|
||||||
|
@ -119,7 +119,7 @@ function techage.liquid.put(pos, outdir, name, amount, player_name)
|
|||||||
local peek = liquid.peek(item.pos, item.indir)
|
local peek = liquid.peek(item.pos, item.indir)
|
||||||
if peek and peek ~= name then return amount or 0 end
|
if peek and peek ~= name then return amount or 0 end
|
||||||
if player_name then
|
if player_name then
|
||||||
local num = techage.get_node_number(pos)
|
local num = techage.get_node_number(pos) or "000"
|
||||||
techage.mark_position(player_name, item.pos, "("..num..") put", "", 1)
|
techage.mark_position(player_name, item.pos, "("..num..") put", "", 1)
|
||||||
end
|
end
|
||||||
amount = liquid.put(item.pos, item.indir, name, amount)
|
amount = liquid.put(item.pos, item.indir, name, amount)
|
||||||
|
@ -148,7 +148,7 @@ local function can_dig(pos, player)
|
|||||||
end
|
end
|
||||||
local mem = tubelib2.get_mem(pos)
|
local mem = tubelib2.get_mem(pos)
|
||||||
local inv = minetest.get_meta(pos):get_inventory()
|
local inv = minetest.get_meta(pos):get_inventory()
|
||||||
return inv:is_empty("src") and inv:is_empty("dst") and (mem.liquid.amount or 0) == 0
|
return inv:is_empty("src") and inv:is_empty("dst") and (not mem.liquid or (mem.liquid.amount or 0) == 0)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -76,7 +76,7 @@ Power=Energie
|
|||||||
Primary available=Primär verfügbar
|
Primary available=Primär verfügbar
|
||||||
Primary needed=Primär benötigt
|
Primary needed=Primär benötigt
|
||||||
Pusher=Schieber
|
Pusher=Schieber
|
||||||
Recipe=Rezepte
|
Recipe=Rezept
|
||||||
Remove derrick=Entferne Ölturm
|
Remove derrick=Entferne Ölturm
|
||||||
Rinsing=Waschen
|
Rinsing=Waschen
|
||||||
River Water Barrel=Flusswasserfass
|
River Water Barrel=Flusswasserfass
|
||||||
|
@ -156,7 +156,7 @@ local function command(pos, command, player)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local cmnd, payload = command:match('^pipe%s+(%w+)%s*(.*)$')
|
local cmnd, payload = command:match('^pipe%s+([%w_]+)%s*(.*)$')
|
||||||
if cmnd then
|
if cmnd then
|
||||||
if not minetest.check_player_privs(player, "server") then
|
if not minetest.check_player_privs(player, "server") then
|
||||||
output(pos, "server privs missing")
|
output(pos, "server privs missing")
|
||||||
|
Loading…
Reference in New Issue
Block a user