X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;ds=inline;f=lib%2Fstkstring.c;h=4fa5ab14ed551f5a7d5eebb87de49e78ed8ea1df;hb=f0459952ab7a84b2a2e16ee38456087b0986a228;hp=eaeacf00f7c950aaf27de5aefa570bf58d395f6d;hpb=47a0795e8a28e8ad6ff55cda89e300267d9e590c;p=libucw.git diff --git a/lib/stkstring.c b/lib/stkstring.c index eaeacf00..4fa5ab14 100644 --- a/lib/stkstring.c +++ b/lib/stkstring.c @@ -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); } } @@ -70,6 +62,27 @@ stk_hexdump_internal(char *dst, byte *src, uns n) *dst = 0; } +void +stk_fsize_internal(char *buf, u64 x) +{ + if (x < 1<<10) + sprintf(buf, "%dB", (int)x); + else if (x < 10<<10) + sprintf(buf, "%.1fK", (double)x/(1<<10)); + else if (x < 1<<20) + sprintf(buf, "%dK", (int)(x/(1<<10))); + else if (x < 10<<20) + sprintf(buf, "%.1fM", (double)x/(1<<20)); + else if (x < 1<<30) + sprintf(buf, "%dM", (int)(x/(1<<20))); + else if (x < (u64)10<<30) + sprintf(buf, "%.1fG", (double)x/(1<<30)); + else if (x != ~(u64)0) + sprintf(buf, "%dG", (int)(x/(1<<30))); + else + strcpy(buf, "unknown"); +} + #ifdef TEST int main(void) @@ -84,6 +97,7 @@ int main(void) puts(stk_hexdump(a, 3)); char *ary[] = { "The", "jaws", "that", "bite" }; puts(stk_strjoin(ary, 4, ' ')); + puts(stk_fsize(1234567)); return 0; }