Skip to content

Commit

Permalink
Luacontroller: Fix remove_functions stack overflow bug
Browse files Browse the repository at this point in the history
  • Loading branch information
electrodude authored and Jeija committed Apr 26, 2016
1 parent 4249ed4 commit 6cae381
Showing 1 changed file with 21 additions and 9 deletions.
30 changes: 21 additions & 9 deletions mesecons_luacontroller/init.lua
Expand Up @@ -229,23 +229,35 @@ end

local function remove_functions(x)
local tp = type(x)
if tp == "table" then
if tp == "function" then
return nil
end

-- Make sure to not serialize the same table multiple times, otherwise
-- writing mem.test = mem in the LuaController will lead to infinite recursion
local seen = {}

local function rfuncs(x)
if seen[x] then return end
seen[x] = true
if type(x) ~= "table" then return end

for key, value in pairs(x) do
local key_t, val_t = type(key), type(value)
if key_t == "function" or val_t == "function" then
if type(key) == "function" or type(value) == "function" then
x[key] = nil
else
if key_t == "table" then
remove_functions(key)
if type(key) == "table" then
rfuncs(key)
end
if val_t == "table" then
remove_functions(value)
if type(value) == "table" then
rfuncs(value)
end
end
end
elseif tp == "function" then
return nil
end

rfuncs(x)

return x
end

Expand Down

0 comments on commit 6cae381

Please sign in to comment.