forked from minetest-mods/mesecons
Fix a bug in which the wrong node was being checked for.
This commit is contained in:
parent
f221aeb066
commit
c0eb0982aa
@ -16,16 +16,16 @@ minetest.register_node("jeija:mesecon_plug", {
|
|||||||
mesecon:register_on_signal_on(function(pos, node)
|
mesecon:register_on_signal_on(function(pos, node)
|
||||||
if node.name=="jeija:mesecon_plug" then
|
if node.name=="jeija:mesecon_plug" then
|
||||||
local set_node_on = function(pos)
|
local set_node_on = function(pos)
|
||||||
node = minetest.env:get_node(pos)
|
node = minetest.env:get_node(pos)
|
||||||
if node.name=="jeija:mesecon_socket_off" then
|
if node.name=="jeija:mesecon_socket_off" then
|
||||||
minetest.env:add_node(pos, {name="jeija:mesecon_socket_on"})
|
minetest.env:add_node(pos, {name="jeija:mesecon_socket_on"})
|
||||||
nodeupdate(pos)
|
nodeupdate(pos)
|
||||||
mesecon:receptor_on(pos)
|
mesecon:receptor_on(pos)
|
||||||
elseif node.name=="jeija:mesecon_inverter_on" then
|
elseif node.name=="jeija:mesecon_inverter_on" then
|
||||||
minetest.env:add_node(pos, {name="jeija:mesecon_inverter_off"})
|
minetest.env:add_node(pos, {name="jeija:mesecon_inverter_off"})
|
||||||
nodeupdate(pos)
|
nodeupdate(pos)
|
||||||
mesecon:receptor_off(pos)
|
mesecon:receptor_off(pos)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
lnode = minetest.env:get_node({x=pos.x-1, y=pos.y, z=pos.z}) --a node between this node and the one two nodes away
|
lnode = minetest.env:get_node({x=pos.x-1, y=pos.y, z=pos.z}) --a node between this node and the one two nodes away
|
||||||
@ -38,23 +38,23 @@ mesecon:register_on_signal_on(function(pos, node)
|
|||||||
if lnode.name=="air" then set_node_on({x=pos.x, y=pos.y, z=pos.z-2}) end
|
if lnode.name=="air" then set_node_on({x=pos.x, y=pos.y, z=pos.z-2}) end
|
||||||
|
|
||||||
lnode = minetest.env:get_node({x=pos.x, y=pos.y, z=pos.z+1}) --a node between this node and the one two nodes away
|
lnode = minetest.env:get_node({x=pos.x, y=pos.y, z=pos.z+1}) --a node between this node and the one two nodes away
|
||||||
if lnode.name=="air" then set_node_on({x=pos.x-2, y=pos.y, z=pos.z+2}) end
|
if lnode.name=="air" then set_node_on({x=pos.x, y=pos.y, z=pos.z+2}) end
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
mesecon:register_on_signal_off(function(pos, node)
|
mesecon:register_on_signal_off(function(pos, node)
|
||||||
if node.name=="jeija:mesecon_plug" then
|
if node.name=="jeija:mesecon_plug" then
|
||||||
local set_node_off = function(pos)
|
local set_node_off = function(pos)
|
||||||
node = minetest.env:get_node(pos)
|
node = minetest.env:get_node(pos)
|
||||||
if node.name=="jeija:mesecon_socket_on" then
|
if node.name=="jeija:mesecon_socket_on" then
|
||||||
minetest.env:add_node(pos, {name="jeija:mesecon_socket_off"})
|
minetest.env:add_node(pos, {name="jeija:mesecon_socket_off"})
|
||||||
nodeupdate(pos)
|
nodeupdate(pos)
|
||||||
mesecon:receptor_off(pos)
|
mesecon:receptor_off(pos)
|
||||||
elseif node.name=="jeija:mesecon_inverter_off" then
|
elseif node.name=="jeija:mesecon_inverter_off" then
|
||||||
minetest.env:add_node(pos, {name="jeija:mesecon_inverter_on"})
|
minetest.env:add_node(pos, {name="jeija:mesecon_inverter_on"})
|
||||||
nodeupdate(pos)
|
nodeupdate(pos)
|
||||||
mesecon:receptor_on(pos)
|
mesecon:receptor_on(pos)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
lnode = minetest.env:get_node({x=pos.x-1, y=pos.y, z=pos.z}) --a node between this node and the one two nodes away
|
lnode = minetest.env:get_node({x=pos.x-1, y=pos.y, z=pos.z}) --a node between this node and the one two nodes away
|
||||||
@ -67,7 +67,7 @@ mesecon:register_on_signal_off(function(pos, node)
|
|||||||
if lnode.name=="air" then set_node_off({x=pos.x, y=pos.y, z=pos.z-2}) end
|
if lnode.name=="air" then set_node_off({x=pos.x, y=pos.y, z=pos.z-2}) end
|
||||||
|
|
||||||
lnode = minetest.env:get_node({x=pos.x, y=pos.y, z=pos.z+1}) --a node between this node and the one two nodes away
|
lnode = minetest.env:get_node({x=pos.x, y=pos.y, z=pos.z+1}) --a node between this node and the one two nodes away
|
||||||
if lnode.name=="air" then set_node_off({x=pos.x-2, y=pos.y, z=pos.z+2}) end
|
if lnode.name=="air" then set_node_off({x=pos.x, y=pos.y, z=pos.z+2}) end
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
@ -96,7 +96,7 @@ minetest.register_on_dignode(function(pos, oldnode, digger)
|
|||||||
if lnode.name=="air" then set_node_deactivated({x=pos.x, y=pos.y, z=pos.z-2}) end
|
if lnode.name=="air" then set_node_deactivated({x=pos.x, y=pos.y, z=pos.z-2}) end
|
||||||
|
|
||||||
lnode = minetest.env:get_node({x=pos.x, y=pos.y, z=pos.z+1}) --a node between this node and the one two nodes away
|
lnode = minetest.env:get_node({x=pos.x, y=pos.y, z=pos.z+1}) --a node between this node and the one two nodes away
|
||||||
if lnode.name=="air" then set_node_deactivated({x=pos.x-2, y=pos.y, z=pos.z+2}) end
|
if lnode.name=="air" then set_node_deactivated({x=pos.x, y=pos.y, z=pos.z+2}) end
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user