X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fwrbuf.c;h=6d9b145d99b4da4f954692d174fb76708db4fa2d;hp=871028d53d93708a7f52c4ede3efc391c59127c1;hb=dca8928db421aa8750ac9ffead1a5c09a85f4f8b;hpb=574ae68dc570706b4468b29e82681efe15bc7180 diff --git a/src/wrbuf.c b/src/wrbuf.c index 871028d..6d9b145 100644 --- a/src/wrbuf.c +++ b/src/wrbuf.c @@ -1,5 +1,5 @@ /* This file is part of the YAZ toolkit. - * Copyright (C) 1995-2013 Index Data + * Copyright (C) Index Data * See the file LICENSE for details. */ @@ -16,6 +16,7 @@ #include #include #include +#include #include #include @@ -30,6 +31,7 @@ WRBUF wrbuf_alloc(void) n->buf = 0; n->size = 0; n->pos = 0; + wrbuf_grow(n, 1); return n; } @@ -57,9 +59,8 @@ int wrbuf_grow(WRBUF b, size_t minsize) togrow = b->size; if (togrow < minsize) togrow = minsize; - if (b->size && !(b->buf =(char *)xrealloc(b->buf, b->size += togrow))) - abort(); - else if (!b->size && !(b->buf = (char *)xmalloc(b->size = togrow))) + b->buf = (char *) xrealloc(b->buf, 1 + (b->size += togrow)); + if (!b->buf) abort(); return 0; } @@ -169,8 +170,9 @@ void wrbuf_printf(WRBUF b, const char *fmt, ...) va_end(ap); } -int wrbuf_iconv_write_x(WRBUF b, yaz_iconv_t cd, const char *buf, - size_t size, int cdata) +int wrbuf_iconv_write2(WRBUF b, yaz_iconv_t cd, const char *buf, + size_t size, + void (*wfunc)(WRBUF, const char *, size_t)) { int ret = 0; if (cd) @@ -193,40 +195,24 @@ int wrbuf_iconv_write_x(WRBUF b, yaz_iconv_t cd, const char *buf, break; } } - switch (cdata) - { - case 0: - wrbuf_write(b, outbuf, outp - outbuf); - break; - case 1: - wrbuf_xmlputs_n(b, outbuf, outp - outbuf); - break; - case 2: - wrbuf_json_write(b, outbuf, outp - outbuf); - break; - } + (*wfunc)(b, outbuf, outp - outbuf); } } else - { - switch (cdata) - { - case 0: - wrbuf_write(b, buf, size); - break; - case 1: - wrbuf_xmlputs_n(b, buf, size); - break; - case 2: - wrbuf_json_write(b, buf, size); - } - } + (*wfunc)(b, buf, size); return ret; } +int wrbuf_iconv_write_x(WRBUF b, yaz_iconv_t cd, const char *buf, + size_t size, int cdata) +{ + return wrbuf_iconv_write2(b, cd, buf, size, + cdata ? wrbuf_xmlputs_n : wrbuf_write); +} + void wrbuf_iconv_write(WRBUF b, yaz_iconv_t cd, const char *buf, size_t size) { - wrbuf_iconv_write_x(b, cd, buf, size, 0); + wrbuf_iconv_write2(b, cd, buf, size, wrbuf_write); } void wrbuf_iconv_puts(WRBUF b, yaz_iconv_t cd, const char *strz) @@ -243,23 +229,23 @@ void wrbuf_iconv_putchar(WRBUF b, yaz_iconv_t cd, int ch) void wrbuf_iconv_write_cdata(WRBUF b, yaz_iconv_t cd, const char *buf, size_t size) { - wrbuf_iconv_write_x(b, cd, buf, size, 1); + wrbuf_iconv_write2(b, cd, buf, size, wrbuf_xmlputs_n); } void wrbuf_iconv_puts_cdata(WRBUF b, yaz_iconv_t cd, const char *strz) { - wrbuf_iconv_write_x(b, cd, strz, strlen(strz), 1); + wrbuf_iconv_write2(b, cd, strz, strlen(strz), wrbuf_xmlputs_n); } void wrbuf_iconv_json_write(WRBUF b, yaz_iconv_t cd, const char *buf, size_t size) { - wrbuf_iconv_write_x(b, cd, buf, size, 2); + wrbuf_iconv_write2(b, cd, buf, size, wrbuf_json_write); } void wrbuf_iconv_json_puts(WRBUF b, yaz_iconv_t cd, const char *strz) { - wrbuf_iconv_write_x(b, cd, strz, strlen(strz), 2); + wrbuf_iconv_write2(b, cd, strz, strlen(strz), wrbuf_json_write); } void wrbuf_iconv_reset(WRBUF b, yaz_iconv_t cd) @@ -277,8 +263,17 @@ void wrbuf_iconv_reset(WRBUF b, yaz_iconv_t cd) const char *wrbuf_cstr(WRBUF b) { - wrbuf_putc(b, '\0'); /* add '\0' */ - (b->pos)--; /* don't include '\0' in count */ + assert(b && b->pos <= b->size); + b->buf[b->pos] = '\0'; + return b->buf; +} + +const char *wrbuf_cstr_null(WRBUF b) +{ + if (!b || b->pos == 0) + return 0; + assert(b->pos <= b->size); + b->buf[b->pos] = '\0'; return b->buf; }