X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=lib%2Fstkstring.c;h=4fa5ab14ed551f5a7d5eebb87de49e78ed8ea1df;hb=f0459952ab7a84b2a2e16ee38456087b0986a228;hp=30cff4c864b6f99aeac28db8ba776ee7ea1d8dda;hpb=378118b449c9577c16b3f635895422d9bc0314aa;p=libucw.git diff --git a/lib/stkstring.c b/lib/stkstring.c index 30cff4c8..4fa5ab14 100644 --- a/lib/stkstring.c +++ b/lib/stkstring.c @@ -13,7 +13,7 @@ stk_array_len(char **s, uns cnt) } void -stk_array_copy(char *x, char **s, uns cnt) +stk_array_join(char *x, char **s, uns cnt, uns sep) { while (cnt--) { @@ -21,47 +21,83 @@ stk_array_copy(char *x, char **s, uns cnt) memcpy(x, *s, l); x += l; s++; + if (sep && cnt) + *x++ = sep; } *x = 0; } -char *stk_printf_buf; -static int stk_printf_len; - uns stk_printf_internal(char *fmt, ...) { - va_list args; + 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 (;;) { - int l = vsnprintf(stk_printf_buf, stk_printf_len, fmt, args); + va_copy(args2, args); + int l = vsnprintf(buf, len, fmt, args2); + va_end(args2); if (l < 0) - stk_printf_len *= 2; - else if (l < stk_printf_len) - return l+1; + len *= 2; else - stk_printf_len = MAX(stk_printf_len*2, l+1); - stk_printf_buf = xrealloc(stk_printf_buf, stk_printf_len); + { + va_end(args); + return l+1; + } + buf = alloca(len); } } +void +stk_hexdump_internal(char *dst, byte *src, uns n) +{ + for (uns i=0; i