New nmem utility, nmem_transfer, that transfer blocks from one
[yaz-moved-to-github.git] / odr / ber_bit.c
index ce8e21a..6f9dcdc 100644 (file)
@@ -1,10 +1,29 @@
 /*
- * Copyright (C) 1994, Index Data I/S 
- * All rights reserved.
+ * Copyright (c) 1995, Index Data
+ * See the file LICENSE for details.
  * Sebastian Hammer, Adam Dickmeiss
  *
  * $Log: ber_bit.c,v $
- * Revision 1.1  1995-02-02 20:38:49  quinn
+ * Revision 1.7  1995-09-29 17:12:16  quinn
+ * Smallish
+ *
+ * Revision 1.6  1995/09/27  15:02:54  quinn
+ * Modified function heads & prototypes.
+ *
+ * Revision 1.5  1995/05/16  08:50:43  quinn
+ * License, documentation, and memory fixes
+ *
+ * Revision 1.4  1995/04/18  08:15:13  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:04  quinn
+ * Added better error checking.
+ *
+ * Revision 1.2  1995/02/03  17:04:31  quinn
+ * *** empty log message ***
+ *
+ * Revision 1.1  1995/02/02  20:38:49  quinn
  * Updates.
  *
  *
@@ -12,7 +31,7 @@
 
 #include <odr.h>
 
-int ber_bitstring(ODR o, ODR_BITMASK *p, int cons)
+int ber_bitstring(ODR o, Odr_bitmask *p, int cons)
 {
     int res, len;
     unsigned char *base;
@@ -21,7 +40,10 @@ int ber_bitstring(ODR o, ODR_BITMASK *p, int cons)
     {
        case ODR_DECODE:
            if ((res = ber_declen(o->bp, &len)) < 0)
+           {
+               o->error = OPROTO;
                return 0;
+           }
            o->bp += res;
            o->left -= res;
            if (cons)       /* fetch component strings */
@@ -34,11 +56,17 @@ int ber_bitstring(ODR o, ODR_BITMASK *p, int cons)
            }
            /* primitive bitstring */
            if (len < 0)
+           {
+               o->error = OOTHER;
                return 0;
+           }
            if (len == 0)
                return 1;
            if (len - 1 > ODR_BITMASK_SIZE)
+           {
+               o->error = OOTHER;
                return 0;
+           }
            o->bp++;      /* silently ignore the unused-bits field */
            o->left--;
            len--;
@@ -48,21 +76,16 @@ int ber_bitstring(ODR o, ODR_BITMASK *p, int cons)
            o->left -= len;
            return 1;
        case ODR_ENCODE:
-           if ((res = ber_enclen(o->bp, p->top + 2, 5, 0)) < 0)
+           if ((res = ber_enclen(o, p->top + 2, 5, 0)) < 0)
                return 0;
-           o->bp += res;
-           o->left -= res;
-           if (p->top + 2 > o->left)
+           if (odr_putc(o, 0) < 0)    /* no unused bits here */
                return 0;
-           *(o->bp++) = 0;    /* no unused bits here */
-           o->left--;
            if (p->top < 0)
                return 1;
-           memcpy(o->bp, p->bits, p->top + 1);
-           o->bp += p->top + 1;
-           o->left -= p->top +1;
+           if (odr_write(o, p->bits, p->top + 1) < 0)
+               return 0;
            return 1;
        case ODR_PRINT: return 1;
-       default: return 0;
+       default: o->error = OOTHER; return 0;
     }
 }