X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=odr%2Fber_null.c;h=3b84a1dbd3a3808857f26d6de17dd704900b513c;hb=0442642bb213139271943552e5c1bc731ee96872;hp=ef5871e56b0098c3a3e4de44b3b4b00c3e294e8b;hpb=d9ee01635f03f9095a66f71b73580560d48798e8;p=yaz-moved-to-github.git diff --git a/odr/ber_null.c b/odr/ber_null.c index ef5871e..3b84a1d 100644 --- a/odr/ber_null.c +++ b/odr/ber_null.c @@ -1,40 +1,15 @@ /* - * Copyright (c) 1995, Index Data + * Copyright (c) 1995-2003, Index Data * See the file LICENSE for details. * Sebastian Hammer, Adam Dickmeiss * - * $Log: ber_null.c,v $ - * Revision 1.9 1999-11-30 13:47:11 adam - * Improved installation. Moved header files to include/yaz. - * - * Revision 1.8 1995/09/29 17:12:18 quinn - * Smallish - * - * Revision 1.7 1995/09/27 15:02:55 quinn - * Modified function heads & prototypes. - * - * Revision 1.6 1995/05/22 11:32:01 quinn - * Fixing Interface to odr_null. - * - * Revision 1.5 1995/05/16 08:50:46 quinn - * License, documentation, and memory fixes - * - * Revision 1.4 1995/04/18 08:15:16 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.3 1995/03/08 12:12:09 quinn - * Added better error checking. - * - * Revision 1.2 1995/02/09 15:51:46 quinn - * Works better now. - * - * Revision 1.1 1995/02/02 16:21:52 quinn - * First kick. - * + * $Id: ber_null.c,v 1.14 2003-03-11 11:03:31 adam Exp $ */ +#if HAVE_CONFIG_H +#include +#endif -#include +#include "odr-priv.h" /* * BER-en/decoder for NULL type. @@ -43,25 +18,29 @@ int ber_null(ODR o) { switch (o->direction) { - case ODR_ENCODE: - if (odr_putc(o, 0X00) < 0) - return 0; + case ODR_ENCODE: + if (odr_putc(o, 0X00) < 0) + return 0; #ifdef ODR_DEBUG - fprintf(stderr, "[NULL]\n"); + fprintf(stderr, "[NULL]\n"); #endif - return 1; - case ODR_DECODE: - if (*(o->bp++) != 0X00) - { - o->error = OPROTO; - return 0; - } - o->left--; + return 1; + case ODR_DECODE: + if (odr_max(o) < 1) + { + odr_seterror(o, OPROTO, 39); + return 0; + } + if (*(o->bp++) != 0X00) + { + odr_seterror(o, OPROTO, 12); + return 0; + } #ifdef ODR_DEBUG - fprintf(stderr, "[NULL]\n"); + fprintf(stderr, "[NULL]\n"); #endif - return 1; - case ODR_PRINT: return 1; - default: o->error = OOTHER; return 0; + return 1; + case ODR_PRINT: return 1; + default: odr_seterror(o, OOTHER, 13); return 0; } }