diff options
author | Pierre-Yves Rollo <dev@pyrollo.com> | 2015-12-03 15:43:39 +0100 |
---|---|---|
committer | Pierre-Yves Rollo <dev@pyrollo.com> | 2015-12-03 15:43:39 +0100 |
commit | dc7aea71ee7db3deb1f6672cbe2f6d3a07efe549 (patch) | |
tree | f4480bb86dee02ab69d05c75595b82c244db7be0 | |
parent | a7e80f4b9870b671762bee1c821bb0e35d7b6e7d (diff) |
Check existence of material before registering stele
-rw-r--r-- | steles/nodes.lua | 91 |
1 files changed, 47 insertions, 44 deletions
diff --git a/steles/nodes.lua b/steles/nodes.lua index ce80382..c71606d 100644 --- a/steles/nodes.lua +++ b/steles/nodes.lua @@ -14,52 +14,55 @@ display_lib.register_display_entity("steles:text") for _, material in ipairs(steles.materials) do local ndef = minetest.registered_nodes[material] - local parts = material:split(":") - minetest.register_node("steles:"..parts[2].."_stele", { - description = ndef.description.." Stele", - sunlight_propagates = true, - paramtype = "light", - paramtype2 = "facedir", - tiles = ndef.tiles, - drawtype = "nodebox", - node_box = { - type = "fixed", - fixed = { - {-5/16, -4/16, -2/16, 5/16, 0.5, 2/16}, - {-7/16, -0.5, -4/16, 7/16, -4/16, 4/16} - } - }, - groups = ndef.groups, - display_entities = { - ["steles:text"] = { - on_display_update = font_lib.on_display_update, - depth = -2/16-0.001, height = 2/16, - size = { x = 14/16, y = 12/16 }, - resolution = { x = 144, y = 64 }, - maxlines = 3, + if ndef then + local parts = material:split(":") + + minetest.register_node("steles:"..parts[2].."_stele", { + description = ndef.description.." Stele", + sunlight_propagates = true, + paramtype = "light", + paramtype2 = "facedir", + tiles = ndef.tiles, + drawtype = "nodebox", + node_box = { + type = "fixed", + fixed = { + {-5/16, -4/16, -2/16, 5/16, 0.5, 2/16}, + {-7/16, -0.5, -4/16, 7/16, -4/16, 4/16} + } }, - }, - on_place = display_lib.on_place, - on_construct = function(pos) - local meta = minetest.get_meta(pos) - meta:set_string("formspec", "size[6,4]".. - "textarea[0.5,0.7;5.5,2;display_text;Displayed text (3 lines max);${display_text}]".. - "button_exit[2,3;2,1;ok;Write]") - display_lib.on_construct(pos) - end, - on_destruct = display_lib.on_destruct, - on_rotate = display_lib.on_rotate, - on_receive_fields = function(pos, formname, fields, player) - if not minetest.is_protected(pos, player:get_player_name()) then - local meta = minetest.get_meta(pos) - if fields and fields.ok then - meta:set_string("display_text", fields.display_text) - meta:set_string("infotext", "\""..fields.display_text.."\"") - display_lib.update_entities(pos) - end - end + groups = ndef.groups, + display_entities = { + ["steles:text"] = { + on_display_update = font_lib.on_display_update, + depth = -2/16-0.001, height = 2/16, + size = { x = 14/16, y = 12/16 }, + resolution = { x = 144, y = 64 }, + maxlines = 3, + }, + }, + on_place = display_lib.on_place, + on_construct = function(pos) + local meta = minetest.get_meta(pos) + meta:set_string("formspec", "size[6,4]".. + "textarea[0.5,0.7;5.5,2;display_text;Displayed text (3 lines max);${display_text}]".. + "button_exit[2,3;2,1;ok;Write]") + display_lib.on_construct(pos) end, - }) + on_destruct = display_lib.on_destruct, + on_rotate = display_lib.on_rotate, + on_receive_fields = function(pos, formname, fields, player) + if not minetest.is_protected(pos, player:get_player_name()) then + local meta = minetest.get_meta(pos) + if fields and fields.ok then + meta:set_string("display_text", fields.display_text) + meta:set_string("infotext", "\""..fields.display_text.."\"") + display_lib.update_entities(pos) + end + end + end, + }) + end end |