1 /* This file is part of the YAZ toolkit.
2 * Copyright (C) 1995-2011 Index Data
3 * See the file LICENSE for details.
8 * \brief Implements NMEM dup utilities
16 #include <yaz/nmem_xml.h>
18 char *nmem_strdup (NMEM mem, const char *src)
20 char *dst = (char *)nmem_malloc (mem, strlen(src)+1);
25 char *nmem_strdup_null(NMEM mem, const char *src)
30 return nmem_strdup(mem, src);
33 char *nmem_strdupn (NMEM mem, const char *src, size_t n)
35 char *dst = (char *)nmem_malloc (mem, n+1);
41 nmem_int_t *nmem_intdup(NMEM mem, nmem_int_t v)
43 nmem_int_t *dst = (nmem_int_t*) nmem_malloc (mem, sizeof(*dst));
48 nmem_bool_t *nmem_booldup(NMEM mem, nmem_bool_t v)
50 nmem_bool_t *dst = (nmem_bool_t*) nmem_malloc (mem, sizeof(*dst));
55 void nmem_strsplit_blank(NMEM nmem, const char *dstr, char ***darray, int *num)
57 nmem_strsplit(nmem, " ", dstr, darray, num);
61 void nmem_strsplit(NMEM nmem, const char *delim, const char *dstr,
62 char ***darray, int *num)
64 nmem_strsplitx(nmem, delim, dstr, darray, num, 1);
67 void nmem_strsplitx(NMEM nmem, const char *delim, const char *dstr,
68 char ***darray, int *num, int collapse)
70 const char *cp = dstr;
79 while (*cp && strchr(delim, *cp))
83 while (*cp && !strchr(delim, *cp))
90 while (*cp && !strchr(delim, *cp))
102 *darray = (char **) nmem_malloc(nmem, *num * sizeof(**darray));
111 while (*cp && strchr(delim, *cp))
116 while (*cp && !strchr(delim, *cp))
118 (*darray)[i++] = nmem_strdupn(nmem, cp0, cp - cp0);
123 while (*cp && !strchr(delim, *cp))
125 (*darray)[i++] = nmem_strdupn(nmem, cp0, cp - cp0);
135 char *nmem_text_node_cdata(const xmlNode *ptr_cdata, NMEM nmem)
141 for (ptr = ptr_cdata; ptr; ptr = ptr->next)
142 if (ptr->type == XML_TEXT_NODE)
143 len += xmlStrlen(ptr->content);
144 cdata = (char *) nmem_malloc(nmem, len+1);
146 for (ptr = ptr_cdata; ptr; ptr = ptr->next)
147 if (ptr->type == XML_TEXT_NODE)
148 strcat(cdata, (const char *) ptr->content);
156 * c-file-style: "Stroustrup"
157 * indent-tabs-mode: nil
159 * vim: shiftwidth=4 tabstop=8 expandtab