blob: f7b2e3016c591d12985ebaec590e97c8553eb0ee [file] [log] [blame]
Georges-Henri Baron326a31d2012-06-28 12:05:09 +02001/*
David Wagnerb76c9d62014-02-05 18:30:24 +01002 * Copyright (c) 2011-2014, Intel Corporation
3 * All rights reserved.
Georges-Henri Baron326a31d2012-06-28 12:05:09 +02004 *
David Wagnerb76c9d62014-02-05 18:30:24 +01005 * Redistribution and use in source and binary forms, with or without modification,
6 * are permitted provided that the following conditions are met:
Georges-Henri Baron326a31d2012-06-28 12:05:09 +02007 *
David Wagnerb76c9d62014-02-05 18:30:24 +01008 * 1. Redistributions of source code must retain the above copyright notice, this
9 * list of conditions and the following disclaimer.
10 *
11 * 2. Redistributions in binary form must reproduce the above copyright notice,
12 * this list of conditions and the following disclaimer in the documentation and/or
13 * other materials provided with the distribution.
14 *
15 * 3. Neither the name of the copyright holder nor the names of its contributors
16 * may be used to endorse or promote products derived from this software without
17 * specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
23 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
24 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
25 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
26 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020029 */
30
31#pragma once
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020032#include "XmlDocSource.h"
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020033#include <string>
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020034
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020035/**
36 * Source class that read a file to get an xml document.
37 * Its base class will validate the document.
38 */
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020039class CXmlFileDocSource : public CXmlDocSource
40{
41public:
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020042 /**
43 * Constructor
44 *
45 * @param[in] strXmlInstanceFile a string containing the path to the xml file
46 * @param[in] strXmlSchemaFile a string containing the path to the schema file
47 * @param[in] strRootElementType a string containing the root element type
48 * @param[in] strRootElementName a string containing the root element name
49 * @param[in] strNameAttributeName a string containing the name of the root name attribute
Mattijs Korpershoek31418912014-04-08 14:05:21 +020050 * @param[in] bValidateWithSchema a boolean that toggles schema validation
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020051 */
Sebastien Gonzalved9526492014-02-20 22:28:03 +010052 CXmlFileDocSource(const std::string& strXmlInstanceFile,
53 const std::string& strXmlSchemaFile,
54 const std::string& strRootElementType,
55 const std::string& strRootElementName,
56 const std::string& strNameAttrituteName,
Mattijs Korpershoek31418912014-04-08 14:05:21 +020057 bool bValidateWithSchema);
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020058 /**
59 * Constructor
60 *
61 * @param[in] strXmlInstanceFile a string containing the path to the xml file
62 * @param[in] strXmlSchemaFile a string containing the path to the schema file
63 * @param[in] strRootElementType a string containing the root element type
Mattijs Korpershoek31418912014-04-08 14:05:21 +020064 * @param[in] bValidateWithSchema a boolean that toggles schema validation
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020065 */
Sebastien Gonzalved9526492014-02-20 22:28:03 +010066 CXmlFileDocSource(const std::string& strXmlInstanceFile, const std::string& strXmlSchemaFile, const std::string& strRootElementType,
Mattijs Korpershoek31418912014-04-08 14:05:21 +020067 bool bValidateWithSchema);
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020068
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020069 /**
70 * CXmlDocSource method implementation.
71 *
72 * @param[out] serializingContext is used as error output
73 *
74 * @return false if any error occurs
75 */
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020076 virtual bool populate(CXmlSerializingContext& serializingContext);
77
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020078 /**
79 * Method that checks that the file exists and is readable.
80 *
81 * @param[out] serializingContext is used as error output
82 *
83 * @return false if any error occurs during the parsing
84 */
Frédéric Boisnarda409daa2012-10-18 18:20:03 +020085 virtual bool isParsable(CXmlSerializingContext& serializingContext) const;
86
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020087private:
Guillaume Denneulin3ba083e2014-01-31 15:09:42 +010088 /**
89 * Read xml file
90 *
91 * This function reads an xml file and processes eventual included files
92 * WARNING: to compile this function, libxml2 has to be compiled with LIBXML_XINCLUDE_ENABLED
93 *
94 * @param[in] strFileName the file name
95 *
96 * @return a pointer to generated xml document object
97 */
Sebastien Gonzalved9526492014-02-20 22:28:03 +010098 static _xmlDoc* readFile(const std::string& strFileName);
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020099
Georges-Henri Baroncec86c12012-09-04 17:30:28 +0200100 /**
101 * Instance file
102 */
Sebastien Gonzalved9526492014-02-20 22:28:03 +0100103 std::string _strXmlInstanceFile;
Georges-Henri Baron326a31d2012-06-28 12:05:09 +0200104};