Diff for /servers/slapd/filter.c between versions 1.72.2.9 and 1.72.2.10

version 1.72.2.9, 2003/02/09 16:31:36 version 1.72.2.10, 2003/03/12 20:58:48
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.89 2003/01/20 19:21:17 kurt Exp $ */  /* $OpenLDAP: pkg/ldap/servers/slapd/filter.c,v 1.72.2.9 2003/02/09 16:31:36 kurt Exp $ */
 /*  /*
  * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved.   * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved.
  * COPYING RESTRICTIONS APPLY, see COPYRIGHT file   * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
Line 602  filter2bv( Filter *f, struct berval *fst Line 602  filter2bv( Filter *f, struct berval *fst
   
                 fstr->bv_len = f->f_av_desc->ad_cname.bv_len +                  fstr->bv_len = f->f_av_desc->ad_cname.bv_len +
                         tmp.bv_len + ( sizeof("(=)") - 1 );                          tmp.bv_len + ( sizeof("(=)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=%s)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=%s)",
                         f->f_av_desc->ad_cname.bv_val,                          f->f_av_desc->ad_cname.bv_val,
Line 616  filter2bv( Filter *f, struct berval *fst Line 616  filter2bv( Filter *f, struct berval *fst
   
                 fstr->bv_len = f->f_av_desc->ad_cname.bv_len +                  fstr->bv_len = f->f_av_desc->ad_cname.bv_len +
                         tmp.bv_len + ( sizeof("(>=)") - 1 );                          tmp.bv_len + ( sizeof("(>=)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s>=%s)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s>=%s)",
                         f->f_av_desc->ad_cname.bv_val,                          f->f_av_desc->ad_cname.bv_val,
Line 630  filter2bv( Filter *f, struct berval *fst Line 630  filter2bv( Filter *f, struct berval *fst
   
                 fstr->bv_len = f->f_av_desc->ad_cname.bv_len +                  fstr->bv_len = f->f_av_desc->ad_cname.bv_len +
                         tmp.bv_len + ( sizeof("(<=)") - 1 );                          tmp.bv_len + ( sizeof("(<=)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s<=%s)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s<=%s)",
                         f->f_av_desc->ad_cname.bv_val,                          f->f_av_desc->ad_cname.bv_val,
Line 644  filter2bv( Filter *f, struct berval *fst Line 644  filter2bv( Filter *f, struct berval *fst
   
                 fstr->bv_len = f->f_av_desc->ad_cname.bv_len +                  fstr->bv_len = f->f_av_desc->ad_cname.bv_len +
                         tmp.bv_len + ( sizeof("(~=)") - 1 );                          tmp.bv_len + ( sizeof("(~=)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s~=%s)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s~=%s)",
                         f->f_av_desc->ad_cname.bv_val,                          f->f_av_desc->ad_cname.bv_val,
Line 655  filter2bv( Filter *f, struct berval *fst Line 655  filter2bv( Filter *f, struct berval *fst
         case LDAP_FILTER_SUBSTRINGS:          case LDAP_FILTER_SUBSTRINGS:
                 fstr->bv_len = f->f_sub_desc->ad_cname.bv_len +                  fstr->bv_len = f->f_sub_desc->ad_cname.bv_len +
                         ( sizeof("(=*)") - 1 );                          ( sizeof("(=*)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 128 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 128 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=*)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=*)",
                         f->f_sub_desc->ad_cname.bv_val );                          f->f_sub_desc->ad_cname.bv_val );
Line 710  filter2bv( Filter *f, struct berval *fst Line 710  filter2bv( Filter *f, struct berval *fst
         case LDAP_FILTER_PRESENT:          case LDAP_FILTER_PRESENT:
                 fstr->bv_len = f->f_desc->ad_cname.bv_len +                  fstr->bv_len = f->f_desc->ad_cname.bv_len +
                         ( sizeof("(=*)") - 1 );                          ( sizeof("(=*)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=*)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=*)",
                         f->f_desc->ad_cname.bv_val );                          f->f_desc->ad_cname.bv_val );
Line 720  filter2bv( Filter *f, struct berval *fst Line 720  filter2bv( Filter *f, struct berval *fst
         case LDAP_FILTER_OR:          case LDAP_FILTER_OR:
         case LDAP_FILTER_NOT:          case LDAP_FILTER_NOT:
                 fstr->bv_len = sizeof("(%)") - 1;                  fstr->bv_len = sizeof("(%)") - 1;
                 fstr->bv_val = malloc( fstr->bv_len + 128 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 128 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%c)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%c)",
                         f->f_choice == LDAP_FILTER_AND ? '&' :                          f->f_choice == LDAP_FILTER_AND ? '&' :
Line 757  filter2bv( Filter *f, struct berval *fst Line 757  filter2bv( Filter *f, struct berval *fst
                         ( f->f_mr_dnattrs ? sizeof(":dn")-1 : 0 ) +                          ( f->f_mr_dnattrs ? sizeof(":dn")-1 : 0 ) +
                         ( f->f_mr_rule_text.bv_len ? f->f_mr_rule_text.bv_len+1 : 0 ) +                          ( f->f_mr_rule_text.bv_len ? f->f_mr_rule_text.bv_len+1 : 0 ) +
                         tmp.bv_len + ( sizeof("(:=)") - 1 );                          tmp.bv_len + ( sizeof("(:=)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s%s%s%s:=%s)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s%s%s%s:=%s)",
                         ad.bv_val,                          ad.bv_val,
Line 1141  vrFilter2bv( ValuesReturnFilter *vrf, st Line 1141  vrFilter2bv( ValuesReturnFilter *vrf, st
         }          }
   
         fstr->bv_len = sizeof("()") - 1;          fstr->bv_len = sizeof("()") - 1;
         fstr->bv_val = malloc( fstr->bv_len + 128 );          fstr->bv_val = ch_malloc( fstr->bv_len + 128 );
   
         snprintf( fstr->bv_val, fstr->bv_len + 1, "()");          snprintf( fstr->bv_val, fstr->bv_len + 1, "()");
   
Line 1177  simple_vrFilter2bv( ValuesReturnFilter * Line 1177  simple_vrFilter2bv( ValuesReturnFilter *
   
                 fstr->bv_len = vrf->vrf_av_desc->ad_cname.bv_len +                  fstr->bv_len = vrf->vrf_av_desc->ad_cname.bv_len +
                         tmp.bv_len + ( sizeof("(=)") - 1 );                          tmp.bv_len + ( sizeof("(=)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=%s)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=%s)",
                         vrf->vrf_av_desc->ad_cname.bv_val,                          vrf->vrf_av_desc->ad_cname.bv_val,
Line 1191  simple_vrFilter2bv( ValuesReturnFilter * Line 1191  simple_vrFilter2bv( ValuesReturnFilter *
   
                 fstr->bv_len = vrf->vrf_av_desc->ad_cname.bv_len +                  fstr->bv_len = vrf->vrf_av_desc->ad_cname.bv_len +
                         tmp.bv_len + ( sizeof("(>=)") - 1 );                          tmp.bv_len + ( sizeof("(>=)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s>=%s)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s>=%s)",
                         vrf->vrf_av_desc->ad_cname.bv_val,                          vrf->vrf_av_desc->ad_cname.bv_val,
Line 1205  simple_vrFilter2bv( ValuesReturnFilter * Line 1205  simple_vrFilter2bv( ValuesReturnFilter *
   
                 fstr->bv_len = vrf->vrf_av_desc->ad_cname.bv_len +                  fstr->bv_len = vrf->vrf_av_desc->ad_cname.bv_len +
                         tmp.bv_len + ( sizeof("(<=)") - 1 );                          tmp.bv_len + ( sizeof("(<=)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s<=%s)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s<=%s)",
                         vrf->vrf_av_desc->ad_cname.bv_val,                          vrf->vrf_av_desc->ad_cname.bv_val,
Line 1219  simple_vrFilter2bv( ValuesReturnFilter * Line 1219  simple_vrFilter2bv( ValuesReturnFilter *
   
                 fstr->bv_len = vrf->vrf_av_desc->ad_cname.bv_len +                  fstr->bv_len = vrf->vrf_av_desc->ad_cname.bv_len +
                         tmp.bv_len + ( sizeof("(~=)") - 1 );                          tmp.bv_len + ( sizeof("(~=)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s~=%s)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s~=%s)",
                         vrf->vrf_av_desc->ad_cname.bv_val,                          vrf->vrf_av_desc->ad_cname.bv_val,
Line 1230  simple_vrFilter2bv( ValuesReturnFilter * Line 1230  simple_vrFilter2bv( ValuesReturnFilter *
         case LDAP_FILTER_SUBSTRINGS:          case LDAP_FILTER_SUBSTRINGS:
                 fstr->bv_len = vrf->vrf_sub_desc->ad_cname.bv_len +                  fstr->bv_len = vrf->vrf_sub_desc->ad_cname.bv_len +
                         ( sizeof("(=*)") - 1 );                          ( sizeof("(=*)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 128 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 128 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=*)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=*)",
                         vrf->vrf_sub_desc->ad_cname.bv_val );                          vrf->vrf_sub_desc->ad_cname.bv_val );
Line 1286  simple_vrFilter2bv( ValuesReturnFilter * Line 1286  simple_vrFilter2bv( ValuesReturnFilter *
         case LDAP_FILTER_PRESENT:          case LDAP_FILTER_PRESENT:
                 fstr->bv_len = vrf->vrf_desc->ad_cname.bv_len +                  fstr->bv_len = vrf->vrf_desc->ad_cname.bv_len +
                         ( sizeof("(=*)") - 1 );                          ( sizeof("(=*)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=*)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s=*)",
                         vrf->vrf_desc->ad_cname.bv_val );                          vrf->vrf_desc->ad_cname.bv_val );
Line 1307  simple_vrFilter2bv( ValuesReturnFilter * Line 1307  simple_vrFilter2bv( ValuesReturnFilter *
                         ( vrf->vrf_mr_dnattrs ? sizeof(":dn")-1 : 0 ) +                          ( vrf->vrf_mr_dnattrs ? sizeof(":dn")-1 : 0 ) +
                         ( vrf->vrf_mr_rule_text.bv_len ? vrf->vrf_mr_rule_text.bv_len+1 : 0 ) +                          ( vrf->vrf_mr_rule_text.bv_len ? vrf->vrf_mr_rule_text.bv_len+1 : 0 ) +
                         tmp.bv_len + ( sizeof("(:=)") - 1 );                          tmp.bv_len + ( sizeof("(:=)") - 1 );
                 fstr->bv_val = malloc( fstr->bv_len + 1 );                  fstr->bv_val = ch_malloc( fstr->bv_len + 1 );
   
                 snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s%s%s%s:=%s)",                  snprintf( fstr->bv_val, fstr->bv_len + 1, "(%s%s%s%s:=%s)",
                         ad.bv_val,                          ad.bv_val,

Removed from v.1.72.2.9  
changed lines
  Added in v.1.72.2.10


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