X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=odr%2Fber_oct.c;h=e2ba4327329c2361a1f80c7adcdcec1c08e80e69;hb=a1ac953ad3b1f310deec59e44119b52fc1325547;hp=91c0e9d767cde3f5b8912b62eed8c9985109ff2f;hpb=d9ee01635f03f9095a66f71b73580560d48798e8;p=yaz-moved-to-github.git diff --git a/odr/ber_oct.c b/odr/ber_oct.c index 91c0e9d..e2ba432 100644 --- a/odr/ber_oct.c +++ b/odr/ber_oct.c @@ -1,56 +1,15 @@ /* - * Copyright (c) 1995-1999, Index Data + * Copyright (c) 1995-2003, Index Data * See the file LICENSE for details. * Sebastian Hammer, Adam Dickmeiss * - * $Log: ber_oct.c,v $ - * Revision 1.14 1999-11-30 13:47:11 adam - * Improved installation. Moved header files to include/yaz. - * - * Revision 1.13 1999/04/20 09:56:48 adam - * Added 'name' paramter to encoder/decoder routines (typedef Odr_fun). - * Modified all encoders/decoders to reflect this change. - * - * Revision 1.12 1999/01/08 11:23:24 adam - * Added const modifier to some of the BER/ODR encoding routines. - * - * Revision 1.11 1998/02/11 11:53:34 adam - * Changed code so that it compiles as C++. - * - * Revision 1.10 1995/09/29 17:12:18 quinn - * Smallish - * - * Revision 1.9 1995/09/27 15:02:55 quinn - * Modified function heads & prototypes. - * - * Revision 1.8 1995/05/16 08:50:47 quinn - * License, documentation, and memory fixes - * - * Revision 1.7 1995/04/18 08:15:17 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.6 1995/03/17 10:17:41 quinn - * Added memory management. - * - * Revision 1.5 1995/03/08 12:12:10 quinn - * Added better error checking. - * - * Revision 1.4 1995/02/10 15:55:28 quinn - * Bug fixes, mostly. - * - * Revision 1.3 1995/02/03 17:04:34 quinn - * *** empty log message *** - * - * Revision 1.2 1995/02/02 20:38:50 quinn - * Updates. - * - * Revision 1.1 1995/02/02 16:21:52 quinn - * First kick. - * + * $Id: ber_oct.c,v 1.20 2003-01-06 08:20:27 adam Exp $ */ +#if HAVE_CONFIG_H +#include +#endif -#include +#include "odr-priv.h" int ber_octetstring(ODR o, Odr_oct *p, int cons) { @@ -67,7 +26,6 @@ int ber_octetstring(ODR o, Odr_oct *p, int cons) return 0; } o->bp += res; - o->left -= res; if (cons) /* fetch component strings */ { base = o->bp; @@ -93,7 +51,10 @@ int ber_octetstring(ODR o, Odr_oct *p, int cons) memcpy(p->buf + p->len, o->bp, len); p->len += len; o->bp += len; - o->left -= len; + /* the final null is really not part of the buffer, but */ + /* it helps somes applications that assumes C strings */ + if (len) + p->buf[p->len] = '\0'; return 1; case ODR_ENCODE: if ((res = ber_enclen(o, p->len, 5, 0)) < 0)