diff options
| author | electrodude <electrodude512@gmail.com> | 2016-04-20 18:09:38 -0400 | 
|---|---|---|
| committer | Jeija <norrepli@gmail.com> | 2016-04-26 20:40:12 +0200 | 
| commit | 6cae381c2788d2e4061c530cc143ca38bd0862e3 (patch) | |
| tree | 04c2657302826e3a464ba7f92b87a2c374f06d2f | |
| parent | 4249ed4986fd614019c0350de1808041b15a32cc (diff) | |
Luacontroller: Fix `remove_functions` stack overflow bug
| -rw-r--r-- | mesecons_luacontroller/init.lua | 30 | 
1 files changed, 21 insertions, 9 deletions
| diff --git a/mesecons_luacontroller/init.lua b/mesecons_luacontroller/init.lua index e669f93..01f5878 100644 --- a/mesecons_luacontroller/init.lua +++ b/mesecons_luacontroller/init.lua @@ -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 | 
