2 * Copyright (C) 1994, Index Data I/S
4 * Sebastian Hammer, Adam Dickmeiss
7 * Revision 1.8 1995-04-17 09:37:42 quinn
8 * *** empty log message ***
10 * Revision 1.7 1995/03/17 10:17:39 quinn
11 * Added memory management.
13 * Revision 1.6 1995/03/08 12:12:02 quinn
14 * Added better error checking.
16 * Revision 1.5 1995/02/14 20:39:54 quinn
17 * Fixed bugs in completeBER and (serious one in) ber_oid.
19 * Revision 1.4 1995/02/14 11:54:33 quinn
22 * Revision 1.3 1995/02/10 18:57:24 quinn
23 * More in the way of error-checking.
25 * Revision 1.2 1995/02/10 15:55:28 quinn
28 * Revision 1.1 1995/02/09 15:51:45 quinn
35 int ber_any(ODR o, Odr_any **p)
42 if ((res = completeBER(o->bp, o->left)) <= 0) /* FIX THIS */
47 (*p)->buf = odr_malloc(o, res);
48 memcpy((*p)->buf, o->bp, res);
49 (*p)->len = (*p)->size = res;
54 if ((*p)->len > o->left)
59 memcpy(o->bp , (*p)->buf, (*p)->len);
63 default: o->error = OOTHER; return 0;
68 * Return length of BER-package or 0.
70 int completeBER(unsigned char *buf, int len)
72 int res, ll, class, tag, cons;
73 unsigned char *b = buf;
77 if (!buf[0] && !buf[1])
79 if ((res = ber_dectag(b, &class, &tag, &cons)) <= 0)
85 if ((res = ber_declen(b, &ll)) <= 0)
92 return (len >= ll ? ll + (b-buf) : 0);
95 /* constructed - cycle through children */
98 if (*b == 0 && *(b + 1) == 0)
100 if (!(res = completeBER(b, len)))
107 return (b - buf) + 2;