Diff for /libraries/liblber/decode.c between versions 1.34.6.6 and 1.60

version 1.34.6.6, 2000/10/12 19:52:39 version 1.60, 2001/05/06 17:07:24
Line 1 Line 1
 /* decode.c - ber input decoding routines */  /* decode.c - ber input decoding routines */
 /* $OpenLDAP: pkg/ldap/libraries/liblber/decode.c,v 1.34.6.5 2000/10/02 17:26:31 kurt Exp $ */  /* $OpenLDAP: pkg/ldap/libraries/liblber/decode.c,v 1.59 2001/01/17 16:08:44 gwilliams Exp $ */
 /*  /*
  * Copyright 1998-2000 The OpenLDAP Foundation, All Rights Reserved.   * Copyright 1998-2000 The OpenLDAP Foundation, All Rights Reserved.
  * COPYING RESTRICTIONS APPLY, see COPYRIGHT file   * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
Line 109  ber_skip_tag( BerElement *ber, ber_len_t Line 109  ber_skip_tag( BerElement *ber, ber_len_t
   
         /*          /*
          * Next, read the length.  The first byte contains the length of           * Next, read the length.  The first byte contains the length of
          * the length.  If bit 8 is set, the length is the long form,           * the length.  If bit 8 is set, the length is the long form,
          * otherwise it's the short form.  We don't allow a length that's           * otherwise it's the short form.  We don't allow a length that's
          * greater than what we can hold in a ber_len_t.           * greater than what we can hold in a ber_len_t.
          */           */
Line 137  ber_skip_tag( BerElement *ber, ber_len_t Line 137  ber_skip_tag( BerElement *ber, ber_len_t
                 *len = lc;                  *len = lc;
         }          }
   
           /* BER element should have enough data left */
           if( *len > ber_pvt_ber_remaining( ber ) ) {
                   return LBER_DEFAULT;
           }
   
         return tag;          return tag;
 }  }
   
Line 252  ber_get_stringb( Line 257  ber_get_stringb(
         if ( (tag = ber_skip_tag( ber, &datalen )) == LBER_DEFAULT ) {          if ( (tag = ber_skip_tag( ber, &datalen )) == LBER_DEFAULT ) {
                 return LBER_DEFAULT;                  return LBER_DEFAULT;
         }          }
         if ( datalen > (*len - 1) ) {  
           /* must fit within allocated space with termination */
           if ( datalen >= *len ) {
                 return LBER_DEFAULT;                  return LBER_DEFAULT;
         }          }
   
Line 477  ber_scanf ( BerElement *ber, Line 484  ber_scanf ( BerElement *ber,
         LDAP_CONST char         *fmt_reset;          LDAP_CONST char         *fmt_reset;
         char            *last;          char            *last;
         char            *s, **ss, ***sss;          char            *s, **ss, ***sss;
         struct berval   ***bv, **bvp, *bval;          struct berval   ***bv, **bvp, *bval;
         ber_int_t       *i;          ber_int_t       *i;
         int j;          int j;
         ber_len_t       *l;          ber_len_t       *l;
Line 494  ber_scanf ( BerElement *ber, Line 501  ber_scanf ( BerElement *ber,
   
         fmt_reset = fmt;          fmt_reset = fmt;
   
   #ifdef NEW_LOGGING
           LDAP_LOG(( "liblber", LDAP_LEVEL_ENTRY, "ber_scanf fmt (%s) ber:\n", fmt ));
           BER_DUMP(( "liblber", LDAP_LEVEL_DETAIL2, ber, 1 ));
   #else
         ber_log_printf( LDAP_DEBUG_TRACE, ber->ber_debug,          ber_log_printf( LDAP_DEBUG_TRACE, ber->ber_debug,
                 "ber_scanf fmt (%s) ber:\n", fmt );                  "ber_scanf fmt (%s) ber:\n", fmt );
         ber_log_dump( LDAP_DEBUG_BER, ber->ber_debug, ber, 1 );          ber_log_dump( LDAP_DEBUG_BER, ber->ber_debug, ber, 1 );
   #endif
   
         for ( rc = 0; *fmt && rc != LBER_DEFAULT; fmt++ ) {          for ( rc = 0; *fmt && rc != LBER_DEFAULT; fmt++ ) {
                 /* When this is modified, remember to update                  /* When this is modified, remember to update
Line 624  ber_scanf ( BerElement *ber, Line 636  ber_scanf ( BerElement *ber,
   
                 default:                  default:
                         if( ber->ber_debug ) {                          if( ber->ber_debug ) {
   #ifdef NEW_LOGGING
                                   LDAP_LOG(( "liblber", LDAP_LEVEL_ERR,
                                              "ber_scanf: unknown fmt %c\n", *fmt ));
   #else
                                 ber_log_printf( LDAP_DEBUG_ANY, ber->ber_debug,                                  ber_log_printf( LDAP_DEBUG_ANY, ber->ber_debug,
                                         "ber_scanf: unknown fmt %c\n", *fmt );                                          "ber_scanf: unknown fmt %c\n", *fmt );
   #endif
                         }                          }
                         rc = LBER_DEFAULT;                          rc = LBER_DEFAULT;
                         break;                          break;
Line 710  ber_scanf ( BerElement *ber, Line 727  ber_scanf ( BerElement *ber,
                 case 'v':       /* sequence of strings */                  case 'v':       /* sequence of strings */
                         sss = va_arg( ap, char *** );                          sss = va_arg( ap, char *** );
                         if ( *sss ) {                          if ( *sss ) {
                                 for (j = 0;  (*sss)[j];  j++) {                                  for (j = 0;  (*sss)[j];  j++) {
                                         LBER_FREE( (*sss)[j] );                                          LBER_FREE( (*sss)[j] );
                                         (*sss)[j] = NULL;                                          (*sss)[j] = NULL;
                                 }                                  }

Removed from v.1.34.6.6  
changed lines
  Added in v.1.60


______________
© Copyright 1998-2020, OpenLDAP Foundation, info@OpenLDAP.org