mirror of
https://github.com/minetest-mods/mesecons.git
synced 2025-01-27 16:50:18 +01:00
Add conductor rules, add demo isolated mesecons to proof that it works
This commit is contained in:
parent
e74bb1ce75
commit
78fdedc880
@ -154,7 +154,9 @@ function mesecon:receptor_on(pos, rules)
|
|||||||
np.x = pos.x + rules[i].x
|
np.x = pos.x + rules[i].x
|
||||||
np.y = pos.y + rules[i].y
|
np.y = pos.y + rules[i].y
|
||||||
np.z = pos.z + rules[i].z
|
np.z = pos.z + rules[i].z
|
||||||
mesecon:turnon(np, pos)
|
if mesecon:rules_link(pos, np, rules) then
|
||||||
|
mesecon:turnon(np, pos)
|
||||||
|
end
|
||||||
i=i+1
|
i=i+1
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -171,8 +173,7 @@ function mesecon:receptor_off(pos, rules)
|
|||||||
np.x = pos.x + rules[i].x
|
np.x = pos.x + rules[i].x
|
||||||
np.y = pos.y + rules[i].y
|
np.y = pos.y + rules[i].y
|
||||||
np.z = pos.z + rules[i].z
|
np.z = pos.z + rules[i].z
|
||||||
connected = mesecon:connected_to_pw_src(np)
|
if mesecon:rules_link(pos, np, rules) and mesecon:connected_to_pw_src(np) == false then
|
||||||
if connected == false then
|
|
||||||
mesecon:turnoff(np, pos)
|
mesecon:turnoff(np, pos)
|
||||||
end
|
end
|
||||||
i=i+1
|
i=i+1
|
||||||
@ -206,15 +207,19 @@ function mesecon:register_on_signal_change(action)
|
|||||||
mesecon.actions_change[i]=action
|
mesecon.actions_change[i]=action
|
||||||
end
|
end
|
||||||
|
|
||||||
function mesecon:register_conductor (onstate, offstate, rules)
|
function mesecon:register_conductor (onstate, offstate, rules, get_rules)
|
||||||
local i=0
|
local i = 1
|
||||||
while mesecon.conductors[i]~=nil do
|
while mesecon.conductors[i]~=nil do
|
||||||
i=i+1
|
i = i + 1
|
||||||
|
end
|
||||||
|
if rules == nil then
|
||||||
|
rules = mesecon:get_rules("default")
|
||||||
end
|
end
|
||||||
mesecon.conductors[i]={}
|
mesecon.conductors[i]={}
|
||||||
mesecon.conductors[i].on = onstate
|
mesecon.conductors[i].onstate = onstate
|
||||||
mesecon.conductors[i].off = offstate
|
mesecon.conductors[i].offstate = offstate
|
||||||
mesecon.conductors[i].rules = offstate
|
mesecon.conductors[i].rules = rules
|
||||||
|
mesecon.conductors[i].get_rules = get_rules
|
||||||
end
|
end
|
||||||
|
|
||||||
mesecon:add_rules("default",
|
mesecon:add_rules("default",
|
||||||
|
@ -98,47 +98,6 @@ function mesecon:effector_get_input_rules(node)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Helpers for nodeboxlike mesecons
|
|
||||||
function mesecon:receptor_outputs (cpos, rpos) --cpos = conductor pos, rpos = receptor pos
|
|
||||||
local rnode = minetest.env:get_node (rpos)
|
|
||||||
local rules = mesecon:receptor_get_rules (rnode)
|
|
||||||
if rules == nil then return false end
|
|
||||||
|
|
||||||
local i = 1
|
|
||||||
while rules[i] ~= nil do
|
|
||||||
if rpos.x + rules[i].x == cpos.x
|
|
||||||
and rpos.y + rules[i].y == cpos.y
|
|
||||||
and rpos.z + rules[i].z == cpos.z then
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
i = i + 1
|
|
||||||
end
|
|
||||||
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
|
|
||||||
function mesecon:effector_inputs (srcpos, destpos)
|
|
||||||
local destnode = minetest.env:get_node (destpos)
|
|
||||||
local rules = mesecon:effector_get_input_rules (destnode)
|
|
||||||
if rules == nil then return false end
|
|
||||||
|
|
||||||
local i = 1
|
|
||||||
while rules[i] ~= nil do
|
|
||||||
if destpos.x + rules[i].x == srcpos.x
|
|
||||||
and destpos.y + rules[i].y == srcpos.y
|
|
||||||
and destpos.z + rules[i].z == srcpos.z then
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
i = i + 1
|
|
||||||
end
|
|
||||||
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
|
|
||||||
function mesecon:node_connects(cpos, rpos) --cpos = conductor pos, rpos = receptor pos
|
|
||||||
return mesecon:receptor_outputs (cpos, rpos) or mesecon:effector_inputs (cpos, rpos)
|
|
||||||
end
|
|
||||||
|
|
||||||
--Signals
|
--Signals
|
||||||
|
|
||||||
function mesecon:activate(pos)
|
function mesecon:activate(pos)
|
||||||
@ -177,7 +136,7 @@ end
|
|||||||
--Rules
|
--Rules
|
||||||
|
|
||||||
function mesecon:add_rules(name, rules)
|
function mesecon:add_rules(name, rules)
|
||||||
local i=0
|
local i = 1
|
||||||
while mesecon.rules[i]~=nil do
|
while mesecon.rules[i]~=nil do
|
||||||
i=i+1
|
i=i+1
|
||||||
end
|
end
|
||||||
@ -187,7 +146,7 @@ function mesecon:add_rules(name, rules)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function mesecon:get_rules(name)
|
function mesecon:get_rules(name)
|
||||||
local i=0
|
local i = 1
|
||||||
while mesecon.rules[i]~=nil do
|
while mesecon.rules[i]~=nil do
|
||||||
if mesecon.rules[i].name==name then
|
if mesecon.rules[i].name==name then
|
||||||
return mesecon.rules[i].rules
|
return mesecon.rules[i].rules
|
||||||
@ -199,10 +158,10 @@ end
|
|||||||
--Conductor system stuff
|
--Conductor system stuff
|
||||||
|
|
||||||
function mesecon:get_conductor_on(offstate)
|
function mesecon:get_conductor_on(offstate)
|
||||||
local i=0
|
local i = 1
|
||||||
while mesecon.conductors[i]~=nil do
|
while mesecon.conductors[i]~=nil do
|
||||||
if mesecon.conductors[i].off==offstate then
|
if mesecon.conductors[i].offstate == offstate then
|
||||||
return mesecon.conductors[i].on
|
return mesecon.conductors[i].onstate
|
||||||
end
|
end
|
||||||
i=i+1
|
i=i+1
|
||||||
end
|
end
|
||||||
@ -210,10 +169,10 @@ function mesecon:get_conductor_on(offstate)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function mesecon:get_conductor_off(onstate)
|
function mesecon:get_conductor_off(onstate)
|
||||||
local i=0
|
local i = 1
|
||||||
while mesecon.conductors[i]~=nil do
|
while mesecon.conductors[i]~=nil do
|
||||||
if mesecon.conductors[i].on==onstate then
|
if mesecon.conductors[i].onstate == onstate then
|
||||||
return mesecon.conductors[i].off
|
return mesecon.conductors[i].offstate
|
||||||
end
|
end
|
||||||
i=i+1
|
i=i+1
|
||||||
end
|
end
|
||||||
@ -221,9 +180,9 @@ function mesecon:get_conductor_off(onstate)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function mesecon:is_conductor_on(name)
|
function mesecon:is_conductor_on(name)
|
||||||
local i=0
|
local i = 1
|
||||||
while mesecon.conductors[i]~=nil do
|
while mesecon.conductors[i]~=nil do
|
||||||
if mesecon.conductors[i].on==name then
|
if mesecon.conductors[i].onstate == name then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
i=i+1
|
i=i+1
|
||||||
@ -232,9 +191,9 @@ function mesecon:is_conductor_on(name)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function mesecon:is_conductor_off(name)
|
function mesecon:is_conductor_off(name)
|
||||||
local i=0
|
local i = 1
|
||||||
while mesecon.conductors[i]~=nil do
|
while mesecon.conductors[i]~=nil do
|
||||||
if mesecon.conductors[i].off==name then
|
if mesecon.conductors[i].offstate == name then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
i=i+1
|
i=i+1
|
||||||
@ -242,6 +201,26 @@ function mesecon:is_conductor_off(name)
|
|||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function mesecon:is_conductor(name)
|
||||||
|
return mesecon:is_conductor_on(name) or mesecon:is_conductor_off(name)
|
||||||
|
end
|
||||||
|
|
||||||
|
function mesecon:conductor_get_rules(node)
|
||||||
|
local i = 1
|
||||||
|
while mesecon.conductors[i] ~= nil do
|
||||||
|
if mesecon.conductors[i].onstate == node.name
|
||||||
|
or mesecon.conductors[i].offstate == node.name then
|
||||||
|
if mesecon.conductors[i].get_rules ~= nil then
|
||||||
|
return mesecon.conductors[i].get_rules(node.param2)
|
||||||
|
else
|
||||||
|
return mesecon.conductors[i].rules
|
||||||
|
end
|
||||||
|
end
|
||||||
|
i = i + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
--
|
||||||
function mesecon:is_power_on(pos)
|
function mesecon:is_power_on(pos)
|
||||||
local node = minetest.env:get_node(pos)
|
local node = minetest.env:get_node(pos)
|
||||||
if mesecon:is_conductor_on(node.name) or mesecon:is_receptor_node(node.name) then
|
if mesecon:is_conductor_on(node.name) or mesecon:is_receptor_node(node.name) then
|
||||||
@ -258,12 +237,12 @@ function mesecon:is_power_off(pos)
|
|||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
function mesecon:turnon(pos, sourcepos)
|
function mesecon:turnon(pos)
|
||||||
local node = minetest.env:get_node(pos)
|
local node = minetest.env:get_node(pos)
|
||||||
local rules = mesecon:get_rules("default") --TODO: Use rules of conductor
|
|
||||||
local i = 1
|
local i = 1
|
||||||
|
|
||||||
if mesecon:is_conductor_off(node.name) then
|
if mesecon:is_conductor_off(node.name) then
|
||||||
|
local rules = mesecon:conductor_get_rules(node)
|
||||||
minetest.env:add_node(pos, {name=mesecon:get_conductor_on(node.name)})
|
minetest.env:add_node(pos, {name=mesecon:get_conductor_on(node.name)})
|
||||||
|
|
||||||
while rules[i]~=nil do
|
while rules[i]~=nil do
|
||||||
@ -271,150 +250,210 @@ function mesecon:turnon(pos, sourcepos)
|
|||||||
np.x = pos.x + rules[i].x
|
np.x = pos.x + rules[i].x
|
||||||
np.y = pos.y + rules[i].y
|
np.y = pos.y + rules[i].y
|
||||||
np.z = pos.z + rules[i].z
|
np.z = pos.z + rules[i].z
|
||||||
|
|
||||||
mesecon:turnon(np, pos)
|
if mesecon:rules_link(pos, np) then
|
||||||
|
mesecon:turnon(np)
|
||||||
|
end
|
||||||
i=i+1
|
i=i+1
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if mesecon:is_effector(node.name) then
|
if mesecon:is_effector(node.name) then
|
||||||
if mesecon:effector_inputs(sourcepos, pos) then
|
mesecon:changesignal(pos)
|
||||||
mesecon:changesignal(pos)
|
if mesecon:is_effector_off(node.name) then mesecon:activate(pos) end
|
||||||
if mesecon:is_effector_off(node.name) then mesecon:activate(pos) end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function mesecon:turnoff(pos, sourcepos)
|
function mesecon:turnoff(pos) --receptor rules used because output could have been dug
|
||||||
local node = minetest.env:get_node(pos)
|
local node = minetest.env:get_node(pos)
|
||||||
rules = mesecon:get_rules("default") --TODO: Use rules of conductor
|
|
||||||
local i = 1
|
local i = 1
|
||||||
|
local rules
|
||||||
|
|
||||||
if mesecon:is_conductor_on(node.name) then
|
if mesecon:is_conductor_on(node.name) then
|
||||||
|
rules = mesecon:conductor_get_rules(node)
|
||||||
|
|
||||||
minetest.env:add_node(pos, {name=mesecon:get_conductor_off(node.name)})
|
minetest.env:add_node(pos, {name=mesecon:get_conductor_off(node.name)})
|
||||||
|
|
||||||
while rules[i]~=nil do
|
while rules[i]~=nil do
|
||||||
local np = {}
|
local np = {
|
||||||
np.x = pos.x + rules[i].x
|
x = pos.x + rules[i].x,
|
||||||
np.y = pos.y + rules[i].y
|
y = pos.y + rules[i].y,
|
||||||
np.z = pos.z + rules[i].z
|
z = pos.z + rules[i].z,}
|
||||||
|
|
||||||
|
if mesecon:rules_link(pos, np) then
|
||||||
|
mesecon:turnoff(np)
|
||||||
|
end
|
||||||
|
|
||||||
mesecon:turnoff(np, pos)
|
|
||||||
i = i + 1
|
i = i + 1
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if mesecon:is_effector(node.name) then
|
if mesecon:is_effector(node.name) then
|
||||||
if mesecon:effector_inputs(sourcepos, pos) then
|
mesecon:changesignal(pos)
|
||||||
mesecon:changesignal(pos)
|
if mesecon:is_effector_on(node.name) and not mesecon:is_powered(pos) then mesecon:deactivate(pos) end
|
||||||
if mesecon:is_effector_on(node.name) and not mesecon:is_powered(pos) then mesecon:deactivate(pos) end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
function mesecon:connected_to_pw_src(pos, checked)
|
function mesecon:connected_to_pw_src(pos, checked)
|
||||||
if checked == nil then
|
local c = 1
|
||||||
checked = {}
|
if checked == nil then checked = {} end
|
||||||
end
|
while checked[c] ~= nil do --find out if node has already been checked (to prevent from endless loop)
|
||||||
local connected
|
if compare_pos(checked[c], pos) then
|
||||||
local i = 1
|
|
||||||
|
|
||||||
while checked[i] ~= nil do --find out if node has already been checked
|
|
||||||
if compare_pos(checked[i], pos) then
|
|
||||||
return false, checked
|
return false, checked
|
||||||
end
|
end
|
||||||
i = i + 1
|
c = c + 1
|
||||||
end
|
end
|
||||||
|
checked[c] = {x=pos.x, y=pos.y, z=pos.z} --add current node to checked
|
||||||
checked[i] = {x=pos.x, y=pos.y, z=pos.z} --add current node to checked
|
|
||||||
|
|
||||||
local node = minetest.env:get_node_or_nil(pos)
|
local node = minetest.env:get_node_or_nil(pos)
|
||||||
if node == nil then return false, checked end
|
if node == nil then return false, checked end
|
||||||
|
if not mesecon:is_conductor(node.name) then return false, checked end
|
||||||
|
|
||||||
if mesecon:is_conductor_on(node.name) or mesecon:is_conductor_off(node.name) then
|
if mesecon:is_powered_by_receptor(pos) then --return if conductor is powered
|
||||||
if mesecon:is_powered_by_receptor(pos) then --return if conductor is powered
|
return true, checked
|
||||||
return true, checked
|
end
|
||||||
end
|
|
||||||
|
|
||||||
local rules = mesecon:get_rules("default") --TODO: Use conductor specific rules
|
--Check if conductors around are connected
|
||||||
local i = 1
|
local connected
|
||||||
while rules[i] ~= nil do
|
local rules = mesecon:conductor_get_rules(node)
|
||||||
local np = {}
|
|
||||||
np.x = pos.x + rules[i].x
|
local i = 1
|
||||||
np.y = pos.y + rules[i].y
|
while rules[i] ~= nil do
|
||||||
np.z = pos.z + rules[i].z
|
local np = {}
|
||||||
|
np.x = pos.x + rules[i].x
|
||||||
|
np.y = pos.y + rules[i].y
|
||||||
|
np.z = pos.z + rules[i].z
|
||||||
|
if mesecon:rules_link(pos, np) then
|
||||||
connected, checked = mesecon:connected_to_pw_src(np, checked)
|
connected, checked = mesecon:connected_to_pw_src(np, checked)
|
||||||
if connected then
|
if connected then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
i=i+1
|
|
||||||
end
|
end
|
||||||
|
i=i+1
|
||||||
end
|
end
|
||||||
return false, checked
|
return false, checked
|
||||||
end
|
end
|
||||||
|
|
||||||
function mesecon:is_powered_by_receptor(pos)
|
function mesecon:rules_link(output, input, dug_outputrules) --output/input are positions (outputrules optional, used if node has been dug)
|
||||||
local rcpt
|
|
||||||
local rcpt_pos = {}
|
|
||||||
local rcpt_checked = {} --using a checked array speeds this up
|
|
||||||
local i = 1
|
|
||||||
local j = 1
|
|
||||||
local k = 1
|
local k = 1
|
||||||
local rules
|
local l = 1
|
||||||
local pos_checked = false
|
|
||||||
|
|
||||||
while mesecon.rules[i]~=nil do
|
local outputnode = minetest.env:get_node(output)
|
||||||
local j=1
|
local inputnode = minetest.env:get_node(input)
|
||||||
while mesecon.rules[i].rules[j]~=nil do
|
|
||||||
rcpt_pos = {
|
|
||||||
x = pos.x-mesecon.rules[i].rules[j].x,
|
|
||||||
y = pos.y-mesecon.rules[i].rules[j].y,
|
|
||||||
z = pos.z-mesecon.rules[i].rules[j].z}
|
|
||||||
|
|
||||||
k = 1
|
local outputrules = dug_outputrules
|
||||||
pos_checked = false
|
local inputrules
|
||||||
while rcpt_checked[k] ~= nil do
|
|
||||||
if compare_pos(rcpt_checked[k], rcpt_pos) then
|
|
||||||
pos_checked = true
|
|
||||||
end
|
|
||||||
k = k + 1
|
|
||||||
end
|
|
||||||
|
|
||||||
if not pos_checked then
|
if outputrules == nil then
|
||||||
table.insert(rcpt_checked, rcpt_pos)
|
if mesecon:is_conductor(outputnode.name) then
|
||||||
rcpt = minetest.env:get_node(rcpt_pos)
|
outputrules = mesecon:conductor_get_rules(outputnode)
|
||||||
|
elseif mesecon:is_receptor_node(outputnode.name) or mesecon:is_receptor_node_off(outputnode.name) then
|
||||||
if mesecon:is_receptor_node(rcpt.name) then
|
outputrules = mesecon:receptor_get_rules(outputnode)
|
||||||
rules = mesecon:receptor_get_rules(rcpt)
|
else
|
||||||
j = 1
|
return false
|
||||||
while rules[j] ~= nil do
|
|
||||||
if rcpt_pos.x + rules[j].x == pos.x
|
|
||||||
and rcpt_pos.y + rules[j].y == pos.y
|
|
||||||
and rcpt_pos.z + rules[j].z == pos.z then
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
j=j+1
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
j=j+1
|
|
||||||
end
|
end
|
||||||
i=i+1
|
end
|
||||||
|
|
||||||
|
if mesecon:is_conductor(inputnode.name) then
|
||||||
|
inputrules = mesecon:conductor_get_rules(inputnode)
|
||||||
|
elseif mesecon:is_effector(inputnode.name) then
|
||||||
|
inputrules = mesecon:effector_get_input_rules(inputnode)
|
||||||
|
else
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
while outputrules[k] ~= nil do
|
||||||
|
if outputrules[k].x + output.x == input.x
|
||||||
|
and outputrules[k].y + output.y == input.y
|
||||||
|
and outputrules[k].z + output.z == input.z then -- Check if output sends to input
|
||||||
|
l = 1
|
||||||
|
while inputrules[l] ~= nil do
|
||||||
|
if inputrules[l].x + input.x == output.x
|
||||||
|
and inputrules[l].y + input.y == output.y
|
||||||
|
and inputrules[l].z + input.z == output.z then --Check if input accepts from output
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
l = l + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
k = k + 1
|
||||||
end
|
end
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
function mesecon:is_powered_by_conductor(pos)
|
function mesecon:rules_link_bothdir(pos1, pos2)
|
||||||
local k=1
|
return mesecon:rules_link(pos1, pos2) or mesecon:rules_link(pos2, pos1)
|
||||||
|
end
|
||||||
|
|
||||||
rules=mesecon:get_rules("default") --TODO: use conductor specific rules
|
function mesecon:is_powered_by_conductor(pos)
|
||||||
while rules[k]~=nil do
|
local j = 1
|
||||||
if mesecon:is_conductor_on(minetest.env:get_node({x=pos.x+rules[k].x, y=pos.y+rules[k].y, z=pos.z+rules[k].z}).name) then
|
local k = 1
|
||||||
|
|
||||||
|
local rules
|
||||||
|
local con_pos = {}
|
||||||
|
local con_rules = {}
|
||||||
|
local con_node
|
||||||
|
|
||||||
|
local node = minetest.env:get_node(pos)
|
||||||
|
if mesecon:is_conductor(node.name) then
|
||||||
|
rules = mesecon:conductor_get_rules(node)
|
||||||
|
elseif mesecon:is_effector(node.name) then
|
||||||
|
rules = mesecon:effector_get_input_rules(node)
|
||||||
|
else
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
while rules[j] ~= nil do
|
||||||
|
local con_pos = {
|
||||||
|
x = pos.x + rules[j].x,
|
||||||
|
y = pos.y + rules[j].y,
|
||||||
|
z = pos.z + rules[j].z}
|
||||||
|
|
||||||
|
con_node = minetest.env:get_node(con_pos)
|
||||||
|
|
||||||
|
if mesecon:is_conductor_on(con_node.name) and mesecon:rules_link(con_pos, pos) then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
k=k+1
|
j = j + 1
|
||||||
end
|
end
|
||||||
|
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
function mesecon:is_powered_by_receptor(pos)
|
||||||
|
local j = 1
|
||||||
|
local k = 1
|
||||||
|
|
||||||
|
local rules
|
||||||
|
local rcpt_pos = {}
|
||||||
|
local rcpt_rules = {}
|
||||||
|
local rcpt_node
|
||||||
|
|
||||||
|
local node = minetest.env:get_node(pos)
|
||||||
|
if mesecon:is_conductor(node.name) then
|
||||||
|
rules = mesecon:conductor_get_rules(node)
|
||||||
|
elseif mesecon:is_effector(node.name) then
|
||||||
|
rules = mesecon:effector_get_input_rules(node)
|
||||||
|
else
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
while rules[j] ~= nil do
|
||||||
|
local rcpt_pos = {
|
||||||
|
x = pos.x + rules[j].x,
|
||||||
|
y = pos.y + rules[j].y,
|
||||||
|
z = pos.z + rules[j].z}
|
||||||
|
|
||||||
|
rcpt_node = minetest.env:get_node(rcpt_pos)
|
||||||
|
|
||||||
|
if mesecon:is_receptor_node(rcpt_node.name) and mesecon:rules_link(rcpt_pos, pos) then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
j = j + 1
|
||||||
|
end
|
||||||
|
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -486,3 +525,5 @@ function mesecon:rotate_rules_up(rules)
|
|||||||
end
|
end
|
||||||
return nr
|
return nr
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--TODO: is_powered returns the position (see services.lua!!!)
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
minetest.register_on_dignode(
|
minetest.register_on_dignode(
|
||||||
function(pos, oldnode, digger)
|
function(pos, oldnode, digger)
|
||||||
if mesecon:is_conductor_on(oldnode.name) then
|
if mesecon:is_conductor_on(oldnode.name) then
|
||||||
print("receptor_off")
|
|
||||||
mesecon:receptor_off(pos)
|
mesecon:receptor_off(pos)
|
||||||
end
|
end
|
||||||
|
|
||||||
if mesecon:is_receptor_node(oldnode.name) then
|
if mesecon:is_receptor_node(oldnode.name) then
|
||||||
mesecon:receptor_off(pos, mesecon:receptor_get_rules(oldnode))
|
mesecon:receptor_off(pos, mesecon:receptor_get_rules(oldnode))
|
||||||
@ -19,7 +18,7 @@ minetest.register_on_placenode(
|
|||||||
|
|
||||||
if mesecon:is_powered(pos) then
|
if mesecon:is_powered(pos) then
|
||||||
if mesecon:is_conductor_off(node.name) then
|
if mesecon:is_conductor_off(node.name) then
|
||||||
mesecon:turnon(pos) -- in this case we don't need a source as the destination certainly is a conductor and not a receptor
|
mesecon:turnon(pos)
|
||||||
else
|
else
|
||||||
mesecon:changesignal(pos)
|
mesecon:changesignal(pos)
|
||||||
mesecon:activate(pos)
|
mesecon:activate(pos)
|
||||||
|
@ -260,20 +260,20 @@ function mesecon:update_autoconnect(pos, secondcall, replace_old)
|
|||||||
if zmyg == 2 then zmy = 1 else zmy = 0 end
|
if zmyg == 2 then zmy = 1 else zmy = 0 end
|
||||||
|
|
||||||
-- If group == 3 then the mesecon only connects to input and output ports
|
-- If group == 3 then the mesecon only connects to input and output ports
|
||||||
if xpg == 3 and mesecon:node_connects(pos, xppos) then xp = 1 end
|
if xpg == 3 and mesecon:rules_link_bothdir(pos, xppos) then xp = 1 end
|
||||||
if xmg == 3 and mesecon:node_connects(pos, xmpos) then xm = 1 end
|
if xmg == 3 and mesecon:rules_link_bothdir(pos, xmpos) then xm = 1 end
|
||||||
if zpg == 3 and mesecon:node_connects(pos, zppos) then zp = 1 end
|
if zpg == 3 and mesecon:rules_link_bothdir(pos, zppos) then zp = 1 end
|
||||||
if zmg == 3 and mesecon:node_connects(pos, zmpos) then zm = 1 end
|
if zmg == 3 and mesecon:rules_link_bothdir(pos, zmpos) then zm = 1 end
|
||||||
|
|
||||||
if xpymg == 3 and mesecon:node_connects(pos, xpympos) then xp = 1 end
|
if xpymg == 3 and mesecon:rules_link_bothdir(pos, xpympos) then xp = 1 end
|
||||||
if xmymg == 3 and mesecon:node_connects(pos, xmympos) then xm = 1 end
|
if xmymg == 3 and mesecon:rules_link_bothdir(pos, xmympos) then xm = 1 end
|
||||||
if zpymg == 3 and mesecon:node_connects(pos, zpympos) then zp = 1 end
|
if zpymg == 3 and mesecon:rules_link_bothdir(pos, zpympos) then zp = 1 end
|
||||||
if zmymg == 3 and mesecon:node_connects(pos, zmympos) then zm = 1 end
|
if zmymg == 3 and mesecon:rules_link_bothdir(pos, zmympos) then zm = 1 end
|
||||||
|
|
||||||
if xpyg == 3 then if mesecon:node_connects(pos, xpypos) then xpy = 1 end end
|
if xpyg == 3 then if mesecon:rules_link(pos, xpypos) then xpy = 1 end end
|
||||||
if zpyg == 3 then if mesecon:node_connects(pos, zpypos) then zpy = 1 end end
|
if zpyg == 3 then if mesecon:rules_link(pos, zpypos) then zpy = 1 end end
|
||||||
if xmyg == 3 then if mesecon:node_connects(pos, xmypos) then xmy = 1 end end
|
if xmyg == 3 then if mesecon:rules_link(pos, xmypos) then xmy = 1 end end
|
||||||
if zmyg == 3 then if mesecon:node_connects(pos, zmypos) then zmy = 1 end end
|
if zmyg == 3 then if mesecon:rules_link(pos, zmypos) then zmy = 1 end end
|
||||||
|
|
||||||
-- Backward compatibility
|
-- Backward compatibility
|
||||||
if replace_old then
|
if replace_old then
|
||||||
|
1
mesecons_isolated/depends.txt
Normal file
1
mesecons_isolated/depends.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
mesecons
|
18
mesecons_isolated/init.lua
Normal file
18
mesecons_isolated/init.lua
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
minetest.register_node("mesecons_isolated:isolated_on", {
|
||||||
|
description = "isolated mesecons",
|
||||||
|
tiles = {"default_stone.png"},
|
||||||
|
groups = {dig_immediate = 3, mesecon = 3, mesecon_conductor_craftable=1},
|
||||||
|
drop = "mesecons_isolated:isolated_off",
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_node("mesecons_isolated:isolated_off", {
|
||||||
|
description = "isolated mesecons",
|
||||||
|
tiles = {"default_wood.png"},
|
||||||
|
groups = {dig_immediate = 3, mesecon = 3, mesecon_conductor_craftable=1, not_in_creative_inventory = 1},
|
||||||
|
})
|
||||||
|
|
||||||
|
mesecon:add_rules("isolated", {
|
||||||
|
{x = 1, y = 0, z = 0},
|
||||||
|
{x =-1, y = 0, z = 0},})
|
||||||
|
|
||||||
|
mesecon:register_conductor("mesecons_isolated:isolated_on", "mesecons_isolated:isolated_off", mesecon:get_rules("isolated"))
|
Loading…
Reference in New Issue
Block a user