2 * Copyright (C) 1994, Index Data I/S
4 * Sebastian Hammer, Adam Dickmeiss
7 * Revision 1.6 1995-03-01 08:40:56 quinn
10 * Revision 1.5 1995/02/10 18:57:26 quinn
11 * More in the way of error-checking.
13 * Revision 1.4 1995/02/10 15:55:29 quinn
16 * Revision 1.3 1995/02/09 15:51:49 quinn
19 * Revision 1.2 1995/02/07 14:13:46 quinn
22 * Revision 1.1 1995/02/03 17:04:38 quinn
31 * Top level oid en/decoder.
32 * Returns 1 on success, 0 on error.
34 int odr_oid(ODR o, Odr_oid **p, int opt)
40 o->t_class = ODR_UNIVERSAL;
43 if ((res = ber_tag(o, p, o->t_class, o->t_tag, &cons)) < 0)
47 if (o->direction == ODR_PRINT)
51 fprintf(o->print, "%sOID:", odr_indent(o));
52 for (i = 0; (*p)[i] > -1; i++)
53 fprintf(o->print, " %d", (*p)[i]);
54 fprintf(o->print, "\n");
57 if (o->direction == ODR_DECODE)
58 *p = nalloc(o, ODR_OID_SIZE * sizeof(**p));
59 return ber_oidc(o, *p);