X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=odr%2Fodr_tag.c;h=99486450b1a10352a47f142b7a6828bf483cf1cf;hb=fc89703038b1168a8f52b6920c50dedb9080063d;hp=9e3ee323bd4b0b8ab3dde032459d304d8dd8b0b6;hpb=63cafe41a93427118959a74201b3e331169a71d9;p=yaz-moved-to-github.git diff --git a/odr/odr_tag.c b/odr/odr_tag.c index 9e3ee32..9948645 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.5 1995-09-29 17:12:27 quinn + * 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 * Smallish * * Revision 1.4 1995/09/27 15:03:00 quinn @@ -23,6 +29,23 @@ #include +int odr_peektag(ODR o, int *class, 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, class, tag, cons) <= 0) + { + o->error = OREQUIRED; + return 0; + } + return 1; +} + int odr_implicit_settag(ODR o, int class, int tag) { if (o->error) @@ -34,3 +57,19 @@ int odr_implicit_settag(ODR o, int class, int tag) } return 1; } + +int odr_initmember(ODR o, void *p, int size) +{ + char **pp = (char **) p; + + if (o->error) + return 0; + if (o->direction == ODR_DECODE) + *pp = odr_malloc(o, size); + else if (!*pp) + { + o->t_class = -1; + return 0; + } + return 1; +}