2 * $Id: cnid_close.c,v 1.23 2002-05-29 18:02:59 jmarcus Exp $
7 #endif /* HAVE_CONFIG_H */
12 #endif /* HAVE_UNISTD_H */
15 #endif /* HAVE_FCNTL_H */
17 #include <atalk/logger.h>
22 #include <atalk/cnid.h>
24 #include "cnid_private.h"
26 void cnid_close(void *CNID) {
34 /* Flush the transaction log and delete the log file if we can. */
35 if ((db->lockfd > -1) && ((db->flags & CNIDFLAG_DB_RO) == 0)) {
38 lock.l_type = F_WRLCK;
39 lock.l_whence = SEEK_SET;
40 lock.l_start = lock.l_len = 0;
41 if (fcntl(db->lockfd, F_SETLK, &lock) == 0) {
46 /* Checkpoint the databases until we can checkpoint no
48 rc = txn_checkpoint(db->dbenv, 0, 0, 0);
49 while (rc == DB_INCOMPLETE) {
50 rc = txn_checkpoint(db->dbenv, 0, 0, 0);
53 #if DB_VERSION_MINOR > 2
54 if ((rc = log_archive(db->dbenv, &list, DB_ARCH_ABS)) != 0) {
55 #else /* DB_VERSION_MINOR < 2 */
56 if ((rc = log_archive(db->dbenv, &list, DB_ARCH_ABS, NULL)) != 0) {
57 #endif /* DB_VERSION_MINOR */
58 LOG(log_error, logtype_default, "cnid_close: Unable to archive logfiles: %s", db_strerror(rc));
62 for (first = list; *list != NULL; ++list) {
63 if ((rc = remove(*list)) != 0) {
65 LOG(log_info, logtype_default, "cnid_close: failed to remove %s: %s", *list, strerror(rc));
72 (void)remove(db->lock_file);
75 db->db_didname->close(db->db_didname, 0);
76 db->db_devino->close(db->db_devino, 0);
77 db->db_cnid->close(db->db_cnid, 0);
79 db->db_mangle->close(db->db_mangle, 0);
80 #endif /* FILE_MANGLING */
81 db->dbenv->close(db->dbenv, 0);
83 if (db->lockfd > -1) {
84 close(db->lockfd); /* This will also release any locks we have. */