aboutsummaryrefslogtreecommitdiff
path: root/src/db.cpp
diff options
context:
space:
mode:
authorGavin Andresen <[email protected]>2012-10-08 17:18:17 -0400
committerGavin Andresen <[email protected]>2012-10-08 17:18:17 -0400
commitc2bb42168ba19bb8be4d330238080cb4233cd390 (patch)
treea41c410e8fe04edd5e01d714979b1ef09b44cd42 /src/db.cpp
parentMerge pull request #1859 from Diapolo/proxy_locks (diff)
parentHandle incompatible BDB environments (diff)
downloaddiscoin-c2bb42168ba19bb8be4d330238080cb4233cd390.tar.xz
discoin-c2bb42168ba19bb8be4d330238080cb4233cd390.zip
Merge branch 'BDB_DOWNGRADE'
Diffstat (limited to 'src/db.cpp')
-rw-r--r--src/db.cpp19
1 files changed, 7 insertions, 12 deletions
diff --git a/src/db.cpp b/src/db.cpp
index 867703fbd..7ca9e3495 100644
--- a/src/db.cpp
+++ b/src/db.cpp
@@ -34,19 +34,14 @@ void CDBEnv::EnvShutdown()
return;
fDbEnvInit = false;
- try
- {
- dbenv.close(0);
- }
- catch (const DbException& e)
- {
- printf("EnvShutdown exception: %s (%d)\n", e.what(), e.get_errno());
- }
+ int ret = dbenv.close(0);
+ if (ret != 0)
+ printf("EnvShutdown exception: %s (%d)\n", DbEnv::strerror(ret), ret);
if (!fMockDb)
DbEnv(0).remove(GetDataDir().string().c_str(), 0);
}
-CDBEnv::CDBEnv() : dbenv(0)
+CDBEnv::CDBEnv() : dbenv(DB_CXX_NO_EXCEPTIONS)
{
}
@@ -100,8 +95,8 @@ bool CDBEnv::Open(boost::filesystem::path pathEnv_)
DB_RECOVER |
nEnvFlags,
S_IRUSR | S_IWUSR);
- if (ret > 0)
- return error("CDB() : error %d opening database environment", ret);
+ if (ret != 0)
+ return error("CDB() : error %s (%d) opening database environment", DbEnv::strerror(ret), ret);
fDbEnvInit = true;
fMockDb = false;
@@ -191,7 +186,7 @@ CDB::CDB(const char *pszFile, const char* pszMode) :
nFlags, // Flags
0);
- if (ret > 0)
+ if (ret != 0)
{
delete pdb;
pdb = NULL;