StoragePlugin: pass EventLoop to constructor

This commit is contained in:
Max Kellermann 2014-10-07 19:45:40 +02:00
parent 1aac0b10c9
commit 3d2558bde6
11 changed files with 31 additions and 15 deletions

View File

@ -1589,11 +1589,15 @@ endif
test_run_storage_LDADD = \ test_run_storage_LDADD = \
$(STORAGE_LIBS) \ $(STORAGE_LIBS) \
$(FS_LIBS) \ $(FS_LIBS) \
libevent.a \
libthread.a \
libsystem.a \ libsystem.a \
libutil.a \ libutil.a \
$(GLIB_LIBS) $(GLIB_LIBS)
test_run_storage_SOURCES = \ test_run_storage_SOURCES = \
src/Log.cxx src/LogBackend.cxx \ src/Log.cxx src/LogBackend.cxx \
src/IOThread.cxx \
test/ScopeIOThread.hxx \
test/run_storage.cxx test/run_storage.cxx
endif endif

View File

@ -166,7 +166,7 @@ glue_mapper_init(Error &error)
static bool static bool
InitStorage(Error &error) InitStorage(Error &error)
{ {
Storage *storage = CreateConfiguredStorage(error); Storage *storage = CreateConfiguredStorage(io_thread_get(), error);
if (storage == nullptr) if (storage == nullptr)
return !error.IsDefined(); return !error.IsDefined();

View File

@ -35,6 +35,7 @@
#include "db/plugins/simple/SimpleDatabasePlugin.hxx" #include "db/plugins/simple/SimpleDatabasePlugin.hxx"
#include "db/update/Service.hxx" #include "db/update/Service.hxx"
#include "TimePrint.hxx" #include "TimePrint.hxx"
#include "IOThread.hxx"
#include "Idle.hxx" #include "Idle.hxx"
#include <inttypes.h> /* for PRIu64 */ #include <inttypes.h> /* for PRIu64 */
@ -121,7 +122,7 @@ CommandResult
handle_listfiles_storage(Client &client, const char *uri) handle_listfiles_storage(Client &client, const char *uri)
{ {
Error error; Error error;
Storage *storage = CreateStorageURI(uri, error); Storage *storage = CreateStorageURI(io_thread_get(), uri, error);
if (storage == nullptr) { if (storage == nullptr) {
if (error.IsDefined()) if (error.IsDefined())
return print_error(client, error); return print_error(client, error);
@ -217,7 +218,8 @@ handle_mount(Client &client, gcc_unused unsigned argc, char *argv[])
} }
Error error; Error error;
Storage *storage = CreateStorageURI(remote_uri, error); Storage *storage = CreateStorageURI(io_thread_get(), remote_uri,
error);
if (storage == nullptr) { if (storage == nullptr) {
if (error.IsDefined()) if (error.IsDefined())
return print_error(client, error); return print_error(client, error);

View File

@ -31,9 +31,10 @@
#include <assert.h> #include <assert.h>
static Storage * static Storage *
CreateConfiguredStorageUri(const char *uri, Error &error) CreateConfiguredStorageUri(EventLoop &event_loop, const char *uri,
Error &error)
{ {
Storage *storage = CreateStorageURI(uri, error); Storage *storage = CreateStorageURI(event_loop, uri, error);
if (storage == nullptr && !error.IsDefined()) if (storage == nullptr && !error.IsDefined())
error.Format(config_domain, error.Format(config_domain,
"Unrecognized storage URI: %s", uri); "Unrecognized storage URI: %s", uri);
@ -63,13 +64,13 @@ CreateConfiguredStorageLocal(Error &error)
} }
Storage * Storage *
CreateConfiguredStorage(Error &error) CreateConfiguredStorage(EventLoop &event_loop, Error &error)
{ {
assert(!error.IsDefined()); assert(!error.IsDefined());
auto uri = config_get_string(CONF_MUSIC_DIR, nullptr); auto uri = config_get_string(CONF_MUSIC_DIR, nullptr);
if (uri != nullptr && uri_has_scheme(uri)) if (uri != nullptr && uri_has_scheme(uri))
return CreateConfiguredStorageUri(uri, error); return CreateConfiguredStorageUri(event_loop, uri, error);
return CreateConfiguredStorageLocal(error); return CreateConfiguredStorageLocal(error);
} }

View File

@ -25,6 +25,7 @@
class Error; class Error;
class Storage; class Storage;
class EventLoop;
/** /**
* Read storage configuration settings and create a #Storage instance * Read storage configuration settings and create a #Storage instance
@ -32,7 +33,7 @@ class Storage;
* (no #Error set in that case). * (no #Error set in that case).
*/ */
Storage * Storage *
CreateConfiguredStorage(Error &error); CreateConfiguredStorage(EventLoop &event_loop, Error &error);
/** /**
* Returns true if there is configuration for a #Storage instance. * Returns true if there is configuration for a #Storage instance.

View File

@ -52,7 +52,7 @@ GetStoragePluginByName(const char *name)
} }
Storage * Storage *
CreateStorageURI(const char *uri, Error &error) CreateStorageURI(EventLoop &event_loop, const char *uri, Error &error)
{ {
assert(!error.IsDefined()); assert(!error.IsDefined());
@ -62,7 +62,7 @@ CreateStorageURI(const char *uri, Error &error)
if (plugin.create_uri == nullptr) if (plugin.create_uri == nullptr)
continue; continue;
Storage *storage = plugin.create_uri(uri, error); Storage *storage = plugin.create_uri(event_loop, uri, error);
if (storage != nullptr || error.IsDefined()) if (storage != nullptr || error.IsDefined())
return storage; return storage;
} }

View File

@ -26,6 +26,7 @@
struct StoragePlugin; struct StoragePlugin;
class Storage; class Storage;
class Error; class Error;
class EventLoop;
/** /**
* nullptr terminated list of all storage plugins which were enabled at * nullptr terminated list of all storage plugins which were enabled at
@ -39,6 +40,6 @@ GetStoragePluginByName(const char *name);
gcc_nonnull_all gcc_malloc gcc_nonnull_all gcc_malloc
Storage * Storage *
CreateStorageURI(const char *uri, Error &error); CreateStorageURI(EventLoop &event_loop, const char *uri, Error &error);
#endif #endif

View File

@ -24,11 +24,13 @@
class Error; class Error;
class Storage; class Storage;
class EventLoop;
struct StoragePlugin { struct StoragePlugin {
const char *name; const char *name;
Storage *(*create_uri)(const char *uri, Error &error); Storage *(*create_uri)(EventLoop &event_loop, const char *uri,
Error &error);
}; };
#endif #endif

View File

@ -203,7 +203,8 @@ NfsStorage::OpenDirectory(const char *uri_utf8, Error &error)
} }
static Storage * static Storage *
CreateNfsStorageURI(const char *base, Error &error) CreateNfsStorageURI(gcc_unused EventLoop &event_loop, const char *base,
Error &error)
{ {
if (memcmp(base, "nfs://", 6) != 0) if (memcmp(base, "nfs://", 6) != 0)
return nullptr; return nullptr;

View File

@ -180,7 +180,8 @@ SmbclientDirectoryReader::GetInfo(gcc_unused bool follow, FileInfo &info,
} }
static Storage * static Storage *
CreateSmbclientStorageURI(const char *base, Error &error) CreateSmbclientStorageURI(gcc_unused EventLoop &event_loop, const char *base,
Error &error)
{ {
if (memcmp(base, "smb://", 6) != 0) if (memcmp(base, "smb://", 6) != 0)
return nullptr; return nullptr;

View File

@ -18,6 +18,7 @@
*/ */
#include "config.h" #include "config.h"
#include "ScopeIOThread.hxx"
#include "storage/Registry.hxx" #include "storage/Registry.hxx"
#include "storage/StorageInterface.hxx" #include "storage/StorageInterface.hxx"
#include "storage/FileInfo.hxx" #include "storage/FileInfo.hxx"
@ -38,7 +39,7 @@ static Storage *
MakeStorage(const char *uri) MakeStorage(const char *uri)
{ {
Error error; Error error;
Storage *storage = CreateStorageURI(uri, error); Storage *storage = CreateStorageURI(io_thread_get(), uri, error);
if (storage == nullptr) { if (storage == nullptr) {
fprintf(stderr, "%s\n", error.GetMessage()); fprintf(stderr, "%s\n", error.GetMessage());
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
@ -112,6 +113,8 @@ main(int argc, char **argv)
const char *const command = argv[1]; const char *const command = argv[1];
const char *const storage_uri = argv[2]; const char *const storage_uri = argv[2];
const ScopeIOThread io_thread;
if (strcmp(command, "ls") == 0) { if (strcmp(command, "ls") == 0) {
if (argc != 4) { if (argc != 4) {
fprintf(stderr, "Usage: run_storage ls URI PATH\n"); fprintf(stderr, "Usage: run_storage ls URI PATH\n");