X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=odr%2Fodr_seq.c;h=cb3d703aea6520ca1f751657cadde99ae95e0533;hb=11a58ec3e43c76b092d85510825f7317d7efc3ad;hp=f135d8523f0a467a4a05d669265eacfc1a5d5117;hpb=10981b2f116449523a9f628c20a78212ce91553e;p=yaz-moved-to-github.git diff --git a/odr/odr_seq.c b/odr/odr_seq.c index f135d85..cb3d703 100644 --- a/odr/odr_seq.c +++ b/odr/odr_seq.c @@ -4,7 +4,16 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: odr_seq.c,v $ - * Revision 1.5 1995-02-09 15:51:49 quinn + * Revision 1.8 1995-03-15 11:18:05 quinn + * Fixed serious bug in odr_cons + * + * Revision 1.7 1995/03/08 12:12:30 quinn + * Added better error checking. + * + * Revision 1.6 1995/02/10 15:55:29 quinn + * Bug fixes, mostly. + * + * Revision 1.5 1995/02/09 15:51:49 quinn * Works better now. * * Revision 1.4 1995/02/07 17:53:00 quinn @@ -28,12 +37,13 @@ int odr_sequence_begin(ODR o, void *p, int size) { char **pp = (char**) p; + if (o->error) + return 0; if (o->t_class < 0) { o->t_class = ODR_UNIVERSAL; o->t_tag = ODR_SEQUENCE; } - if (o->direction == ODR_DECODE) *pp = 0; if (odr_constructed_begin(o, p, o->t_class, o->t_tag)) @@ -64,12 +74,7 @@ int odr_sequence_end(ODR o) int odr_sequence_more(ODR o) { - if (o->stackp < 0) - return 0; - if (o->stack[o->stackp].len >= 0) - return o->bp - o->stack[o->stackp].base < o->stack[o->stackp].len; - else - return (!(*o->bp == 0 && *(o->bp + 1) == 0)); + return odr_constructed_more(o); } int odr_sequence_of(ODR o, Odr_fun type, void *p, int *num) @@ -110,11 +115,21 @@ int odr_sequence_of(ODR o, Odr_fun type, void *p, int *num) } break; case ODR_ENCODE: case ODR_PRINT: +#ifdef ODR_DEBUG + fprintf(stderr, "[seqof: num=%d]", *num); +#endif for (i = 0; i < *num; i++) + { +#ifdef ODR_DEBUG + fprintf(stderr, "[seqof: elem #%d]", i); +#endif if (!(*type)(o, *pp + i, 0)) return 0; + } break; - default: return 0; + default: + o->error = OOTHER; + return 0; } return odr_sequence_end(o); }