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