X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fber_oct.c;h=a88da376f8aa1f3461aa3f5bc6a5ff94c9865c6e;hp=d86e4145cc576b9e8a63f441d9306b8beb6ad276;hb=f0df1959fda559c0d952810c338a9fde667b5a63;hpb=38dfcb07c905b2ba53e84678c3ce53c40e27b0b7 diff --git a/src/ber_oct.c b/src/ber_oct.c index d86e414..a88da37 100644 --- a/src/ber_oct.c +++ b/src/ber_oct.c @@ -1,5 +1,5 @@ /* This file is part of the YAZ toolkit. - * Copyright (C) 1995-2013 Index Data + * Copyright (C) Index Data * See the file LICENSE for details. */ @@ -23,22 +23,19 @@ int ber_octetstring(ODR o, Odr_oct *p, int cons) { int res, len; const char *base; -#if OCT_SIZE - unsigned char *c; -#endif switch (o->direction) { case ODR_DECODE: - if ((res = ber_declen(o->bp, &len, odr_max(o))) < 0) + if ((res = ber_declen(o->op->bp, &len, odr_max(o))) < 0) { odr_seterror(o, OPROTO, 14); return 0; } - o->bp += res; + o->op->bp += res; if (cons) /* fetch component strings */ { - base = o->bp; + base = o->op->bp; while (odp_more_chunks(o, base, len)) if (!odr_octetstring(o, &p, 0, 0)) return 0; @@ -55,31 +52,9 @@ int ber_octetstring(ODR o, Odr_oct *p, int cons) odr_seterror(o, OOTHER, 16); return 0; } -#if OCT_SIZE - assert(p->size == 0); - assert(p->len == 0); - if (len + 1 > p->size - p->len) - { - c = (unsigned char *)odr_malloc(o, p->size += len + 1); - if (p->len) - memcpy(c, p->buf, p->len); - p->buf = c; - } - if (len) - memcpy(p->buf + p->len, o->bp, len); - p->len += len; - o->bp += len; - /* the final null is really not part of the buffer, but */ - /* it helps somes applications that assumes C strings */ - if (len) - p->buf[p->len] = '\0'; -#else p->len = len; - p->buf = odr_malloc(o, len + 1); - memcpy(p->buf, o->bp, len); - p->buf[len] = '\0'; - o->bp += len; -#endif + p->buf = odr_strdupn(o, o->op->bp, len); + o->op->bp += len; return 1; case ODR_ENCODE: if ((res = ber_enclen(o, p->len, 5, 0)) < 0)