1*c33452fbSAndroid Build Coastguard Worker /* 2*c33452fbSAndroid Build Coastguard Worker * Copyright (c) 2011-2015, Intel Corporation 3*c33452fbSAndroid Build Coastguard Worker * All rights reserved. 4*c33452fbSAndroid Build Coastguard Worker * 5*c33452fbSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without modification, 6*c33452fbSAndroid Build Coastguard Worker * are permitted provided that the following conditions are met: 7*c33452fbSAndroid Build Coastguard Worker * 8*c33452fbSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright notice, this 9*c33452fbSAndroid Build Coastguard Worker * list of conditions and the following disclaimer. 10*c33452fbSAndroid Build Coastguard Worker * 11*c33452fbSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright notice, 12*c33452fbSAndroid Build Coastguard Worker * this list of conditions and the following disclaimer in the documentation and/or 13*c33452fbSAndroid Build Coastguard Worker * other materials provided with the distribution. 14*c33452fbSAndroid Build Coastguard Worker * 15*c33452fbSAndroid Build Coastguard Worker * 3. Neither the name of the copyright holder nor the names of its contributors 16*c33452fbSAndroid Build Coastguard Worker * may be used to endorse or promote products derived from this software without 17*c33452fbSAndroid Build Coastguard Worker * specific prior written permission. 18*c33452fbSAndroid Build Coastguard Worker * 19*c33452fbSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 20*c33452fbSAndroid Build Coastguard Worker * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 21*c33452fbSAndroid Build Coastguard Worker * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 22*c33452fbSAndroid Build Coastguard Worker * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR 23*c33452fbSAndroid Build Coastguard Worker * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 24*c33452fbSAndroid Build Coastguard Worker * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 25*c33452fbSAndroid Build Coastguard Worker * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON 26*c33452fbSAndroid Build Coastguard Worker * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 27*c33452fbSAndroid Build Coastguard Worker * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 28*c33452fbSAndroid Build Coastguard Worker * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 29*c33452fbSAndroid Build Coastguard Worker */ 30*c33452fbSAndroid Build Coastguard Worker 31*c33452fbSAndroid Build Coastguard Worker #pragma once 32*c33452fbSAndroid Build Coastguard Worker #include "XmlElement.h" 33*c33452fbSAndroid Build Coastguard Worker #include "XmlSerializingContext.h" 34*c33452fbSAndroid Build Coastguard Worker 35*c33452fbSAndroid Build Coastguard Worker #include "NonCopyable.hpp" 36*c33452fbSAndroid Build Coastguard Worker 37*c33452fbSAndroid Build Coastguard Worker #include <string> 38*c33452fbSAndroid Build Coastguard Worker 39*c33452fbSAndroid Build Coastguard Worker struct _xmlDoc; 40*c33452fbSAndroid Build Coastguard Worker struct _xmlNode; 41*c33452fbSAndroid Build Coastguard Worker struct _xmlError; 42*c33452fbSAndroid Build Coastguard Worker 43*c33452fbSAndroid Build Coastguard Worker /** 44*c33452fbSAndroid Build Coastguard Worker * The CXmlDocSource is used by CXmlDocSink. 45*c33452fbSAndroid Build Coastguard Worker * The interaction between the xml source and xml sink is defined 46*c33452fbSAndroid Build Coastguard Worker * in the process method of CXmlDocSink. One can subclass CXmlDocSource 47*c33452fbSAndroid Build Coastguard Worker * for different purposes by implementing the populate method and then 48*c33452fbSAndroid Build Coastguard Worker * use it with any existing implementation of CXmlDocSink. 49*c33452fbSAndroid Build Coastguard Worker */ 50*c33452fbSAndroid Build Coastguard Worker class CXmlDocSource : private utility::NonCopyable 51*c33452fbSAndroid Build Coastguard Worker { 52*c33452fbSAndroid Build Coastguard Worker public: 53*c33452fbSAndroid Build Coastguard Worker /** 54*c33452fbSAndroid Build Coastguard Worker * Constructor 55*c33452fbSAndroid Build Coastguard Worker * 56*c33452fbSAndroid Build Coastguard Worker * @param[out] pDoc a pointer to the xml document that will be filled by the class 57*c33452fbSAndroid Build Coastguard Worker * @param[in] pRootNode a pointer to the root element of the document. 58*c33452fbSAndroid Build Coastguard Worker * @param[in] bValidateWithSchema a boolean that toggles schema validation 59*c33452fbSAndroid Build Coastguard Worker */ 60*c33452fbSAndroid Build Coastguard Worker CXmlDocSource(_xmlDoc *pDoc, bool bValidateWithSchema = false, _xmlNode *pRootNode = nullptr); 61*c33452fbSAndroid Build Coastguard Worker 62*c33452fbSAndroid Build Coastguard Worker /** 63*c33452fbSAndroid Build Coastguard Worker * Constructor 64*c33452fbSAndroid Build Coastguard Worker * 65*c33452fbSAndroid Build Coastguard Worker * @param[out] pDoc a pointer to the xml document that will be filled by the class 66*c33452fbSAndroid Build Coastguard Worker * @param[in] strRootElementType a string containing the root element type 67*c33452fbSAndroid Build Coastguard Worker * @param[in] strRootElementName a string containing the root element name 68*c33452fbSAndroid Build Coastguard Worker * @param[in] strNameAttributeName a string containing the name of the root name attribute 69*c33452fbSAndroid Build Coastguard Worker * @param[in] bValidateWithSchema a boolean that toggles schema validation 70*c33452fbSAndroid Build Coastguard Worker */ 71*c33452fbSAndroid Build Coastguard Worker CXmlDocSource(_xmlDoc *pDoc, bool bValidateWithSchema, 72*c33452fbSAndroid Build Coastguard Worker const std::string &strRootElementType = "", 73*c33452fbSAndroid Build Coastguard Worker const std::string &strRootElementName = "", 74*c33452fbSAndroid Build Coastguard Worker const std::string &strNameAttributeName = ""); 75*c33452fbSAndroid Build Coastguard Worker 76*c33452fbSAndroid Build Coastguard Worker /** 77*c33452fbSAndroid Build Coastguard Worker * Destructor 78*c33452fbSAndroid Build Coastguard Worker */ 79*c33452fbSAndroid Build Coastguard Worker virtual ~CXmlDocSource(); 80*c33452fbSAndroid Build Coastguard Worker 81*c33452fbSAndroid Build Coastguard Worker /** 82*c33452fbSAndroid Build Coastguard Worker * Method called by the CXmlDocSink::process method. 83*c33452fbSAndroid Build Coastguard Worker * 84*c33452fbSAndroid Build Coastguard Worker * @param[out] serializingContext is used as error output 85*c33452fbSAndroid Build Coastguard Worker * 86*c33452fbSAndroid Build Coastguard Worker * @return false if there are any error 87*c33452fbSAndroid Build Coastguard Worker */ 88*c33452fbSAndroid Build Coastguard Worker virtual bool populate(CXmlSerializingContext &serializingContext); 89*c33452fbSAndroid Build Coastguard Worker 90*c33452fbSAndroid Build Coastguard Worker /** 91*c33452fbSAndroid Build Coastguard Worker * Method that returns the root element of the Xml tree. 92*c33452fbSAndroid Build Coastguard Worker * 93*c33452fbSAndroid Build Coastguard Worker * @param[out] xmlRootElement a reference to the CXmleElement destination 94*c33452fbSAndroid Build Coastguard Worker */ 95*c33452fbSAndroid Build Coastguard Worker void getRootElement(CXmlElement &xmlRootElement) const; 96*c33452fbSAndroid Build Coastguard Worker 97*c33452fbSAndroid Build Coastguard Worker /** 98*c33452fbSAndroid Build Coastguard Worker * Getter method. 99*c33452fbSAndroid Build Coastguard Worker * 100*c33452fbSAndroid Build Coastguard Worker * @return the root element's name 101*c33452fbSAndroid Build Coastguard Worker */ 102*c33452fbSAndroid Build Coastguard Worker std::string getRootElementName() const; 103*c33452fbSAndroid Build Coastguard Worker 104*c33452fbSAndroid Build Coastguard Worker /** Get the Schemas' base (folder) URI 105*c33452fbSAndroid Build Coastguard Worker */ 106*c33452fbSAndroid Build Coastguard Worker std::string getSchemaBaseUri(); 107*c33452fbSAndroid Build Coastguard Worker 108*c33452fbSAndroid Build Coastguard Worker /** Set the Schema's base (folder) URI 109*c33452fbSAndroid Build Coastguard Worker * 110*c33452fbSAndroid Build Coastguard Worker * The schema for validating the XML document will be searched for in that 111*c33452fbSAndroid Build Coastguard Worker * folder. 112*c33452fbSAndroid Build Coastguard Worker * 113*c33452fbSAndroid Build Coastguard Worker * @param[in] uri The Schemas' base URI 114*c33452fbSAndroid Build Coastguard Worker */ 115*c33452fbSAndroid Build Coastguard Worker void setSchemaBaseUri(const std::string &uri); 116*c33452fbSAndroid Build Coastguard Worker 117*c33452fbSAndroid Build Coastguard Worker /** 118*c33452fbSAndroid Build Coastguard Worker * Getter method. 119*c33452fbSAndroid Build Coastguard Worker * Method that returns the root element's attribute with name matching strAttributeName. 120*c33452fbSAndroid Build Coastguard Worker * 121*c33452fbSAndroid Build Coastguard Worker * @param[in] strAttributeName is a std::string used to find the corresponding attribute 122*c33452fbSAndroid Build Coastguard Worker * 123*c33452fbSAndroid Build Coastguard Worker * @return the value of the root's attribute named as strAttributeName 124*c33452fbSAndroid Build Coastguard Worker */ 125*c33452fbSAndroid Build Coastguard Worker std::string getRootElementAttributeString(const std::string &strAttributeName) const; 126*c33452fbSAndroid Build Coastguard Worker 127*c33452fbSAndroid Build Coastguard Worker /** 128*c33452fbSAndroid Build Coastguard Worker * Getter method. 129*c33452fbSAndroid Build Coastguard Worker * Method that returns the xmlDoc contained in the Source. 130*c33452fbSAndroid Build Coastguard Worker * (Can be used in a Doc Sink) 131*c33452fbSAndroid Build Coastguard Worker * 132*c33452fbSAndroid Build Coastguard Worker * @return the document _pDoc 133*c33452fbSAndroid Build Coastguard Worker */ 134*c33452fbSAndroid Build Coastguard Worker _xmlDoc *getDoc() const; 135*c33452fbSAndroid Build Coastguard Worker 136*c33452fbSAndroid Build Coastguard Worker /** 137*c33452fbSAndroid Build Coastguard Worker * Method that checks that the xml document has been correctly parsed. 138*c33452fbSAndroid Build Coastguard Worker * 139*c33452fbSAndroid Build Coastguard Worker * @return false if any error occurs during the parsing 140*c33452fbSAndroid Build Coastguard Worker */ 141*c33452fbSAndroid Build Coastguard Worker virtual bool isParsable() const; 142*c33452fbSAndroid Build Coastguard Worker 143*c33452fbSAndroid Build Coastguard Worker /** 144*c33452fbSAndroid Build Coastguard Worker * Helper method to build final URI from base and relative uri/path 145*c33452fbSAndroid Build Coastguard Worker * 146*c33452fbSAndroid Build Coastguard Worker * base = "/path/to/file.xml" 147*c33452fbSAndroid Build Coastguard Worker * - uri - returned value 148*c33452fbSAndroid Build Coastguard Worker * . /path/to/ 149*c33452fbSAndroid Build Coastguard Worker * file.xsd /path/to/file.xsd 150*c33452fbSAndroid Build Coastguard Worker * ../from/file.xsd /path/from/file.xsd 151*c33452fbSAndroid Build Coastguard Worker * /path2/file.xsd /path2/file.xsd 152*c33452fbSAndroid Build Coastguard Worker * 153*c33452fbSAndroid Build Coastguard Worker * @param[in] base uri, if base is directory, it must contains separator last 154*c33452fbSAndroid Build Coastguard Worker * @param[in] relative uri 155*c33452fbSAndroid Build Coastguard Worker * 156*c33452fbSAndroid Build Coastguard Worker * @return new made URI if succeeded relative input otherwise 157*c33452fbSAndroid Build Coastguard Worker */ 158*c33452fbSAndroid Build Coastguard Worker static std::string mkUri(const std::string &base, const std::string &relative); 159*c33452fbSAndroid Build Coastguard Worker 160*c33452fbSAndroid Build Coastguard Worker /** 161*c33452fbSAndroid Build Coastguard Worker * Helper method for creating an xml document from either a file or a 162*c33452fbSAndroid Build Coastguard Worker * string. 163*c33452fbSAndroid Build Coastguard Worker * 164*c33452fbSAndroid Build Coastguard Worker * @param[in] source either a filename or a string representing an xml document 165*c33452fbSAndroid Build Coastguard Worker * @param[in] fromFile true if source is a filename, false if source is an xml 166*c33452fbSAndroid Build Coastguard Worker * represents an xml document 167*c33452fbSAndroid Build Coastguard Worker * @param[in] xincludes if true, process xincludes tags 168*c33452fbSAndroid Build Coastguard Worker * @param[in] serializingContext will receive any serialization error 169*c33452fbSAndroid Build Coastguard Worker */ 170*c33452fbSAndroid Build Coastguard Worker static _xmlDoc *mkXmlDoc(const std::string &source, bool fromFile, bool xincludes, 171*c33452fbSAndroid Build Coastguard Worker CXmlSerializingContext &serializingContext); 172*c33452fbSAndroid Build Coastguard Worker 173*c33452fbSAndroid Build Coastguard Worker protected: 174*c33452fbSAndroid Build Coastguard Worker /** 175*c33452fbSAndroid Build Coastguard Worker * Doc 176*c33452fbSAndroid Build Coastguard Worker */ 177*c33452fbSAndroid Build Coastguard Worker _xmlDoc *_pDoc; 178*c33452fbSAndroid Build Coastguard Worker 179*c33452fbSAndroid Build Coastguard Worker /** 180*c33452fbSAndroid Build Coastguard Worker * Root node 181*c33452fbSAndroid Build Coastguard Worker */ 182*c33452fbSAndroid Build Coastguard Worker _xmlNode *_pRootNode; 183*c33452fbSAndroid Build Coastguard Worker 184*c33452fbSAndroid Build Coastguard Worker private: 185*c33452fbSAndroid Build Coastguard Worker /** Method that check the validity of the document with the xsd file. 186*c33452fbSAndroid Build Coastguard Worker * 187*c33452fbSAndroid Build Coastguard Worker * @return true if document is valid, false if any error occures 188*c33452fbSAndroid Build Coastguard Worker */ 189*c33452fbSAndroid Build Coastguard Worker bool isInstanceDocumentValid(); 190*c33452fbSAndroid Build Coastguard Worker std::string getSchemaUri() const; 191*c33452fbSAndroid Build Coastguard Worker 192*c33452fbSAndroid Build Coastguard Worker /** 193*c33452fbSAndroid Build Coastguard Worker * Element type info 194*c33452fbSAndroid Build Coastguard Worker */ 195*c33452fbSAndroid Build Coastguard Worker std::string _strRootElementType; 196*c33452fbSAndroid Build Coastguard Worker 197*c33452fbSAndroid Build Coastguard Worker /** 198*c33452fbSAndroid Build Coastguard Worker * Element name info 199*c33452fbSAndroid Build Coastguard Worker */ 200*c33452fbSAndroid Build Coastguard Worker std::string _strRootElementName; 201*c33452fbSAndroid Build Coastguard Worker 202*c33452fbSAndroid Build Coastguard Worker /** 203*c33452fbSAndroid Build Coastguard Worker * Element name attribute info 204*c33452fbSAndroid Build Coastguard Worker */ 205*c33452fbSAndroid Build Coastguard Worker std::string _strNameAttributeName; 206*c33452fbSAndroid Build Coastguard Worker 207*c33452fbSAndroid Build Coastguard Worker /** 208*c33452fbSAndroid Build Coastguard Worker * Boolean that enables the validation via xsd files 209*c33452fbSAndroid Build Coastguard Worker */ 210*c33452fbSAndroid Build Coastguard Worker bool _bValidateWithSchema; 211*c33452fbSAndroid Build Coastguard Worker 212*c33452fbSAndroid Build Coastguard Worker std::string _schemaBaseUri; 213*c33452fbSAndroid Build Coastguard Worker }; 214