X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Foperational.c;h=cbc149421c459d840bbd6f2afd279b4738c28854;hb=f1ffe0076f6662543988fcced94f5ecba904ae7d;hp=f938076f0c5f3de69abb341473209ade25cc4168;hpb=dc0eacd40b625258355eea866d62188e5aa7ce3b;p=openldap diff --git a/servers/slapd/operational.c b/servers/slapd/operational.c index f938076f0c..cbc149421c 100644 --- a/servers/slapd/operational.c +++ b/servers/slapd/operational.c @@ -27,7 +27,7 @@ slap_operational_subschemaSubentry( Backend *be ) Attribute *a; /* The backend wants to take care of it */ - if ( be && be!= frontendDB && be->be_schemadn.bv_val ) return NULL; + if ( be && !SLAP_FRONTEND(be) && be->be_schemadn.bv_val ) return NULL; a = ch_malloc( sizeof( Attribute ) ); a->a_desc = slap_schema.si_ad_subschemaSubentry; @@ -53,18 +53,20 @@ slap_operational_entryDN( Entry *e ) { Attribute *a; + assert( e != NULL ); + assert( !BER_BVISNULL( &e->e_name ) ); + assert( !BER_BVISNULL( &e->e_nname ) ); + a = ch_malloc( sizeof( Attribute ) ); a->a_desc = slap_schema.si_ad_entryDN; a->a_vals = ch_malloc( 2 * sizeof( struct berval ) ); - ber_dupbv( a->a_vals, &e->e_name ); - a->a_vals[1].bv_len = 0; - a->a_vals[1].bv_val = NULL; + ber_dupbv( &a->a_vals[ 0 ], &e->e_name ); + BER_BVZERO( &a->a_vals[ 1 ] ); a->a_nvals = ch_malloc( 2 * sizeof( struct berval ) ); - ber_dupbv( a->a_nvals, &e->e_nname ); - a->a_nvals[1].bv_len = 0; - a->a_nvals[1].bv_val = NULL; + ber_dupbv( &a->a_nvals[ 0 ], &e->e_nname ); + BER_BVZERO( &a->a_nvals[ 1 ] ); a->a_next = NULL; a->a_flags = 0;