New nmem utility, nmem_transfer, that transfer blocks from one
[yaz-moved-to-github.git] / odr / odr_oct.c
1 /*
2  * Copyright (c) 1995, Index Data
3  * See the file LICENSE for details.
4  * Sebastian Hammer, Adam Dickmeiss
5  *
6  * $Log: odr_oct.c,v $
7  * Revision 1.12  1998-02-11 11:53:34  adam
8  * Changed code so that it compiles as C++.
9  *
10  * Revision 1.11  1995/09/29 17:12:25  quinn
11  * Smallish
12  *
13  * Revision 1.10  1995/09/27  15:02:59  quinn
14  * Modified function heads & prototypes.
15  *
16  * Revision 1.9  1995/05/16  08:50:56  quinn
17  * License, documentation, and memory fixes
18  *
19  * Revision 1.8  1995/03/17  10:17:54  quinn
20  * Added memory management.
21  *
22  * Revision 1.7  1995/03/08  12:12:27  quinn
23  * Added better error checking.
24  *
25  * Revision 1.6  1995/02/10  18:57:26  quinn
26  * More in the way of error-checking.
27  *
28  * Revision 1.5  1995/02/09  15:51:49  quinn
29  * Works better now.
30  *
31  * Revision 1.4  1995/02/07  14:13:46  quinn
32  * Bug fixes.
33  *
34  * Revision 1.3  1995/02/03  17:04:38  quinn
35  * *** empty log message ***
36  *
37  * Revision 1.2  1995/02/02  20:38:51  quinn
38  * Updates.
39  *
40  * Revision 1.1  1995/02/02  16:21:54  quinn
41  * First kick.
42  *
43  */
44
45 #include <odr.h>
46
47 /*
48  * Top level octet string en/decoder.
49  * Returns 1 on success, 0 on error.
50  */
51 int odr_octetstring(ODR o, Odr_oct **p, int opt)
52 {
53     int res, cons = 0;
54
55     if (o->error)
56         return 0;
57     if (o->t_class < 0)
58     {
59         o->t_class = ODR_UNIVERSAL;
60         o->t_tag = ODR_OCTETSTRING;
61     }
62     if ((res = ber_tag(o, p, o->t_class, o->t_tag, &cons, opt)) < 0)
63         return 0;
64     if (!res)
65         return opt;
66     if (o->direction == ODR_PRINT)
67     {
68         fprintf(o->print, "%sOCTETSTRING(len=%d)\n", odr_indent(o), (*p)->len);
69         return 1;
70     }
71     if (o->direction == ODR_DECODE)
72     {
73         *p = (Odr_oct *)odr_malloc(o, sizeof(Odr_oct));
74         (*p)->size= 0;
75         (*p)->len = 0;
76         (*p)->buf = 0;
77     }
78     if (ber_octetstring(o, *p, cons))
79         return 1;
80     o->error = OOTHER;
81     return 0;
82 }
83
84 /*
85  * Friendlier interface to octetstring.
86  */
87 int odr_cstring(ODR o, char **p, int opt)
88 {
89     int cons = 0, res;
90     Odr_oct *t;
91
92     if (o->error)
93         return 0;
94     if (o->t_class < 0)
95     {
96         o->t_class = ODR_UNIVERSAL;
97         o->t_tag = ODR_OCTETSTRING;
98     }
99     if ((res = ber_tag(o, p, o->t_class, o->t_tag, &cons, opt)) < 0)
100         return 0;
101     if (!res)
102         return opt;
103     if (o->direction == ODR_PRINT)
104     {
105         fprintf(o->print, "%s'%s'\n", odr_indent(o), *p);
106         return 1;
107     }
108     t = (Odr_oct *)odr_malloc(o, sizeof(Odr_oct));   /* wrapper for octstring */
109     if (o->direction == ODR_ENCODE)
110     {
111         t->buf = (unsigned char *) *p;
112         t->size = t->len = strlen(*p);
113     }
114     else
115     {
116         t->size= 0;
117         t->len = 0;
118         t->buf = 0;
119     }
120     if (!ber_octetstring(o, t, cons))
121         return 0;
122     if (o->direction == ODR_DECODE)
123     {
124         *p = (char *) t->buf;
125         *(*p + t->len) = '\0';  /* ber_octs reserves space for this */
126     }
127     return 1;
128 }