summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeija <norrepli@gmail.com>2012-08-09 12:54:31 +0200
committerJeija <norrepli@gmail.com>2012-08-09 12:54:31 +0200
commitca4a8cd26436769e75963e8dff215e09b53dc945 (patch)
tree4213bbf779baf15c0e8a1453756df9f80c6c8fb5
parent8b41402558ee9f2e4b785529ccc8a34c76dcc991 (diff)
downloadmesecons-ca4a8cd26436769e75963e8dff215e09b53dc945.tar
mesecons-ca4a8cd26436769e75963e8dff215e09b53dc945.tar.gz
mesecons-ca4a8cd26436769e75963e8dff215e09b53dc945.tar.bz2
mesecons-ca4a8cd26436769e75963e8dff215e09b53dc945.tar.xz
mesecons-ca4a8cd26436769e75963e8dff215e09b53dc945.zip
Use all of VanessaE's textures, bugfixes & improvements
-rw-r--r--mesecons_microcontroller/init.lua155
1 files changed, 99 insertions, 56 deletions
diff --git a/mesecons_microcontroller/init.lua b/mesecons_microcontroller/init.lua
index e05f983..501d338 100644
--- a/mesecons_microcontroller/init.lua
+++ b/mesecons_microcontroller/init.lua
@@ -1,10 +1,15 @@
EEPROM_SIZE = 255
-minetest.register_node("mesecons_microcontroller:microcontroller", {
+for a = 0, 1 do
+for b = 0, 1 do
+for c = 0, 1 do
+for d = 0, 1 do
+local nodename = "mesecons_microcontroller:microcontroller"..tostring(d)..tostring(c)..tostring(b)..tostring(a)
+minetest.register_node(nodename, {
description = "Microcontroller",
drawtype = "nodebox",
tiles = {
- "jeija_microcontroller_top_0000.png",
+ "jeija_microcontroller_top_"..tostring(d)..tostring(c)..tostring(b)..tostring(a)..".png",
"jeija_microcontroller_sides.png",
},
inventory_image = "jeija_microcontroller_top_0000.png",
@@ -13,6 +18,7 @@ minetest.register_node("mesecons_microcontroller:microcontroller", {
walkable = true,
groups = {dig_immediate=2},
material = minetest.digprop_constanttime(1.0),
+ drop = '"mesecons_microcontroller:microcontroller0000" 1',
selection_box = {
type = "fixed",
fixed = { -8/16, -8/16, -8/16, 8/16, -4/16, 8/16 },
@@ -49,9 +55,20 @@ minetest.register_node("mesecons_microcontroller:microcontroller", {
end
end
})
+local rules={}
+if (a == 1) then table.insert(rules, {x = -1, y = 0, z = 0}) end
+if (b == 1) then table.insert(rules, {x = 0, y = 0, z = 1}) end
+if (c == 1) then table.insert(rules, {x = 1, y = 0, z = 0}) end
+if (d == 1) then table.insert(rules, {x = 0, y = 0, z = -1}) end
+mesecon:add_rules(nodename, rules)
+mesecon:add_receptor_node(nodename, rules)
+end
+end
+end
+end
minetest.register_craft({
- output = 'craft "mesecons_microcontroller:microcontroller" 2',
+ output = 'craft "mesecons_microcontroller:microcontroller0000" 2',
recipe = {
{'mesecons_materials:silicon', 'mesecons_materials:silicon', 'mesecons:mesecon_off'},
{'mesecons_materials:silicon', 'mesecons_materials:silicon', 'mesecons:mesecon_off'},
@@ -60,10 +77,7 @@ minetest.register_craft({
})
function reset_yc(pos)
- mesecon:receptor_off(pos, mesecon:get_rules("microcontrollerA"))
- mesecon:receptor_off(pos, mesecon:get_rules("microcontrollerB"))
- mesecon:receptor_off(pos, mesecon:get_rules("microcontrollerC"))
- mesecon:receptor_off(pos, mesecon:get_rules("microcontrollerD"))
+ yc_action(pos, {a=false, b=false, c=false, d=false})
local meta = minetest.env:get_meta(pos)
local r = ""
for i=1, EEPROM_SIZE+1 do r=r.."0" end --Generate a string with EEPROM_SIZE*"0"
@@ -94,7 +108,9 @@ end
function parse_yccode(code, pos)
local endi = 1
- local L = yc_get_portstates(pos)
+ local Lreal = yc_get_real_portstates(pos)
+ local Lvirtual = yc_get_virtual_portstates(pos)
+ if Lvirtual == nil then return nil end
local c
local eeprom = minetest.env:get_meta(pos):get_string("eeprom")
while true do
@@ -102,7 +118,7 @@ function parse_yccode(code, pos)
if command == nil then return nil end
if command == true then break end
if command == "if" then
- r, endi = yc_command_if(code, endi, L, eeprom)
+ r, endi = yc_command_if(code, endi, yc_merge_portstates(Lreal, Lvirtual), eeprom)
if r == nil then return nil end
if r == true then -- nothing
elseif r == false then
@@ -114,11 +130,11 @@ function parse_yccode(code, pos)
if params == nil then return nil end
end
if command == "on" then
- L = yc_command_on (params, L)
+ L = yc_command_on (params, Lvirtual)
elseif command == "off" then
- L = yc_command_off(params, L)
+ L = yc_command_off(params, Lvirtual)
elseif command == "sbi" then
- new_eeprom = yc_command_sbi (params, eeprom, L)
+ new_eeprom = yc_command_sbi (params, eeprom, yc_merge_portstates(Lreal, Lvirtual))
if new_eeprom == nil then return nil
else eeprom = new_eeprom end
elseif command == "if" then --nothing
@@ -129,7 +145,7 @@ function parse_yccode(code, pos)
if eeprom == nil then return nil else
minetest.env:get_meta(pos):set_string("eeprom", eeprom) end
end
- yc_action(pos, L)
+ yc_action(pos, Lvirtual)
return true
end
@@ -257,7 +273,7 @@ function yc_command_if_getcondition(code, starti)
end
function yc_command_parsecondition(cond, L, eeprom)
- cond = string.gsub(cond, "A", tostring(L.a and 1 or 0))
+ cond = string.gsub(cond, "A", tonumber(L.a and 1 or 0))
cond = string.gsub(cond, "B", tonumber(L.b and 1 or 0))
cond = string.gsub(cond, "C", tonumber(L.c and 1 or 0))
cond = string.gsub(cond, "D", tonumber(L.d and 1 or 0))
@@ -346,36 +362,50 @@ function yc_eeprom_read(number, eeprom)
return value, endi
end
-function yc_get_port_rules(port)
- local rules = nil
- if port == "A" then
- rules = mesecon:get_rules("microcontrollerA")
- elseif port == "B" then
- rules = mesecon:get_rules("microcontrollerB")
- elseif port == "C" then
- rules = mesecon:get_rules("microcontrollerC")
- elseif port == "D" then
- rules = mesecon:get_rules("microcontrollerD")
- end
- return rules
-end
+function yc_action(pos, L) --L-->Lvirtual
+ yc_action_setports(pos, L)
-function yc_action(pos, L)
- yc_action_setport("A", L.a, pos)
- yc_action_setport("B", L.b, pos)
- yc_action_setport("C", L.c, pos)
- yc_action_setport("D", L.d, pos)
+ local meta = minetest.env:get_meta(pos)
+ local code = meta:get_string("code")
+ local eeprom = meta:get_string("eeprom")
+ local infotext = meta:get_string("infotext")
+ local formspec = meta:get_string("formspec")
+ local name = "mesecons_microcontroller:microcontroller"
+ ..tonumber(L.d and 1 or 0)
+ ..tonumber(L.c and 1 or 0)
+ ..tonumber(L.b and 1 or 0)
+ ..tonumber(L.a and 1 or 0)
+ minetest.env:add_node(pos, {name=name})
+ local meta = minetest.env:get_meta(pos)
+ meta:set_string("code", code)
+ meta:set_string("eeprom", eeprom)
+ meta:set_string("infotext", infotext)
+ meta:set_string("formspec", formspec)
end
-function yc_action_setport(port, state, pos)
- local rules = mesecon:get_rules("microcontroller"..port)
- if state == false then
- if mesecon:is_power_on({x=pos.x+rules[1].x, y=pos.y+rules[1].y, z=pos.z+rules[1].z}) then
- mesecon:turnoff(pos, rules[1].x, rules[1].y, rules[1].z, false)
- end
- elseif state == true then
- if mesecon:is_power_off({x=pos.x+rules[1].x, y=pos.y+rules[1].y, z=pos.z+rules[1].z}) then
- mesecon:turnon(pos, rules[1].x, rules[1].y, rules[1].z, false)
+function yc_action_setports(pos, L)
+ local ps = tonumber(L.d and 1 or 0)
+ ..tonumber(L.c and 1 or 0)
+ ..tonumber(L.b and 1 or 0)
+ ..tonumber(L.a and 1 or 0)
+
+ local rulesps
+ local rules
+ for i=1, 4 do
+ if i == 1 then rulesps = "1000" end
+ if i == 2 then rulesps = "0100" end
+ if i == 3 then rulesps = "0010" end
+ if i == 4 then rulesps = "0001" end
+ rules = mesecon:get_rules("mesecons_microcontroller:microcontroller"..rulesps)
+
+ if ps:sub(i, i) == "1" then
+ if mesecon:is_power_off({x=pos.x+rules[1].x, y=pos.y+rules[1].y, z=pos.z+rules[1].z}) then
+ mesecon:receptor_on(pos, rules)
+ end
+ else
+ if mesecon:is_power_on({x=pos.x+rules[1].x, y=pos.y+rules[1].y, z=pos.z+rules[1].z}) then
+ mesecon:receptor_off(pos, rules)
+ end
end
end
end
@@ -389,11 +419,11 @@ function yc_set_portstate(port, state, L)
return L
end
-function yc_get_portstates(pos)
- rulesA = mesecon:get_rules("microcontrollerA")
- rulesB = mesecon:get_rules("microcontrollerB")
- rulesC = mesecon:get_rules("microcontrollerC")
- rulesD = mesecon:get_rules("microcontrollerD")
+function yc_get_real_portstates(pos)
+ rulesA = mesecon:get_rules("mesecons_microcontroller:microcontroller0001")
+ rulesB = mesecon:get_rules("mesecons_microcontroller:microcontroller0010")
+ rulesC = mesecon:get_rules("mesecons_microcontroller:microcontroller0100")
+ rulesD = mesecon:get_rules("mesecons_microcontroller:microcontroller1000")
local L = {
a = mesecon:is_power_on({x=pos.x+rulesA[1].x, y=pos.y+rulesA[1].y, z=pos.z+rulesA[1].z}),
b = mesecon:is_power_on({x=pos.x+rulesB[1].x, y=pos.y+rulesB[1].y, z=pos.z+rulesB[1].z}),
@@ -403,6 +433,28 @@ function yc_get_portstates(pos)
return L
end
+function yc_get_virtual_portstates(pos)
+ name = minetest.env:get_node(pos).name
+ b, a = string.find(name, ":microcontroller")
+ if a == nil then return nil end
+ a = a + 1
+
+ Lvirtual = {false, false, false, false}
+ if name:sub(a , a ) == "1" then Lvirtual.d = true end
+ if name:sub(a+1, a+1) == "1" then Lvirtual.c = true end
+ if name:sub(a+2, a+2) == "1" then Lvirtual.b = true end
+ if name:sub(a+2, a+3) == "1" then Lvirtual.a = true end
+ return Lvirtual
+end
+
+function yc_merge_portstates(Lreal, Lvirtual)
+ if Lvirtual.a~=nil then Lreal.a = Lvirtual.a end
+ if Lvirtual.b~=nil then Lreal.b = Lvirtual.b end
+ if Lvirtual.c~=nil then Lreal.c = Lvirtual.c end
+ if Lvirtual.d~=nil then Lreal.d = Lvirtual.d end
+ return Lreal
+end
+
function yc_skip_to_endif(code, starti)
local i = starti
local s = false
@@ -417,16 +469,7 @@ function yc_skip_to_endif(code, starti)
end
mesecon:register_on_signal_change(function(pos, node)
- if node.name == "mesecons_microcontroller:microcontroller" then
+ if string.find(node.name, "mesecons_microcontroller:microcontroller")~=nil then
minetest.after(0.5, update_yc, pos)
end
end)
-
-
-mesecon:add_rules("microcontrollerA", {{x = -1, y = 0, z = 0}})
-mesecon:add_rules("microcontrollerB", {{x = 0, y = 0, z = 1}})
-mesecon:add_rules("microcontrollerC", {{x = 1, y = 0, z = 0}})
-mesecon:add_rules("microcontrollerD", {{x = 0, y = 0, z = -1}})
-mesecon:add_rules("microcontroller_default", {})
-mesecon:add_receptor_node("mesecons_microcontroller:microcontroller", mesecon:get_rules("microcontroller_default"))
-mesecon:add_receptor_node("mesecons_microcontroller:microcontroller", mesecon:get_rules("microcontroller_default"))