db/update/Service: Enqueue() throws on error

This commit is contained in:
Max Kellermann 2018-08-19 23:15:52 +02:00
parent 9999914c74
commit cc64c715a2
4 changed files with 11 additions and 15 deletions

View File

@ -617,9 +617,7 @@ mpd_main_after_fork(const ConfigData &raw_config, const Config &config)
if (create_db) { if (create_db) {
/* the database failed to load: recreate the /* the database failed to load: recreate the
database */ database */
unsigned job = instance->update->Enqueue("", true); instance->update->Enqueue("", true);
if (job == 0)
throw std::runtime_error("directory update failed");
} }
#endif #endif

View File

@ -249,13 +249,8 @@ handle_update(Response &r, UpdateService &update,
const char *uri_utf8, bool discard) const char *uri_utf8, bool discard)
{ {
unsigned ret = update.Enqueue(uri_utf8, discard); unsigned ret = update.Enqueue(uri_utf8, discard);
if (ret > 0) { r.Format("updating_db: %i\n", ret);
r.Format("updating_db: %i\n", ret); return CommandResult::OK;
return CommandResult::OK;
} else {
r.Error(ACK_ERROR_UPDATE_ALREADY, "already updating");
return CommandResult::ERROR;
}
} }
static CommandResult static CommandResult

View File

@ -26,6 +26,7 @@
#include "db/plugins/simple/SimpleDatabasePlugin.hxx" #include "db/plugins/simple/SimpleDatabasePlugin.hxx"
#include "db/plugins/simple/Directory.hxx" #include "db/plugins/simple/Directory.hxx"
#include "storage/CompositeStorage.hxx" #include "storage/CompositeStorage.hxx"
#include "protocol/Ack.hxx"
#include "Idle.hxx" #include "Idle.hxx"
#include "Log.hxx" #include "Log.hxx"
#include "thread/Thread.hxx" #include "thread/Thread.hxx"
@ -192,8 +193,7 @@ UpdateService::Enqueue(const char *path, bool discard)
Database &_db2 = *lr.directory->mounted_database; Database &_db2 = *lr.directory->mounted_database;
if (!_db2.IsPlugin(simple_db_plugin)) if (!_db2.IsPlugin(simple_db_plugin))
/* cannot update this type of database */ throw std::runtime_error("Cannot update this type of database");
return 0;
db2 = static_cast<SimpleDatabase *>(&_db2); db2 = static_cast<SimpleDatabase *>(&_db2);
@ -219,12 +219,13 @@ UpdateService::Enqueue(const char *path, bool discard)
if (storage2 == nullptr) if (storage2 == nullptr)
/* no storage found at this mount point - should not /* no storage found at this mount point - should not
happen */ happen */
return 0; throw std::runtime_error("No storage at this path");
if (walk != nullptr) { if (walk != nullptr) {
const unsigned id = GenerateId(); const unsigned id = GenerateId();
if (!queue.Push(*db2, *storage2, path, discard, id)) if (!queue.Push(*db2, *storage2, path, discard, id))
return 0; throw ProtocolError(ACK_ERROR_UPDATE_ALREADY,
"Update queue is full");
update_task_id = id; update_task_id = id;
return id; return id;

View File

@ -82,9 +82,11 @@ public:
/** /**
* Add this path to the database update queue. * Add this path to the database update queue.
* *
* Throws on error
*
* @param path a path to update; if an empty string, * @param path a path to update; if an empty string,
* the whole music directory is updated * the whole music directory is updated
* @return the job id, or 0 on error * @return the job id
*/ */
gcc_nonnull_all gcc_nonnull_all
unsigned Enqueue(const char *path, bool discard); unsigned Enqueue(const char *path, bool discard);