icta controller, wall pipe improved, red stone added
@ -13,9 +13,9 @@ Textures: CC BY-SA 3.0
|
|||||||
|
|
||||||
|
|
||||||
### Dependencies
|
### Dependencies
|
||||||
Required: default, doors, tubelib2, basic_materials, bucket, stairs, lcdlib
|
Required: default, doors, tubelib2, basic_materials, bucket, stairs, screwdriver, minecart, lcdlib, safer_lua
|
||||||
Optional: unified_inventory, wielded_light, minecart
|
Optional: unified_inventory,wielded_light,unifieddyes
|
||||||
Highly recommended: signs_bot, minecart
|
Highly recommended: signs_bot, hyperloop
|
||||||
|
|
||||||
|
|
||||||
### History
|
### History
|
||||||
|
@ -222,7 +222,7 @@ techage.register_node({"techage:generator", "techage:generator_on"}, {
|
|||||||
end,
|
end,
|
||||||
on_recv_message = function(pos, src, topic, payload)
|
on_recv_message = function(pos, src, topic, payload)
|
||||||
local nvm = techage.get_nvm(pos)
|
local nvm = techage.get_nvm(pos)
|
||||||
if topic == "power" then
|
if topic == "delivered" then
|
||||||
return math.floor((nvm.provided or 0) + 0.5)
|
return math.floor((nvm.provided or 0) + 0.5)
|
||||||
else
|
else
|
||||||
return State:on_receive_message(pos, topic, payload)
|
return State:on_receive_message(pos, topic, payload)
|
||||||
|
@ -226,7 +226,7 @@ techage.register_node({"techage:ta4_generator", "techage:ta4_generator_on"}, {
|
|||||||
end,
|
end,
|
||||||
on_recv_message = function(pos, src, topic, payload)
|
on_recv_message = function(pos, src, topic, payload)
|
||||||
local nvm = techage.get_nvm(pos)
|
local nvm = techage.get_nvm(pos)
|
||||||
if topic == "power" then
|
if topic == "delivered" then
|
||||||
return math.floor((nvm.provided or 0) + 0.5)
|
return math.floor((nvm.provided or 0) + 0.5)
|
||||||
else
|
else
|
||||||
return State:on_receive_message(pos, topic, payload)
|
return State:on_receive_message(pos, topic, payload)
|
||||||
|
@ -261,8 +261,8 @@ techage.register_node({"techage:heatexchanger1"}, {
|
|||||||
else
|
else
|
||||||
return "stopped"
|
return "stopped"
|
||||||
end
|
end
|
||||||
elseif topic == "power" then
|
elseif topic == "delivered" then
|
||||||
return math.max(nvm.needed or 0, 0)
|
return -math.max(nvm.needed or 0, 0)
|
||||||
elseif topic == "load" then
|
elseif topic == "load" then
|
||||||
return techage.power.percent(nvm.capa_max, nvm.capa)
|
return techage.power.percent(nvm.capa_max, nvm.capa)
|
||||||
elseif topic == "on" then
|
elseif topic == "on" then
|
||||||
|
@ -29,6 +29,26 @@ local function after_dig_node(pos, oldnode, oldmetadata, digger)
|
|||||||
Pipe:after_dig_node(pos)
|
Pipe:after_dig_node(pos)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function tubelib2_on_update2(pos, outdir, tlib2, node)
|
||||||
|
techage.liquid.update_network(pos, outdir)
|
||||||
|
local conn = M(pos):get_int("pipe2_conn")
|
||||||
|
if conn == 20 or conn == 40 then
|
||||||
|
-- replace node by tube
|
||||||
|
minetest.remove_node(pos)
|
||||||
|
Pipe:after_dig_node(pos)
|
||||||
|
node.name = "techage:ta4_wall_pipe"
|
||||||
|
minetest.set_node(pos, node)
|
||||||
|
Pipe:after_place_tube(pos)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local networks_def = {
|
||||||
|
pipe2 = {
|
||||||
|
sides = {F=1, B=1},
|
||||||
|
ntype = "tank",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
minetest.register_node("techage:ta4_pipe_inlet", {
|
minetest.register_node("techage:ta4_pipe_inlet", {
|
||||||
description = S("TA4 Pipe Inlet"),
|
description = S("TA4 Pipe Inlet"),
|
||||||
tiles = {
|
tiles = {
|
||||||
@ -43,6 +63,8 @@ minetest.register_node("techage:ta4_pipe_inlet", {
|
|||||||
|
|
||||||
after_place_node = after_place_node,
|
after_place_node = after_place_node,
|
||||||
after_dig_node = after_dig_node,
|
after_dig_node = after_dig_node,
|
||||||
|
tubelib2_on_update2 = tubelib2_on_update2,
|
||||||
|
networks = networks_def,
|
||||||
|
|
||||||
paramtype2 = "facedir", -- important!
|
paramtype2 = "facedir", -- important!
|
||||||
on_rotate = screwdriver.disallow, -- important!
|
on_rotate = screwdriver.disallow, -- important!
|
||||||
@ -51,6 +73,41 @@ minetest.register_node("techage:ta4_pipe_inlet", {
|
|||||||
sounds = default.node_sound_metal_defaults(),
|
sounds = default.node_sound_metal_defaults(),
|
||||||
})
|
})
|
||||||
|
|
||||||
|
minetest.register_node("techage:ta4_wall_pipe", {
|
||||||
|
description = S("TA4 Wall Pipe"),
|
||||||
|
tiles = {
|
||||||
|
-- up, down, right, left, back, front
|
||||||
|
"basic_materials_concrete_block.png",
|
||||||
|
"basic_materials_concrete_block.png",
|
||||||
|
"basic_materials_concrete_block.png",
|
||||||
|
"basic_materials_concrete_block.png",
|
||||||
|
"basic_materials_concrete_block.png^techage_tes_inlet.png",
|
||||||
|
"basic_materials_concrete_block.png^techage_tes_inlet.png",
|
||||||
|
},
|
||||||
|
|
||||||
|
after_place_node = function(pos, placer, itemstack, pointed_thing)
|
||||||
|
if not Pipe:after_place_tube(pos, placer, pointed_thing) then
|
||||||
|
minetest.remove_node(pos)
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end,
|
||||||
|
|
||||||
|
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
||||||
|
if oldmetadata and oldmetadata.fields and oldmetadata.fields.tl2_param2 then
|
||||||
|
oldnode.param2 = oldmetadata.fields.tl2_param2
|
||||||
|
Pipe:after_dig_tube(pos, oldnode)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
|
||||||
|
paramtype2 = "facedir", -- important!
|
||||||
|
on_rotate = screwdriver.disallow, -- important!
|
||||||
|
groups = {crumbly = 2, cracky = 2, snappy = 2, not_in_creative_inventory = 1},
|
||||||
|
is_ground_content = false,
|
||||||
|
drop = "techage:ta4_pipe_inlet",
|
||||||
|
sounds = default.node_sound_metal_defaults(),
|
||||||
|
})
|
||||||
|
|
||||||
Pipe:add_secondary_node_names({"techage:ta4_pipe_inlet"})
|
Pipe:add_secondary_node_names({"techage:ta4_pipe_inlet"})
|
||||||
|
|
||||||
local Numbers = {
|
local Numbers = {
|
||||||
|
@ -285,8 +285,8 @@ techage.register_node({"techage:ta4_electrolyzer", "techage:ta4_electrolyzer_on"
|
|||||||
local nvm = techage.get_nvm(pos)
|
local nvm = techage.get_nvm(pos)
|
||||||
if topic == "load" then
|
if topic == "load" then
|
||||||
return techage.power.percent(CAPACITY, (nvm.liquid and nvm.liquid.amount) or 0)
|
return techage.power.percent(CAPACITY, (nvm.liquid and nvm.liquid.amount) or 0)
|
||||||
elseif topic == "power" then
|
elseif topic == "delivered" then
|
||||||
return math.floor((nvm.taken or 0) + 0.5)
|
return -math.floor((nvm.taken or 0) + 0.5)
|
||||||
else
|
else
|
||||||
return State:on_receive_message(pos, topic, payload)
|
return State:on_receive_message(pos, topic, payload)
|
||||||
end
|
end
|
||||||
|
@ -276,7 +276,7 @@ techage.register_node({"techage:ta4_fuelcell", "techage:ta4_fuelcell_on"}, {
|
|||||||
local nvm = techage.get_nvm(pos)
|
local nvm = techage.get_nvm(pos)
|
||||||
if topic == "load" then
|
if topic == "load" then
|
||||||
return techage.power.percent(CAPACITY, (nvm.liquid and nvm.liquid.amount) or 0)
|
return techage.power.percent(CAPACITY, (nvm.liquid and nvm.liquid.amount) or 0)
|
||||||
elseif topic == "power" then
|
elseif topic == "delivered" then
|
||||||
return math.floor((nvm.given or 0) + 0.5)
|
return math.floor((nvm.given or 0) + 0.5)
|
||||||
else
|
else
|
||||||
return State:on_receive_message(pos, topic, payload)
|
return State:on_receive_message(pos, topic, payload)
|
||||||
|
@ -160,7 +160,7 @@ techage.icta_register_condition("input", {
|
|||||||
})
|
})
|
||||||
|
|
||||||
techage.icta_register_condition("state", {
|
techage.icta_register_condition("state", {
|
||||||
title = "block state request",
|
title = "read block state",
|
||||||
formspec = {
|
formspec = {
|
||||||
{
|
{
|
||||||
type = "number",
|
type = "number",
|
||||||
@ -198,7 +198,7 @@ techage.icta_register_condition("state", {
|
|||||||
})
|
})
|
||||||
|
|
||||||
techage.icta_register_condition("fuel", {
|
techage.icta_register_condition("fuel", {
|
||||||
title = "fuel request",
|
title = "read amount of fuel",
|
||||||
formspec = {
|
formspec = {
|
||||||
{
|
{
|
||||||
type = "number",
|
type = "number",
|
||||||
@ -235,7 +235,7 @@ techage.icta_register_condition("fuel", {
|
|||||||
})
|
})
|
||||||
|
|
||||||
techage.icta_register_condition("load", {
|
techage.icta_register_condition("load", {
|
||||||
title = "load request",
|
title = "read power/liquid load",
|
||||||
formspec = {
|
formspec = {
|
||||||
{
|
{
|
||||||
type = "number",
|
type = "number",
|
||||||
@ -271,8 +271,45 @@ techage.icta_register_condition("load", {
|
|||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
techage.icta_register_condition("delivered", {
|
||||||
|
title = "read delivered power",
|
||||||
|
formspec = {
|
||||||
|
{
|
||||||
|
type = "number",
|
||||||
|
name = "number",
|
||||||
|
label = "block number",
|
||||||
|
default = "",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type = "textlist",
|
||||||
|
name = "operand",
|
||||||
|
label = "",
|
||||||
|
choices = "greater,less",
|
||||||
|
default = "greater",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type = "digits",
|
||||||
|
name = "value",
|
||||||
|
label = "than",
|
||||||
|
default = ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type = "label",
|
||||||
|
name = "lbl",
|
||||||
|
label = "Read and evaluate the delivered\npower from a generator block.\nPower consuming blocks like accus\ncould also provide a negative value.",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
button = function(data, environ)
|
||||||
|
return 'deliv('..techage.fmt_number(data.number)..","..data.operand..' '..data.value..')'
|
||||||
|
end,
|
||||||
|
code = function(data, environ)
|
||||||
|
return send_single_string(environ, data.number, "delivered"),
|
||||||
|
techage.operand(data.operand)..tonumber(data.value)
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
techage.icta_register_condition("chest", {
|
techage.icta_register_condition("chest", {
|
||||||
title = "chest state request",
|
title = "read chest state",
|
||||||
formspec = {
|
formspec = {
|
||||||
{
|
{
|
||||||
type = "number",
|
type = "number",
|
||||||
@ -311,7 +348,7 @@ techage.icta_register_condition("chest", {
|
|||||||
})
|
})
|
||||||
|
|
||||||
techage.icta_register_condition("signaltower", {
|
techage.icta_register_condition("signaltower", {
|
||||||
title = "Signal Tower state request",
|
title = "read Signal Tower state",
|
||||||
formspec = {
|
formspec = {
|
||||||
{
|
{
|
||||||
type = "number",
|
type = "number",
|
||||||
@ -347,7 +384,7 @@ techage.icta_register_condition("signaltower", {
|
|||||||
})
|
})
|
||||||
|
|
||||||
techage.icta_register_action("signaltower", {
|
techage.icta_register_action("signaltower", {
|
||||||
title = "Signal Tower command",
|
title = "send Signal Tower command",
|
||||||
formspec = {
|
formspec = {
|
||||||
{
|
{
|
||||||
type = "numbers",
|
type = "numbers",
|
||||||
@ -464,7 +501,7 @@ techage.icta_register_action("cleardisplay", {
|
|||||||
})
|
})
|
||||||
|
|
||||||
techage.icta_register_action("chat", {
|
techage.icta_register_action("chat", {
|
||||||
title = "chat send",
|
title = "send chat message",
|
||||||
formspec = {
|
formspec = {
|
||||||
{
|
{
|
||||||
type = "ascii",
|
type = "ascii",
|
||||||
@ -505,7 +542,7 @@ function techage.icta_door_toggle(pos, owner, state)
|
|||||||
end
|
end
|
||||||
|
|
||||||
techage.icta_register_action("door", {
|
techage.icta_register_action("door", {
|
||||||
title = "doors open/close",
|
title = "open/close door",
|
||||||
formspec = {
|
formspec = {
|
||||||
{
|
{
|
||||||
type = "digits",
|
type = "digits",
|
||||||
@ -548,7 +585,7 @@ function techage.icta_player_detect(own_num, number, name)
|
|||||||
end
|
end
|
||||||
|
|
||||||
techage.icta_register_condition("playerdetector", {
|
techage.icta_register_condition("playerdetector", {
|
||||||
title = "Player Detector name request",
|
title = "read Player Detector",
|
||||||
formspec = {
|
formspec = {
|
||||||
{
|
{
|
||||||
type = "number",
|
type = "number",
|
||||||
|
@ -34,7 +34,7 @@ local function add_controls_to_table(tbl, kvDefinition, kvSelect)
|
|||||||
tbl[#tbl+1] = "label[0,"..offs..";"..elem.label..":]"
|
tbl[#tbl+1] = "label[0,"..offs..";"..elem.label..":]"
|
||||||
offs = offs + 0.4
|
offs = offs + 0.4
|
||||||
end
|
end
|
||||||
if elem.type == "numbers" or elem.type == "digits" or elem.type == "letters"
|
if elem.type == "numbers" or elem.type == "number" or elem.type == "digits" or elem.type == "letters"
|
||||||
or elem.type == "ascii" then
|
or elem.type == "ascii" then
|
||||||
val = kvSelect[elem.name] or elem.default
|
val = kvSelect[elem.name] or elem.default
|
||||||
tbl[#tbl+1] = "field[0.3,"..(offs+0.2)..";8,1;"..elem.name..";;"..val.."]"
|
tbl[#tbl+1] = "field[0.3,"..(offs+0.2)..";8,1;"..elem.name..";;"..val.."]"
|
||||||
@ -76,6 +76,15 @@ local function field_to_kvSelect(kvDefinition, kvSelect, fields)
|
|||||||
error = true
|
error = true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
elseif elem.type == "number" then
|
||||||
|
if fields[elem.name] then
|
||||||
|
if fields[elem.name]:find("^[%d ]+$") then
|
||||||
|
kvSelect[elem.name] = fields[elem.name]
|
||||||
|
else
|
||||||
|
kvSelect[elem.name] = elem.default
|
||||||
|
error = true
|
||||||
|
end
|
||||||
|
end
|
||||||
elseif elem.type == "digits" then -- including positions
|
elseif elem.type == "digits" then -- including positions
|
||||||
if fields[elem.name] then
|
if fields[elem.name] then
|
||||||
if fields[elem.name]:find("^[+%%-,%d]+$") then
|
if fields[elem.name]:find("^[+%%-,%d]+$") then
|
||||||
|
6
init.lua
@ -223,6 +223,11 @@ else
|
|||||||
dofile(MP.."/icta_controller/display.lua")
|
dofile(MP.."/icta_controller/display.lua")
|
||||||
dofile(MP.."/icta_controller/signaltower.lua")
|
dofile(MP.."/icta_controller/signaltower.lua")
|
||||||
|
|
||||||
|
-- Lua Controller
|
||||||
|
-- dofile(MP.."/lua_controller/controller.lua")
|
||||||
|
-- dofile(MP.."/lua_controller/commands.lua")
|
||||||
|
-- dofile(MP.."/lua_controller/server.lua")
|
||||||
|
|
||||||
-- Items
|
-- Items
|
||||||
dofile(MP.."/items/barrel.lua")
|
dofile(MP.."/items/barrel.lua")
|
||||||
dofile(MP.."/items/baborium.lua")
|
dofile(MP.."/items/baborium.lua")
|
||||||
@ -239,6 +244,7 @@ else
|
|||||||
dofile(MP.."/items/plastic.lua")
|
dofile(MP.."/items/plastic.lua")
|
||||||
dofile(MP.."/items/hydrogen.lua")
|
dofile(MP.."/items/hydrogen.lua")
|
||||||
dofile(MP.."/items/electronic.lua")
|
dofile(MP.."/items/electronic.lua")
|
||||||
|
dofile(MP.."/items/redstone.lua")
|
||||||
|
|
||||||
if techage.basalt_stone_enabled then
|
if techage.basalt_stone_enabled then
|
||||||
dofile(MP.."/items/basalt.lua")
|
dofile(MP.."/items/basalt.lua")
|
||||||
|
103
items/redstone.lua
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
--[[
|
||||||
|
|
||||||
|
TechAge
|
||||||
|
=======
|
||||||
|
|
||||||
|
Copyright (C) 2019 Joachim Stolberg
|
||||||
|
|
||||||
|
GPL v3
|
||||||
|
See LICENSE.txt for more information
|
||||||
|
|
||||||
|
Redstone as result from the redmud/sand
|
||||||
|
|
||||||
|
]]--
|
||||||
|
|
||||||
|
local S = techage.S
|
||||||
|
|
||||||
|
|
||||||
|
minetest.register_node("techage:red_stone", {
|
||||||
|
description = S("Red Stone"),
|
||||||
|
tiles = {"default_stone.png^[colorize:#ff4538:110"},
|
||||||
|
groups = {cracky = 3, stone = 1},
|
||||||
|
drop = 'techage:basalt_cobble',
|
||||||
|
sounds = default.node_sound_stone_defaults(),
|
||||||
|
})
|
||||||
|
|
||||||
|
stairs.register_stair_and_slab(
|
||||||
|
"red_stone",
|
||||||
|
"techage:red_stone",
|
||||||
|
{cracky = 3, stone = 1},
|
||||||
|
{"default_stone.png^[colorize:#ff4538:110"},
|
||||||
|
"Red Stone Stair",
|
||||||
|
"Red Stone Slab",
|
||||||
|
default.node_sound_stone_defaults(),
|
||||||
|
false
|
||||||
|
)
|
||||||
|
|
||||||
|
minetest.register_node("techage:red_stone_brick", {
|
||||||
|
description = S("Red Stone Brick"),
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
place_param2 = 0,
|
||||||
|
tiles = {"default_stone_brick.png^[colorize:#ff4538:110"},
|
||||||
|
is_ground_content = false,
|
||||||
|
groups = {cracky = 2, stone = 1},
|
||||||
|
sounds = default.node_sound_stone_defaults(),
|
||||||
|
})
|
||||||
|
|
||||||
|
stairs.register_stair_and_slab(
|
||||||
|
"red_stone_brick",
|
||||||
|
"techage:red_stone_brick",
|
||||||
|
{cracky = 2, stone = 1},
|
||||||
|
{"default_stone_brick.png^[colorize:#ff4538:110"},
|
||||||
|
"Red Brick Stair",
|
||||||
|
"Red Brick Slab",
|
||||||
|
default.node_sound_stone_defaults(),
|
||||||
|
false
|
||||||
|
)
|
||||||
|
|
||||||
|
minetest.register_node("techage:red_stone_block", {
|
||||||
|
description = S("Red Stone Block"),
|
||||||
|
tiles = {"default_stone_block.png^[colorize:#ff4538:110"},
|
||||||
|
is_ground_content = false,
|
||||||
|
groups = {cracky = 2, stone = 1},
|
||||||
|
sounds = default.node_sound_stone_defaults(),
|
||||||
|
})
|
||||||
|
|
||||||
|
stairs.register_stair_and_slab(
|
||||||
|
"red_stone_block",
|
||||||
|
"techage:red_stone_block",
|
||||||
|
{cracky = 2, stone = 1},
|
||||||
|
{"default_stone_block.png^[colorize:#ff4538:110"},
|
||||||
|
"Red Stone Block Stair",
|
||||||
|
"Red Stone Block Slab",
|
||||||
|
default.node_sound_stone_defaults(),
|
||||||
|
false
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = "techage:red_stone_brick 4",
|
||||||
|
recipe = {
|
||||||
|
{"techage:red_stone", "techage:red_stone"},
|
||||||
|
{"techage:red_stone", "techage:red_stone"},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = "techage:red_stone_block 9",
|
||||||
|
recipe = {
|
||||||
|
{"techage:red_stone", "techage:red_stone", "techage:red_stone"},
|
||||||
|
{"techage:red_stone", "techage:red_stone", "techage:red_stone"},
|
||||||
|
{"techage:red_stone", "techage:red_stone", "techage:red_stone"},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
techage.furnace.register_recipe({
|
||||||
|
output = "techage:red_stone",
|
||||||
|
recipe = {
|
||||||
|
"techage:redmud",
|
||||||
|
"default:sand",
|
||||||
|
},
|
||||||
|
time = 4,
|
||||||
|
})
|
||||||
|
|
@ -27,10 +27,15 @@ local Pipe = tubelib2.Tube:new({
|
|||||||
show_infotext = false,
|
show_infotext = false,
|
||||||
force_to_use_tubes = true,
|
force_to_use_tubes = true,
|
||||||
tube_type = "pipe2",
|
tube_type = "pipe2",
|
||||||
primary_node_names = {"techage:ta3_pipeS", "techage:ta3_pipeA"},
|
primary_node_names = {"techage:ta3_pipeS", "techage:ta3_pipeA", "techage:ta4_wall_pipe"},
|
||||||
secondary_node_names = {},
|
secondary_node_names = {},
|
||||||
after_place_tube = function(pos, param2, tube_type, num_tubes)
|
after_place_tube = function(pos, param2, tube_type, num_tubes)
|
||||||
|
local name = minetest.get_node(pos).name
|
||||||
|
if name == "techage:ta4_wall_pipe" then
|
||||||
|
minetest.swap_node(pos, {name = "techage:ta4_wall_pipe", param2 = param2})
|
||||||
|
else
|
||||||
minetest.swap_node(pos, {name = "techage:ta3_pipe"..tube_type, param2 = param2})
|
minetest.swap_node(pos, {name = "techage:ta3_pipe"..tube_type, param2 = param2})
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
2
mod.conf
@ -1,4 +1,4 @@
|
|||||||
name = techage
|
name = techage
|
||||||
depends = default,doors,tubelib2,basic_materials,bucket,stairs,screwdriver,minecart,lcdlib
|
depends = default,doors,tubelib2,basic_materials,bucket,stairs,screwdriver,minecart,lcdlib,safer_lua
|
||||||
optional_depends = unified_inventory,wielded_light,unifieddyes
|
optional_depends = unified_inventory,wielded_light,unifieddyes
|
||||||
description = Techage, go through 4 tech ages in search of wealth and power!
|
description = Techage, go through 4 tech ages in search of wealth and power!
|
@ -201,7 +201,7 @@ Solar:add_secondary_node_names({"techage:ta4_solar_inverter"})
|
|||||||
techage.register_node({"techage:ta4_solar_inverter"}, {
|
techage.register_node({"techage:ta4_solar_inverter"}, {
|
||||||
on_recv_message = function(pos, src, topic, payload)
|
on_recv_message = function(pos, src, topic, payload)
|
||||||
local nvm = techage.get_nvm(pos)
|
local nvm = techage.get_nvm(pos)
|
||||||
if topic == "power" then
|
if topic == "delivered" then
|
||||||
return math.floor((nvm.delivered or 0) + 0.5)
|
return math.floor((nvm.delivered or 0) + 0.5)
|
||||||
else
|
else
|
||||||
return State:on_receive_message(pos, topic, payload)
|
return State:on_receive_message(pos, topic, payload)
|
||||||
|
@ -205,8 +205,8 @@ techage.register_node({"techage:ta3_akku"}, {
|
|||||||
local nvm = techage.get_nvm(pos)
|
local nvm = techage.get_nvm(pos)
|
||||||
if topic == "load" then
|
if topic == "load" then
|
||||||
return techage.power.percent(PWR_CAPA, nvm.capa)
|
return techage.power.percent(PWR_CAPA, nvm.capa)
|
||||||
elseif topic == "power" then
|
elseif topic == "delivered" then
|
||||||
return nvm.needed or 0
|
return -(nvm.needed or 0)
|
||||||
else
|
else
|
||||||
return State:on_receive_message(pos, topic, payload)
|
return State:on_receive_message(pos, topic, payload)
|
||||||
end
|
end
|
||||||
|
@ -283,7 +283,7 @@ Cable:add_secondary_node_names({"techage:tiny_generator", "techage:tiny_generato
|
|||||||
techage.register_node({"techage:tiny_generator", "techage:tiny_generator_on"}, {
|
techage.register_node({"techage:tiny_generator", "techage:tiny_generator_on"}, {
|
||||||
on_recv_message = function(pos, src, topic, payload)
|
on_recv_message = function(pos, src, topic, payload)
|
||||||
local nvm = techage.get_nvm(pos)
|
local nvm = techage.get_nvm(pos)
|
||||||
if topic == "power" then
|
if topic == "delivered" then
|
||||||
return nvm.provided or 0
|
return nvm.provided or 0
|
||||||
elseif topic == "fuel" then
|
elseif topic == "fuel" then
|
||||||
return techage.fuel.get_fuel_amount(nvm)
|
return techage.fuel.get_fuel_amount(nvm)
|
||||||
|
BIN
textures/techage_lua_controller.png
Normal file
After Width: | Height: | Size: 346 B |
BIN
textures/techage_lua_controller_inventory.png
Normal file
After Width: | Height: | Size: 838 B |
BIN
textures/techage_lua_server_back.png
Normal file
After Width: | Height: | Size: 351 B |
BIN
textures/techage_lua_server_front.png
Normal file
After Width: | Height: | Size: 326 B |
BIN
textures/techage_lua_server_side.png
Normal file
After Width: | Height: | Size: 224 B |
BIN
textures/techage_lua_server_top.png
Normal file
After Width: | Height: | Size: 265 B |
Before Width: | Height: | Size: 811 B After Width: | Height: | Size: 650 B |
BIN
textures/techage_server_back.png
Normal file
After Width: | Height: | Size: 351 B |
BIN
textures/techage_server_front.png
Normal file
After Width: | Height: | Size: 326 B |
BIN
textures/techage_server_side.png
Normal file
After Width: | Height: | Size: 224 B |
BIN
textures/techage_server_top.png
Normal file
After Width: | Height: | Size: 265 B |
@ -242,10 +242,10 @@ local function read_state(itemstack, user, pointed_thing)
|
|||||||
load = dump(load)
|
load = dump(load)
|
||||||
minetest.chat_send_player(user:get_player_name(), ndef.description.." "..number..": load = "..load.." % ")
|
minetest.chat_send_player(user:get_player_name(), ndef.description.." "..number..": load = "..load.." % ")
|
||||||
end
|
end
|
||||||
local power = techage.send_single("0", number, "power", nil)
|
local delivered = techage.send_single("0", number, "delivered", nil)
|
||||||
if power and power ~= "" and power ~= "unsupported" then
|
if delivered and delivered ~= "" and delivered ~= "unsupported" then
|
||||||
power = dump(power)
|
delivered = dump(delivered)
|
||||||
minetest.chat_send_player(user:get_player_name(), ndef.description.." "..number..": power = "..power.." ku ")
|
minetest.chat_send_player(user:get_player_name(), ndef.description.." "..number..": delivered = "..delivered.." ku ")
|
||||||
end
|
end
|
||||||
local owner = M(pos):get_string("owner") or ""
|
local owner = M(pos):get_string("owner") or ""
|
||||||
if owner ~= "" then
|
if owner ~= "" then
|
||||||
|
@ -261,7 +261,7 @@ techage.register_node({"techage:ta4_wind_turbine"}, {
|
|||||||
else
|
else
|
||||||
return "stopped"
|
return "stopped"
|
||||||
end
|
end
|
||||||
elseif topic == "power" then
|
elseif topic == "delivered" then
|
||||||
return nvm.delivered or 0
|
return nvm.delivered or 0
|
||||||
elseif topic == "on" then
|
elseif topic == "on" then
|
||||||
nvm.running = true
|
nvm.running = true
|
||||||
|