diff options
| author | Benjamin Paassen <bpaassen@techfak.uni-bielefeld.de> | 2014-12-10 11:23:50 +0100 |
|---|---|---|
| committer | Benjamin Paassen <bpaassen@techfak.uni-bielefeld.de> | 2014-12-10 11:23:50 +0100 |
| commit | d4df46459e558f10cab9dc51ef0ee5bf5e769ad1 (patch) | |
| tree | 670b8f009cb603c697690b4fc0a1e589e237f6d6 /src/core/Registry.cpp | |
| parent | a8f78252f05327d37aec3b853109b6d1359af452 (diff) | |
integrated ResourceLocator into the Registry.
Diffstat (limited to 'src/core/Registry.cpp')
| -rw-r--r-- | src/core/Registry.cpp | 25 |
1 files changed, 23 insertions, 2 deletions
diff --git a/src/core/Registry.cpp b/src/core/Registry.cpp index 1961b35..6ff9594 100644 --- a/src/core/Registry.cpp +++ b/src/core/Registry.cpp @@ -29,12 +29,14 @@ using namespace parser; void Registry::registerParser(parser::Parser *parser) { parsers.push_back(parser); - for (const auto &mime : parser.mimetypes()) { + for (const auto &mime : parser->mimetypes()) { + //TODO: This does not allow for multiple parsers with the same mimetype. + // Is that how its supposed to be? parserMimetypes.insert(std::make_pair(mime, parser)); } } -Parser* Registry::getParserForMimetype(const std::string &mimetype) +Parser *Registry::getParserForMimetype(const std::string &mimetype) const { const auto it = parserMimetypes.find(mimetype); if (it != parserMimetypes.end()) { @@ -43,5 +45,24 @@ Parser* Registry::getParserForMimetype(const std::string &mimetype) return nullptr; } +void Registry::registerResourceLocator(ResourceLocator *locator) +{ + locators.push_back(locator); +} + +ResourceLocator::Location Registry::locateResource( + const std::string &path, const std::string &relativeTo, + ResourceLocator::Type type) const +{ + ResourceLocator::Location *last; + for (auto &locator : locators) { + ResourceLocator::Location loc = locator->locate(path, relativeTo, type); + if (loc.found) { + return loc; + } + last = &loc; + } + return *last; +} } |
