]> mj.ucw.cz Git - libucw.git/commitdiff
thread-safe stk_printf
authorPavel Charvat <pavel.charvat@netcentrum.cz>
Mon, 9 Oct 2006 08:21:56 +0000 (10:21 +0200)
committerPavel Charvat <pavel.charvat@netcentrum.cz>
Mon, 9 Oct 2006 08:21:56 +0000 (10:21 +0200)
lib/stkstring.c
lib/stkstring.h

index eaeacf00f7c950aaf27de5aefa570bf58d395f6d..c3b77301adba1744725721b87e7deb8f7af633b8 100644 (file)
@@ -27,34 +27,26 @@ stk_array_join(char *x, char **s, uns cnt, uns sep)
   *x = 0;
 }
 
-char *stk_printf_buf;
-static int stk_printf_len;
-
 uns
 stk_printf_internal(char *fmt, ...)
 {
+  uns len = 256;
+  char *buf = alloca(len);
   va_list args, args2;
   va_start(args, fmt);
-  if (!stk_printf_buf)
-    {
-      stk_printf_buf = xmalloc(256);
-      stk_printf_len = 256;
-    }
   for (;;)
     {
       va_copy(args2, args);
-      int l = vsnprintf(stk_printf_buf, stk_printf_len, fmt, args2);
+      int l = vsnprintf(buf, len, fmt, args2);
       va_end(args2);
       if (l < 0)
-       stk_printf_len *= 2;
-      else if (l < stk_printf_len)
+       len *= 2;
+      else
        {
          va_end(args);
          return l+1;
        }
-      else
-       stk_printf_len = MAX(stk_printf_len*2, l+1);
-      stk_printf_buf = xrealloc(stk_printf_buf, stk_printf_len);
+      buf = alloca(len);
     }
 }
 
index 1ed2568972f9f6606950a7fbd355596ba283741b..f72d3c594286ffc2ea7c2531f67fedf9bdc92970 100644 (file)
@@ -17,7 +17,7 @@
 #define stk_strmulticat(s...) ({ char *_s[]={s}; char *_x=alloca(stk_array_len(_s, ARRAY_SIZE(_s)-1)); stk_array_join(_x, _s, ARRAY_SIZE(_s)-1, 0); _x; })
 #define stk_strarraycat(s,n) ({ char **_s=(s); int _n=(n); char *_x=alloca(stk_array_len(_s,_n)); stk_array_join(_x, _s, _n, 0); _x; })
 #define stk_strjoin(s,n,sep) ({ char **_s=(s); int _n=(n); char *_x=alloca(stk_array_len(_s,_n)+_n-1); stk_array_join(_x, _s, _n, (sep)); _x; })
-#define stk_printf(f...) ({ uns _l=stk_printf_internal(f); char *_x=alloca(_l); memcpy(_x, stk_printf_buf, _l); _x; })
+#define stk_printf(f...) ({ uns _l=stk_printf_internal(f); char *_x=alloca(_l); sprintf(_x, f); _x; })
 #define stk_hexdump(s,n) ({ uns _n=(n); char *_x=alloca(3*_n+1); stk_hexdump_internal(_x,(byte*)(s),_n); _x; })
 #define stk_str_unesc(s) ({ byte *_s=(s); byte *_d=alloca(strlen(_s)+1); str_unesc(_d, _s); _d; })
 
@@ -25,5 +25,3 @@ uns stk_array_len(char **s, uns cnt);
 void stk_array_join(char *x, char **s, uns cnt, uns sep);
 uns stk_printf_internal(char *x, ...) FORMAT_CHECK(printf,1,2);
 void stk_hexdump_internal(char *dst, byte *src, uns n);
-
-extern char *stk_printf_buf;