aboutsummaryrefslogtreecommitdiff
path: root/steles
diff options
context:
space:
mode:
authorPierre-Yves Rollo <dev@pyrollo.com>2015-12-03 15:43:39 +0100
committerPierre-Yves Rollo <dev@pyrollo.com>2015-12-03 15:43:39 +0100
commitdc7aea71ee7db3deb1f6672cbe2f6d3a07efe549 (patch)
treef4480bb86dee02ab69d05c75595b82c244db7be0 /steles
parenta7e80f4b9870b671762bee1c821bb0e35d7b6e7d (diff)
downloaddisplay_modpack-dc7aea71ee7db3deb1f6672cbe2f6d3a07efe549.tar.gz
display_modpack-dc7aea71ee7db3deb1f6672cbe2f6d3a07efe549.tar.bz2
display_modpack-dc7aea71ee7db3deb1f6672cbe2f6d3a07efe549.zip
Check existence of material before registering stele
Diffstat (limited to 'steles')
-rw-r--r--steles/nodes.lua91
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