X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=lib%2Fstkstring.c;h=eaeacf00f7c950aaf27de5aefa570bf58d395f6d;hb=beb9738f1fbcba84bc0f09f742fb66b1ddfcf349;hp=a8593215ea71d478eba5232dd204340f28f2a844;hpb=512c07b430959e72f574e34cc2bd60b8e4672ad8;p=libucw.git diff --git a/lib/stkstring.c b/lib/stkstring.c index a8593215..eaeacf00 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,6 +21,8 @@ stk_array_copy(char *x, char **s, uns cnt) memcpy(x, *s, l); x += l; s++; + if (sep && cnt) + *x++ = sep; } *x = 0; } @@ -31,7 +33,7 @@ static int stk_printf_len; uns stk_printf_internal(char *fmt, ...) { - va_list args; + va_list args, args2; va_start(args, fmt); if (!stk_printf_buf) { @@ -40,11 +42,16 @@ stk_printf_internal(char *fmt, ...) } for (;;) { - int l = vsnprintf(stk_printf_buf, stk_printf_len, fmt, args); + va_copy(args2, args); + int l = vsnprintf(stk_printf_buf, stk_printf_len, fmt, args2); + va_end(args2); if (l < 0) stk_printf_len *= 2; else if (l < stk_printf_len) - return l+1; + { + 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); @@ -67,14 +74,16 @@ stk_hexdump_internal(char *dst, byte *src, uns n) int main(void) { - char *a = stk_strdup("are"); + char *a = stk_strndup("are!",3); a = stk_strcat(a, " the "); - a = stk_strmulticat(a, "Jabberwock, ", "my", NULL); + a = stk_strmulticat(a, stk_strdup("Jabberwock, "), "my", NULL); char *arr[] = { a, " son" }; a = stk_strarraycat(arr, 2); a = stk_printf("Bew%s!", a); puts(a); puts(stk_hexdump(a, 3)); + char *ary[] = { "The", "jaws", "that", "bite" }; + puts(stk_strjoin(ary, 4, ' ')); return 0; }