From f05e742b88e3ebf7401c252332022f1a2f7eb8b0 Mon Sep 17 00:00:00 2001 From: Adrian Kummerlaender Date: Fri, 4 Jul 2014 22:41:17 +0200 Subject: Changed FunctionTransform result type to node-set * using xalan::FormatterToXercesDOM internally ** this required changes to the TransformationFacade::generate member method overloads * TransformationFacade::generate now accepts references to xalan::FormatterListener instances ** "generate(std::basic_ostream&..." instantiates a xalan::FormatterToXML and passes it to the actual generate member method * changed ResultNodeFacade's "getNode" method into a "getResultElement" method ** xalan::FormatterToXercesDOM requires a xercesc::DOMElement instance instead of the previously available xercesc::DOMNode instance ** changed FunctionReadDirectory accordingly * adapted FunctionTransform test case accordingly --- src/transformation_facade.cc | 38 ++++++++++++++++++++++---------------- 1 file changed, 22 insertions(+), 16 deletions(-) (limited to 'src/transformation_facade.cc') diff --git a/src/transformation_facade.cc b/src/transformation_facade.cc index 9d248b8..4017cd0 100644 --- a/src/transformation_facade.cc +++ b/src/transformation_facade.cc @@ -2,6 +2,9 @@ #include #include +#include +#include +#include #include "support/xerces_string_guard.h" @@ -66,42 +69,45 @@ WarningCapacitor::warning_cache_ptr TransformationFacade::getCachedWarnings() { return this->warning_capacitor_.discharge(); } -void TransformationFacade::generate(std::basic_ostream& targetStream) { +void TransformationFacade::generate( + std::basic_ostream& targetStream, + const xalan::XObjectPtr& parameter +) { StylesheetParameterGuard guard(this->transformer_); + guard.set("parameters", parameter); - this->generate(targetStream, guard); + this->generate(targetStream); } -void TransformationFacade::generate( - std::basic_ostream& targetStream, - const StylesheetParameterGuard::map& parameters -) { - StylesheetParameterGuard guard(this->transformer_, parameters); +void TransformationFacade::generate(std::basic_ostream& targetStream) { + StylesheetParameterGuard guard(this->transformer_); + + xalan::XalanStdOutputStream outputStream(targetStream); + xalan::XalanOutputStreamPrintWriter outputWriter(outputStream); - this->generate(targetStream, guard); + xalan::FormatterToXML formatter(outputWriter); + formatter.setDoIndent(true); + + this->generate(formatter); } void TransformationFacade::generate( - std::basic_ostream& targetStream, + xalan::FormatterListener& formatter, const xalan::XObjectPtr& parameter ) { StylesheetParameterGuard guard(this->transformer_); guard.set("parameters", parameter); - this->generate(targetStream, guard); + this->generate(formatter); } - -void TransformationFacade::generate( - std::basic_ostream& targetStream, - StylesheetParameterGuard& -) { +void TransformationFacade::generate(xalan::FormatterListener& target) { ErrorCapacitor errorCapacitor(&this->error_multiplexer_); this->transformer_.transform( *(this->input_), this->transformation_, - targetStream + target ); errorCapacitor.discharge(); -- cgit v1.2.3