more robust handling of function/table/string values

in register_generate_plant() call (to handle e.g. unknown nodes being spawned)
This commit is contained in:
Vanessa Ezekowitz 2014-05-15 06:08:25 -04:00
parent 064572c0a7
commit 087c661090

View File

@ -197,20 +197,24 @@ function plantslib:search_for_surfaces(minp, maxp, biomedef, node_or_function_or
if type(node_or_function_or_model) == "table" then if type(node_or_function_or_model) == "table" then
plantslib:dbg("Spawn tree at {"..dump(pos).."}") plantslib:dbg("Spawn tree at {"..dump(pos).."}")
local t2=os.clock()
plantslib:generate_tree(pos, node_or_function_or_model) plantslib:generate_tree(pos, node_or_function_or_model)
plantslib:dbg("That tree took ".. (os.clock()-t2)*1000 .."ms to spawn.")
elseif type(node_or_function_or_model) == "string" then spawned = true
if not minetest.registered_nodes[node_or_function_or_model] then elseif type(node_or_function_or_model) == "string" and
plantslib:dbg("Call function: "..node_or_function_or_model.."("..dump_pos(pos)..")") minetest.registered_nodes[node_or_function_or_model] then
local t2=os.clock() plantslib:dbg("Add node: "..node_or_function_or_model.." at ("..dump(p_top)..")")
assert(loadstring(node_or_function_or_model.."("..dump_pos(pos)..")"))() minetest.add_node(p_top, { name = node_or_function_or_model })
plantslib:dbg("Executed that function in ".. (os.clock()-t2)*1000 .."ms") spawned = true
else elseif type(loadstring("return "..node_or_function_or_model)) == "function" then
plantslib:dbg("Add node: "..node_or_function_or_model.." at ("..dump(p_top)..")") plantslib:dbg("Call function: "..node_or_function_or_model.."("..dump_pos(pos)..")")
minetest.add_node(p_top, { name = node_or_function_or_model }) local t2=os.clock()
end assert(loadstring(node_or_function_or_model.."("..dump_pos(pos)..")"))()
spawned = true
plantslib:dbg("Executed that function in ".. (os.clock()-t2)*1000 .."ms")
else
plantslib:dbg("Ignored invalid definition for object "..dump(node_or_function_or_model).." that was pointed at {"..dump(pos).."}")
end end
spawned = true
else else
tries = tries + 1 tries = tries + 1
plantslib:dbg("No room to spawn object at {"..dump(pos).."} -- trying again elsewhere") plantslib:dbg("No room to spawn object at {"..dump(pos).."} -- trying again elsewhere")