diff options
author | Vanessa Ezekowitz <vanessaezekowitz@gmail.com> | 2016-06-03 19:16:56 -0400 |
---|---|---|
committer | Vanessa Ezekowitz <vanessaezekowitz@gmail.com> | 2016-06-03 19:27:18 -0400 |
commit | 842a6d94916296912aba934b2b23d59244ea463b (patch) | |
tree | 20b92c24d2887296a3506c62233534a0e459c426 /digilines/rtc.lua | |
parent | df2f0076c553c42c5ef4d2d2fbaff58b0ef8e4fd (diff) | |
download | dreambuilder_modpack-842a6d94916296912aba934b2b23d59244ea463b.tar dreambuilder_modpack-842a6d94916296912aba934b2b23d59244ea463b.tar.gz dreambuilder_modpack-842a6d94916296912aba934b2b23d59244ea463b.tar.bz2 dreambuilder_modpack-842a6d94916296912aba934b2b23d59244ea463b.tar.xz dreambuilder_modpack-842a6d94916296912aba934b2b23d59244ea463b.zip |
update castle, colormachine, moreblocks, pipeworks, tpr, and digilines
Diffstat (limited to 'digilines/rtc.lua')
-rw-r--r-- | digilines/rtc.lua | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/digilines/rtc.lua b/digilines/rtc.lua new file mode 100644 index 0000000..f8f6af4 --- /dev/null +++ b/digilines/rtc.lua @@ -0,0 +1,59 @@ +local GET_COMMAND = "GET" + +local rtc_nodebox = +{ + type = "fixed", + fixed = { + { -8/16, -8/16, -8/16, 8/16, -7/16, 8/16 }, -- bottom slab + + { -7/16, -7/16, -7/16, 7/16, -5/16, 7/16 }, + } +} + +local rtc_selbox = +{ + type = "fixed", + fixed = {{ -8/16, -8/16, -8/16, 8/16, -3/16, 8/16 }} +} + +local on_digiline_receive = function (pos, node, channel, msg) + local setchan = minetest.get_meta(pos):get_string("channel") + if channel == setchan and msg == GET_COMMAND then + local timeofday = minetest.get_timeofday() + digiline:receptor_send(pos, digiline.rules.default, channel, timeofday) + end +end + +minetest.register_alias("digilines_rtc:rtc", "digilines:rtc") +minetest.register_node("digilines:rtc", { + description = "Digiline Real Time Clock (RTC)", + drawtype = "nodebox", + tiles = {"digilines_rtc.png"}, + + paramtype = "light", + paramtype2 = "facedir", + groups = {dig_immediate=2}, + selection_box = rtc_selbox, + node_box = rtc_nodebox, + digiline = + { + receptor = {}, + effector = { + action = on_digiline_receive + }, + }, + on_construct = function(pos) + local meta = minetest.get_meta(pos) + meta:set_string("formspec", "field[channel;Channel;${channel}]") + end, + on_receive_fields = function(pos, formname, fields, sender) + local name = sender:get_player_name() + if minetest.is_protected(pos, name) and not minetest.check_player_privs(name, {protection_bypass=true}) then + minetest.record_protection_violation(pos, name) + return + end + if (fields.channel) then + minetest.get_meta(pos):set_string("channel", fields.channel) + end + end, +}) |