X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=odr%2Fodr_tag.c;h=129a2726b61471d4d22924692540aa582ac4dbc6;hb=113640450c45ca7ac96285cc8ca666bfd597ed21;hp=5679838ed5950370ae0598eabc5f52b38781405e;hpb=b2d4fae21009b1909a35ef9ae6bcd27c1a5dca74;p=yaz-moved-to-github.git diff --git a/odr/odr_tag.c b/odr/odr_tag.c index 5679838..129a272 100644 --- a/odr/odr_tag.c +++ b/odr/odr_tag.c @@ -4,7 +4,13 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: odr_tag.c,v $ - * Revision 1.6 1995-12-14 16:28:26 quinn + * Revision 1.8 1997-05-14 06:53:59 adam + * C++ support. + * + * Revision 1.7 1996/02/20 12:52:54 quinn + * Added odr_peektag + * + * Revision 1.6 1995/12/14 16:28:26 quinn * More explain stuff. * * Revision 1.5 1995/09/29 17:12:27 quinn @@ -26,13 +32,30 @@ #include -int odr_implicit_settag(ODR o, int class, int tag) +int odr_peektag(ODR o, int *zclass, int *tag, int *cons) +{ + if (o->direction != ODR_DECODE) + { + o->error = OOTHER; + return 0; + } + if (o->stackp > -1 && !odr_constructed_more(o)) + return 0; + if (ber_dectag(o->bp, zclass, tag, cons) <= 0) + { + o->error = OREQUIRED; + return 0; + } + return 1; +} + +int odr_implicit_settag(ODR o, int zclass, int tag) { if (o->error) return 0; if (o->t_class < 0) { - o->t_class = class; + o->t_class = zclass; o->t_tag = tag; } return 1;