X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fwrbuf.c;h=344e5742cc00e71ba8d6ad8a1deff7892e918724;hp=13793edba5a9157ab1780623c2a5eaf39762ae71;hb=e746aded3630be444c66f12e341a63413df92371;hpb=027d8648a24b0b61b31a5f1752b29520791fd2fd diff --git a/src/wrbuf.c b/src/wrbuf.c index 13793ed..344e574 100644 --- a/src/wrbuf.c +++ b/src/wrbuf.c @@ -1,5 +1,5 @@ /* This file is part of the YAZ toolkit. - * Copyright (C) 1995-2011 Index Data + * Copyright (C) 1995-2013 Index Data * See the file LICENSE for details. */ @@ -96,7 +96,7 @@ void wrbuf_vp_puts(const char *buf, void *client_data) wrbuf_puts(b, buf); } -void wrbuf_puts_replace_char(WRBUF b, const char *buf, +void wrbuf_puts_replace_char(WRBUF b, const char *buf, const char from, const char to) { while(*buf) @@ -169,8 +169,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,25 +194,24 @@ int wrbuf_iconv_write_x(WRBUF b, yaz_iconv_t cd, const char *buf, break; } } - if (cdata) - wrbuf_xmlputs_n(b, outbuf, outp - outbuf); - else - wrbuf_write(b, outbuf, outp - outbuf); + (*wfunc)(b, outbuf, outp - outbuf); } } else - { - if (cdata) - wrbuf_xmlputs_n(b, buf, size); - else - wrbuf_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) @@ -228,12 +228,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_write2(b, cd, buf, size, wrbuf_json_write); +} + +void wrbuf_iconv_json_puts(WRBUF b, yaz_iconv_t cd, const char *strz) +{ + wrbuf_iconv_write2(b, cd, strz, strlen(strz), wrbuf_json_write); } void wrbuf_iconv_reset(WRBUF b, yaz_iconv_t cd) @@ -278,6 +289,46 @@ void wrbuf_write_escaped(WRBUF b, const char *str, size_t len) wrbuf_putc(b, str[i]); } +void wrbuf_json_write(WRBUF b, const char *cp, size_t sz) +{ + size_t i; + for (i = 0; i < sz; i++) + { + if (cp[i] > 0 && cp[i] < 32) + { + wrbuf_putc(b, '\\'); + switch (cp[i]) + { + case '\b': wrbuf_putc(b, 'b'); break; + case '\f': wrbuf_putc(b, 'f'); break; + case '\n': wrbuf_putc(b, 'n'); break; + case '\r': wrbuf_putc(b, 'r'); break; + case '\t': wrbuf_putc(b, 't'); break; + default: + wrbuf_printf(b, "u%04x", cp[i]); + } + } + else if (cp[i] == '"') + { + wrbuf_putc(b, '\\'); wrbuf_putc(b, '"'); + } + else if (cp[i] == '\\') + { + wrbuf_putc(b, '\\'); wrbuf_putc(b, '\\'); + } + else + { /* leave encoding as raw UTF-8 */ + wrbuf_putc(b, cp[i]); + } + } + +} + +void wrbuf_json_puts(WRBUF b, const char *str) +{ + wrbuf_json_write(b, str, strlen(str)); +} + /* * Local variables: * c-basic-offset: 4