Diff for /servers/slapd/filter.c between versions 1.134.2.4 and 1.137

version 1.134.2.4, 2007/09/27 21:14:23 version 1.137, 2006/12/26 03:51:08
Line 1 Line 1
 /* filter.c - routines for parsing and dealing with filters */  /* filter.c - routines for parsing and dealing with filters */
 /* $OpenLDAP: pkg/ldap/servers/slapd/filter.c,v 1.134.2.3 2007/08/31 23:13:59 quanah Exp $ */  /* $OpenLDAP: pkg/ldap/servers/slapd/filter.c,v 1.136 2006/12/25 22:30:45 hyc Exp $ */
 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.  /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
  *   *
  * Copyright 1998-2007 The OpenLDAP Foundation.   * Copyright 1998-2006 The OpenLDAP Foundation.
  * All rights reserved.   * All rights reserved.
  *   *
  * Redistribution and use in source and binary forms, with or without   * Redistribution and use in source and binary forms, with or without
Line 33 Line 33
   
 #include "slap.h"  #include "slap.h"
   
 const Filter *slap_filter_objectClass_pres;  
 const struct berval *slap_filterstr_objectClass_pres;  
   
 static int      get_filter_list(  static int      get_filter_list(
         Operation *op,          Operation *op,
         BerElement *ber,          BerElement *ber,
Line 60  static int get_simple_vrFilter( Line 57  static int get_simple_vrFilter(
         const char **text );          const char **text );
   
 int  int
 filter_init( void )  
 {  
         static Filter filter_objectClass_pres = { LDAP_FILTER_PRESENT };  
         static struct berval filterstr_objectClass_pres = BER_BVC("(objectClass=*)");  
   
         filter_objectClass_pres.f_desc = slap_schema.si_ad_objectClass;  
   
         slap_filter_objectClass_pres = &filter_objectClass_pres;  
         slap_filterstr_objectClass_pres = &filterstr_objectClass_pres;  
   
         return 0;  
 }  
   
 void  
 filter_destroy( void )  
 {  
         return;  
 }  
   
 int  
 get_filter(  get_filter(
         Operation *op,          Operation *op,
         BerElement *ber,          BerElement *ber,
Line 641  simple: Line 618  simple:
                         len = fstr->bv_len;                          len = fstr->bv_len;
   
                         filter_escape_value_x( &f->f_sub_initial, &tmp, op->o_tmpmemctx );                          filter_escape_value_x( &f->f_sub_initial, &tmp, op->o_tmpmemctx );
                         tmplen = tmp.bv_len;                          tmplen = tmp.bv_len ? tmp.bv_len : STRLENOF( "(null)" );
   
                         fstr->bv_len += tmplen;                          fstr->bv_len += tmplen;
                         fstr->bv_val = op->o_tmprealloc( fstr->bv_val,                          fstr->bv_val = op->o_tmprealloc( fstr->bv_val,
                                 fstr->bv_len + 1, op->o_tmpmemctx );                                  fstr->bv_len + 1, op->o_tmpmemctx );
   
                         snprintf( &fstr->bv_val[len - 2],                          snprintf( &fstr->bv_val[len-2],
                                 tmplen + STRLENOF( /*(*/ "*)" ) + 1,                                  tmplen + STRLENOF( /*(*/ "*)" ) + 1,
                                 /* "(attr=" */ "%s*)",                                  /* "(attr=" */ "%s*)",
                                 tmp.bv_len ? tmp.bv_val : "");                                  tmp.bv_len ? tmp.bv_val : "(null)");
   
                         ber_memfree_x( tmp.bv_val, op->o_tmpmemctx );                          ber_memfree_x( tmp.bv_val, op->o_tmpmemctx );
                 }                  }
Line 662  simple: Line 639  simple:
                                 len = fstr->bv_len;                                  len = fstr->bv_len;
                                 filter_escape_value_x( &f->f_sub_any[i],                                  filter_escape_value_x( &f->f_sub_any[i],
                                         &tmp, op->o_tmpmemctx );                                          &tmp, op->o_tmpmemctx );
                                 tmplen = tmp.bv_len;                                  tmplen = tmp.bv_len ? tmp.bv_len : STRLENOF( "(null)" );
   
                                 fstr->bv_len += tmplen + STRLENOF( /*(*/ ")" );                                  fstr->bv_len += tmplen + STRLENOF( /*(*/ ")" );
                                 fstr->bv_val = op->o_tmprealloc( fstr->bv_val,                                  fstr->bv_val = op->o_tmprealloc( fstr->bv_val,
                                         fstr->bv_len + 1, op->o_tmpmemctx );                                          fstr->bv_len + 1, op->o_tmpmemctx );
   
                                 snprintf( &fstr->bv_val[len - 1],                                  snprintf( &fstr->bv_val[len-1],
                                         tmplen + STRLENOF( /*(*/ "*)" ) + 1,                                          tmplen + STRLENOF( /*(*/ "*)" ) + 1,
                                         /* "(attr=[init]*[any*]" */ "%s*)",                                          /* "(attr=[init]*[any*]" */ "%s*)",
                                         tmp.bv_len ? tmp.bv_val : "");                                          tmp.bv_len ? tmp.bv_val : "(null)");
                                 ber_memfree_x( tmp.bv_val, op->o_tmpmemctx );                                  ber_memfree_x( tmp.bv_val, op->o_tmpmemctx );
                         }                          }
                 }                  }
