diff options
author | Benjamin Paassen <bpaassen@techfak.uni-bielefeld.de> | 2014-12-10 16:06:08 +0100 |
---|---|---|
committer | Benjamin Paassen <bpaassen@techfak.uni-bielefeld.de> | 2014-12-10 16:06:08 +0100 |
commit | f053b48f925cf65aaf6ca937f89dacf59196c719 (patch) | |
tree | d2c9e26bd7dc50bedf253ae0ec1a933522d5976b /src | |
parent | 3664b38b1e78063e2bdf994b613f430916544b9c (diff) |
started implementing FileLocator (boost).
Diffstat (limited to 'src')
-rw-r--r-- | src/core/ResourceLocator.hpp | 15 | ||||
-rw-r--r-- | src/plugins/boost/FileLocator.hpp | 64 |
2 files changed, 75 insertions, 4 deletions
diff --git a/src/core/ResourceLocator.hpp b/src/core/ResourceLocator.hpp index aaea8a5..36930e9 100644 --- a/src/core/ResourceLocator.hpp +++ b/src/core/ResourceLocator.hpp @@ -59,10 +59,15 @@ public: const bool found; const ResourceLocator &locator; const Type type; + /** + * This is a fully qualified/canonical path to the resource found or + * in an undefined state (possibly empty) if the 'found' flag is set + * to 'false'. + */ const std::string location; Location(const bool found, const ResourceLocator &locator, - const Type type, const std::string location) + const Type type, const std::string location) : found(found), locator(locator), type(type), location(location) { } @@ -89,7 +94,9 @@ public: * 'found' flag set accordingly. * * @param path is the resource name. - * @param relativeTo TODO: What is the meaning of this parameter? + * @param relativeTo is an already resolved fully qualified name/canonical + * path that is to be used as base directory for this + * search. * @param type is the type of this resource. * * @return A Location containing either the found location of the @@ -97,8 +104,8 @@ public: * and the found flag set to 'false'. */ virtual Location locate(const std::string &path, - const std::string &relativeTo, - const Type type) const = 0; + const std::string &relativeTo, + const Type type) const = 0; /** * This method returns a strem containing the data of the resource at the diff --git a/src/plugins/boost/FileLocator.hpp b/src/plugins/boost/FileLocator.hpp new file mode 100644 index 0000000..50a77db --- /dev/null +++ b/src/plugins/boost/FileLocator.hpp @@ -0,0 +1,64 @@ +/* + Ousía + Copyright (C) 2014, 2015 Benjamin Paaßen, Andreas Stöckel + + 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 3 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, see <http://www.gnu.org/licenses/>. +*/ + +#ifndef _OUSIA_FILE_LOCATOR_HPP_ +#define _OUSIA_FILE_LOCATOR_HPP_ + +#include <map> +#include <set> + +#include <core/ResourceLocator.hpp> + +namespace ousia { + +/** + * A ResourceLocator is a class able to locate resources in some way, usually + * on the hard drive. + * + * We specify this as an abstract superclass to have an interface layer between + * the program core and possible future extensions in terms of resource + * locations (e.g. online resources, .zip files, etc.). + */ +class FileLocator : public ResourceLocator { +private: + map<ResourceLocator::Type, std::vector<std::string>> searchPaths; + +public: + FileLocator() searchpaths() {} + + /** + * Adds a search paths for the given types. + * + * @param path is a fully qualified/canonical path to a directory. + * @param types is a set of Resource Types. The FileLocator will look for + * resources of the specified types at the given path in the + * future. + */ + void addSearchPath(const std::string &path, + std::set<ResourceLocator::Type> types); + + Location locate(const std::string &path, const std::string &relativeTo, + const Type type) const override; + + std::unique_ptr<std::istream> stream( + const std::string &location) const override; +}; +} + +#endif /* _OUSIA_FILE_LOCATOR_HPP_ */ + |