From 5b8dce745655f22be968287ab57dd3cf1b5ecb76 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Sun, 28 Feb 2016 11:19:28 +0100 Subject: [PATCH] db/simple: throw DatabaseError on error --- src/command/StorageCommands.cxx | 9 ++- .../plugins/simple/SimpleDatabasePlugin.cxx | 64 ++++++++----------- .../plugins/simple/SimpleDatabasePlugin.hxx | 2 +- 3 files changed, 34 insertions(+), 41 deletions(-) diff --git a/src/command/StorageCommands.cxx b/src/command/StorageCommands.cxx index edc1f0e18..fef454ef8 100644 --- a/src/command/StorageCommands.cxx +++ b/src/command/StorageCommands.cxx @@ -237,9 +237,14 @@ handle_mount(Client &client, Request args, Response &r) if (_db != nullptr && _db->IsPlugin(simple_db_plugin)) { SimpleDatabase &db = *(SimpleDatabase *)_db; - if (!db.Mount(local_uri, remote_uri, error)) { + try { + if (!db.Mount(local_uri, remote_uri, error)) { + composite.Unmount(local_uri); + return print_error(r, error); + } + } catch (...) { composite.Unmount(local_uri); - return print_error(r, error); + throw; } // TODO: call Instance::OnDatabaseModified()? diff --git a/src/db/plugins/simple/SimpleDatabasePlugin.cxx b/src/db/plugins/simple/SimpleDatabasePlugin.cxx index cbc2c96d8..88e2c6535 100644 --- a/src/db/plugins/simple/SimpleDatabasePlugin.cxx +++ b/src/db/plugins/simple/SimpleDatabasePlugin.cxx @@ -269,27 +269,21 @@ SimpleDatabase::GetSong(const char *uri, Error &error) const return prefixed_light_song; } - if (r.uri == nullptr) { + if (r.uri == nullptr) /* it's a directory */ - error.Format(db_domain, (int)DatabaseErrorCode::NOT_FOUND, - "No such song: %s", uri); - return nullptr; - } + throw DatabaseError(DatabaseErrorCode::NOT_FOUND, + "No such song"); - if (strchr(r.uri, '/') != nullptr) { + if (strchr(r.uri, '/') != nullptr) /* refers to a URI "below" the actual song */ - error.Format(db_domain, (int)DatabaseErrorCode::NOT_FOUND, - "No such song: %s", uri); - return nullptr; - } + throw DatabaseError(DatabaseErrorCode::NOT_FOUND, + "No such song"); const Song *song = r.directory->FindSong(r.uri); protect.unlock(); - if (song == nullptr) { - error.Format(db_domain, (int)DatabaseErrorCode::NOT_FOUND, - "No such song: %s", uri); - return nullptr; - } + if (song == nullptr) + throw DatabaseError(DatabaseErrorCode::NOT_FOUND, + "No such song"); light_song = song->Export(); @@ -351,9 +345,8 @@ SimpleDatabase::Visit(const DatabaseSelection &selection, } } - error.Set(db_domain, (int)DatabaseErrorCode::NOT_FOUND, - "No such directory"); - return false; + throw DatabaseError(DatabaseErrorCode::NOT_FOUND, + "No such directory"); } bool @@ -421,8 +414,8 @@ SimpleDatabase::Save() mtime = fi.GetModificationTime(); } -bool -SimpleDatabase::Mount(const char *uri, Database *db, Error &error) +void +SimpleDatabase::Mount(const char *uri, Database *db) { #if !CLANG_CHECK_VERSION(3,6) /* disabled on clang due to -Wtautological-pointer-compare */ @@ -434,21 +427,16 @@ SimpleDatabase::Mount(const char *uri, Database *db, Error &error) ScopeDatabaseLock protect; auto r = root->LookupDirectory(uri); - if (r.uri == nullptr) { - error.Format(db_domain, (int)DatabaseErrorCode::CONFLICT, - "Already exists: %s", uri); - return false; - } + if (r.uri == nullptr) + throw DatabaseError(DatabaseErrorCode::CONFLICT, + "Already exists"); - if (strchr(r.uri, '/') != nullptr) { - error.Format(db_domain, (int)DatabaseErrorCode::NOT_FOUND, - "Parent not found: %s", uri); - return false; - } + if (strchr(r.uri, '/') != nullptr) + throw DatabaseError(DatabaseErrorCode::NOT_FOUND, + "Parent not found"); Directory *mnt = r.directory->CreateChild(r.uri); mnt->mounted_database = db; - return true; } static constexpr bool @@ -467,11 +455,9 @@ bool SimpleDatabase::Mount(const char *local_uri, const char *storage_uri, Error &error) { - if (cache_path.IsNull()) { - error.Format(db_domain, (int)DatabaseErrorCode::NOT_FOUND, - "No 'cache_directory' configured"); - return false; - } + if (cache_path.IsNull()) + throw DatabaseError(DatabaseErrorCode::NOT_FOUND, + "No 'cache_directory' configured"); std::string name(storage_uri); std::replace_if(name.begin(), name.end(), IsUnsafeChar, '_'); @@ -493,10 +479,12 @@ SimpleDatabase::Mount(const char *local_uri, const char *storage_uri, // TODO: update the new database instance? - if (!Mount(local_uri, db, error)) { + try { + Mount(local_uri, db); + } catch (...) { db->Close(); delete db; - return false; + throw; } return true; diff --git a/src/db/plugins/simple/SimpleDatabasePlugin.hxx b/src/db/plugins/simple/SimpleDatabasePlugin.hxx index ea27910ef..b9a7f3172 100644 --- a/src/db/plugins/simple/SimpleDatabasePlugin.hxx +++ b/src/db/plugins/simple/SimpleDatabasePlugin.hxx @@ -97,7 +97,7 @@ public: * success, this object gains ownership of the given #Database */ gcc_nonnull_all - bool Mount(const char *uri, Database *db, Error &error); + void Mount(const char *uri, Database *db); gcc_nonnull_all bool Mount(const char *local_uri, const char *storage_uri,