From 717397e47615c7927c2c0a99ebfc59d30a08321c Mon Sep 17 00:00:00 2001 From: Scott Schurr Date: Mon, 6 Dec 2021 12:55:01 -0800 Subject: [PATCH] NuDBBackend destructor should not throw --- src/ripple/nodestore/backend/NuDBFactory.cpp | 23 ++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/src/ripple/nodestore/backend/NuDBFactory.cpp b/src/ripple/nodestore/backend/NuDBFactory.cpp index 405e13acd6b..2b20b574a2c 100644 --- a/src/ripple/nodestore/backend/NuDBFactory.cpp +++ b/src/ripple/nodestore/backend/NuDBFactory.cpp @@ -92,7 +92,16 @@ class NuDBBackend : public Backend ~NuDBBackend() override { - close(); + try + { + // close can throw and we don't want the destructor to throw. + close(); + } + catch (nudb::system_error const&) + { + // Don't allow exceptions to propagate out of destructors. + // close() has already logged the error. + } } std::string @@ -174,10 +183,20 @@ class NuDBBackend : public Backend nudb::error_code ec; db_.close(ec); if (ec) + { + // Log to make sure the nature of the error gets to the user. + JLOG(j_.fatal()) << "NuBD close() failed: " << ec.message(); Throw(ec); + } + if (deletePath_) { - boost::filesystem::remove_all(name_); + boost::filesystem::remove_all(name_, ec); + if (ec) + { + JLOG(j_.fatal()) << "Filesystem remove_all of " << name_ + << " failed with: " << ec.message(); + } } } }