diff options
author | Anthony Zhang <azhang9@gmail.com> | 2013-05-15 21:36:16 -0400 |
---|---|---|
committer | Anthony Zhang <azhang9@gmail.com> | 2013-05-15 21:36:16 -0400 |
commit | 682cf3479209cb9a62724e957b65a0e450a6dfeb (patch) | |
tree | 1a4dac1b08c7dae71e701a56d0d0edc51f5a754f /mesecons_luacontroller | |
parent | 6f83f4cf1ed616d0c74cfc3cd63a170f822b1046 (diff) |
Add burnt luacontroller (so you don't lose your program after an overheat) and prevent interrupts from piling up (fixes #101, metadata trashing). Idea for burnt luacontroller comes from ShadowNinja.
Diffstat (limited to 'mesecons_luacontroller')
-rw-r--r-- | mesecons_luacontroller/init.lua | 48 |
1 files changed, 44 insertions, 4 deletions
diff --git a/mesecons_luacontroller/init.lua b/mesecons_luacontroller/init.lua index b4b9040..76abcca 100644 --- a/mesecons_luacontroller/init.lua +++ b/mesecons_luacontroller/init.lua @@ -149,8 +149,17 @@ local getinterrupt = function(pos) local iid = iid or math.random() local meta = minetest.env:get_meta(pos) local interrupts = minetest.deserialize(meta:get_string("lc_interrupts")) or {} - table.insert (interrupts, iid) - meta:set_string("lc_interrupts", minetest.serialize(interrupts)) + local found = false + for _, i in ipairs(interrupts) do + if minetest.serialize(i) == minetest.serialize(event.iid) then + found = true + break + end + end + if not found then + table.insert(interrupts, iid) + meta:set_string("lc_interrupts", minetest.serialize(interrupts)) + end minetest.after(time, interrupt, {pos=pos, iid = iid}) end return interrupt @@ -251,9 +260,9 @@ local do_overheat = function (pos, meta) heat(meta) minetest.after(0.5, cool, meta) if overheat(meta) then - minetest.env:remove_node(pos) + mesecon:swap_node(pos, BASENAME.."_burnt") + minetest.env:get_meta(pos):set_string("lc_interrupts", "") minetest.after(0.2, overheat_off, pos) -- wait for pending operations - minetest.env:add_item(pos, BASENAME.."0000") return true end end @@ -479,6 +488,37 @@ end end end +--overheated luacontroller +minetest.register_node(BASENAME .. "_burnt", { + drawtype = "nodebox", + tiles = { + "jeija_luacontroller_burnt_top.png", + "jeija_microcontroller_bottom.png", + "jeija_microcontroller_sides.png", + "jeija_microcontroller_sides.png", + "jeija_microcontroller_sides.png", + "jeija_microcontroller_sides.png" + }, + inventory_image = "jeija_luacontroller_burnt_top.png", + paramtype = "light", + groups = {dig_immediate=2, not_in_creative_inventory=1}, + drop = BASENAME.."0000", + sunlight_propagates = true, + selection_box = selectionbox, + node_box = nodebox, + on_construct = reset_meta, + on_receive_fields = function(pos, formname, fields) + reset(pos) + reset_meta(pos, fields.code) + local err = lc_update(pos, {type="program"}) + if err then print(err) end + reset_meta(pos, fields.code, err) + end, + sounds = default.node_sound_stone_defaults(), + is_luacontroller = true, + virtual_portstates = {a = false, b = false, c = false, d = false}, +}) + ------------------------ -- Craft Registration -- ------------------------ |