X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=odr%2Fodr_util.c;h=0ea1c0803c3cab2d0e3efe2ec95e0ce64571e544;hb=57a0976b6e7d84f77a08dcd4cf03d6656dae60d4;hp=6814c60b3fcafafbd9219c024d932bbd8ab8e9bd;hpb=a7d28a25277a208edb9c44d124f179cc2be6db70;p=yaz-moved-to-github.git diff --git a/odr/odr_util.c b/odr/odr_util.c index 6814c60..0ea1c08 100644 --- a/odr/odr_util.c +++ b/odr/odr_util.c @@ -1,5 +1,80 @@ -#include #include +#include + +char *odr_indent(ODR o) +{ + static char buf[512]; + + memset(buf, ' ', 512); + 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; +} + +/* OID utilities */ + +void odr_oidcpy(Odr_oid *t, Odr_oid *s) +{ + while ((*(t++) = *(s++)) > -1); +} + +void odr_oidcat(Odr_oid *t, Odr_oid *s) +{ + while (*t > -1) + t++; + while ((*(t++) = *(s++)) > -1); +} + +int odr_oidcmp(Odr_oid *o1, Odr_oid *o2) +{ + while (*o1 == *o2 && *o1 > -1) + { + o1++; + o2++; + } + if (*o1 == *o2) + return 0; + else if (*o1 > *o2) + return 1; + else + return -1; +} + +int odr_oidlen(Odr_oid *o) +{ + int len = 0; + + while (*(o++) >= 0) + len++; + return len; +} + +Odr_oid *odr_oiddup(ODR odr, Odr_oid *o) +{ + Odr_oid *r; -void *nalloc(ODR o, int size) { return malloc(size); } -char *odr_indent(ODR o) {return "";} + if (!o) + return 0; + if (!(r = odr_malloc(odr, (odr_oidlen(o) + 1) * sizeof(Odr_oid)))) + return 0; + odr_oidcpy(r, o); + return r; +}