]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/back-ldbm/close.c
zap charray
[openldap] / servers / slapd / back-ldbm / close.c
index 5cb9a75b1cc99710160b8a6017812bba5c0b0543..383817a5d9baf36b9c4f7cb4ba5699c069b00191 100644 (file)
@@ -1,4 +1,9 @@
 /* close.c - close ldbm backend */
+/* $OpenLDAP$ */
+/*
+ * Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved.
+ * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
+ */
 
 #include "portable.h"
 
 int
 ldbm_back_db_close( Backend *be )
 {
-       Debug( LDAP_DEBUG_TRACE, "ldbm backend saving nextid\n", 0, 0, 0 );
-       if ( next_id_save( be ) < 0 ) {
-               Debug( LDAP_DEBUG_ANY, "ldbm backend nextid save failed!\n", 0, 0, 0 );
+       struct ldbminfo *li = (struct ldbminfo *) be->be_private;
+       if ( li->li_dbsyncfreq > 0 )
+       {
+               li->li_dbshutdown++;
+               ldap_pvt_thread_join( li->li_dbsynctid, (void *) NULL );
        }
-
+#ifdef NEW_LOGGING
+       LDAP_LOG( BACK_LDBM, CRIT,
+                  "ldbm_back_db_close: ldbm backend syncing\n", 0, 0, 0 );
+#else
        Debug( LDAP_DEBUG_TRACE, "ldbm backend syncing\n", 0, 0, 0 );
+#endif
+
        ldbm_cache_flush_all( be );
+#ifdef NEW_LOGGING
+       LDAP_LOG( BACK_LDBM, CRIT,
+                  "ldbm_back_db_close: ldbm backend synch'ed\n", 0, 0, 0 );
+#else
        Debug( LDAP_DEBUG_TRACE, "ldbm backend done syncing\n", 0, 0, 0 );
+#endif
+
+
+       cache_release_all( &((struct ldbminfo *) be->be_private)->li_cache );
 
        return 0;
 }