diff options
author | Adrian Kummerländer | 2014-05-20 21:17:10 +0200 |
---|---|---|
committer | Adrian Kummerländer | 2014-05-20 21:17:10 +0200 |
commit | 35334241ce4b76b1b1a66219ce938f27fdf39031 (patch) | |
tree | 1bad6d46b957e47eac2127f16198876cf7fe8450 /src/function/resolve_include.cc | |
parent | 426265b91d4533b7aa16d53124ad9b5d0a6862d6 (diff) | |
download | InputXSLT-35334241ce4b76b1b1a66219ce938f27fdf39031.tar InputXSLT-35334241ce4b76b1b1a66219ce938f27fdf39031.tar.gz InputXSLT-35334241ce4b76b1b1a66219ce938f27fdf39031.tar.bz2 InputXSLT-35334241ce4b76b1b1a66219ce938f27fdf39031.tar.lz InputXSLT-35334241ce4b76b1b1a66219ce938f27fdf39031.tar.xz InputXSLT-35334241ce4b76b1b1a66219ce938f27fdf39031.tar.zst InputXSLT-35334241ce4b76b1b1a66219ce938f27fdf39031.zip |
Replaced FunctionResolveInclude with IncludeEntityResolver
* xalan / xerces offers the possibility of implementing custom entity resolvers which are called upon by "<xsl:include..."
** such a custom resolver was implemented to resolve include path entities
* this is a much better way to support include paths than offering a custom external "resolve-include" function
* as entity paths are expanded before they are passed to the entity resolver, a special "[path]" syntax simmilar to "#include <path>" had to be implemented
Diffstat (limited to 'src/function/resolve_include.cc')
-rw-r--r-- | src/function/resolve_include.cc | 62 |
1 files changed, 0 insertions, 62 deletions
diff --git a/src/function/resolve_include.cc b/src/function/resolve_include.cc deleted file mode 100644 index ac4adf5..0000000 --- a/src/function/resolve_include.cc +++ /dev/null @@ -1,62 +0,0 @@ -#include "resolve_include.h" - -#include <algorithm> - -#include "support/xalan_string.h" - -namespace InputXSLT { - -FunctionResolveInclude::FunctionResolveInclude( - const std::vector<std::string>& path): - path_(new std::vector<FilesystemContext>()) { - this->path_->reserve(path.size()); - - std::transform( - path.begin(), - path.end(), - std::back_inserter(*this->path_), - [](const std::string& path) -> FilesystemContext { - return FilesystemContext(path); - } - ); -} - -xalan::XObjectPtr FunctionResolveInclude::execute( - xalan::XPathExecutionContext& executionContext, - xalan::XalanNode*, - const xalan::XObjectPtr parameter, - const xalan::Locator* -) const { - const std::string filePath(toString(parameter->str())); - - for ( auto&& context : *this->path_ ) { - const boost::filesystem::path resolvedPath( - context.resolve(filePath) - ); - - if ( boost::filesystem::exists(resolvedPath) && - boost::filesystem::is_regular_file(resolvedPath) ) { - return executionContext.getXObjectFactory().createString( - toString(resolvedPath.string()) - ); - } - } - - return executionContext.getXObjectFactory().createString( - toString("error") - ); -} - -FunctionResolveInclude* FunctionResolveInclude::clone( - xalan::MemoryManager& manager) const { - return xalan::XalanCopyConstruct(manager, *this); -} - -const xalan::XalanDOMString& FunctionResolveInclude::getError( - xalan::XalanDOMString& result) const { - result.assign("The function expects one parameter of type string."); - - return result; -} - -} |