]> git.ipfire.org Git - thirdparty/LuaJIT.git/commitdiff
Refactor string buffer growth helpers.
authorMike Pall <mike>
Wed, 29 May 2013 18:17:26 +0000 (20:17 +0200)
committerMike Pall <mike>
Wed, 29 May 2013 18:17:26 +0000 (20:17 +0200)
src/lj_buf.c
src/lj_buf.h
src/lj_str.c

index 1786c10db7f86d09dca32fa359880652f79c2b43..1f6e97bf334f3a370beef88fa1884e117abf33ba 100644 (file)
@@ -3,8 +3,6 @@
 ** Copyright (C) 2005-2013 Mike Pall. See Copyright Notice in luajit.h
 */
 
-#include <stdio.h>
-
 #define lj_buf_c
 #define LUA_CORE
 
 
 /* -- Buffer management --------------------------------------------------- */
 
-LJ_NOINLINE void LJ_FASTCALL lj_buf_grow(SBuf *sb, char *en)
+static void buf_grow(SBuf *sb, MSize sz)
 {
-  lua_State *L = sbufL(sb);
-  char *b = sbufB(sb);
-  MSize sz = (MSize)(en - b);
-  MSize osz = (MSize)(sbufE(sb) - b), nsz = osz;
-  MSize n = (MSize)(sbufP(sb) - b);
-  if (LJ_UNLIKELY(sz > LJ_MAX_MEM))
-    lj_err_mem(L);
+  MSize osz = sbufsz(sb), len = sbuflen(sb), nsz = osz;
+  char *b;
   if (nsz < LJ_MIN_SBUF) nsz = LJ_MIN_SBUF;
   while (nsz < sz) nsz += nsz;
-  b = (char *)lj_mem_realloc(L, b, osz, nsz);
+  b = (char *)lj_mem_realloc(sbufL(sb), sbufB(sb), osz, nsz);
   setmref(sb->b, b);
-  setmref(sb->p, b + n);
+  setmref(sb->p, b + len);
   setmref(sb->e, b + nsz);
 }
 
+LJ_NOINLINE char *LJ_FASTCALL lj_buf_need2(SBuf *sb, MSize sz)
+{
+  lua_assert(sz > sbufsz(sb));
+  if (LJ_UNLIKELY(sz > LJ_MAX_MEM))
+    lj_err_mem(sbufL(sb));
+  buf_grow(sb, sz);
+  return sbufB(sb);
+}
+
+LJ_NOINLINE char *LJ_FASTCALL lj_buf_more2(SBuf *sb, MSize sz)
+{
+  MSize len = sbuflen(sb);
+  lua_assert(sz > sbufleft(sb));
+  if (LJ_UNLIKELY(sz > LJ_MAX_MEM || len + sz > LJ_MAX_MEM))
+    lj_err_mem(sbufL(sb));
+  buf_grow(sb, len + sz);
+  return sbufP(sb);
+}
+
 void LJ_FASTCALL lj_buf_shrink(lua_State *L, SBuf *sb)
 {
   char *b = sbufB(sb);
index 5f78c4a9e3fc24ad7ff2af43fdc9fb35f19b9798..7a123e83856b8505fbc7c9e2e39397744ad45c65 100644 (file)
 #define sbufL(sb)      (mref((sb)->L, lua_State))
 #define sbufsz(sb)     ((MSize)(sbufE((sb)) - sbufB((sb))))
 #define sbuflen(sb)    ((MSize)(sbufP((sb)) - sbufB((sb))))
+#define sbufleft(sb)   ((MSize)(sbufE((sb)) - sbufP((sb))))
 #define setsbufP(sb, q)        (setmref((sb)->p, (q)))
 #define setsbufL(sb, l)        (setmref((sb)->L, (l)))
 
 /* Buffer management */
-LJ_FUNC void LJ_FASTCALL lj_buf_grow(SBuf *sb, char *en);
+LJ_FUNC char *LJ_FASTCALL lj_buf_need2(SBuf *sb, MSize sz);
+LJ_FUNC char *LJ_FASTCALL lj_buf_more2(SBuf *sb, MSize sz);
 LJ_FUNC void LJ_FASTCALL lj_buf_shrink(lua_State *L, SBuf *sb);
 LJ_FUNC char * LJ_FASTCALL lj_buf_tmp(lua_State *L, MSize sz);
 
@@ -51,17 +53,15 @@ static LJ_AINLINE void lj_buf_free(global_State *g, SBuf *sb)
 
 static LJ_AINLINE char *lj_buf_need(SBuf *sb, MSize sz)
 {
-  char *en = sbufB(sb) + sz;
-  if (LJ_UNLIKELY(en > sbufE(sb)))
-    lj_buf_grow(sb, en);
+  if (LJ_UNLIKELY(sz > sbufsz(sb)))
+    return lj_buf_need2(sb, sz);
   return sbufB(sb);
 }
 
 static LJ_AINLINE char *lj_buf_more(SBuf *sb, MSize sz)
 {
-  char *en = sbufP(sb) + sz;
-  if (LJ_UNLIKELY(en > sbufE(sb)))
-    lj_buf_grow(sb, en);
+  if (LJ_UNLIKELY(sz > sbufleft(sb)))
+    return lj_buf_more2(sb, sz);
   return sbufP(sb);
 }
 
index 24d96067559a9d01cedfc1924e66a6cf9eb9a7dc..5fdd1672d45d7b84b5f68451c2ddedcf68aa1951 100644 (file)
@@ -3,8 +3,6 @@
 ** Copyright (C) 2005-2013 Mike Pall. See Copyright Notice in luajit.h
 */
 
-#include <stdio.h>
-
 #define lj_str_c
 #define LUA_CORE