X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=odr%2Fber_bool.c;h=20a8a35ca8917300f916ed0a2368a8c7141bd8e3;hp=d7f749e847d7a7a88dda06d5f0e3f46019595c55;hb=4d531a1a9131d69c3b6c27fbac42837e22cff61c;hpb=41f4b2c49b60cf5f9ae896b537211ae830c39a55 diff --git a/odr/ber_bool.c b/odr/ber_bool.c index d7f749e..20a8a35 100644 --- a/odr/ber_bool.c +++ b/odr/ber_bool.c @@ -1,72 +1,53 @@ /* - * Copyright (C) 1994, Index Data I/S - * All rights reserved. + * Copyright (c) 1995-2003, Index Data + * See the file LICENSE for details. * Sebastian Hammer, Adam Dickmeiss * - * $Log: ber_bool.c,v $ - * Revision 1.3 1995-03-08 12:12:06 quinn - * Added better error checking. - * - * Revision 1.2 1995/02/09 15:51:45 quinn - * Works better now. - * - * Revision 1.1 1995/02/02 16:21:51 quinn - * First kick. - * + * $Id: ber_bool.c,v 1.13 2003-01-06 08:20:27 adam Exp $ */ -#include -#include +#if HAVE_CONFIG_H +#include +#endif +#include +#include "odr-priv.h" int ber_boolean(ODR o, int *val) { - unsigned char *b = o->bp; int res, len; 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; + case ODR_ENCODE: + 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); + fprintf(stderr, "[val=%d]\n", *val); #endif - o->left--; - return 1; - case ODR_DECODE: - if ((res = ber_declen(b, &len)) < 0) - { - o->error = OPROTO; - return 0; - } - if (len != 1) - { - o->error = OPROTO; - return 0; - } - o->bp+= res; - o->left -= res; - *val = *b; - o->bp++; - o->left--; + return 1; + case ODR_DECODE: + if ((res = ber_declen(o->bp, &len)) < 0) + { + o->error = OPROTO; + return 0; + } + if (len != 1) + { + o->error = OPROTO; + return 0; + } + o->bp+= res; + *val = *o->bp; + o->bp++; #ifdef ODR_DEBUG - fprintf(stderr, "[val=%d]\n", *val); + fprintf(stderr, "[val=%d]\n", *val); #endif - return 1; - case ODR_PRINT: - return 1; - default: o->error = OOTHER; return 0; + return 1; + case ODR_PRINT: + return 1; + default: o->error = OOTHER; return 0; } }