From d822bf32e470e46a3634638fee3c4b1472d2cd26 Mon Sep 17 00:00:00 2001 From: Eelco Dolstra Date: Wed, 1 Mar 2006 16:36:35 +0000 Subject: [PATCH] * Close the database before the destructor runs. --- src/libmain/shared.cc | 3 +++ src/libstore/db.cc | 2 ++ src/libstore/store.cc | 7 +++++++ src/libstore/store.hh | 3 +++ 4 files changed, 15 insertions(+) diff --git a/src/libmain/shared.cc b/src/libmain/shared.cc index a832344c9..1e48a6365 100644 --- a/src/libmain/shared.cc +++ b/src/libmain/shared.cc @@ -14,6 +14,7 @@ extern "C" { #include "globals.hh" #include "gc.hh" +#include "store.hh" #include "shared.hh" #include "config.h" @@ -213,6 +214,8 @@ static void initAndRun(int argc, char * * argv) RemoveTempRoots removeTempRoots; /* unused variable - don't remove */ run(remaining); + + closeDB(); /* it's fine if the DB isn't actually open */ } diff --git a/src/libstore/db.cc b/src/libstore/db.cc index 448b70e6c..667951ae7 100644 --- a/src/libstore/db.cc +++ b/src/libstore/db.cc @@ -278,6 +278,8 @@ void Database::close() } catch (DbException e) { rethrow(e); } delete env; + + env = 0; } diff --git a/src/libstore/store.cc b/src/libstore/store.cc index 94c992f22..e792fd28c 100644 --- a/src/libstore/store.cc +++ b/src/libstore/store.cc @@ -136,6 +136,13 @@ void initDB() } +void closeDB() +{ + /* If the database isn't open, this is a NOP. */ + nixDB.close(); +} + + void createStoreTransaction(Transaction & txn) { Transaction txn2(nixDB); diff --git a/src/libstore/store.hh b/src/libstore/store.hh index c617585ba..a170c69e7 100644 --- a/src/libstore/store.hh +++ b/src/libstore/store.hh @@ -49,6 +49,9 @@ void openDB(bool reserveSpace = true); /* Create the required database tables. */ void initDB(); +/* Close the database. */ +void closeDB(); + /* Get a transaction object. */ void createStoreTransaction(Transaction & txn);