summaryrefslogtreecommitdiff
path: root/src/storage
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2014-02-05 17:03:43 +0100
committerMax Kellermann <max@duempel.org>2014-02-05 18:53:51 +0100
commit0ba1b73395dc7beaa27ed9bb07636970243b76e6 (patch)
treece55bfc2eff1cf7fbcd8d2cc02e85bf2e6b53c46 /src/storage
parent4c995eb49873eac081486a94c6ed8db566248563 (diff)
storage: add abstract interface
Prepare for the plugin interface.
Diffstat (limited to 'src/storage')
-rw-r--r--src/storage/LocalStorage.cxx8
-rw-r--r--src/storage/LocalStorage.hxx47
-rw-r--r--src/storage/StorageInterface.cxx37
-rw-r--r--src/storage/StorageInterface.hxx69
4 files changed, 123 insertions, 38 deletions
diff --git a/src/storage/LocalStorage.cxx b/src/storage/LocalStorage.cxx
index a229b3fe7..f0a1726e0 100644
--- a/src/storage/LocalStorage.cxx
+++ b/src/storage/LocalStorage.cxx
@@ -81,14 +81,6 @@ LocalStorage::MapFS(const char *uri_utf8) const
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
LocalStorage::GetInfo(const char *uri_utf8, bool follow, FileInfo &info,
Error &error)
diff --git a/src/storage/LocalStorage.hxx b/src/storage/LocalStorage.hxx
index 73c11dd80..4acea3d2a 100644
--- a/src/storage/LocalStorage.hxx
+++ b/src/storage/LocalStorage.hxx
@@ -21,14 +21,13 @@
#define MPD_STORAGE_LOCAL_HXX
#include "check.h"
+#include "StorageInterface.hxx"
#include "fs/AllocatedPath.hxx"
#include "fs/DirectoryReader.hxx"
#include <string>
-struct FileInfo;
-
-class LocalDirectoryReader {
+class LocalDirectoryReader final : public StorageDirectoryReader {
AllocatedPath base_fs;
DirectoryReader reader;
@@ -43,12 +42,13 @@ public:
return reader.HasFailed();
}
- const char *Read();
-
- bool GetInfo(bool follow, FileInfo &info, Error &error);
+ /* virtual methods from class StorageDirectoryReader */
+ virtual const char *Read() override;
+ virtual bool GetInfo(bool follow, FileInfo &info,
+ Error &error) override;
};
-class LocalStorage {
+class LocalStorage final : public Storage {
const std::string base_utf8;
const AllocatedPath base_fs;
@@ -58,29 +58,16 @@ public:
LocalStorage(const LocalStorage &) = delete;
- bool GetInfo(const char *uri_utf8, bool follow, FileInfo &info,
- Error &error);
-
- LocalDirectoryReader *OpenDirectory(const char *uri_utf8,
- Error &error);
-
- /**
- * Map the given relative URI to an absolute URI.
- */
- gcc_pure
- std::string MapUTF8(const char *uri_utf8) const;
-
- /**
- * 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;
+ /* virtual methods from class Storage */
+ virtual bool GetInfo(const char *uri_utf8, bool follow, FileInfo &info,
+ Error &error) override;
+
+ virtual LocalDirectoryReader *OpenDirectory(const char *uri_utf8,
+ Error &error) override;
+
+ virtual std::string MapUTF8(const char *uri_utf8) const override;
+
+ virtual AllocatedPath MapFS(const char *uri_utf8) const override;
private:
AllocatedPath MapFS(const char *uri_utf8, Error &error) const;
diff --git a/src/storage/StorageInterface.cxx b/src/storage/StorageInterface.cxx
new file mode 100644
index 000000000..93c50a8ac
--- /dev/null
+++ b/src/storage/StorageInterface.cxx
@@ -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());
+}
diff --git a/src/storage/StorageInterface.hxx b/src/storage/StorageInterface.hxx
new file mode 100644
index 000000000..ecdc882b6
--- /dev/null
+++ b/src/storage/StorageInterface.hxx
@@ -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