From ddfe25807ef90ddd3d10fd4532875ffdb5d5e9c5 Mon Sep 17 00:00:00 2001 From: Adrian Kummerländer Date: Tue, 29 Apr 2014 19:24:58 +0200 Subject: Simplified external function result node set * all functions return a single "error" node in the case that something went wrong * otherwise they return one or more "result" nodes that contain the function results and may be distinguished by one or more attributes * this makes handling the return values easier and more pleasing to the eye as not everything has to be prefixed by "self::*" * updated test transformation accordingly --- dummy/transform.xsl | 28 ++++++++++++++-------------- src/function/read_directory.cc | 34 ++++------------------------------ src/function/read_file.cc | 29 +++++++---------------------- src/function/read_xml_file.cc | 35 ++++++++++------------------------- 4 files changed, 35 insertions(+), 91 deletions(-) diff --git a/dummy/transform.xsl b/dummy/transform.xsl index 359db05..eab7a81 100644 --- a/dummy/transform.xsl +++ b/dummy/transform.xsl @@ -20,11 +20,11 @@
- - + + Could not read text file. - Could not read text file. +
@@ -32,15 +32,15 @@
- + + Could not read XML file. + +
    - +
-
- - Could not read XML file.
@@ -48,20 +48,20 @@
- + + Could not read directory. + +
    - +
    - +
-
- - Could not read directory.
diff --git a/src/function/read_directory.cc b/src/function/read_directory.cc index b0ae13f..686767d 100644 --- a/src/function/read_directory.cc +++ b/src/function/read_directory.cc @@ -37,15 +37,11 @@ xalan::XObjectPtr FunctionReadDirectory::execute( ); if ( boost::filesystem::is_directory(directoryPath) ) { - xercesc::DOMElement* const contentNode( - domDocument->createElement(*XercesStringGuard("content")) - ); - this->fs_context_.iterate( argument->str(), - [&domDocument, &contentNode](const boost::filesystem::path& p) { + [&domDocument, &rootNode](const boost::filesystem::path& p) { xercesc::DOMElement* const itemNode( - domDocument->createElement(*XercesStringGuard("item")) + domDocument->createElement(*XercesStringGuard("result")) ); switch ( boost::filesystem::status(p).type() ) { @@ -77,35 +73,13 @@ xalan::XObjectPtr FunctionReadDirectory::execute( ); itemNode->appendChild(textNode); - contentNode->appendChild(itemNode); + rootNode->appendChild(itemNode); }); - - xercesc::DOMElement* const resultNode( - domDocument->createElement(*XercesStringGuard("status")) - ); - - xercesc::DOMText* const resultTextNode( - domDocument->createTextNode( - *XercesStringGuard("successful") - ) - ); - - resultNode->appendChild(resultTextNode); - - rootNode->appendChild(contentNode); - rootNode->appendChild(resultNode); } else { xercesc::DOMElement* const resultNode( - domDocument->createElement(*XercesStringGuard("status")) - ); - - xercesc::DOMText* const resultTextNode( - domDocument->createTextNode( - *XercesStringGuard("error") - ) + domDocument->createElement(*XercesStringGuard("error")) ); - resultNode->appendChild(resultTextNode); rootNode->appendChild(resultNode); } } diff --git a/src/function/read_file.cc b/src/function/read_file.cc index cfbec59..83456c6 100644 --- a/src/function/read_file.cc +++ b/src/function/read_file.cc @@ -48,43 +48,28 @@ xalan::XObjectPtr FunctionReadFile::execute( (std::istreambuf_iterator()) ); - xercesc::DOMElement* const contentNode( - domDocument->createElement(*XercesStringGuard("content")) - ); - - xercesc::DOMText* const contentTextNode( - domDocument->createTextNode( - *XercesStringGuard(fileContent) - ) + xercesc::DOMElement* const resultNode( + domDocument->createElement(*XercesStringGuard("result")) ); - xercesc::DOMElement* const resultNode( - domDocument->createElement(*XercesStringGuard("status")) + resultNode->setAttribute( + *XercesStringGuard("name"), + *XercesStringGuard(filePath.filename().string()) ); xercesc::DOMText* const resultTextNode( domDocument->createTextNode( - *XercesStringGuard("successful") + *XercesStringGuard(fileContent) ) ); - contentNode->appendChild(contentTextNode); resultNode->appendChild(resultTextNode); - - rootNode->appendChild(contentNode); rootNode->appendChild(resultNode); } else { xercesc::DOMElement* const resultNode( - domDocument->createElement(*XercesStringGuard("status")) + domDocument->createElement(*XercesStringGuard("error")) ); - xercesc::DOMText* const resultTextNode( - domDocument->createTextNode( - *XercesStringGuard("error") - ) - ); - - resultNode->appendChild(resultTextNode); rootNode->appendChild(resultNode); } } diff --git a/src/function/read_xml_file.cc b/src/function/read_xml_file.cc index 52f7735..7b54732 100644 --- a/src/function/read_xml_file.cc +++ b/src/function/read_xml_file.cc @@ -40,48 +40,33 @@ xalan::XObjectPtr FunctionReadXmlFile::execute( ); if ( boost::filesystem::is_regular_file(filePath) ) { - xercesc::DOMElement* const contentNode( - domDocument->createElement(*XercesStringGuard("content")) + xercesc::DOMElement* const resultNode( + domDocument->createElement(*XercesStringGuard("result")) + ); + + resultNode->setAttribute( + *XercesStringGuard("name"), + *XercesStringGuard(filePath.filename().string()) ); xercesc::XercesDOMParser parser; boost::filesystem::ifstream file(filePath); parser.parse(xalan::XSLTInputSource(file)); - xercesc::DOMNode* const contentTreeNode( + xercesc::DOMNode* const resultTreeNode( domDocument->importNode( parser.getDocument()->getDocumentElement(), true ) ); - xercesc::DOMElement* const resultNode( - domDocument->createElement(*XercesStringGuard("status")) - ); - - xercesc::DOMText* const resultTextNode( - domDocument->createTextNode( - *XercesStringGuard("successful") - ) - ); - - contentNode->appendChild(contentTreeNode); - resultNode->appendChild(resultTextNode); - - rootNode->appendChild(contentNode); + resultNode->appendChild(resultTreeNode); rootNode->appendChild(resultNode); } else { xercesc::DOMElement* const resultNode( - domDocument->createElement(*XercesStringGuard("status")) - ); - - xercesc::DOMText* const resultTextNode( - domDocument->createTextNode( - *XercesStringGuard("error") - ) + domDocument->createElement(*XercesStringGuard("error")) ); - resultNode->appendChild(resultTextNode); rootNode->appendChild(resultNode); } } -- cgit v1.2.3