X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fodr_util.c;h=644c3c37c25fbcfdfc2f84209cd44bf7d104e021;hp=6beac3b92b9c3e95c7d883206c4a45ddf61b4d6a;hb=d02429b9a7fb8bb01961a51c2446eb1dce048c78;hpb=4c176312acdc3444c9afc820f76a393e64668e52 diff --git a/src/odr_util.c b/src/odr_util.c index 6beac3b..644c3c3 100644 --- a/src/odr_util.c +++ b/src/odr_util.c @@ -1,8 +1,6 @@ -/* - * Copyright (C) 1995-2005, Index Data ApS +/* This file is part of the YAZ toolkit. + * Copyright (C) 1995-2012 Index Data * See the file LICENSE for details. - * - * $Id: odr_util.c,v 1.7 2005-01-15 19:47:14 adam Exp $ */ /** * \file odr_util.c @@ -14,79 +12,71 @@ #include #include -#include #include "odr-priv.h" -#include +#include void odr_prname(ODR o, const char *name) { - if (name) - odr_printf(o, "%*s%s ", o->indent*4, "", name); + if (o->op->indent < 16) + odr_printf(o, "%*s", o->op->indent * 2, ""); else - odr_printf(o, "%*s", o->indent*4, ""); + odr_printf(o, "level=%-7d%*s", o->op->indent, + 2 * (o->op->indent % 8) , ""); + if (name) + odr_printf(o, "%s ", name); } int odp_more_chunks(ODR o, const unsigned char *base, int len) { if (!len) - return 0; + return 0; if (len < 0) /* indefinite length */ { - if (*o->bp == 0 && *(o->bp + 1) == 0) - { - o->bp += 2; - return 0; - } - else - return 1; + if (*o->bp == 0 && *(o->bp + 1) == 0) + { + o->bp += 2; + return 0; + } + else + return 1; } else return o->bp - base < len; } -Odr_oid *odr_oiddup_nmem(NMEM nmem, Odr_oid *o) +Odr_oid *odr_oiddup_nmem(NMEM nmem, const Odr_oid *o) { Odr_oid *r; if (!o) - return 0; - if (!(r = (int *)nmem_malloc(nmem, (oid_oidlen(o) + 1) * sizeof(int)))) - return 0; + return 0; + if (!(r = (Odr_oid *) + nmem_malloc(nmem, (oid_oidlen(o) + 1) * sizeof(Odr_oid)))) + return 0; oid_oidcpy(r, o); return r; } -Odr_oid *odr_oiddup(ODR odr, Odr_oid *o) +Odr_oid *odr_oiddup(ODR odr, const Odr_oid *o) { - if (!odr->mem) - odr->mem = nmem_create(); - return odr_oiddup_nmem (odr->mem, o); + return odr_oiddup_nmem(odr_getmem(odr), o); } Odr_oid *odr_getoidbystr_nmem(NMEM nmem, const char *str) { - int num = 1, i = 0; - const char *p = str; + Odr_oid oid[OID_SIZE]; Odr_oid *ret; - if (!isdigit(*(const unsigned char *) str)) - return 0; - while ((p = strchr(p, '.'))) - num++, p++; - ret = (int *)nmem_malloc(nmem, sizeof(*ret)*(num + 1)); - p = str; - do - ret[i++] = atoi(p); - while ((p = strchr(p, '.')) && *++p); - ret[i] = -1; + if (oid_dotstring_to_oid(str, oid)) + return 0; + ret = (Odr_oid *)nmem_malloc(nmem, sizeof(*ret)*(oid_oidlen(oid) + 1)); + oid_oidcpy(ret, oid); return ret; } Odr_oid *odr_getoidbystr(ODR o, const char *str) { - if (!o->mem) - o->mem = nmem_create(); - return odr_getoidbystr_nmem (o->mem, str); + return odr_getoidbystr_nmem(odr_getmem(o), str); } int odr_missing(ODR o, int opt, const char *name) @@ -107,8 +97,8 @@ int odr_missing(ODR o, int opt, const char *name) * 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"); + * initRequest->implementationName = odr_prepend(o, + * initRequest->implementationName, "ZOOM-C"); */ char *odr_prepend(ODR o, const char *prefix, const char *old) { @@ -118,11 +108,20 @@ char *odr_prepend(ODR o, const char *prefix, const char *old) *res = '\0'; if (prefix != 0) - strcpy (res, prefix); + strcpy (res, prefix); if (prefix != 0 && old != 0) - strcat (res, "/"); + strcat (res, "/"); if (old !=0) - strcat (res, old); + strcat (res, old); return res; } +/* + * Local variables: + * c-basic-offset: 4 + * c-file-style: "Stroustrup" + * indent-tabs-mode: nil + * End: + * vim: shiftwidth=4 tabstop=8 expandtab + */ +