X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Foperational.c;h=3eca598b574101df9131aa395b7db14d3d1fdbf8;hb=0f17b4f852ce45f517ac86f6866ce39a62476fdb;hp=b9396b2473fd194affd1174765a1349981bedb1e;hpb=07ebdca237e239aeca47ff53b8f68d5f24ae4a7a;p=openldap diff --git a/servers/slapd/operational.c b/servers/slapd/operational.c index b9396b2473..3eca598b57 100644 --- a/servers/slapd/operational.c +++ b/servers/slapd/operational.c @@ -12,7 +12,6 @@ * helpers for on-the-fly operational attribute generation */ -#ifdef SLAPD_SCHEMA_DN Attribute * slap_operational_subschemaSubentry( Backend *be ) { @@ -34,20 +33,29 @@ slap_operational_subschemaSubentry( Backend *be ) return a; } -#endif /* SLAPD_SCHEMA_DN */ Attribute * slap_operational_hasSubordinate( int hs ) { Attribute *a; - + char *val; + ber_len_t len; + + if ( hs ) { + val = "TRUE"; + len = sizeof( "TRUE" ) - 1; + + } else { + val = "FALSE"; + len = sizeof( "FALSE" ) - 1; + + } + a = ch_malloc( sizeof( Attribute ) ); a->a_desc = slap_schema.si_ad_hasSubordinates; - a->a_vals = ch_malloc( 2 * sizeof( struct berval ) ); - ber_str2bv( hs ? "TRUE" : "FALSE", - hs ? sizeof("TRUE")-1 : sizeof("FALSE")-1, - 1, a->a_vals ); + + ber_str2bv( val, len, 1, a->a_vals ); a->a_vals[1].bv_val = NULL; a->a_next = NULL;