]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/back-ldbm/close.c
Add a default case with assert() just in case.
[openldap] / servers / slapd / back-ldbm / close.c
index 310f441b5d1343b565bd84cdd5ff59ca7c570931..7a2a83e12119d8a3a71125c2d2db77aee3d92d7a 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"
 
 #include "slap.h"
 #include "back-ldbm.h"
 
-void
-ldbm_back_close( Backend *be )
+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(( "backend", LDAP_LEVEL_CRIT,
+                  "ldbm_back_db_close: ldbm backend syncing\n" ));
+#else
        Debug( LDAP_DEBUG_TRACE, "ldbm backend syncing\n", 0, 0, 0 );
+#endif
+
        ldbm_cache_flush_all( be );
+#ifdef NEW_LOGGING
+       LDAP_LOG(( "backend", LDAP_LEVEL_CRIT,
+                  "ldbm_back_db_close: ldbm backend synch'ed\n" ));
+#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;
 }