summaryrefslogtreecommitdiff
path: root/src/core/Registry.hpp
diff options
context:
space:
mode:
authorBenjamin Paassen <bpaassen@techfak.uni-bielefeld.de>2015-01-20 01:24:17 +0100
committerBenjamin Paassen <bpaassen@techfak.uni-bielefeld.de>2015-01-20 01:24:17 +0100
commit57a1ea659ae125934c541951113c0c3a38b10971 (patch)
tree8bf6f93a1c4b56cd48777b2f2f80c77466ef61ee /src/core/Registry.hpp
parent20d3e71f26ca884271ed5d372a8459394554c147 (diff)
parent533e1a93c8f636b78f5687dd9c343a81563081a1 (diff)
Merge branch 'master' of somweyr.de:ousia
Diffstat (limited to 'src/core/Registry.hpp')
-rw-r--r--src/core/Registry.hpp21
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;
};
}