libabigail
abg-libxml-utils.h
Go to the documentation of this file.
1// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
2// -*- mode: C++ -*-
3//
4// Copyright (C) 2013-2025 Red Hat, Inc.
5
6/// @file
7
8#ifndef __ABG_LIBXML_UTILS_H__
9#define __ABG_LIBXML_UTILS_H__
10
11#include <libxml/xmlreader.h>
12
13#include <istream>
14#include <memory>
15
16#include "abg-sptr-utils.h"
17
18namespace abigail
19{
20
21/// Internal namespace for xml manipulation utilities.
22namespace xml
23{
24
26using std::shared_ptr;
27
28/// A convenience typedef for a shared pointer of xmlTextReader.
29typedef shared_ptr<xmlTextReader> reader_sptr;
30
31/// A convenience typedef for a shared pointer of xmlChar.
32typedef shared_ptr<xmlChar> xml_char_sptr;
33
34/// This functor is used to instantiate a shared_ptr for the
35/// xmlTextReader.
37{
38 void
39 operator()(xmlTextReaderPtr reader)
40 {xmlFreeTextReader(reader);}
41};
42
43/// This functor is used to instantiate a shared_ptr for xmlChar
45{
46 void
47 operator()(xmlChar* str)
48 { xmlFree(str); }
49};
50
51reader_sptr new_reader_from_file(const std::string& path);
52reader_sptr new_reader_from_buffer(const std::string& buffer);
54bool xml_char_sptr_to_string(xml_char_sptr, std::string&);
55
56int get_xml_node_depth(xmlNodePtr);
57
58/// Get the name of the current element node the reader is pointing
59/// to. Note that this macro returns an instance of
60/// shared_ptr<xmlChar> so that the caller doesn't have to worry about
61/// managing memory itself. Also note that the reader is a
62/// shared_ptr<xmlTextReader>
63#define XML_READER_GET_NODE_NAME(reader) \
64 xml::build_sptr(xmlTextReaderName(reader.get()))
65
66/// Get the type of the current node of the shared_ptr<xmlTextReader>
67/// passed in argument.
68#define XML_READER_GET_NODE_TYPE(reader) \
69 static_cast<xmlReaderTypes> (xmlTextReaderNodeType(reader.get()))
70
71/// Get the value of attribute 'name' on the current node of 'reader'
72/// which is an instance of shared_ptr<xmlTextReader>.
73#define XML_READER_GET_ATTRIBUTE(reader, name) \
74 xml::build_sptr(xmlTextReaderGetAttribute(reader.get(), BAD_CAST(name)))
75
76/// Get the value of attribute 'name' ont the instance of xmlNodePtr
77/// denoted by 'node'.
78#define XML_NODE_GET_ATTRIBUTE(node, name) \
79 xml::build_sptr(xmlGetProp(node, BAD_CAST(name)))
80
81#define CHAR_STR(xml_char_str) \
82 reinterpret_cast<char*>(xml_char_str.get())
83
84void
85escape_xml_string(const std::string& str,
86 std::string& escaped);
87
88std::string
89escape_xml_string(const std::string& str);
90
91void
92escape_xml_comment(const std::string& str,
93 std::string& escaped);
94
95std::string
96escape_xml_comment(const std::string& str);
97
98void
99unescape_xml_string(const std::string& str,
100 std::string& escaped);
101
102std::string
103unescape_xml_string(const std::string& str);
104
105void
106unescape_xml_comment(const std::string& str,
107 std::string& escaped);
108
109std::string
110unescape_xml_comment(const std::string& str);
111
112}//end namespace xml
113
114namespace sptr_utils
115{
116/// Specialization of sptr_utils::build_sptr for xmlTextReader
117template<>
119build_sptr<xmlTextReader>(xmlTextReader *p);
120
121/// Specialization of build_str for xmlChar.
122template<>
124build_sptr<xmlChar>(xmlChar *p);
125}// end namespace sptr_utils
126
127}//end namespace abigail
128#endif //__ABG_LIBXML_UTILS_H__
Utilities to ease the wrapping of C types into std::shared_ptr.
shared_ptr< xmlChar > build_sptr< xmlChar >(xmlChar *p)
Build and return a shared_ptr for a pointer to xmlChar.
shared_ptr< T > build_sptr(T *p)
This is to be specialized for the diverse C types that needs wrapping in shared_ptr.
shared_ptr< xmlTextReader > build_sptr< xmlTextReader >(::xmlTextReader *p)
Build and return a shared_ptr for a pointer to xmlTextReader.
void unescape_xml_comment(const std::string &str, std::string &escaped)
Read a string, detect the '#&45;' entity and un-escape it into the '-' character.
reader_sptr new_reader_from_file(const std::string &path)
Instantiate an xmlTextReader that parses the content of an on-disk file, wrap it into a smart pointer...
int get_xml_node_depth(xmlNodePtr n)
Return the depth of an xml element node.
bool xml_char_sptr_to_string(xml_char_sptr ssptr, std::string &s)
Convert a shared pointer to xmlChar into an std::string.
void escape_xml_comment(const std::string &str, std::string &escaped)
Escape the '-' character, to avoid having a '–' in a comment.
reader_sptr new_reader_from_buffer(const std::string &buffer)
Instanciate an xmlTextReader that parses the content of an in-memory buffer, wrap it into a smart poi...
shared_ptr< xmlChar > xml_char_sptr
A convenience typedef for a shared pointer of xmlChar.
void unescape_xml_string(const std::string &str, std::string &escaped)
Read a string, detect the 5 predefined XML entities it may contain and un-escape them,...
reader_sptr new_reader_from_istream(std::istream *in)
Instanciate an xmlTextReader that parses a content coming from an input stream.
shared_ptr< xmlTextReader > reader_sptr
A convenience typedef for a shared pointer of xmlTextReader.
void escape_xml_string(const std::string &str, std::string &escaped)
Escape the 5 characters representing the predefined XML entities.
Toplevel namespace for libabigail.
This functor is used to instantiate a shared_ptr for xmlChar.
This functor is used to instantiate a shared_ptr for the xmlTextReader.