StoragePlugin: pass EventLoop to constructor
This commit is contained in:
parent
1aac0b10c9
commit
3d2558bde6
@ -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
|
||||||
|
@ -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();
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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.
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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");
|
||||||
|
Loading…
Reference in New Issue
Block a user