- odr_implicit(o, odr_integer, &pp->alfa, ODR_CONTEXT, 1, 1) &&
- odr_implicit(o, odr_integer, &pp->beta, ODR_CONTEXT, 2, 1) &&
- odr_sequence_end(o);
+ z_ReferenceId(o, &pp->referenceId, 1) &&
+ odr_implicit(o, odr_bitstring, &pp->protocolVersion, ODR_CONTEXT,
+ 3, 0) &&
+ odr_implicit(o, odr_bitstring, &pp->options, ODR_CONTEXT, 4, 0) &&
+ odr_implicit(o, odr_integer, &pp->preferredMessageSize, ODR_CONTEXT,
+ 5, 0) &&
+ odr_implicit(o, odr_integer, &pp->maximumRecordSize, ODR_CONTEXT,
+ 6, 0) &&
+ odr_implicit(o, odr_visiblestring, &pp->idAuthentication, ODR_CONTEXT,
+ 7, 1) &&
+ odr_implicit(o, odr_visiblestring, &pp->implementationId, ODR_CONTEXT,
+ 110, 1) &&
+ odr_implicit(o, odr_visiblestring, &pp->implementationName, ODR_CONTEXT,
+ 111, 1) &&
+ odr_implicit(o, odr_visiblestring, &pp->implementationVersion,
+ ODR_CONTEXT, 112, 1) &&
+ odr_sequence_end(o);
+}
+
+struct A
+{
+ int which;
+ union
+ {
+ int *b; /* integer */
+ char *c; /* visstring */
+ } u;
+};
+
+int f_A(ODR o, struct A **p, int opt)
+{
+ int res;
+ Odr_arm arm[] =
+ {
+ { -1, -1, -1, 0, (Odr_fun) odr_integer },
+ { ODR_IMPLICIT, ODR_CONTEXT, 200, 1, (Odr_fun) odr_visiblestring },
+ { -1, -1, -1, -1, 0 }
+ };
+
+ if (o->direction == ODR_DECODE && !*p)
+ *p = odr_malloc(o, sizeof(**p));
+ res = odr_choice(o, arm, &(*p)->u, &(*p)->which);
+ if (!res)
+ {
+ *p = 0;
+ return opt;
+ }
+ return 1;