blob: 7a8bb8d9c8affaf6fd4b4660d3956ffc7cc1097f [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
50 */
51 CXmlFileDocSource(const string& strXmlInstanceFile,
52 const string& strXmlSchemaFile,
53 const string& strRootElementType,
54 const string& strRootElementName,
55 const string& strNameAttrituteName);
56 /**
57 * Constructor
58 *
59 * @param[in] strXmlInstanceFile a string containing the path to the xml file
60 * @param[in] strXmlSchemaFile a string containing the path to the schema file
61 * @param[in] strRootElementType a string containing the root element type
62 */
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020063 CXmlFileDocSource(const string& strXmlInstanceFile, const string& strXmlSchemaFile, const string& strRootElementType);
64
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020065 /**
66 * CXmlDocSource method implementation.
67 *
68 * @param[out] serializingContext is used as error output
69 *
70 * @return false if any error occurs
71 */
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020072 virtual bool populate(CXmlSerializingContext& serializingContext);
73
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020074 /**
75 * Method that checks that the file exists and is readable.
76 *
77 * @param[out] serializingContext is used as error output
78 *
79 * @return false if any error occurs during the parsing
80 */
Frédéric Boisnarda409daa2012-10-18 18:20:03 +020081 virtual bool isParsable(CXmlSerializingContext& serializingContext) const;
82
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020083private:
Guillaume Denneulin3ba083e2014-01-31 15:09:42 +010084 /**
85 * Read xml file
86 *
87 * This function reads an xml file and processes eventual included files
88 * WARNING: to compile this function, libxml2 has to be compiled with LIBXML_XINCLUDE_ENABLED
89 *
90 * @param[in] strFileName the file name
91 *
92 * @return a pointer to generated xml document object
93 */
94 static _xmlDoc* readFile(const string& strFileName);
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020095
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020096 /**
97 * Instance file
98 */
Georges-Henri Baron326a31d2012-06-28 12:05:09 +020099 string _strXmlInstanceFile;
Georges-Henri Baron326a31d2012-06-28 12:05:09 +0200100};