X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fber_any.c;h=f12b4ba4b2122cb37ded484e0afb71c2b4855030;hp=d5edc77caa0701a03a276ab02834c1224bff4b2d;hb=6ee0d7c0404834a0a59547c3bd7e2686f838ce37;hpb=77c5a4fca8b516fd39b8ba213daed17a465a6b2a diff --git a/src/ber_any.c b/src/ber_any.c index d5edc77..f12b4ba 100644 --- a/src/ber_any.c +++ b/src/ber_any.c @@ -1,9 +1,9 @@ /* This file is part of the YAZ toolkit. - * Copyright (C) 1995-2012 Index Data + * Copyright (C) 1995-2013 Index Data * See the file LICENSE for details. */ -/** +/** * \file ber_any.c * \brief Implements BER ANY encoding and decoding. * @@ -21,19 +21,19 @@ int ber_any(ODR o, Odr_any **p) { int res; - + switch (o->direction) { case ODR_DECODE: - if ((res = completeBER(o->bp, odr_max(o))) <= 0) /* FIX THIS */ + if ((res = completeBER(o->op->bp, odr_max(o))) <= 0) /* FIX THIS */ { odr_seterror(o, OPROTO, 2); return 0; } - (*p)->buf = (unsigned char *)odr_malloc(o, res); - memcpy((*p)->buf, o->bp, res); - (*p)->len = (*p)->size = res; - o->bp += res; + (*p)->buf = (char *)odr_malloc(o, res); + memcpy((*p)->buf, o->op->bp, res); + (*p)->len = res; + o->op->bp += res; return 1; case ODR_ENCODE: if (odr_write(o, (*p)->buf, (*p)->len) < 0) @@ -45,11 +45,11 @@ int ber_any(ODR o, Odr_any **p) #define BER_ANY_DEBUG 0 -int completeBER_n(const unsigned char *buf, int len, int level) +int completeBER_n(const char *buf, int len, int level) { int res, ll, zclass, tag, cons; - const unsigned char *b = buf; - + const char *b = buf; + if (level > 1000) { #if BER_ANY_DEBUG @@ -74,7 +74,7 @@ int completeBER_n(const unsigned char *buf, int len, int level) #endif return -1; /* error */ } - if (res == -1) + if (res == -1) { #if BER_ANY_DEBUG yaz_log(YLOG_LOG, "<<<<<<<<< return2 lev=%d res=%d", level, res); @@ -109,10 +109,9 @@ int completeBER_n(const unsigned char *buf, int len, int level) { if (b[0] == 0 && b[1] == 0) break; - if (!(res = completeBER_n(b, len, level+1))) - return 0; - if (res == -1) - return -1; + res = completeBER_n(b, len, level+1); + if (res <= 0) + return res; b += res; len -= res; } @@ -121,7 +120,7 @@ int completeBER_n(const unsigned char *buf, int len, int level) return (b - buf) + 2; } -int completeBER(const unsigned char *buf, int len) +int completeBER(const char *buf, int len) { int res = completeBER_n(buf, len, 0); #if BER_ANY_DEBUG