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