rework of slap_mods2entry dup

This commit is contained in:
Jong Hyuk Choi 2004-09-24 08:19:50 +00:00
parent c7d4f2841e
commit dda85fafe9

View File

@ -422,24 +422,32 @@ slap_mods2entry(
/* should check for duplicates */ /* should check for duplicates */
if ( dup ) {
for ( j = 0; mods->sml_values[j].bv_val; j++ ) {
ber_dupbv( &attr->a_vals[i+j], &mods->sml_values[j] );
}
BER_BVZERO( &attr->a_vals[i+j] );
} else {
AC_MEMCPY( &attr->a_vals[i], mods->sml_values, AC_MEMCPY( &attr->a_vals[i], mods->sml_values,
sizeof( struct berval ) * j ); sizeof( struct berval ) * j );
/* trim the mods array */
ch_free( mods->sml_values ); ch_free( mods->sml_values );
mods->sml_values = NULL; mods->sml_values = NULL;
}
if( mods->sml_nvalues ) { if( mods->sml_nvalues ) {
attr->a_nvals = ch_realloc( attr->a_nvals, attr->a_nvals = ch_realloc( attr->a_nvals,
sizeof( struct berval ) * (i+j) ); sizeof( struct berval ) * (i+j) );
if ( dup ) {
for ( j = 0; mods->sml_nvalues[j].bv_val; j++ ) {
ber_dupbv( &attr->a_nvals[i+j], &mods->sml_nvalues[j] );
}
BER_BVZERO( &attr->a_nvals[i+j] );
} else {
AC_MEMCPY( &attr->a_nvals[i], mods->sml_nvalues, AC_MEMCPY( &attr->a_nvals[i], mods->sml_nvalues,
sizeof( struct berval ) * j ); sizeof( struct berval ) * j );
/* trim the mods array */
ch_free( mods->sml_nvalues ); ch_free( mods->sml_nvalues );
mods->sml_nvalues = NULL; mods->sml_nvalues = NULL;
}
} else { } else {
attr->a_nvals = attr->a_vals; attr->a_nvals = attr->a_vals;
} }