aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoberto Ierusalimschy <roberto@inf.puc-rio.br>2015-10-06 13:10:22 -0300
committerRoberto Ierusalimschy <roberto@inf.puc-rio.br>2015-10-06 13:10:22 -0300
commit8949904783c2fdda1b6c6cec99637cf6d5471359 (patch)
tree3d5e5a7c91f325c3f66e87acd551eb29cb7657da
parent9294466234f4304fd1d31e343fb5ca48aec03b16 (diff)
downloadlua-8949904783c2fdda1b6c6cec99637cf6d5471359.tar.gz
lua-8949904783c2fdda1b6c6cec99637cf6d5471359.tar.bz2
lua-8949904783c2fdda1b6c6cec99637cf6d5471359.zip
allow NULL string when length is zero in 'lua_pushlstring' and
'luaL_addlstring'
-rw-r--r--lapi.c10
-rw-r--r--lauxlib.c10
2 files changed, 11 insertions, 9 deletions
diff --git a/lapi.c b/lapi.c
index 63258055..072190bc 100644
--- a/lapi.c
+++ b/lapi.c
@@ -1,5 +1,5 @@
1/* 1/*
2** $Id: lapi.c,v 2.254 2015/08/25 18:50:37 roberto Exp roberto $ 2** $Id: lapi.c,v 2.255 2015/09/09 13:45:50 roberto Exp roberto $
3** Lua API 3** Lua API
4** See Copyright Notice in lua.h 4** See Copyright Notice in lua.h
5*/ 5*/
@@ -472,15 +472,15 @@ LUA_API void lua_pushinteger (lua_State *L, lua_Integer n) {
472 472
473 473
474/* 474/*
475** Pushes on the stack a string with given length. Even when 'len' == 0, 475** Pushes on the stack a string with given length. Avoid using 's' when
476** 's' cannot be NULL due to later use of 'memcmp' and 'memcpy'. 476** 'len' == 0 (as 's' can be NULL in that case), due to later use of
477** 'memcmp' and 'memcpy'.
477*/ 478*/
478LUA_API const char *lua_pushlstring (lua_State *L, const char *s, size_t len) { 479LUA_API const char *lua_pushlstring (lua_State *L, const char *s, size_t len) {
479 TString *ts; 480 TString *ts;
480 lua_lock(L); 481 lua_lock(L);
481 luaC_checkGC(L); 482 luaC_checkGC(L);
482 api_check(L, s != NULL, "pointer cannot be NULL"); 483 ts = (len == 0) ? luaS_new(L, "") : luaS_newlstr(L, s, len);
483 ts = luaS_newlstr(L, s, len);
484 setsvalue2s(L, L->top, ts); 484 setsvalue2s(L, L->top, ts);
485 api_incr_top(L); 485 api_incr_top(L);
486 lua_unlock(L); 486 lua_unlock(L);
diff --git a/lauxlib.c b/lauxlib.c
index 8985bf28..3702e375 100644
--- a/lauxlib.c
+++ b/lauxlib.c
@@ -1,5 +1,5 @@
1/* 1/*
2** $Id: lauxlib.c,v 1.281 2015/06/18 14:23:14 roberto Exp roberto $ 2** $Id: lauxlib.c,v 1.282 2015/10/02 15:46:49 roberto Exp roberto $
3** Auxiliary functions for building Lua libraries 3** Auxiliary functions for building Lua libraries
4** See Copyright Notice in lua.h 4** See Copyright Notice in lua.h
5*/ 5*/
@@ -512,9 +512,11 @@ LUALIB_API char *luaL_prepbuffsize (luaL_Buffer *B, size_t sz) {
512 512
513 513
514LUALIB_API void luaL_addlstring (luaL_Buffer *B, const char *s, size_t l) { 514LUALIB_API void luaL_addlstring (luaL_Buffer *B, const char *s, size_t l) {
515 char *b = luaL_prepbuffsize(B, l); 515 if (l > 0) { /* avoid 'memcpy' when 's' can be NULL */
516 memcpy(b, s, l * sizeof(char)); 516 char *b = luaL_prepbuffsize(B, l);
517 luaL_addsize(B, l); 517 memcpy(b, s, l * sizeof(char));
518 luaL_addsize(B, l);
519 }
518} 520}
519 521
520 522