diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/function/external_text_formatter.cc (renamed from src/function/execute.cc) | 56 | ||||
-rw-r--r-- | src/function/external_text_formatter.h (renamed from src/function/execute.h) | 10 | ||||
-rw-r--r-- | src/plattform_guard.cc | 6 |
3 files changed, 49 insertions, 23 deletions
diff --git a/src/function/execute.cc b/src/function/external_text_formatter.cc index f19ba75..d1b9e92 100644 --- a/src/function/execute.cc +++ b/src/function/external_text_formatter.cc @@ -1,21 +1,52 @@ -#include "execute.h" +#include "external_text_formatter.h" + +#include <xalanc/XSLT/XSLTInputSource.hpp> #include <xercesc/dom/DOMDocument.hpp> #include <xercesc/dom/DOMImplementation.hpp> #include <xercesc/dom/DOMElement.hpp> +#include <xercesc/parsers/XercesDOMParser.hpp> #include <boost/process.hpp> +#include <sstream> + #include "support/xerces_string_guard.h" #include "support/dom/result_node_facade.h" +namespace { + +using InputXSLT::XercesStringGuard; + +inline xercesc::DOMNode* importDocumentElement( + boost::process::pistream& outputStream, + xercesc::DOMDocument* const domDocument +) { + std::stringstream xmlStream( + "<output>" + std::string( + (std::istreambuf_iterator<char>(outputStream)), + (std::istreambuf_iterator<char>()) + ) + "</output>" + ); + + xercesc::XercesDOMParser parser; + parser.parse(xalan::XSLTInputSource(xmlStream)); + + return domDocument->importNode( + parser.getDocument()->getDocumentElement(), + true + ); +} + +} + namespace InputXSLT { -xercesc::DOMDocument* FunctionExecute::constructDocument( +xercesc::DOMDocument* FunctionExternalTextFormatter::constructDocument( const InputXSLT::FilesystemContext&, const FunctionBase::parameter_tuple& parameters ) { - const std::string& executablePath( + const std::string& formatterPath( std::get<0>(parameters) ); @@ -39,32 +70,27 @@ xercesc::DOMDocument* FunctionExecute::constructDocument( context.stdout_behavior = boost::process::capture_stream(); context.stdin_behavior = boost::process::capture_stream(); - boost::process::child process( + boost::process::child formatterProcess( boost::process::launch( - executablePath, + formatterPath, std::vector<std::string>{""}, context ) ); - boost::process::postream& inputStream = process.get_stdin(); - boost::process::pistream& outputStream = process.get_stdout(); + boost::process::postream& inputStream = formatterProcess.get_stdin(); + boost::process::pistream& outputStream = formatterProcess.get_stdout(); inputStream << stdinText; inputStream.close(); - const std::string resultText( - (std::istreambuf_iterator<char>(outputStream)), - (std::istreambuf_iterator<char>()) - ); - - boost::process::status status = process.wait(); + boost::process::status status = formatterProcess.wait(); if ( status.exited() ) { ResultNodeFacade result(domDocument, rootNode, "result"); - result.setValueNode("code", std::to_string(status.exit_status())); - result.setValueNode("output", resultText); + result.setValueNode("code", std::to_string(status.exit_status())); + result.setContent(importDocumentElement(outputStream, domDocument)); } else { ResultNodeFacade result(domDocument, rootNode, "error"); diff --git a/src/function/execute.h b/src/function/external_text_formatter.h index 12167da..877bac5 100644 --- a/src/function/execute.h +++ b/src/function/external_text_formatter.h @@ -1,12 +1,12 @@ -#ifndef INPUTXSLT_SRC_FUNCTION_EXECUTE_H_ -#define INPUTXSLT_SRC_FUNCTION_EXECUTE_H_ +#ifndef INPUTXSLT_SRC_FUNCTION_EXTERNAL_TEXT_FORMATTER_H_ +#define INPUTXSLT_SRC_FUNCTION_EXTERNAL_TEXT_FORMATTER_H_ #include "base.h" namespace InputXSLT { -class FunctionExecute : public FunctionBase< - FunctionExecute, +class FunctionExternalTextFormatter : public FunctionBase< + FunctionExternalTextFormatter, std::string, std::string > { @@ -25,4 +25,4 @@ class FunctionExecute : public FunctionBase< } -#endif // INPUTXSLT_SRC_FUNCTION_EXECUTE_H_ +#endif // INPUTXSLT_SRC_FUNCTION_EXTERNAL_TEXT_FORMATTER_H_ diff --git a/src/plattform_guard.cc b/src/plattform_guard.cc index ff4de08..d787adf 100644 --- a/src/plattform_guard.cc +++ b/src/plattform_guard.cc @@ -10,7 +10,7 @@ #include "function/read_xml_file.h" #include "function/read_directory.h" #include "function/transform.h" -#include "function/execute.h" +#include "function/external_text_formatter.h" namespace InputXSLT { @@ -49,8 +49,8 @@ PlattformGuard::PlattformGuard(const std::vector<std::string>& path): xalan::XalanTransformer::installExternalFunctionGlobal( customNamespace, - xalan::XalanDOMString("execute"), - InputXSLT::FunctionExecute(&this->include_resolver_) + xalan::XalanDOMString("external-text-formatter"), + InputXSLT::FunctionExternalTextFormatter(&this->include_resolver_) ); } |