diff options
author | Benjamin Paassen <bpaassen@techfak.uni-bielefeld.de> | 2015-01-20 01:24:17 +0100 |
---|---|---|
committer | Benjamin Paassen <bpaassen@techfak.uni-bielefeld.de> | 2015-01-20 01:24:17 +0100 |
commit | 57a1ea659ae125934c541951113c0c3a38b10971 (patch) | |
tree | 8bf6f93a1c4b56cd48777b2f2f80c77466ef61ee /src/core/Registry.hpp | |
parent | 20d3e71f26ca884271ed5d372a8459394554c147 (diff) | |
parent | 533e1a93c8f636b78f5687dd9c343a81563081a1 (diff) |
Merge branch 'master' of somweyr.de:ousia
Diffstat (limited to 'src/core/Registry.hpp')
-rw-r--r-- | src/core/Registry.hpp | 21 |
1 files changed, 9 insertions, 12 deletions
diff --git a/src/core/Registry.hpp b/src/core/Registry.hpp index 01d57e8..40eede1 100644 --- a/src/core/Registry.hpp +++ b/src/core/Registry.hpp @@ -22,37 +22,34 @@ #include <map> #include <vector> -#include "ResourceLocator.hpp" +#include <core/resource/Resource.hpp> namespace ousia { // TODO: Add support for ScriptEngine type -class Logger; - namespace parser { class Parser; } +class ResourceLocator; class Registry { private: - Logger &logger; std::vector<parser::Parser *> parsers; std::map<std::string, parser::Parser *> parserMimetypes; + std::vector<ResourceLocator *> locators; public: - Registry(Logger &logger) : logger(logger) {} - - void registerParser(parser::Parser *parser); + void registerParser(parser::Parser &parser); - parser::Parser *getParserForMimetype(const std::string& mimetype) const; + parser::Parser *getParserForMimetype(const std::string &mimetype) const; - void registerResourceLocator(ResourceLocator *locator); + void registerResourceLocator(ResourceLocator &locator); - ResourceLocator::Location locateResource(const std::string &path, - const std::string &relativeTo, - ResourceLocator::Type type) const; + bool locateResource(Resource &resource, const std::string &path, + ResourceType type = ResourceType::UNKNOWN, + const Resource &relativeTo = NullResource) const; }; } |