e8de2c9db8de395fd12455055ec7df8aced8f990
[yaz-moved-to-github.git] / asn / prt-dia.c
1 /*
2  * Copyright (c) 1995-1999, Index Data.
3  * See the file LICENSE for details.
4  * Sebastian Hammer, Adam Dickmeiss
5  *
6  * $Log: prt-dia.c,v $
7  * Revision 1.7  1999-11-30 13:47:11  adam
8  * Improved installation. Moved header files to include/yaz.
9  *
10  * Revision 1.6  1999/04/20 09:56:47  adam
11  * Added 'name' paramter to encoder/decoder routines (typedef Odr_fun).
12  * Modified all encoders/decoders to reflect this change.
13  *
14  * Revision 1.5  1998/02/11 11:53:32  adam
15  * Changed code so that it compiles as C++.
16  *
17  * Revision 1.4  1996/01/22 09:46:34  quinn
18  * Added Sort PDU. Moved StringList to main protocol file.
19  *
20  * Revision 1.3  1995/09/29  17:11:54  quinn
21  * Smallish
22  *
23  * Revision 1.2  1995/09/27  15:02:41  quinn
24  * Modified function heads & prototypes.
25  *
26  * Revision 1.1  1995/08/29  11:19:31  quinn
27  * Added Diagnostic Format
28  *
29  *
30  */
31
32 #include <yaz/proto.h>
33
34 int z_TooMany(ODR o, Z_TooMany **p, int opt, const char *name)
35 {
36     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
37         return opt && odr_ok(o);
38     return
39         odr_implicit(o, odr_integer, &(*p)->tooManyWhat, ODR_CONTEXT, 1, 0) &&
40         odr_implicit(o, odr_integer, &(*p)->max, ODR_CONTEXT, 2, 1) &&
41         odr_sequence_end(o);
42 }
43
44 int z_BadSpec(ODR o, Z_BadSpec **p, int opt, const char *name)
45 {
46     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
47         return opt && odr_ok(o);
48     return
49         odr_implicit(o, z_Specification, &(*p)->spec, ODR_CONTEXT, 1, 0) &&
50         odr_implicit(o, z_DatabaseName, &(*p)->db, ODR_CONTEXT, 2, 1) &&
51         odr_implicit_settag(o, ODR_CONTEXT, 3) &&
52         (odr_sequence_of(o, (Odr_fun)z_Specification, &(*p)->goodOnes,
53             &(*p)->num_goodOnes, 0) || odr_ok(o)) &&
54         odr_sequence_end(o);
55 }
56
57 int z_DbUnavailWhy(ODR o, Z_DbUnavailWhy **p, int opt, const char *name)
58 {
59     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
60         return opt && odr_ok(o);
61     return
62         odr_implicit(o, odr_integer, &(*p)->reasonCode, ODR_CONTEXT, 1, 1) &&
63         odr_implicit(o, z_InternationalString, &(*p)->message, ODR_CONTEXT,
64             2, 1) &&
65         odr_sequence_end(o);
66 }
67
68 int z_DbUnavail(ODR o, Z_DbUnavail **p, int opt, const char *name)
69 {
70     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
71         return opt && odr_ok(o);
72     return
73         odr_implicit(o, z_DatabaseName, &(*p)->db, ODR_CONTEXT, 1, 0) &&
74         odr_implicit(o, z_DbUnavailWhy, &(*p)->why, ODR_CONTEXT, 2, 0) &&
75         odr_sequence_end(o);
76 }
77
78 int z_Attribute(ODR o, Z_Attribute **p, int opt, const char *name)
79 {
80     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
81         return opt && odr_ok(o);
82     return
83         odr_implicit(o, odr_oid, &(*p)->id, ODR_CONTEXT, 1, 0) &&
84         odr_implicit(o, odr_integer, &(*p)->type, ODR_CONTEXT, 2, 1) &&
85         odr_implicit(o, odr_integer, &(*p)->value, ODR_CONTEXT, 3, 1) &&
86         odr_explicit(o, z_Term, &(*p)->term, ODR_CONTEXT, 4, 1) &&
87         odr_sequence_end(o);
88 }
89
90 int z_AttCombo(ODR o, Z_AttCombo **p, int opt, const char *name)
91 {
92     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
93         return opt && odr_ok(o);
94     return
95         odr_implicit(o, z_AttributeList, &(*p)->unsupportedCombination,
96             ODR_CONTEXT, 1, 0) &&
97         odr_implicit_settag(o, ODR_CONTEXT, 2) &&
98         (odr_sequence_of(o, (Odr_fun)z_AttributeList, &(*p)->alternatives,
99             &(*p)->num_alternatives, 0) || odr_ok(o)) &&
100         odr_sequence_end(o);
101 }
102
103 int z_DiagTerm(ODR o, Z_DiagTerm **p, int opt, const char *name)
104 {
105     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
106         return opt && odr_ok(o);
107     return
108         odr_implicit(o, odr_integer, &(*p)->problem, ODR_CONTEXT, 1, 1) &&
109         odr_explicit(o, z_Term, &(*p)->term, ODR_CONTEXT, 2, 0) &&
110         odr_sequence_end(o);
111 }
112
113 int z_Proximity(ODR o, Z_Proximity **p, int opt, const char *name)
114 {
115     static Odr_arm arm[] =
116     {
117         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_Proximity_resultSets,
118          (Odr_fun)odr_null, 0},
119         {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_Proximity_badSet,
120             (Odr_fun)z_InternationalString, 0},
121         {ODR_IMPLICIT, ODR_CONTEXT, 3, Z_Proximity_relation,
122          (Odr_fun)odr_integer, 0},
123         {ODR_IMPLICIT, ODR_CONTEXT, 4, Z_Proximity_unit,
124          (Odr_fun)odr_integer, 0},
125         {ODR_IMPLICIT, ODR_CONTEXT, 5, Z_Proximity_distance,
126          (Odr_fun)odr_integer, 0},
127         {ODR_EXPLICIT, ODR_CONTEXT, 6, Z_Proximity_attributes,
128          (Odr_fun)z_AttributeList, 0},
129         {ODR_IMPLICIT, ODR_CONTEXT, 7, Z_Proximity_ordered,
130          (Odr_fun)odr_null, 0},
131         {ODR_IMPLICIT, ODR_CONTEXT, 8, Z_Proximity_exclusion,
132          (Odr_fun)odr_null, 0},
133         {-1, -1, -1, -1, 0, 0}
134     };
135     
136     if (o->direction == ODR_DECODE)
137         *p = (Z_Proximity *)odr_malloc(o, sizeof(**p));
138     else if (!*p)
139         return opt;
140     if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0))
141         return 1;
142     *p = 0;
143     return opt && odr_ok(o);
144 }
145
146 int z_AttrListList(ODR o, Z_AttrListList **p, int opt, const char *name)
147 {
148     if (o->direction == ODR_DECODE)
149         *p = (Z_AttrListList *)odr_malloc(o, sizeof(**p));
150     else if (!*p)
151         return opt;
152     if (odr_sequence_of(o, (Odr_fun)z_AttributeList, &(*p)->lists,
153                         &(*p)->num_lists, 0))
154         return 1;
155     *p = 0;
156     return opt && odr_ok(o);
157 }
158
159 int z_Scan(ODR o, Z_Scan **p, int opt, const char *name)
160 {
161     static Odr_arm arm[] =
162     {
163         {ODR_IMPLICIT, ODR_CONTEXT, 0, Z_ScanD_nonZeroStepSize,
164          (Odr_fun)odr_null, 0},
165         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_ScanD_specifiedStepSize,
166          (Odr_fun)odr_null, 0},
167         {ODR_IMPLICIT, ODR_CONTEXT, 3, Z_ScanD_termList1,
168          (Odr_fun)odr_null, 0},
169         {ODR_IMPLICIT, ODR_CONTEXT, 4, Z_ScanD_termList2,
170          (Odr_fun)z_AttrListList, 0},
171         {ODR_IMPLICIT, ODR_CONTEXT, 5, Z_ScanD_posInResponse,
172          (Odr_fun)odr_integer, 0},
173         {ODR_IMPLICIT, ODR_CONTEXT, 6, Z_ScanD_resources,
174          (Odr_fun)odr_null, 0},
175         {ODR_IMPLICIT, ODR_CONTEXT, 7, Z_ScanD_endOfList,
176          (Odr_fun)odr_null, 0},
177         {-1, -1, -1, -1, 0, 0}
178     };
179     
180     if (o->direction == ODR_DECODE)
181         *p = (Z_Scan *)odr_malloc(o, sizeof(**p));
182     else if (!*p)
183         return opt;
184     if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0))
185         return 1;
186     *p = 0;
187     return opt && odr_ok(o);
188 }
189
190 int z_Sort(ODR o, Z_Sort **p, int opt, const char *name)
191 {
192     static Odr_arm arm[] =
193     {
194         {ODR_IMPLICIT, ODR_CONTEXT, 0, Z_SortD_sequence,
195          (Odr_fun)odr_null, 0},
196         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_SortD_noRsName,
197          (Odr_fun)odr_null, 0},
198         {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_SortD_tooMany,
199          (Odr_fun)odr_integer, 0},
200         {ODR_IMPLICIT, ODR_CONTEXT, 3, Z_SortD_incompatible,
201          (Odr_fun)odr_null, 0},
202         {ODR_IMPLICIT, ODR_CONTEXT, 4, Z_SortD_generic,
203          (Odr_fun)odr_null, 0},
204         {ODR_IMPLICIT, ODR_CONTEXT, 5, Z_SortD_dbSpecific,
205          (Odr_fun)odr_null, 0},
206 #if 0
207         {ODR_EXPLICIT, ODR_CONTEXT, 6, Z_SortD_sortElement,
208          (Odr_fun)z_SortElement, 0},
209 #endif
210         {ODR_IMPLICIT, ODR_CONTEXT, 7, Z_SortD_key,
211          (Odr_fun)odr_integer, 0},
212         {ODR_IMPLICIT, ODR_CONTEXT, 8, Z_SortD_action,
213          (Odr_fun)odr_null, 0},
214         {ODR_IMPLICIT, ODR_CONTEXT, 9, Z_SortD_illegal,
215          (Odr_fun)odr_integer, 0},
216         {ODR_IMPLICIT, ODR_CONTEXT, 10, Z_SortD_inputTooLarge,
217          (Odr_fun)z_StringList, 0},
218         {ODR_IMPLICIT, ODR_CONTEXT, 11, Z_SortD_aggregateTooLarge,
219          (Odr_fun)odr_null, 0},
220         {-1, -1, -1, -1, 0, 0}
221     };
222
223     if (o->direction == ODR_DECODE)
224         *p = (Z_Sort *)odr_malloc(o, sizeof(**p));
225     else if (!*p)
226         return opt;
227     if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0))
228         return 1;
229     *p = 0;
230     return opt && odr_ok(o);
231 }
232
233 int z_Segmentation(ODR o, Z_Segmentation **p, int opt, const char *name)
234 {
235     static Odr_arm arm[] =
236     {
237         {ODR_IMPLICIT, ODR_CONTEXT, 0, Z_SegmentationD_segments,
238          (Odr_fun)odr_null, 0},
239         {-1, -1, -1, -1, 0, 0}
240     };
241
242     if (o->direction == ODR_DECODE)
243         *p = (Z_Segmentation *)odr_malloc(o, sizeof(**p));
244     else if (!*p)
245         return opt;
246     if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0))
247         return 1;
248     *p = 0;
249     return opt && odr_ok(o);
250 }
251
252 int z_ExtServices(ODR o, Z_ExtServices **p, int opt, const char *name)
253 {
254     static Odr_arm arm[] =
255     {
256         {ODR_IMPLICIT, ODR_CONTEXT, 0, Z_ExtServicesD_req,
257          (Odr_fun)odr_integer, 0},
258         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_ExtServicesD_permission,
259          (Odr_fun)odr_integer, 0},
260         {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_ExtServicesD_immediate,
261          (Odr_fun)odr_integer, 0},
262         {-1, -1, -1, -1, 0, 0}
263     };
264     
265     if (o->direction == ODR_DECODE)
266         *p = (Z_ExtServices *)odr_malloc(o, sizeof(**p));
267     else if (!*p)
268         return opt;
269     if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0))
270         return 1;
271     *p = 0;
272     return opt && odr_ok(o);
273 }
274
275 int z_OidList(ODR o, Z_OidList **p, int opt, const char *name)
276 {
277     if (o->direction == ODR_DECODE)
278         *p = (Z_OidList *)odr_malloc(o, sizeof(**p));
279     else if (!*p)
280         return opt;
281     if (odr_sequence_of(o, (Odr_fun)odr_oid, &(*p)->oids, &(*p)->num_oids, 0))
282         return 1;
283     *p = 0;
284     return opt && odr_ok(o);
285 }
286
287 int z_AccessCtrl(ODR o, Z_AccessCtrl **p, int opt, const char *name)
288 {
289     static Odr_arm arm[] =
290     {
291         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_AccessCtrlD_noUser,
292          (Odr_fun)odr_null, 0},
293         {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_AccessCtrlD_refused,
294          (Odr_fun)odr_null, 0},
295         {ODR_IMPLICIT, ODR_CONTEXT, 3, Z_AccessCtrlD_simple,
296          (Odr_fun)odr_null, 0},
297         {ODR_IMPLICIT, ODR_CONTEXT, 4, Z_AccessCtrlD_oid,
298          (Odr_fun)z_OidList, 0},
299         {ODR_IMPLICIT, ODR_CONTEXT, 5, Z_AccessCtrlD_alternative,
300          (Odr_fun)z_OidList, 0},
301         {ODR_IMPLICIT, ODR_CONTEXT, 6, Z_AccessCtrlD_pwdInv,
302          (Odr_fun)odr_null, 0},
303         {ODR_IMPLICIT, ODR_CONTEXT, 7, Z_AccessCtrlD_pwdExp,
304          (Odr_fun)odr_null, 0},
305         {-1, -1, -1, -1, 0, 0}
306     };
307
308     if (o->direction == ODR_DECODE)
309         *p = (Z_AccessCtrl *)odr_malloc(o, sizeof(**p));
310     else if (!*p)
311         return opt;
312     if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0))
313         return 1;
314     *p = 0;
315     return opt && odr_ok(o);
316 }
317
318 int z_RecordSyntax(ODR o, Z_RecordSyntax **p, int opt, const char *name)
319 {
320     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
321         return opt && odr_ok(o);
322     return
323         odr_implicit(o, odr_oid, &(*p)->unsupportedSyntax,
324                      ODR_CONTEXT, 1, 0) &&
325         odr_implicit_settag(o, ODR_CONTEXT, 2) &&
326         (odr_sequence_of(o, (Odr_fun)odr_oid, &(*p)->suggestedAlternatives,
327                          &(*p)->num_suggestedAlternatives, 0) || odr_ok(o)) &&
328         odr_sequence_end(o);
329 }
330
331 int z_DiagFormat(ODR o, Z_DiagFormat **p, int opt, const char *name)
332 {
333     static Odr_arm arm[] =
334     {
335         {ODR_IMPLICIT, ODR_CONTEXT, 1000, Z_DiagFormat_tooMany,
336          (Odr_fun)z_TooMany, 0},
337         {ODR_IMPLICIT, ODR_CONTEXT, 1001, Z_DiagFormat_badSpec,
338          (Odr_fun)z_BadSpec, 0},
339         {ODR_IMPLICIT, ODR_CONTEXT, 1002, Z_DiagFormat_dbUnavail,
340          (Odr_fun)z_DbUnavail, 0},
341         {ODR_IMPLICIT, ODR_CONTEXT, 1003, Z_DiagFormat_unSupOp,
342          (Odr_fun)odr_integer, 0},
343         {ODR_IMPLICIT, ODR_CONTEXT, 1004, Z_DiagFormat_attribute,
344          (Odr_fun)z_Attribute, 0},
345         {ODR_IMPLICIT, ODR_CONTEXT, 1005, Z_DiagFormat_attCombo,
346          (Odr_fun)z_AttCombo, 0},
347         {ODR_IMPLICIT, ODR_CONTEXT, 1006, Z_DiagFormat_term,
348          (Odr_fun)z_DiagTerm, 0},
349         {ODR_EXPLICIT, ODR_CONTEXT, 1007, Z_DiagFormat_proximity,
350          (Odr_fun)z_Proximity, 0},
351         {ODR_EXPLICIT, ODR_CONTEXT, 1008, Z_DiagFormat_scan,
352          (Odr_fun)z_Scan, 0},
353         {ODR_EXPLICIT, ODR_CONTEXT, 1009, Z_DiagFormat_sort,
354          (Odr_fun)z_Sort, 0},
355         {ODR_EXPLICIT, ODR_CONTEXT, 1010, Z_DiagFormat_segmentation,
356          (Odr_fun)z_Segmentation, 0},
357         {ODR_EXPLICIT, ODR_CONTEXT, 1011, Z_DiagFormat_extServices,
358          (Odr_fun)z_ExtServices, 0},
359         {ODR_EXPLICIT, ODR_CONTEXT, 1012, Z_DiagFormat_accessCtrl,
360          (Odr_fun)z_AccessCtrl, 0},
361         {ODR_IMPLICIT, ODR_CONTEXT, 1013, Z_DiagFormat_recordSyntax,
362          (Odr_fun)z_RecordSyntax, 0},
363         {-1, -1, -1, -1, 0, 0}
364     };
365
366     if (o->direction == ODR_DECODE)
367         *p = (Z_DiagFormat *)odr_malloc(o, sizeof(**p));
368     else if (!*p)
369         return opt;
370     if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0))
371         return 1;
372     *p = 0;
373     return opt && odr_ok(o);
374 }
375
376 int z_Diagnostic(ODR o, Z_Diagnostic **p, int opt, const char *name)
377 {
378     static Odr_arm arm[] =
379     {
380         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_Diagnostic_defaultDiagRec,
381          (Odr_fun)z_DefaultDiagFormat, 0},
382         {ODR_EXPLICIT, ODR_CONTEXT, 2, Z_Diagnostic_explicitDiagnostic,
383          (Odr_fun)z_DiagFormat, 0},
384         {-1, -1, -1, -1, 0, 0}
385     };
386     
387     if (o->direction == ODR_DECODE)
388         *p = (Z_Diagnostic *)odr_malloc(o, sizeof(**p));
389     else if (!*p)
390         return opt;
391     if (odr_choice(o, arm, &(*p)->u, &(*p)->which, 0))
392         return 1;
393     *p = 0;
394     return opt && odr_ok(o);
395 }
396
397 int z_DiagnosticUnit(ODR o, Z_DiagnosticUnit **p, int opt, const char *name)
398 {
399     if (!odr_sequence_begin(o, p, sizeof(**p), 0))
400         return opt && odr_ok(o);
401     return
402         odr_explicit(o, z_Diagnostic, &(*p)->diagnostic, ODR_CONTEXT, 1, 1) &&
403         odr_implicit(o, z_InternationalString, &(*p)->message,
404                      ODR_CONTEXT, 2, 1) &&
405         odr_sequence_end(o);
406 }
407
408 int z_DiagnosticFormat(ODR o, Z_DiagnosticFormat **p, int opt,
409                        const char *name)
410 {
411     if (o->direction == ODR_DECODE)
412         *p = (Z_DiagnosticFormat *)odr_malloc(o, sizeof(**p));
413     else if (!*p)
414         return opt;
415     if (odr_sequence_of(o, (Odr_fun)z_DiagnosticUnit, &(*p)->diagnostics,
416         &(*p)->num_diagnostics, 0))
417         return 1;
418     *p = 0;
419     return opt && odr_ok(o);
420 }