Fix crash when loading schematic in a LuaJIT build in recent Minetest versions (thanks LazyJ & VanessaE!).

This commit is contained in:
Anthony Zhang 2014-12-29 18:26:37 -05:00
parent 7f580611f5
commit 04fdf92aca
1 changed files with 7 additions and 5 deletions

View File

@ -158,21 +158,23 @@ function worldedit.load_schematic(value)
-- This is broken for larger tables in the current version of LuaJIT -- This is broken for larger tables in the current version of LuaJIT
nodes = minetest.deserialize(content) nodes = minetest.deserialize(content)
else else
-- XXX: This is a filthy hack that works surprisingly well -- XXX: This is a filthy hack that works surprisingly well - in LuaJIT, `minetest.deserialize` will fail due to the register limit
nodes = {} nodes = {}
value = value:gsub("return%s*{", "", 1):gsub("}%s*$", "", 1) value = value:gsub("return%s*{", "", 1):gsub("}%s*$", "", 1) -- remove the starting and ending values to leave only the node data
local escaped = value:gsub("\\\\", "@@"):gsub("\\\"", "@@"):gsub("(\"[^\"]*\")", function(s) return string.rep("@", #s) end) local escaped = value:gsub("\\\\", "@@"):gsub("\\\"", "@@"):gsub("(\"[^\"]*\")", function(s) return string.rep("@", #s) end)
local startpos, startpos1, endpos = 1, 1 local startpos, startpos1, endpos = 1, 1
while true do while true do -- go through each individual node entry (except the last)
startpos, endpos = escaped:find("},%s*{", startpos) startpos, endpos = escaped:find("},%s*{", startpos)
if not startpos then if not startpos then
break break
end end
local current = value:sub(startpos1, startpos) local current = value:sub(startpos1, startpos)
table.insert(nodes, minetest.deserialize("return " .. current)) local entry = minetest.deserialize("return " .. current)
table.insert(nodes, entry)
startpos, startpos1 = endpos, endpos startpos, startpos1 = endpos, endpos
end end
table.insert(nodes, minetest.deserialize("return " .. value:sub(startpos1))) local entry = minetest.deserialize("return " .. value:sub(startpos1)) -- process the last entry
table.insert(nodes, entry)
end end
else else
return nil return nil