From: Diego Martinez Date: Thu, 4 Feb 2016 12:58:44 +0000 (-0300) Subject: builtin: Fix `print` crashing on nil "holes". X-Git-Tag: 0.4.14~285 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=430195381d8d7254a7b8cdcf6b50769c2c598329;p=oweals%2Fminetest.git builtin: Fix `print` crashing on nil "holes". The engine implementation of `print` packs the varargs into a table and passes the table directly to `table.concat`. If you pass any value not supported by `table.concat` (particularly `nil`), the server crashes. This is unexpected behavior, as `print` is supposed to be able to work with anything. This patch changes the implementation so it first converts all arguments using `tostring`, which fixes the issue and makes the custom `print` function compatible with the stock Lua behavior. --- diff --git a/builtin/init.lua b/builtin/init.lua index b3004468e..6b27cf76e 100644 --- a/builtin/init.lua +++ b/builtin/init.lua @@ -12,7 +12,11 @@ if core.print then -- Override native print and use -- terminal if that's turned on function print(...) - core_print(table.concat({...}, "\t")) + local n, t = select("#", ...), { ... } + for i = 1, n do + t[i] = tostring(t[i]) + end + core_print(table.concat(t, "\t")) end core.print = nil -- don't pollute our namespace end