X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=lib%2Fstkstring.c;h=13bc8e063d1070eaf819f3f90fd6864ef7df00f5;hb=f39ec2e7c8ccdbe0a48037ae5fe5f6f90b374db4;hp=c84d6279d890f21456b9175d0fdf100c263167df;hpb=449b6a65695233ea809c0f3c72dfb4fcc1f4308c;p=libucw.git diff --git a/lib/stkstring.c b/lib/stkstring.c index c84d6279..13bc8e06 100644 --- a/lib/stkstring.c +++ b/lib/stkstring.c @@ -28,7 +28,7 @@ stk_array_join(char *x, char **s, uns cnt, uns sep) } uns -stk_printf_internal(char *fmt, ...) +stk_printf_internal(const char *fmt, ...) { uns len = 256; char *buf = alloca(len); @@ -50,8 +50,30 @@ stk_printf_internal(char *fmt, ...) } } +uns +stk_vprintf_internal(const char *fmt, va_list args) +{ + uns len = 256; + char *buf = alloca(len); + va_list args2; + for (;;) + { + va_copy(args2, args); + int l = vsnprintf(buf, len, fmt, args2); + va_end(args2); + if (l < 0) + len *= 2; + else + { + va_end(args); + return l+1; + } + buf = alloca(len); + } +} + void -stk_hexdump_internal(char *dst, byte *src, uns n) +stk_hexdump_internal(char *dst, const byte *src, uns n) { for (uns i=0; i