X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=odr%2Fodr_util.c;h=72b80d6c27ee8073c62a199ae1f5e453b93323a8;hb=475b8ce3047108dcf7a87251733299077d7001e7;hp=6814c60b3fcafafbd9219c024d932bbd8ab8e9bd;hpb=a7d28a25277a208edb9c44d124f179cc2be6db70;p=yaz-moved-to-github.git diff --git a/odr/odr_util.c b/odr/odr_util.c index 6814c60..72b80d6 100644 --- a/odr/odr_util.c +++ b/odr/odr_util.c @@ -1,5 +1,94 @@ -#include +/* + * Copyright (c) 1995-1997, Index Data + * See the file LICENSE for details. + * Sebastian Hammer, Adam Dickmeiss + * + * $Log: odr_util.c,v $ + * Revision 1.13 1998-02-11 11:53:34 adam + * Changed code so that it compiles as C++. + * + * Revision 1.12 1997/10/31 12:20:08 adam + * Improved memory debugging for xmalloc/nmem.c. References to NMEM + * instead of ODR in n ESPEC-1 handling in source d1_espec.c. + * Bug fix: missing fclose in data1_read_espec1. + * + */ + #include +#include +#include +#include +#include + +char *odr_indent(ODR o) +{ + static char buf[512]; + int i = o->indent; + + memset(buf, ' ', 512); + if (i >= 128) + i = 127; + buf[o->indent * 4] = 0; + return buf; +} + +int odp_more_chunks(ODR o, unsigned char *base, int len) +{ + if (!len) + return 0; + if (len < 0) /* indefinite length */ + { + if (*o->bp == 0 && *(o->bp + 1) == 0) + { + o->bp += 2; + o->left -= 2; + return 0; + } + else + return 1; + } + else + return o->bp - base < len; +} + +Odr_oid *odr_oiddup_nmem(NMEM nmem, Odr_oid *o) +{ + Odr_oid *r; + + if (!o) + return 0; + if (!(r = (int *)nmem_malloc(nmem, (oid_oidlen(o) + 1) * sizeof(int)))) + return 0; + oid_oidcpy(r, o); + return r; +} + +Odr_oid *odr_oiddup(ODR odr, Odr_oid *o) +{ + return odr_oiddup_nmem (odr->mem, o); +} + +Odr_oid *odr_getoidbystr_nmem(NMEM nmem, char *str) +{ + int num = 1, i = 0; + char *p = str; + Odr_oid *ret; + + if (!isdigit(*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; + return ret; +} + +Odr_oid *odr_getoidbystr(ODR o, char *str) +{ + return odr_getoidbystr_nmem (o->mem, str); +} -void *nalloc(ODR o, int size) { return malloc(size); } -char *odr_indent(ODR o) {return "";}