Modified function heads & prototypes.
[yaz-moved-to-github.git] / asn / prt-grs.c
1 /*
2  * Copyright (c) 1995, Index Data.
3  * See the file LICENSE for details.
4  * Sebastian Hammer, Adam Dickmeiss
5  *
6  * $Log: prt-grs.c,v $
7  * Revision 1.3  1995-09-27 15:02:43  quinn
8  * Modified function heads & prototypes.
9  *
10  * Revision 1.2  1995/08/28  10:58:58  quinn
11  * Added extra choice-entry to data to catch visiblestring.
12  *
13  * Revision 1.1  1995/08/17  12:47:09  quinn
14  * Added GRS-1.
15  *
16  *
17  */
18
19 #include <proto.h>
20
21 int z_TaggedElement(ODR o, Z_TaggedElement **p, int opt);
22 int z_ElementData(ODR o, Z_ElementData **p, int opt);
23 int z_ElementMetaData(ODR o, Z_ElementMetaData **p, int opt);
24 int z_TagUnit(ODR o, Z_TagUnit **p, int opt);
25 int z_TagPath(ODR o, Z_TagPath **p, int opt);
26 int z_Order(ODR o, Z_Order **p, int opt);
27 int z_Usage(ODR o, Z_Usage **p, int opt);
28 int z_HitVector(ODR o, Z_HitVector **p, int opt);
29 int z_Triple(ODR o, Z_Triple **p, int opt);
30 int z_Variant(ODR o, Z_Variant **p, int opt);
31
32 int MDF z_GenericRecord(ODR o, Z_GenericRecord **p, int opt)
33 {
34     if (o->direction == ODR_DECODE)
35         *p = odr_malloc(o, sizeof(**p));
36     else if (!*p)
37         return opt;
38     if (odr_sequence_of(o, z_TaggedElement, &(*p)->elements, &(*p)->num_elements))
39         return 1;
40     *p = 0;
41     return opt && odr_ok(o);
42 }
43
44 int z_TaggedElement(ODR o, Z_TaggedElement **p, int opt)
45 {
46     if (!odr_sequence_begin(o, p, sizeof(**p)))
47         return opt && odr_ok(o);
48     return
49         odr_implicit(o, odr_integer, &(*p)->tagType, ODR_CONTEXT, 1, 1) &&
50         odr_explicit(o, z_StringOrNumeric, &(*p)->tagValue, ODR_CONTEXT, 2, 0) &&
51         odr_implicit(o, odr_integer, &(*p)->tagOccurrence, ODR_CONTEXT, 3, 1) &&
52         odr_explicit(o, z_ElementData, &(*p)->content, ODR_CONTEXT, 4, 0) &&
53         odr_implicit(o, z_ElementMetaData, &(*p)->metaData, ODR_CONTEXT, 5, 1) &&
54         odr_implicit(o, z_Variant, &(*p)->appliedVariant, ODR_CONTEXT, 6, 1) &&
55         odr_sequence_end(o);
56 }
57     
58 int z_ElementData(ODR o, Z_ElementData **p, int opt)
59 {
60     static Odr_arm arm[] =
61     {
62         {ODR_NONE, -1, -1, Z_ElementData_octets, odr_octetstring},
63         {ODR_NONE, -1, -1, Z_ElementData_numeric, odr_integer},
64         {ODR_NONE, -1, -1, Z_ElementData_date, odr_generalizedtime},
65         {ODR_NONE, -1, -1, Z_ElementData_ext, z_External},
66         {ODR_NONE, -1, -1, Z_ElementData_string, z_InternationalString},
67         /* The entry below provides some backwards compatibility */
68         {ODR_NONE, -1, -1, Z_ElementData_string, odr_visiblestring},
69         {ODR_NONE, -1, -1, Z_ElementData_trueOrFalse, odr_bool},
70         {ODR_NONE, -1, -1, Z_ElementData_oid, odr_oid},
71         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_ElementData_intUnit, z_IntUnit},
72         {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_ElementData_elementNotThere, odr_null},
73         {ODR_IMPLICIT, ODR_CONTEXT, 3, Z_ElementData_elementEmpty, odr_null},
74         {ODR_IMPLICIT, ODR_CONTEXT, 4, Z_ElementData_noDataRequested, odr_null},
75         {ODR_IMPLICIT, ODR_CONTEXT, 5, Z_ElementData_diagnostic, z_External},
76         {ODR_EXPLICIT, ODR_CONTEXT, 6, Z_ElementData_subtree, z_GenericRecord},
77         {-1, -1, -1, -1, 0}
78     };
79     
80     if (o->direction == ODR_DECODE)
81         *p = odr_malloc(o, sizeof(**p));
82     else if (!*p)
83         return opt;
84     if (odr_choice(o, arm, &(*p)->u, &(*p)->which))
85         return 1;
86     *p = 0;
87     return opt && odr_ok(o);
88 }
89
90 int z_ElementMetaData(ODR o, Z_ElementMetaData **p, int opt)
91 {
92     if (!odr_sequence_begin(o, p, sizeof(**p)))
93         return opt && odr_ok(o);
94     return
95         odr_implicit(o, z_Order, &(*p)->seriesOrder, ODR_CONTEXT, 1, 1) &&
96         odr_implicit(o, z_Usage, &(*p)->usageRight, ODR_CONTEXT, 2, 1) &&
97         odr_implicit_settag(o, ODR_CONTEXT, 3) &&
98         (odr_sequence_of(o, z_HitVector, &(*p)->hits, &(*p)->num_hits) ||
99             odr_ok(o)) &&
100         odr_implicit(o, z_InternationalString, &(*p)->displayName, ODR_CONTEXT,
101             4, 1) &&
102         odr_implicit_settag(o, ODR_CONTEXT, 5) &&
103         (odr_sequence_of(o, z_Variant, &(*p)->supportedVariants,
104             &(*p)->num_supportedVariants) || odr_ok(o)) &&
105         odr_implicit(o, z_InternationalString, &(*p)->message, ODR_CONTEXT,
106             6, 1) &&
107         odr_implicit(o, odr_octetstring, &(*p)->elementDescriptor, ODR_CONTEXT,
108             7, 1) &&
109         odr_implicit(o, z_TagPath, &(*p)->surrogateFor, ODR_CONTEXT, 8, 1) &&
110         odr_implicit(o, z_TagPath, &(*p)->surrogateElement, ODR_CONTEXT, 9, 1) &&
111         odr_implicit(o, z_External, &(*p)->other, ODR_CONTEXT, 99, 1) &&
112         odr_sequence_end(o);
113 }
114
115 int z_TagUnit(ODR o, Z_TagUnit **p, int opt)
116 {
117     if (!odr_sequence_begin(o, p, sizeof(**p)))
118         return opt && odr_ok(o);
119     return
120         odr_implicit(o, odr_integer, &(*p)->tagType, ODR_CONTEXT, 1, 1) &&
121         odr_explicit(o, z_StringOrNumeric, &(*p)->tagValue, ODR_CONTEXT, 2, 0) &&
122         odr_implicit(o, odr_integer, &(*p)->tagOccurrence, ODR_CONTEXT, 3, 1) &&
123         odr_sequence_end(o);
124 }
125
126 int z_TagPath(ODR o, Z_TagPath **p, int opt)
127 {
128     if (o->direction == ODR_DECODE)
129         *p = odr_malloc(o, sizeof(**p));
130     else if (!*p)
131         return opt;
132     if (odr_sequence_of(o, z_TagUnit, &(*p)->tags, &(*p)->num_tags))
133         return 1;
134     *p = 0;
135     return opt && odr_ok(o);
136 }
137
138 int z_Order(ODR o, Z_Order **p, int opt)
139 {
140     if (!odr_sequence_begin(o, p, sizeof(**p)))
141         return opt && odr_ok(o);
142     return
143         odr_implicit(o, odr_bool, &(*p)->ascending, ODR_CONTEXT, 1, 0) &&
144         odr_implicit(o, odr_integer, &(*p)->order, ODR_CONTEXT, 2, 0) &&
145         odr_sequence_end(o);
146 }
147
148 int z_Usage(ODR o, Z_Usage **p, int opt)
149 {
150     if (!odr_sequence_begin(o, p, sizeof(**p)))
151         return opt && odr_ok(o);
152     return
153         odr_implicit(o, odr_integer, &(*p)->type, ODR_CONTEXT, 1, 0) &&
154         odr_implicit(o, z_InternationalString, &(*p)->restriction, ODR_CONTEXT,
155             2, 1) &&
156         odr_sequence_end(o);
157 }
158
159 int z_HitVector(ODR o, Z_HitVector **p, int opt)
160 {
161     if (!odr_sequence_begin(o, p, sizeof(**p)))
162         return opt && odr_ok(o);
163     return
164         z_Term(o, &(*p)->satisfier, 1) &&
165         odr_implicit(o, z_IntUnit, &(*p)->offsetIntoElement, ODR_CONTEXT, 1, 1) &&
166         odr_implicit(o, z_IntUnit, &(*p)->length, ODR_CONTEXT, 2, 1) &&
167         odr_implicit(o, odr_integer, &(*p)->hitRank, ODR_CONTEXT, 3, 1) &&
168         odr_implicit(o, odr_octetstring, &(*p)->targetToken, ODR_CONTEXT,
169             4, 1) &&
170         odr_sequence_end(o);
171 }
172
173 int z_Triple(ODR o, Z_Triple **p, int opt)
174 {
175     static Odr_arm arm[] =
176     {
177         {ODR_NONE, -1, -1, Z_Triple_integer, odr_integer},
178         {ODR_NONE, -1, -1, Z_Triple_internationalString, z_InternationalString},
179         {ODR_NONE, -1, -1, Z_Triple_octetString, odr_octetstring},
180         {ODR_NONE, -1, -1, Z_Triple_oid, odr_oid},
181         {ODR_NONE, -1, -1, Z_Triple_boolean, odr_bool},
182         {ODR_NONE, -1, -1, Z_Triple_null, odr_null},
183         {ODR_IMPLICIT, ODR_CONTEXT, 1, Z_Triple_unit, z_Unit},
184         {ODR_IMPLICIT, ODR_CONTEXT, 2, Z_Triple_valueAndUnit, z_IntUnit},
185         {-1, -1, -1, -1, 0}
186     };
187
188     if (!odr_sequence_begin(o, p, sizeof(**p)))
189         return opt && odr_ok(o);
190     return
191         odr_implicit(o, odr_oid, &(*p)->variantSetId, ODR_CONTEXT, 0, 1) &&
192         odr_implicit(o, odr_integer, &(*p)->class, ODR_CONTEXT, 1, 0) &&
193         odr_implicit(o, odr_integer, &(*p)->type, ODR_CONTEXT, 2, 0) &&
194         odr_constructed_begin(o, &(*p)->value, ODR_CONTEXT, 3) &&
195         odr_choice(o, arm, &(*p)->value, &(*p)->which) &&
196         odr_constructed_end(o) &&
197         odr_sequence_end(o);
198 }
199
200 int z_Variant(ODR o, Z_Variant **p, int opt)
201 {
202     if (!odr_sequence_begin(o, p, sizeof(**p)))
203         return opt && odr_ok(o);
204     return
205         odr_implicit(o, odr_oid, &(*p)->globalVariantSetId, ODR_CONTEXT,
206             1, 1) &&
207         odr_implicit_settag(o, ODR_CONTEXT, 2) &&
208         odr_sequence_of(o, z_Triple, &(*p)->triples, &(*p)->num_triples) &&
209         odr_sequence_end(o);
210 }