mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-12-26 01:29:59 -05:00
improve previous commit
This commit is contained in:
parent
ae20e41b70
commit
829685e218
1 changed files with 13 additions and 49 deletions
|
|
@ -307,6 +307,11 @@ attr_merge(
|
|||
return rc;
|
||||
}
|
||||
|
||||
/*
|
||||
* if a normalization function is defined for the equality matchingRule
|
||||
* of desc, the value is normalized and stored in nval; otherwise nval
|
||||
* is NULL
|
||||
*/
|
||||
int
|
||||
attr_normalize(
|
||||
AttributeDescription *desc,
|
||||
|
|
@ -361,41 +366,12 @@ attr_merge_normalize(
|
|||
BerVarray nvals = NULL;
|
||||
int rc;
|
||||
|
||||
#if 0
|
||||
if ( desc->ad_type->sat_equality &&
|
||||
desc->ad_type->sat_equality->smr_normalize )
|
||||
{
|
||||
int i;
|
||||
|
||||
for ( i = 0; !BER_BVISNULL( &vals[i] ); i++ );
|
||||
|
||||
nvals = slap_sl_calloc( sizeof(struct berval), i + 1, memctx );
|
||||
for ( i = 0; !BER_BVISNULL( &vals[i] ); i++ ) {
|
||||
rc = (*desc->ad_type->sat_equality->smr_normalize)(
|
||||
SLAP_MR_VALUE_OF_ATTRIBUTE_SYNTAX,
|
||||
desc->ad_type->sat_syntax,
|
||||
desc->ad_type->sat_equality,
|
||||
&vals[i], &nvals[i], memctx );
|
||||
|
||||
if ( rc != LDAP_SUCCESS ) {
|
||||
BER_BVZERO( &nvals[i + 1] );
|
||||
goto error_return;
|
||||
}
|
||||
}
|
||||
BER_BVZERO( &nvals[i] );
|
||||
}
|
||||
#endif
|
||||
|
||||
rc = attr_normalize( desc, vals, &nvals, memctx );
|
||||
if ( rc == LDAP_SUCCESS ) {
|
||||
rc = attr_merge( e, desc, vals, nvals );
|
||||
}
|
||||
|
||||
#if 0
|
||||
error_return:;
|
||||
#endif
|
||||
if ( nvals != NULL ) {
|
||||
ber_bvarray_free_x( nvals, memctx );
|
||||
if ( nvals != NULL ) {
|
||||
ber_bvarray_free_x( nvals, memctx );
|
||||
}
|
||||
}
|
||||
|
||||
return rc;
|
||||
|
|
@ -434,6 +410,11 @@ attr_merge_one(
|
|||
return rc;
|
||||
}
|
||||
|
||||
/*
|
||||
* if a normalization function is defined for the equality matchingRule
|
||||
* of desc, the value is normalized and stored in nval; otherwise nval
|
||||
* is NULL
|
||||
*/
|
||||
int
|
||||
attr_normalize_one(
|
||||
AttributeDescription *desc,
|
||||
|
|
@ -478,23 +459,6 @@ attr_merge_normalize_one(
|
|||
nvalp = &nval;
|
||||
}
|
||||
|
||||
#if 0
|
||||
if ( desc->ad_type->sat_equality &&
|
||||
desc->ad_type->sat_equality->smr_normalize )
|
||||
{
|
||||
rc = desc->ad_type->sat_equality->smr_normalize)
|
||||
SLAP_MR_VALUE_OF_ATTRIBUTE_SYNTAX,
|
||||
desc->ad_type->sat_syntax,
|
||||
desc->ad_type->sat_equality,
|
||||
val, &nval, memctx );
|
||||
|
||||
if ( rc != LDAP_SUCCESS ) {
|
||||
return rc;
|
||||
}
|
||||
nvalp = &nval;
|
||||
}
|
||||
#endif
|
||||
|
||||
rc = attr_merge_one( e, desc, val, nvalp );
|
||||
if ( nvalp != NULL ) {
|
||||
slap_sl_free( nval.bv_val, memctx );
|
||||
|
|
|
|||
Loading…
Reference in a new issue