+int z_NamePlusRecordList(ODR o, Z_NamePlusRecordList **p, int opt)
+{
+ if (o->direction == ODR_DECODE)
+ *p = nalloc(o, sizeof(**p));
+ if (odr_sequence_of(o, z_NamePlusRecordList, &(*p)->records,
+ &(*p)->num_records))
+ return 1;
+ *p = 0;
+ return 0;
+}
+
+int z_Records(ODR o, Z_Records **p, int opt)
+{
+ Odr_arm arm[] =
+ {
+ {ODR_IMPLICIT, ODR_CONTEXT, 28, Z_Records_DBOSD, z_NamePlusRecordList},
+ {ODR_IMPLICIT, ODR_CONTEXT, 130, Z_Records_NSD, z_DiagRec},
+ {-1, -1, -1, -1, 0}
+ };
+
+ if (o->direction == ODR_DECODE)
+ *p = nalloc(o, sizeof(**p));
+ else if (!*p)
+ return opt;
+ if (odr_choice(o, arm, &(*p)->u, &(*p)->which))
+ return 1;
+ *p = 0;
+ return opt;
+}
+
+/* ------------------------ SEARCHRESPONSE ----------------*/
+
+int z_NumberOfRecordsReturned(ODR o, int **p, int opt)
+{
+ return odr_implicit(o, odr_integer, p, ODR_CONTEXT, 24, opt);
+}
+
+int z_NextResultSetPosition(ODR o, int **p, int opt)
+{
+ return odr_implicit(o, odr_integer, p, ODR_CONTEXT, 25, opt);
+}
+
+int z_PresentStatus(ODR o, int **p, int opt)
+{
+ return odr_implicit(o, odr_integer, p, ODR_CONTEXT, 27, opt);
+}
+
+int z_SearchResponse(ODR o, Z_SearchResponse **p, int opt)
+{
+ Z_SearchResponse *pp;
+
+ if (!odr_sequence_begin(o, p, sizeof(**p)))
+ return opt;
+ pp = *p;
+ return
+ z_ReferenceId(o, &pp->referenceId, 1) &&
+ odr_implicit(o, odr_integer, &pp->resultCount, ODR_CONTEXT, 23, 0) &&
+ z_NumberOfRecordsReturned(o, &pp->numberOfRecordsReturned, 0) &&
+ z_NextResultSetPosition(o, &pp->nextResultSetPosition, 0) &&
+ odr_implicit(o, odr_bool, &pp->searchStatus, ODR_CONTEXT, 22, 0) &&
+ odr_implicit(o, odr_integer, &pp->resultSetStatus, ODR_CONTEXT, 26, 1) &&
+ z_PresentStatus(o, &pp->presentStatus, 1) &&
+ z_Records(o, &pp->records, 1) &&
+ odr_sequence_end(o);
+}
+
+/* --------------------- PRESENT SERVICE ---------------------- */
+
+int z_PresentRequest(ODR o, Z_PresentRequest **p, int opt)
+{
+ Z_PresentRequest *pp;
+
+ if (!odr_sequence_begin(o, p, sizeof(**p)))
+ return opt;
+ pp = *p;
+ return
+ z_ReferenceId(o, &pp->referenceId, 1) &&
+ z_ResultSetId(o, &pp->resultSetId, 0) &&
+ odr_implicit(o, odr_integer, &pp->resultSetStartPoint, ODR_CONTEXT,
+ 30, 0) &&
+ odr_implicit(o, odr_integer, &pp->numberOfRecordsRequested, ODR_CONTEXT,
+ 29, 0) &&
+ z_ElementSetNames(o, &pp->elementSetNames, 1) &&
+ z_PreferredRecordSyntax(o, &pp->preferredRecordSyntax, 1) &&
+ odr_sequence_end(o);
+}
+
+int z_PresentResponse(ODR o, Z_PresentResponse **p, int opt)
+{
+ Z_PresentResponse *pp;
+
+ if (!odr_sequence_begin(o, p, sizeof(**p)))
+ return opt;
+ pp = *p;
+ return
+ z_ReferenceId(o, &pp->referenceId, 1) &&
+ z_NumberOfRecordsReturned(o, &pp->numberOfRecordsReturned, 0) &&
+ z_NextResultSetPosition(o, &pp->nextResultSetPosition, 0) &&
+ z_PresentStatus(o, &pp->presentStatus, 0) &&
+ z_Records(o, &pp->records, 1) &&
+ odr_sequence_end(o);
+}
+
+/* ------------------------ APDU ------------------------- */
+