switch bugfix, recipe missing

This commit is contained in:
Joachim Stolberg 2020-02-25 19:43:27 +01:00
parent 3b33cfec36
commit 2a6d1519c9
3 changed files with 30 additions and 7 deletions

View File

@ -38,7 +38,7 @@ local Cable = tubelib2.Tube:new({
M(pos):set_int("tl2_param2", param2) M(pos):set_int("tl2_param2", param2)
return return
elseif name == "techage:powerswitch_box" then elseif name == "techage:powerswitch_box" then
minetest.swap_node(pos, {name = "techage:powerswitch_box", param2 = param2}) minetest.swap_node(pos, {name = "techage:powerswitch_box", param2 = param2 % 32})
M(pos):set_int("tl2_param2", param2) M(pos):set_int("tl2_param2", param2)
return return
elseif name == "techage:power_line" or name == "techage:power_lineS" or name == "techage:power_lineA" then elseif name == "techage:power_line" or name == "techage:power_lineS" or name == "techage:power_lineA" then

View File

@ -57,3 +57,11 @@ techage.register_junction("techage:electric_junction", 2/8, Boxes, Cable, {
}, },
}) })
minetest.register_craft({
output = "techage:electric_junction0 2",
recipe = {
{"", "basic_materials:plastic_sheet", ""},
{"basic_materials:plastic_sheet", "default:copper_ingot", "basic_materials:plastic_sheet"},
{"", "basic_materials:plastic_sheet", ""},
},
})

View File

@ -28,6 +28,11 @@ local Param2ToDir = {
[5] = 3, [5] = 3,
} }
local function is_switchbox(pos)
return techage.get_node_lvm(pos).name == "techage:powerswitch_box" or
M(pos):get_string("techage_hidden_nodename") == "techage:powerswitch_box"
end
local function switch_on(pos, node, clicker, name) local function switch_on(pos, node, clicker, name)
if clicker and minetest.is_protected(pos, clicker:get_player_name()) then if clicker and minetest.is_protected(pos, clicker:get_player_name()) then
return return
@ -41,9 +46,13 @@ local function switch_on(pos, node, clicker, name)
}) })
local dir = Param2ToDir[node.param2] local dir = Param2ToDir[node.param2]
local pos2 = tubelib2.get_pos(pos, dir) local pos2 = tubelib2.get_pos(pos, dir)
local node2 = techage.get_node_lvm(pos2)
if node2.name == "techage:powerswitch_box" then if is_switchbox(pos2) then
M(pos2):set_int("tl2_param2", M(pos2):get_int("techage_hidden_param2")) if M(pos2):get_int("tl2_param2_copy") == 0 then
M(pos2):set_int("tl2_param2", techage.get_node_lvm(pos2).param2)
else
M(pos2):set_int("tl2_param2", M(pos2):get_int("tl2_param2_copy"))
end
Cable:after_place_tube(pos2, clicker) Cable:after_place_tube(pos2, clicker)
end end
end end
@ -62,9 +71,11 @@ local function switch_off(pos, node, clicker, name)
}) })
local dir = Param2ToDir[node.param2] local dir = Param2ToDir[node.param2]
local pos2 = tubelib2.get_pos(pos, dir) local pos2 = tubelib2.get_pos(pos, dir)
if is_switchbox(pos2) then
local node2 = techage.get_node_lvm(pos2) local node2 = techage.get_node_lvm(pos2)
if node2.name == "techage:powerswitch_box" then node2.param2 = M(pos2):get_int("tl2_param2")
node2.param2 = Cable:get_primary_node_param2(pos2) M(pos2):set_int("tl2_param2_copy", M(pos2):get_int("tl2_param2"))
M(pos2):set_int("tl2_param2", 0) M(pos2):set_int("tl2_param2", 0)
Cable:after_dig_tube(pos2, node2) Cable:after_dig_tube(pos2, node2)
end end
@ -93,6 +104,8 @@ minetest.register_node("techage:powerswitch", {
meta:set_string("node_number", number) meta:set_string("node_number", number)
meta:set_string("owner", placer:get_player_name()) meta:set_string("owner", placer:get_player_name())
meta:set_string("infotext", S("TA Power Switch").." "..number) meta:set_string("infotext", S("TA Power Switch").." "..number)
local node = minetest.get_node(pos)
switch_on(pos, node, placer, "techage:powerswitch_on")
end, end,
on_rightclick = function(pos, node, clicker) on_rightclick = function(pos, node, clicker)
@ -161,6 +174,8 @@ minetest.register_node("techage:powerswitchsmall", {
meta:set_string("node_number", number) meta:set_string("node_number", number)
meta:set_string("owner", placer:get_player_name()) meta:set_string("owner", placer:get_player_name())
meta:set_string("infotext", S("TA Power Switch Small").." "..number) meta:set_string("infotext", S("TA Power Switch Small").." "..number)
local node = minetest.get_node(pos)
switch_on(pos, node, placer, "techage:powerswitchsmall_on")
end, end,
on_rightclick = function(pos, node, clicker) on_rightclick = function(pos, node, clicker)