X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fslapschema.c;h=7e9903e9bbdba4d4b6439d0482857164a73f72f3;hb=4f05d992f2146921dbc13d3477de9918f20172b9;hp=6a00be85c7e0f5e66660b47a4ecd3964e8a41a50;hpb=57e68fa5b3bd7d10f6e56eda8f0320e5b82f6117;p=openldap diff --git a/servers/slapd/slapschema.c b/servers/slapd/slapschema.c index 6a00be85c7..7e9903e9bb 100644 --- a/servers/slapd/slapschema.c +++ b/servers/slapd/slapschema.c @@ -1,7 +1,7 @@ /* $OpenLDAP$ */ /* This work is part of OpenLDAP Software . * - * Copyright 1998-2009 The OpenLDAP Foundation. + * Copyright 1998-2014 The OpenLDAP Foundation. * Portions Copyright 1998-2003 Kurt D. Zeilenga. * Portions Copyright 2003 IBM Corporation. * All rights reserved. @@ -49,9 +49,14 @@ slapschema( int argc, char **argv ) Connection conn = { 0 }; OperationBuffer opbuf; Operation *op = NULL; + void *thrctx; + int requestBSF = 0; + int doBSF = 0; slap_tool_init( progname, SLAPCAT, argc, argv ); + requestBSF = ( sub_ndn.bv_len || filter ); + #ifdef SIGPIPE (void) SIGNAL( SIGPIPE, slapcat_sig ); #endif @@ -63,7 +68,7 @@ slapschema( int argc, char **argv ) if( !be->be_entry_open || !be->be_entry_close || - !be->be_entry_first || + !( be->be_entry_first || be->be_entry_first_x ) || !be->be_entry_next || !be->be_entry_get ) { @@ -78,15 +83,29 @@ slapschema( int argc, char **argv ) exit( EXIT_FAILURE ); } - connection_fake_init( &conn, &opbuf, &conn ); + thrctx = ldap_pvt_thread_pool_context(); + connection_fake_init( &conn, &opbuf, thrctx ); op = &opbuf.ob_op; op->o_tmpmemctx = NULL; op->o_bd = be; - for ( id = be->be_entry_first( be ); - id != NOID; - id = be->be_entry_next( be ) ) - { + + if ( !requestBSF && be->be_entry_first ) { + id = be->be_entry_first( be ); + + } else { + if ( be->be_entry_first_x ) { + id = be->be_entry_first_x( be, + sub_ndn.bv_len ? &sub_ndn : NULL, scope, filter ); + + } else { + assert( be->be_entry_first != NULL ); + doBSF = 1; + id = be->be_entry_first( be ); + } + } + + for ( ; id != NOID; id = be->be_entry_next( be ) ) { Entry* e; char textbuf[SLAP_TEXT_BUFLEN]; size_t textlen = sizeof(textbuf); @@ -103,17 +122,21 @@ slapschema( int argc, char **argv ) break; } - if( sub_ndn.bv_len && !dnIsSuffix( &e->e_nname, &sub_ndn ) ) { - be_entry_release_r( op, e ); - continue; - } - - if( filter != NULL ) { - int rc = test_filter( NULL, e, filter ); - if( rc != LDAP_COMPARE_TRUE ) { + if ( doBSF ) { + if ( sub_ndn.bv_len && !dnIsSuffixScope( &e->e_nname, &sub_ndn, scope ) ) + { be_entry_release_r( op, e ); continue; } + + + if ( filter != NULL ) { + int rc = test_filter( NULL, e, filter ); + if ( rc != LDAP_COMPARE_TRUE ) { + be_entry_release_r( op, e ); + continue; + } + } } if( verbose ) {