X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fnmemsdup.c;h=9584cff5d7ee44ecc464ad4cbdbe95749c65f637;hp=75b6e85afe3127b396a9fbc3dfe5205d0b57e5e0;hb=07ebfd1140984b5a36427dd5b0f3cb6a4b48684e;hpb=adad3479963999a4085240a5cd2a6aa4d405e846 diff --git a/src/nmemsdup.c b/src/nmemsdup.c index 75b6e85..9584cff 100644 --- a/src/nmemsdup.c +++ b/src/nmemsdup.c @@ -74,6 +74,14 @@ void nmem_strsplit_escape(NMEM nmem, const char *delim, const char *dstr, char ***darray, int *num, int collapse, int escape_char) { + nmem_strsplit_escape2(nmem, delim, dstr, darray, num, collapse, + escape_char, 1); +} + +void nmem_strsplit_escape2(NMEM nmem, const char *delim, const char *dstr, + char ***darray, int *num, int collapse, + int escape_char, int subst_escape) +{ *darray = 0; /* two passes over the input string.. */ while (1) @@ -102,16 +110,19 @@ void nmem_strsplit_escape(NMEM nmem, const char *delim, const char *dstr, } if (*darray) { - char *dst, *src; (*darray)[i] = nmem_strdupn(nmem, cp0, cp - cp0); - dst = src = (*darray)[i]; - while (*src != '\0') + if (subst_escape) { - if (*src == escape_char && src[1]) - src++; - *dst++ = *src++; + char *dst = (*darray)[i]; + const char *src = dst; + while (*src != '\0') + { + if (*src == escape_char && src[1]) + src++; + *dst++ = *src++; + } + *dst = '\0'; } - *dst = '\0'; } i++; if (!collapse)