Add odr_prepend()
authorMike Taylor <mike@indexdata.com>
Wed, 26 Nov 2003 16:23:42 +0000 (16:23 +0000)
committerMike Taylor <mike@indexdata.com>
Wed, 26 Nov 2003 16:23:42 +0000 (16:23 +0000)
include/yaz/odr.h
src/odr_util.c

index 6d1c30a..1a2e690 100644 (file)
@@ -23,7 +23,7 @@
  * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
  * OF THIS SOFTWARE.
  *
- * $Id: odr.h,v 1.13 2003-10-16 10:37:06 adam Exp $
+ * $Id: odr.h,v 1.14 2003-11-26 16:24:04 mike Exp $
  */
 
 #ifndef ODR_H
@@ -297,6 +297,7 @@ YAZ_EXPORT int odr_initmember(ODR o, void *p, int size);
 YAZ_EXPORT int odr_peektag(ODR o, int *zclass, int *tag, int *cons);
 YAZ_EXPORT void odr_setlenlen(ODR o, int len);
 YAZ_EXPORT int odr_missing(ODR o, int opt, const char *name);
+YAZ_EXPORT char *odr_prepend(ODR o, const char *prefix, const char *old);
 
 typedef struct Odr_external
 {
index d95a693..bb1955c 100644 (file)
@@ -2,7 +2,7 @@
  * Copyright (c) 1995-2003, Index Data
  * See the file LICENSE for details.
  *
- * $Id: odr_util.c,v 1.1 2003-10-27 12:21:34 adam Exp $
+ * $Id: odr_util.c,v 1.2 2003-11-26 16:23:42 mike Exp $
  */
 #if HAVE_CONFIG_H
 #include <config.h>
@@ -92,3 +92,29 @@ int odr_missing(ODR o, int opt, const char *name)
     }
     return opt;
 }
+
+/*
+ * Reallocate the buffer `old', using the ODR memory pool `o' to be
+ * big enough to hold its existing value (if any) plus `prefix' (if
+ * any) and a separator character.  Copy `prefix', a forward slash and
+ * the old value into the new area and return its address.  Can be
+ * used as follows:
+ *     initRequest->implementationName = odr_prepend(o,
+ *             initRequest->implementationName, "ZOOM-C");
+ */
+char *odr_prepend(ODR o, const char *prefix, const char *old)
+{
+    int plen = (prefix == 0) ? 0 : strlen(prefix);
+    int olen = (old == 0) ? 0 : strlen(old);
+    char *res = (char*) odr_malloc (o, olen + plen + 2);
+
+    *res = '\0';
+    if (prefix != 0)
+       strcpy (res, prefix);
+    if (prefix != 0 && old != 0)
+       strcat (res, "/");
+    if (old !=0)
+       strcat (res, old);
+
+    return res;
+}