summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYegappan Lakshmanan <yegappan@yahoo.com>2021-07-29 20:22:14 +0200
committerBram Moolenaar <Bram@vim.org>2021-07-29 20:22:14 +0200
commit41114a2a27047bf1884e092b98c6298c128eb2f0 (patch)
treee0af00022d38df4ba34dab48d7c36590d7b5fbbc
parent83cd0156e01b5befadf12ee66bc26436ee8d023f (diff)
downloadvim-git-41114a2a27047bf1884e092b98c6298c128eb2f0.tar.gz
patch 8.2.3244: Lua 5.3 print() with a long string crashesv8.2.3244
Problem: Lua 5.3 print() with a long string crashes. Solution: Use a growarray instead of a Lua buffer. (Yegappan Lakshmanan, closes #8655)
-rw-r--r--src/if_lua.c23
-rw-r--r--src/misc2.c16
-rw-r--r--src/proto/misc2.pro1
-rw-r--r--src/version.c2
4 files changed, 34 insertions, 8 deletions
diff --git a/src/if_lua.c b/src/if_lua.c
index 581040163..a3bb0b96b 100644
--- a/src/if_lua.c
+++ b/src/if_lua.c
@@ -1720,11 +1720,12 @@ static const luaL_Reg luaV_Window_mt[] = {
static int
luaV_print(lua_State *L)
{
- int i, n = lua_gettop(L); // nargs
- const char *s;
- size_t l;
- luaL_Buffer b;
- luaL_buffinit(L, &b);
+ int i, n = lua_gettop(L); // nargs
+ const char *s;
+ size_t l;
+ garray_T msg_ga;
+
+ ga_init2(&msg_ga, 1, 128);
lua_getglobal(L, "tostring");
for (i = 1; i <= n; i++)
{
@@ -1735,13 +1736,19 @@ luaV_print(lua_State *L)
if (s == NULL)
return luaL_error(L, "cannot convert to string");
if (i > 1)
- luaL_addchar(&b, ' '); // use space instead of tab
- luaV_addlstring(&b, s, l, 0);
+ ga_append(&msg_ga, ' '); // use space instead of tab
+ ga_concat_len(&msg_ga, (char_u *)s, l);
lua_pop(L, 1);
}
- luaL_pushresult(&b);
+ // Replace any "\n" with "\0"
+ for (i = 0; i < msg_ga.ga_len; i++)
+ if (((char *)msg_ga.ga_data)[i] == '\n')
+ ((char *)msg_ga.ga_data)[i] = '\0';
+ lua_pushlstring(L, msg_ga.ga_data, msg_ga.ga_len);
if (!got_int)
luaV_msg(L);
+
+ ga_clear(&msg_ga);
return 0;
}
diff --git a/src/misc2.c b/src/misc2.c
index bc984b219..bbf55bb00 100644
--- a/src/misc2.c
+++ b/src/misc2.c
@@ -1566,6 +1566,22 @@ ga_concat(garray_T *gap, char_u *s)
}
/*
+ * Concatenate 'len' bytes from string 's' to a growarray.
+ * When "s" is NULL does not do anything.
+ */
+ void
+ga_concat_len(garray_T *gap, char_u *s, size_t len)
+{
+ if (s == NULL || *s == NUL)
+ return;
+ if (ga_grow(gap, len) == OK)
+ {
+ mch_memmove((char *)gap->ga_data + gap->ga_len, s, (size_t)len);
+ gap->ga_len += len;
+ }
+}
+
+/*
* Append one byte to a growarray which contains bytes.
*/
void
diff --git a/src/proto/misc2.pro b/src/proto/misc2.pro
index 5ecd5958f..a9e2b844c 100644
--- a/src/proto/misc2.pro
+++ b/src/proto/misc2.pro
@@ -45,6 +45,7 @@ int ga_grow_inner(garray_T *gap, int n);
char_u *ga_concat_strings(garray_T *gap, char *sep);
int ga_add_string(garray_T *gap, char_u *p);
void ga_concat(garray_T *gap, char_u *s);
+void ga_concat_len(garray_T *gap, char_u *s, size_t len);
void ga_append(garray_T *gap, int c);
void append_ga_line(garray_T *gap);
int simplify_key(int key, int *modifiers);
diff --git a/src/version.c b/src/version.c
index c0aa0d998..b0e67ed0b 100644
--- a/src/version.c
+++ b/src/version.c
@@ -756,6 +756,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 3244,
+/**/
3243,
/**/
3242,