Line 682  simple: Line 659  simple:
                         len = fstr->bv_len;                          len = fstr->bv_len;
   
                         filter_escape_value_x( &f->f_sub_final, &tmp, op->o_tmpmemctx );                          filter_escape_value_x( &f->f_sub_final, &tmp, op->o_tmpmemctx );
                         tmplen = tmp.bv_len;                          tmplen = tmp.bv_len ? tmp.bv_len : STRLENOF( "(null)" );
   
                         fstr->bv_len += tmplen;                          fstr->bv_len += tmplen;
                         fstr->bv_val = op->o_tmprealloc( fstr->bv_val,                          fstr->bv_val = op->o_tmprealloc( fstr->bv_val,
                                 fstr->bv_len + 1, op->o_tmpmemctx );                                  fstr->bv_len + 1, op->o_tmpmemctx );
   
                         snprintf( &fstr->bv_val[len - 1],                          snprintf( &fstr->bv_val[len-1],
                                 tmplen + STRLENOF( /*(*/ ")" ) + 1,                                  tmplen + STRLENOF( /*(*/ ")" ) + 1,
                                 /* "(attr=[init*][any*]" */ "%s)",                                  /* "(attr=[init*][any*]" */ "%s)",
                                 tmp.bv_len ? tmp.bv_val : "");                                  tmp.bv_len ? tmp.bv_val : "(null)");
   
                         ber_memfree_x( tmp.bv_val, op->o_tmpmemctx );                          ber_memfree_x( tmp.bv_val, op->o_tmpmemctx );
                 }                  }
Line 1024  get_simple_vrFilter( Line 1001  get_simple_vrFilter(
         }          }
   
         if ( err == LDAP_SUCCESS ) {          if ( err == LDAP_SUCCESS ) {
                 *filt = op->o_tmpalloc( sizeof vrf, op->o_tmpmemctx );                  *filt = ch_malloc( sizeof vrf );
                 **filt = vrf;                  **filt = vrf;
         }          }
   
Line 1193  simple_vrFilter2bv( Operation *op, Value Line 1170  simple_vrFilter2bv( Operation *op, Value
 {  {
         struct berval tmp;          struct berval tmp;
         ber_len_t len;          ber_len_t len;
         int undef;  
   
         if ( vrf == NULL ) {          if ( vrf == NULL ) {
                 ber_str2bv_x( "No filter!", STRLENOF("No filter!"), 1, fstr,                  ber_str2bv_x( "No filter!", STRLENOF("No filter!"), 1, fstr,
                         op->o_tmpmemctx );                          op->o_tmpmemctx );
                 return;                  return;
         }          }
         undef = vrf->vrf_choice & SLAPD_FILTER_UNDEFINED;          int undef = vrf->vrf_choice & SLAPD_FILTER_UNDEFINED;
   
         switch ( vrf->vrf_choice & SLAPD_FILTER_MASK ) {          switch ( vrf->vrf_choice & SLAPD_FILTER_MASK ) {
         case LDAP_FILTER_EQUALITY:          case LDAP_FILTER_EQUALITY:

Removed from v.1.134.2.4  
changed lines
  Added in v.1.137


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