From a6fa99b44b6d536a1fb23f9ffd7a84786c63edab Mon Sep 17 00:00:00 2001 From: Benoit Giannangeli Date: Fri, 24 Mar 2017 10:57:49 +0100 Subject: string.char bypass to_luastring conversion --- src/lstrlib.js | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) (limited to 'src') diff --git a/src/lstrlib.js b/src/lstrlib.js index 1b62db1..4bd8664 100644 --- a/src/lstrlib.js +++ b/src/lstrlib.js @@ -53,13 +53,14 @@ const str_len = function(L) { const str_char = function(L) { let n = lapi.lua_gettop(L); /* number of arguments */ - let p = ""; + let p = []; for (let i = 1; i <= n; i++) { let c = lauxlib.luaL_checkinteger(L, i); lauxlib.luaL_argcheck(L, c >= 0 && c <= 255, "value out of range"); // Strings are 8-bit clean - p += String.fromCharCode(c); + p.push(c); } - lapi.lua_pushstring(L, p); + lapi.lua_pushstring(L, ""); + L.stack[L.top - 1].value = p; // Since value are already capped, avoid conversion return 1; }; -- cgit v1.2.3-70-g09d2