aboutsummaryrefslogtreecommitdiff
path: root/src/function
diff options
context:
space:
mode:
authorAdrian Kummerländer2014-05-19 22:14:31 +0200
committerAdrian Kummerländer2014-05-19 22:14:31 +0200
commit426265b91d4533b7aa16d53124ad9b5d0a6862d6 (patch)
tree8d42a9e3b27229bad9a194191ca42f32f9717972 /src/function
parentd19a195985b96701b2ab302538fe24e87e76decf (diff)
downloadInputXSLT-426265b91d4533b7aa16d53124ad9b5d0a6862d6.tar
InputXSLT-426265b91d4533b7aa16d53124ad9b5d0a6862d6.tar.gz
InputXSLT-426265b91d4533b7aa16d53124ad9b5d0a6862d6.tar.bz2
InputXSLT-426265b91d4533b7aa16d53124ad9b5d0a6862d6.tar.lz
InputXSLT-426265b91d4533b7aa16d53124ad9b5d0a6862d6.tar.xz
InputXSLT-426265b91d4533b7aa16d53124ad9b5d0a6862d6.tar.zst
InputXSLT-426265b91d4533b7aa16d53124ad9b5d0a6862d6.zip
Implemented external "resolve-include" function
* resolves paths provided as strings against include paths provided through the newly created "--include" argument of the test executable * this was implemented to enable central collections of XSLT libraries simmilar to how there are C headers in "/usr/include"
Diffstat (limited to 'src/function')
-rw-r--r--src/function/resolve_include.cc62
-rw-r--r--src/function/resolve_include.h44
2 files changed, 106 insertions, 0 deletions
diff --git a/src/function/resolve_include.cc b/src/function/resolve_include.cc
new file mode 100644
index 0000000..ac4adf5
--- /dev/null
+++ b/src/function/resolve_include.cc
@@ -0,0 +1,62 @@
+#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;
+}
+
+}
diff --git a/src/function/resolve_include.h b/src/function/resolve_include.h
new file mode 100644
index 0000000..2d6e62f
--- /dev/null
+++ b/src/function/resolve_include.h
@@ -0,0 +1,44 @@
+#ifndef INPUTXSLT_SRC_FUNCTION_RESOLVE_INCLUDE_H_
+#define INPUTXSLT_SRC_FUNCTION_RESOLVE_INCLUDE_H_
+
+#include <xalanc/XPath/XObjectFactory.hpp>
+#include <xalanc/XPath/Function.hpp>
+#include <xalanc/XPath/XObject.hpp>
+
+#include "boost/filesystem.hpp"
+
+#include <memory>
+#include <string>
+#include <vector>
+
+#include "common.h"
+#include "support/filesystem_context.h"
+
+namespace InputXSLT {
+
+class FunctionResolveInclude : public xalan::Function {
+ public:
+ FunctionResolveInclude(const std::vector<std::string>&);
+
+ virtual xalan::XObjectPtr execute(
+ xalan::XPathExecutionContext&,
+ xalan::XalanNode*,
+ const xalan::XObjectPtr,
+ const xalan::Locator*
+ ) const;
+
+ virtual FunctionResolveInclude* clone(xalan::MemoryManager&) const;
+
+ FunctionResolveInclude& operator=(const FunctionResolveInclude&) = delete;
+ bool operator==(const FunctionResolveInclude&) const = delete;
+
+ private:
+ const std::shared_ptr<std::vector<FilesystemContext>> path_;
+
+ const xalan::XalanDOMString& getError(xalan::XalanDOMString&) const;
+
+};
+
+}
+
+#endif // INPUTXSLT_SRC_FUNCTION_RESOLVE_INCLUDE_H_