X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=odr%2Fber_bool.c;fp=odr%2Fber_bool.c;h=233de651d3d72367a3b3806ccb197e4b13c99783;hb=aa82967af8f06004b567ad1ed40c67b056c44e7b;hp=6161b33b637b172792c31cc32475198d697b2a4d;hpb=f2944c80ada3871faf8ec49bcad1470e6add4bac;p=yaz-moved-to-github.git diff --git a/odr/ber_bool.c b/odr/ber_bool.c index 6161b33..233de65 100644 --- a/odr/ber_bool.c +++ b/odr/ber_bool.c @@ -4,7 +4,11 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: ber_bool.c,v $ - * Revision 1.4 1995-03-21 10:17:27 quinn + * Revision 1.5 1995-04-18 08:15:14 quinn + * Added dynamic memory allocation on encoding (whew). Code is now somewhat + * neater. We'll make the same change for decoding one day. + * + * Revision 1.4 1995/03/21 10:17:27 quinn * Fixed little bug in decoder. * * Revision 1.3 1995/03/08 12:12:06 quinn @@ -29,23 +33,13 @@ int ber_boolean(ODR o, int *val) switch (o->direction) { case ODR_ENCODE: - if (!o->left) - { - o->error = OSPACE; - return 0; - } - if (ber_enclen(o->bp, 1, 1, 1) != 1) - { - o->error = OOTHER; - return 0; - } - o->bp++; - o->left--; - *(o->bp++) = (unsigned char) *val; + if (ber_enclen(o, 1, 1, 1) != 1) + return 0; + if (odr_putc(o, *val) < 0) + return 0; #ifdef ODR_DEBUG fprintf(stderr, "[val=%d]\n", *val); #endif - o->left--; return 1; case ODR_DECODE: if ((res = ber_declen(o->bp, &len)) < 0)