storage: add abstract interface

Prepare for the plugin interface.
This commit is contained in:
Max Kellermann 2014-02-05 17:03:43 +01:00
parent 4c995eb498
commit 0ba1b73395
11 changed files with 146 additions and 60 deletions

View File

@ -418,6 +418,7 @@ if ENABLE_DATABASE
noinst_LIBRARIES += libstorage.a noinst_LIBRARIES += libstorage.a
libstorage_a_SOURCES = \ libstorage_a_SOURCES = \
src/storage/StorageInterface.cxx src/storage/StorageInterface.hxx \
src/storage/LocalStorage.cxx src/storage/LocalStorage.hxx \ src/storage/LocalStorage.cxx src/storage/LocalStorage.hxx \
src/storage/FileInfo.hxx src/storage/FileInfo.hxx

View File

@ -61,7 +61,7 @@ class UpdateService final : DeferredMonitor {
public: public:
UpdateService(EventLoop &_loop, SimpleDatabase &_db, UpdateService(EventLoop &_loop, SimpleDatabase &_db,
LocalStorage &_storage, Storage &_storage,
DatabaseListener &_listener); DatabaseListener &_listener);
/** /**

View File

@ -151,7 +151,7 @@ UpdateService::RunDeferred()
} }
UpdateService::UpdateService(EventLoop &_loop, SimpleDatabase &_db, UpdateService::UpdateService(EventLoop &_loop, SimpleDatabase &_db,
LocalStorage &_storage, Storage &_storage,
DatabaseListener &_listener) DatabaseListener &_listener)
:DeferredMonitor(_loop), db(_db), listener(_listener), :DeferredMonitor(_loop), db(_db), listener(_listener),
progress(UPDATE_PROGRESS_IDLE), progress(UPDATE_PROGRESS_IDLE),

View File

@ -22,7 +22,7 @@
#include "UpdateDomain.hxx" #include "UpdateDomain.hxx"
#include "db/Directory.hxx" #include "db/Directory.hxx"
#include "storage/FileInfo.hxx" #include "storage/FileInfo.hxx"
#include "storage/LocalStorage.hxx" #include "storage/StorageInterface.hxx"
#include "fs/Traits.hxx" #include "fs/Traits.hxx"
#include "fs/FileSystem.hxx" #include "fs/FileSystem.hxx"
#include "util/Error.hxx" #include "util/Error.hxx"
@ -32,7 +32,7 @@
#include <unistd.h> #include <unistd.h>
bool bool
GetInfo(LocalStorage &storage, const char *uri_utf8, FileInfo &info) GetInfo(Storage &storage, const char *uri_utf8, FileInfo &info)
{ {
Error error; Error error;
bool success = storage.GetInfo(uri_utf8, true, info, error); bool success = storage.GetInfo(uri_utf8, true, info, error);
@ -42,7 +42,7 @@ GetInfo(LocalStorage &storage, const char *uri_utf8, FileInfo &info)
} }
bool bool
GetInfo(LocalDirectoryReader &reader, FileInfo &info) GetInfo(StorageDirectoryReader &reader, FileInfo &info)
{ {
Error error; Error error;
bool success = reader.GetInfo(true, info, error); bool success = reader.GetInfo(true, info, error);
@ -52,7 +52,7 @@ GetInfo(LocalDirectoryReader &reader, FileInfo &info)
} }
bool bool
DirectoryExists(LocalStorage &storage, const Directory &directory) DirectoryExists(Storage &storage, const Directory &directory)
{ {
FileInfo info; FileInfo info;
if (!storage.GetInfo(directory.GetPath(), true, info, IgnoreError())) if (!storage.GetInfo(directory.GetPath(), true, info, IgnoreError()))
@ -65,7 +65,7 @@ DirectoryExists(LocalStorage &storage, const Directory &directory)
} }
static bool static bool
GetDirectoryChildInfo(LocalStorage &storage, const Directory &directory, GetDirectoryChildInfo(Storage &storage, const Directory &directory,
const char *name_utf8, FileInfo &info, Error &error) const char *name_utf8, FileInfo &info, Error &error)
{ {
const auto uri_utf8 = PathTraitsUTF8::Build(directory.GetPath(), const auto uri_utf8 = PathTraitsUTF8::Build(directory.GetPath(),
@ -74,7 +74,7 @@ GetDirectoryChildInfo(LocalStorage &storage, const Directory &directory,
} }
bool bool
directory_child_is_regular(LocalStorage &storage, const Directory &directory, directory_child_is_regular(Storage &storage, const Directory &directory,
const char *name_utf8) const char *name_utf8)
{ {
FileInfo info; FileInfo info;
@ -84,7 +84,7 @@ directory_child_is_regular(LocalStorage &storage, const Directory &directory,
} }
bool bool
directory_child_access(LocalStorage &storage, const Directory &directory, directory_child_access(Storage &storage, const Directory &directory,
const char *name, int mode) const char *name, int mode)
{ {
#ifdef WIN32 #ifdef WIN32

View File

@ -25,30 +25,30 @@
struct Directory; struct Directory;
struct FileInfo; struct FileInfo;
class LocalStorage; class Storage;
class LocalDirectoryReader; class StorageDirectoryReader;
/** /**
* Wrapper for LocalStorage::GetInfo() that logs errors instead of * Wrapper for Storage::GetInfo() that logs errors instead of
* returning them. * returning them.
*/ */
bool bool
GetInfo(LocalStorage &storage, const char *uri_utf8, FileInfo &info); GetInfo(Storage &storage, const char *uri_utf8, FileInfo &info);
/** /**
* Wrapper for LocalDirectoryReader::GetInfo() that logs errors * Wrapper for LocalDirectoryReader::GetInfo() that logs errors
* instead of returning them. * instead of returning them.
*/ */
bool bool
GetInfo(LocalDirectoryReader &reader, FileInfo &info); GetInfo(StorageDirectoryReader &reader, FileInfo &info);
gcc_pure gcc_pure
bool bool
DirectoryExists(LocalStorage &storage, const Directory &directory); DirectoryExists(Storage &storage, const Directory &directory);
gcc_pure gcc_pure
bool bool
directory_child_is_regular(LocalStorage &storage, const Directory &directory, directory_child_is_regular(Storage &storage, const Directory &directory,
const char *name_utf8); const char *name_utf8);
/** /**
@ -56,7 +56,7 @@ directory_child_is_regular(LocalStorage &storage, const Directory &directory,
*/ */
gcc_pure gcc_pure
bool bool
directory_child_access(LocalStorage &storage, const Directory &directory, directory_child_access(Storage &storage, const Directory &directory,
const char *name, int mode); const char *name, int mode);
#endif #endif

View File

@ -27,7 +27,7 @@
#include "db/Song.hxx" #include "db/Song.hxx"
#include "db/PlaylistVector.hxx" #include "db/PlaylistVector.hxx"
#include "db/Uri.hxx" #include "db/Uri.hxx"
#include "storage/LocalStorage.hxx" #include "storage/StorageInterface.hxx"
#include "playlist/PlaylistRegistry.hxx" #include "playlist/PlaylistRegistry.hxx"
#include "Mapper.hxx" #include "Mapper.hxx"
#include "ExcludeList.hxx" #include "ExcludeList.hxx"
@ -49,7 +49,7 @@
#include <errno.h> #include <errno.h>
UpdateWalk::UpdateWalk(EventLoop &_loop, DatabaseListener &_listener, UpdateWalk::UpdateWalk(EventLoop &_loop, DatabaseListener &_listener,
LocalStorage &_storage) Storage &_storage)
:storage(_storage), :storage(_storage),
editor(_loop, _listener) editor(_loop, _listener)
{ {
@ -140,7 +140,7 @@ UpdateWalk::PurgeDeletedFromDirectory(Directory &directory)
#ifndef WIN32 #ifndef WIN32
static bool static bool
update_directory_stat(LocalStorage &storage, Directory &directory) update_directory_stat(Storage &storage, Directory &directory)
{ {
FileInfo info; FileInfo info;
if (!GetInfo(storage, directory.GetPath(), info)) if (!GetInfo(storage, directory.GetPath(), info))
@ -152,7 +152,7 @@ update_directory_stat(LocalStorage &storage, Directory &directory)
#endif #endif
static int static int
find_inode_ancestor(LocalStorage &storage, Directory *parent, find_inode_ancestor(Storage &storage, Directory *parent,
unsigned inode, unsigned device) unsigned inode, unsigned device)
{ {
#ifndef WIN32 #ifndef WIN32
@ -320,7 +320,7 @@ UpdateWalk::UpdateDirectory(Directory &directory, const FileInfo &info)
directory_set_stat(directory, info); directory_set_stat(directory, info);
Error error; Error error;
LocalDirectoryReader *const reader = StorageDirectoryReader *const reader =
storage.OpenDirectory(directory.GetPath(), error); storage.OpenDirectory(directory.GetPath(), error);
if (reader == nullptr) { if (reader == nullptr) {
LogError(error); LogError(error);

View File

@ -29,7 +29,7 @@ struct stat;
struct FileInfo; struct FileInfo;
struct Directory; struct Directory;
struct archive_plugin; struct archive_plugin;
class LocalStorage; class Storage;
class ExcludeList; class ExcludeList;
class UpdateWalk final { class UpdateWalk final {
@ -48,13 +48,13 @@ class UpdateWalk final {
bool walk_discard; bool walk_discard;
bool modified; bool modified;
LocalStorage &storage; Storage &storage;
DatabaseEditor editor; DatabaseEditor editor;
public: public:
UpdateWalk(EventLoop &_loop, DatabaseListener &_listener, UpdateWalk(EventLoop &_loop, DatabaseListener &_listener,
LocalStorage &_storage); Storage &_storage);
/** /**
* Returns true if the database was modified. * Returns true if the database was modified.

View File

@ -81,14 +81,6 @@ LocalStorage::MapFS(const char *uri_utf8) const
return MapFS(uri_utf8, IgnoreError()); return MapFS(uri_utf8, IgnoreError());
} }
AllocatedPath
LocalStorage::MapChildFS(const char *uri_utf8,
const char *child_utf8) const
{
const auto uri2 = PathTraitsUTF8::Build(uri_utf8, child_utf8);
return MapFS(uri2.c_str());
}
bool bool
LocalStorage::GetInfo(const char *uri_utf8, bool follow, FileInfo &info, LocalStorage::GetInfo(const char *uri_utf8, bool follow, FileInfo &info,
Error &error) Error &error)

View File

@ -21,14 +21,13 @@
#define MPD_STORAGE_LOCAL_HXX #define MPD_STORAGE_LOCAL_HXX
#include "check.h" #include "check.h"
#include "StorageInterface.hxx"
#include "fs/AllocatedPath.hxx" #include "fs/AllocatedPath.hxx"
#include "fs/DirectoryReader.hxx" #include "fs/DirectoryReader.hxx"
#include <string> #include <string>
struct FileInfo; class LocalDirectoryReader final : public StorageDirectoryReader {
class LocalDirectoryReader {
AllocatedPath base_fs; AllocatedPath base_fs;
DirectoryReader reader; DirectoryReader reader;
@ -43,12 +42,13 @@ public:
return reader.HasFailed(); return reader.HasFailed();
} }
const char *Read(); /* virtual methods from class StorageDirectoryReader */
virtual const char *Read() override;
bool GetInfo(bool follow, FileInfo &info, Error &error); virtual bool GetInfo(bool follow, FileInfo &info,
Error &error) override;
}; };
class LocalStorage { class LocalStorage final : public Storage {
const std::string base_utf8; const std::string base_utf8;
const AllocatedPath base_fs; const AllocatedPath base_fs;
@ -58,29 +58,16 @@ public:
LocalStorage(const LocalStorage &) = delete; LocalStorage(const LocalStorage &) = delete;
bool GetInfo(const char *uri_utf8, bool follow, FileInfo &info, /* virtual methods from class Storage */
Error &error); virtual bool GetInfo(const char *uri_utf8, bool follow, FileInfo &info,
Error &error) override;
LocalDirectoryReader *OpenDirectory(const char *uri_utf8, virtual LocalDirectoryReader *OpenDirectory(const char *uri_utf8,
Error &error); Error &error) override;
/** virtual std::string MapUTF8(const char *uri_utf8) const override;
* Map the given relative URI to an absolute URI.
*/
gcc_pure
std::string MapUTF8(const char *uri_utf8) const;
/** virtual AllocatedPath MapFS(const char *uri_utf8) const override;
* Map the given relative URI to a local file path. Returns
* AllocatedPath::Null() on error or if this storage does not
* support local files.
*/
gcc_pure
AllocatedPath MapFS(const char *uri_utf8) const;
gcc_pure
AllocatedPath MapChildFS(const char *uri_utf8,
const char *child_utf8) const;
private: private:
AllocatedPath MapFS(const char *uri_utf8, Error &error) const; AllocatedPath MapFS(const char *uri_utf8, Error &error) const;

View File

@ -0,0 +1,37 @@
/*
* Copyright (C) 2003-2014 The Music Player Daemon Project
* http://www.musicpd.org
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#include "config.h"
#include "StorageInterface.hxx"
#include "fs/AllocatedPath.hxx"
#include "fs/Traits.hxx"
AllocatedPath
Storage::MapFS(gcc_unused const char *uri_utf8) const
{
return AllocatedPath::Null();
}
AllocatedPath
Storage::MapChildFS(const char *uri_utf8,
const char *child_utf8) const
{
const auto uri2 = PathTraitsUTF8::Build(uri_utf8, child_utf8);
return MapFS(uri2.c_str());
}

View File

@ -0,0 +1,69 @@
/*
* Copyright (C) 2003-2014 The Music Player Daemon Project
* http://www.musicpd.org
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#ifndef MPD_STORAGE_INTERFACE_HXX
#define MPD_STORAGE_INTERFACE_HXX
#include "check.h"
#include "fs/AllocatedPath.hxx"
#include "fs/DirectoryReader.hxx"
#include <string>
struct FileInfo;
class AllocatedPath;
class StorageDirectoryReader {
public:
virtual ~StorageDirectoryReader() {}
virtual const char *Read() = 0;
virtual bool GetInfo(bool follow, FileInfo &info, Error &error) = 0;
};
class Storage {
public:
virtual ~Storage() {}
virtual bool GetInfo(const char *uri_utf8, bool follow, FileInfo &info,
Error &error) = 0;
virtual StorageDirectoryReader *OpenDirectory(const char *uri_utf8,
Error &error) = 0;
/**
* Map the given relative URI to an absolute URI.
*/
gcc_pure
virtual std::string MapUTF8(const char *uri_utf8) const = 0;
/**
* Map the given relative URI to a local file path. Returns
* AllocatedPath::Null() on error or if this storage does not
* support local files.
*/
gcc_pure
virtual AllocatedPath MapFS(const char *uri_utf8) const;
gcc_pure
AllocatedPath MapChildFS(const char *uri_utf8,
const char *child_utf8) const;
};
#endif