blob: 06a0337566eefae2b6f24ba02eae4960ca5e0adc [file] [log] [blame]
Georges-Henri Baroncec86c12012-09-04 17:30:28 +02001/*
David Wagnerb76c9d62014-02-05 18:30:24 +01002 * Copyright (c) 2011-2014, Intel Corporation
3 * All rights reserved.
Georges-Henri Baroncec86c12012-09-04 17:30:28 +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 Baroncec86c12012-09-04 17:30:28 +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.
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020010 *
David Wagnerb76c9d62014-02-05 18:30:24 +010011 * 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 Baroncec86c12012-09-04 17:30:28 +020029 */
30
31#pragma once
32#include "XmlDocSource.h"
33#include <string>
34
35/**
Sebastien Gonzalved9526492014-02-20 22:28:03 +010036 * Source class that get an xml document from a std::string.
Georges-Henri Baroncec86c12012-09-04 17:30:28 +020037 * Its base class will check the validity of the document.
38 */
39class CXmlStringDocSource : public CXmlDocSource
40{
41public:
42 /**
43 * Constructor
44 *
45 * @param[in] strXmlInput a string containing an xml description
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 CXmlStringDocSource(const std::string& strXmlInput,
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 /**
60 * CXmlDocSource method implementation.
61 *
62 * @param[out] serializingContext is used as error output
63 *
64 * @return false if any error occurs
65 */
66 virtual bool populate(CXmlSerializingContext& serializingContext);
67};
68
69