summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKyle <kyle.kylina@gmail.com>2012-09-04 21:16:32 -0700
committerKyle <kyle.kylina@gmail.com>2012-09-04 21:16:32 -0700
commit17fc6ac1f04e8f75674e6e895f78e477e38b0e5c (patch)
tree6c144f3b3a942f934a62f303373a89b9748525d2
parente65c5ca9dc43f09934007fddd89ae81b579bec50 (diff)
downloadmesecons-17fc6ac1f04e8f75674e6e895f78e477e38b0e5c.tar
mesecons-17fc6ac1f04e8f75674e6e895f78e477e38b0e5c.tar.gz
mesecons-17fc6ac1f04e8f75674e6e895f78e477e38b0e5c.tar.bz2
mesecons-17fc6ac1f04e8f75674e6e895f78e477e38b0e5c.tar.xz
mesecons-17fc6ac1f04e8f75674e6e895f78e477e38b0e5c.zip
FACEDIR! (among other things)
-rw-r--r--mesecons_gates/init.lua97
1 files changed, 70 insertions, 27 deletions
diff --git a/mesecons_gates/init.lua b/mesecons_gates/init.lua
index 92f0d9a..b7eae45 100644
--- a/mesecons_gates/init.lua
+++ b/mesecons_gates/init.lua
@@ -1,13 +1,38 @@
outrules = {
{x=1, y=0, z=0},
}
+oneinput = {
+ {x=-1, y=0, z=0},
+ {x=1, y=0, z=0},
+}
+twoinputs = {
+ {x=0, y=0, z=1},
+ {x=0, y=0, z=-1},
+ {x=1, y=0, z=0},
+}
+function get_gate_rules(param2, onlyout, singleinput)
+ if onlyout then
+ rules = outrules
+ else
+ if singleinput then
+ rules = oneinput
+ else
+ rules = twoinputs
+ end
+ end
+ for rotations=0, param2-1 do
+ rules = mesecon:rotate_rules_left(rules)
+ end
+ return rules
+end
+
+function get_gate_rules_one(param2) return get_gate_rules(param2, false, true) end
+function get_gate_rules_two(param2) return get_gate_rules(param2, false, false) end
+function get_gate_rules_out(param2) return get_gate_rules(param2, true) end
gates = {"diode", "not", "nand", "and", "xor"}
for g in ipairs(gates) do gate = gates[g]
if g < 3 then
- rules = {
- {x=-1, y=0, z=0},
- {x=1, y=0, z=0},
- }
+ get_rules = get_gate_rules_one
node_box = {
type = "fixed",
fixed = {
@@ -17,11 +42,7 @@ for g in ipairs(gates) do gate = gates[g]
},
}
else
- rules = {
- {x=0, y=0, z=1},
- {x=0, y=0, z=-1},
- {x=1, y=0, z=0},
- }
+ get_rules = get_gate_rules_two
node_box = {
type = "fixed",
fixed = {
@@ -37,16 +58,17 @@ for g in ipairs(gates) do gate = gates[g]
if on == 1 then
onoff = "on"
drop = nodename.."_off"
- groups = {dig_immediate=2, not_in_creative_inventory=1, mesecon = 3}
- description = "You hacker you!"
nodename = nodename.."_"..onoff
- mesecon:add_receptor_node(nodename, outrules)
+ description = "You hacker you!"
+ groups = {dig_immediate=2, not_in_creative_inventory=1, mesecon = 3}
+ mesecon:add_receptor_node(nodename, get_rules, get_gate_rules_out)
+ --mesecon:add_receptor_node(nodename, mesecon:get_rules("insulated_all"))
else
onoff = "off"
- groups = {dig_immediate=2, mesecon = 3}
- description = gate.." Gate"
nodename = nodename.."_"..onoff
- --mesecon:add_receptor_node_off(nodename, rules)
+ description = gate.." Gate"
+ groups = {dig_immediate=2, mesecon = 3}
+ --mesecon:add_receptor_node_off(nodename, get_gate_rules_out)
end
tiles = "jeija_microcontroller_bottom.png^"..
@@ -56,6 +78,7 @@ for g in ipairs(gates) do gate = gates[g]
minetest.register_node(nodename, {
description = description,
paramtype = "light",
+ paramtype2 = "facedir",
drawtype = "nodebox",
tiles = {tiles},
inventory_image = tiles,
@@ -72,22 +95,24 @@ for g in ipairs(gates) do gate = gates[g]
})
- mesecon:register_effector(nodename, nodename, rules)
+ mesecon:register_effector(nodename, nodename, mesecon:get_rules("insulated_all"), get_rules)
end
end
function get_gate(pos)
- string = minetest.env:get_node(pos).name
- string = string.gsub(string, "mesecons_gates:", "")
- --gate
- string = string.gsub(string, "_on", "")
- string = string.gsub(string, "_off", "")
- return string
+ return
+ string.gsub(
+ string.gsub(
+ string.gsub(
+ minetest.env:get_node(pos).name
+ , "mesecons_gates:", "") --gate
+ ,"_on", "")
+ ,"_off", "")
end
function gate_state(pos)
name = minetest.env:get_node(pos).name
- return string.find(name, "off") == nil
+ return string.find(name, "_on") ~= nil
end
function pop_gate(pos)
@@ -112,21 +137,39 @@ function set_gate(pos, on)
else
onoff = "_off"
end
- minetest.env:add_node(pos, {name="mesecons_gates:"..gate..onoff})
+ param2 = minetest.env:get_node(pos).param2
+ minetest.env:add_node(pos, {
+ name = "mesecons_gates:"..gate..onoff,
+ param2 = param2,
+ })
local meta2 = minetest.env:get_meta(pos)
meta2:set_int("heat", heat)
if on then
- mesecon:receptor_on(pos, outrules)
+ mesecon:receptor_on(pos, get_gate_rules(param2, true))
else
- mesecon:receptor_off(pos, outrules)
+ mesecon:receptor_off(pos, mesecon:get_rules("insulated_all"))
end
end
end
end
+function rotate_ports(L, param2)
+ for rotations=0, param2-1 do
+ port = L.a
+ L.a = L.b
+ L.b = L.c
+ L.c = L.d
+ L.d = port
+ end
+ return L
+end
+
function update_gate(pos)
gate = get_gate(pos)
- L = yc_get_real_portstates(pos)
+ L = rotate_ports(
+ yc_get_real_portstates(pos),
+ minetest.env:get_node(pos).param2
+ )
if gate == "diode" then
set_gate(pos, L.a)
elseif gate == "not" then