Microsoft Information Protection (MIP) SDK for C++: Reference 1.15
Doxygen-generated documentation for MIP SDK written in C++
Loading...
Searching...
No Matches
xml_document.h
Go to the documentation of this file.
1/*
2 *
3 * Copyright (c) Microsoft Corporation.
4 * All rights reserved.
5 *
6 * This code is licensed under the MIT License.
7 *
8 * Permission is hereby granted, free of charge, to any person obtaining a copy
9 * of this software and associated documentation files(the "Software"), to deal
10 * in the Software without restriction, including without limitation the rights
11 * to use, copy, modify, merge, publish, distribute, sublicense, and / or sell
12 * copies of the Software, and to permit persons to whom the Software is
13 * furnished to do so, subject to the following conditions :
14 *
15 * The above copyright notice and this permission notice shall be included in
16 * all copies or substantial portions of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE
21 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24 * THE SOFTWARE.
25 *
26 */
27 /**
28 * @brief Contains XmlDocument interface definition used to interact with xml parsers
29 *
30 * @file xml_document.h
31 */
32#ifndef API_MIP_XML_DOCUMENT_H_
33#define API_MIP_XML_DOCUMENT_H_
34
35#include <memory>
36#include <string>
37#include <vector>
38
39#include "mip/mip_namespace.h"
40#include "mip/xml_node.h"
41
42MIP_NAMESPACE_BEGIN
43
44namespace xml {
45
46/**
47 * Interface to interact with XML document.
48 */
50public:
51 /**
52 * @brief Get matching xml nodes from a specified xpath. Will throw exception of type mip::BadInputError
53 * if xml nodes cannot be parsed, there is an invalid encoding, or the xpath cannot be interpreted
54 *
55 * @param xpath The path to search the xml document for the node
56 * @param node Specify children of a specific node
57 *
58 * @return A vector of matching XmlNode shared pointers or an empty vector if none match
59 */
60 virtual std::vector<std::shared_ptr<XmlNode>> SelectNodes(
61 const std::string& xpath,
62 const std::shared_ptr<XmlNode>& node = nullptr) const = 0;
63 /**
64 * @brief Parse an xml formatted buffer into an xmldocument
65 *
66 * @return A utf-8 xml formatted string of the content of this XmlDocument
67 */
68 virtual std::string GetXmlContent() const = 0;
69 /**
70 * @brief Get the node that is an ancestor of all other nodes
71 *
72 * @return A shared_ptr to an XmlNode
73 */
74 virtual std::shared_ptr<XmlNode> GetRootNode() const = 0;
75
76 /** @cond DOXYGEN_HIDE */
77 virtual ~XmlDocument() {}
78 /** @endcond */
79};
80
81} // xml
82
83MIP_NAMESPACE_END
84
85#endif // API_MIP_XML_DOCUMENT_H_
Interface to interact with XML document.
virtual std::vector< std::shared_ptr< XmlNode > > SelectNodes(const std::string &xpath, const std::shared_ptr< XmlNode > &node=nullptr) const =0
Get matching xml nodes from a specified xpath.
virtual std::shared_ptr< XmlNode > GetRootNode() const =0
Get the node that is an ancestor of all other nodes.
virtual std::string GetXmlContent() const =0
Parse an xml formatted buffer into an xmldocument.
MIP namespace macros.
Contains XmlNode interface definition used to interact with xml parsers.