summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeija <norrepli@gmail.com>2012-08-13 22:33:25 +0200
committerJeija <norrepli@gmail.com>2012-08-13 22:33:25 +0200
commit9f16e4fcaaf683e8e97ef9baea6153c5168f5346 (patch)
treeb8da464421fada9daf56a6d565ebb000dd559ba3
parent9396ce8940641039cfd13156e279f225f21f5b81 (diff)
Add not-yet-working after(time, code) function to the microcontroller
-rw-r--r--mesecons_microcontroller/init.lua33
-rw-r--r--mesecons_torch/init.lua2
2 files changed, 31 insertions, 4 deletions
diff --git a/mesecons_microcontroller/init.lua b/mesecons_microcontroller/init.lua
index faa9ffd..9449c62 100644
--- a/mesecons_microcontroller/init.lua
+++ b/mesecons_microcontroller/init.lua
@@ -141,7 +141,7 @@ function update_yc(pos)
code = yc_code_remove_commentary(code)
code = string.gsub(code, " ", "") --Remove all spaces
code = string.gsub(code, " ", "") --Remove all tabs
- if parse_yccode(code, pos) == nil then
+ if yc_parsecode(code, pos) == nil then
meta:set_string("infotext", "Code not valid!")
else
meta:set_string("infotext", "Working Microcontroller")
@@ -163,7 +163,7 @@ function yc_code_remove_commentary(code)
return code
end
-function parse_yccode(code, pos)
+function yc_parsecode(code, pos)
local endi = 1
local Lreal = yc_get_real_portstates(pos)
local Lvirtual = yc_get_virtual_portstates(pos)
@@ -196,8 +196,11 @@ function parse_yccode(code, pos)
elseif command == "off" then
L = yc_command_off(params, Lvirtual)
elseif command == "print" then
- su = yc_command_print(params, eeprom, yc_merge_portstates(Lreal, Lvirtual))
+ local su = yc_command_print(params, eeprom, yc_merge_portstates(Lreal, Lvirtual))
if su ~= true then return nil end
+ elseif command == "after" then
+ local su = yc_command_after(params, pos)
+ if su == nil then return nil end
elseif command == "sbi" then
new_eeprom, Lvirtual = yc_command_sbi (params, eeprom, yc_merge_portstates(Lreal, Lvirtual), Lvirtual)
if new_eeprom == nil then return nil
@@ -379,6 +382,30 @@ function yc_command_sbi(params, eeprom, L, Lv)
return new_eeprom, Lv
end
+-- after (delay)
+function yc_command_after(params, pos)
+ if params[1] == nil or params[2] == nil or params[3] ~= nil then return nil end
+
+ --get time (maximum time is 200)
+ local time = tonumber(params[1])
+ if time == nil or time > 200 then
+ return nil
+ end
+
+ --get code in quotes "code"
+ if string.sub(params[2], 1, 1) ~= '"' or string.sub(params[2], #params[2], #params[2]) ~= '"' then return nil end
+ local code = string.sub(params[2], 2, #params[2] - 1)
+
+ minetest.after(time, yc_command_after_execute, {pos = pos, code = code})
+ return true
+end
+
+function yc_command_after_execute(params)
+ if string.find(minetest.env:get_node(params.pos).name, "mesecons_microcontroller:microcontroller") ~= nil then --make sure the node has not been dug
+ yc_parsecode(params.code, params.pos)
+ end
+end
+
--If
function yc_command_if(code, starti, L, eeprom)
local cond, endi = yc_command_if_getcondition(code, starti)
diff --git a/mesecons_torch/init.lua b/mesecons_torch/init.lua
index 5e12875..1db8f2a 100644
--- a/mesecons_torch/init.lua
+++ b/mesecons_torch/init.lua
@@ -115,7 +115,7 @@ mesecon:add_rules("mesecontorch",
mesecon:add_receptor_node("mesecons_torch:mesecon_torch_on", nil, mesecon.torch_get_rules)
mesecon:add_receptor_node_off("mesecons_torch:mesecon_torch_off", nil, mesecon.torch_get_rules)
-mesecon:register_effector("mesecons_torch:mesecon_torch_on","mesecons_torch:mesecon_torch_off", nil,mesecon.torch_get_input_rules)
+mesecon:register_effector("mesecons_torch:mesecon_torch_on","mesecons_torch:mesecon_torch_off", nil, mesecon.torch_get_input_rules)
-- Param2 Table (Block Attached To)
-- 5 = z-1