Updated pugixml to version 1.12.1
parent
abfb26ab6f
commit
7bda8b7a77
|
@ -1,63 +0,0 @@
|
||||||
/*
|
|
||||||
* Boost.Foreach support for pugixml classes.
|
|
||||||
* This file is provided to the public domain.
|
|
||||||
* Written by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef HEADER_PUGIXML_FOREACH_HPP
|
|
||||||
#define HEADER_PUGIXML_FOREACH_HPP
|
|
||||||
|
|
||||||
#include <boost/range/iterator.hpp>
|
|
||||||
|
|
||||||
#include "pugixml.hpp"
|
|
||||||
|
|
||||||
/*
|
|
||||||
* These types add support for BOOST_FOREACH macro to xml_node and xml_document classes (child iteration only).
|
|
||||||
* Example usage:
|
|
||||||
* BOOST_FOREACH(xml_node n, doc) {}
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace boost
|
|
||||||
{
|
|
||||||
template<> struct range_mutable_iterator<pugi::xml_node>
|
|
||||||
{
|
|
||||||
typedef pugi::xml_node::iterator type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template<> struct range_const_iterator<pugi::xml_node>
|
|
||||||
{
|
|
||||||
typedef pugi::xml_node::iterator type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template<> struct range_mutable_iterator<pugi::xml_document>
|
|
||||||
{
|
|
||||||
typedef pugi::xml_document::iterator type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template<> struct range_const_iterator<pugi::xml_document>
|
|
||||||
{
|
|
||||||
typedef pugi::xml_document::iterator type;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* These types add support for BOOST_FOREACH macro to xml_node and xml_document classes (child/attribute iteration).
|
|
||||||
* Example usage:
|
|
||||||
* BOOST_FOREACH(xml_node n, children(doc)) {}
|
|
||||||
* BOOST_FOREACH(xml_node n, attributes(doc)) {}
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace pugi
|
|
||||||
{
|
|
||||||
inline xml_object_range<xml_node_iterator> children(const pugi::xml_node& node)
|
|
||||||
{
|
|
||||||
return node.children();
|
|
||||||
}
|
|
||||||
|
|
||||||
inline xml_object_range<xml_attribute_iterator> attributes(const pugi::xml_node& node)
|
|
||||||
{
|
|
||||||
return node.attributes();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -1,6 +1,6 @@
|
||||||
pugixml 1.11 - an XML processing library
|
pugixml 1.12 - an XML processing library
|
||||||
|
|
||||||
Copyright (C) 2006-2020, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
|
Copyright (C) 2006-2022, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
|
||||||
Report bugs and download new versions at https://pugixml.org/
|
Report bugs and download new versions at https://pugixml.org/
|
||||||
|
|
||||||
This is the distribution of pugixml, which is a C++ XML processing library,
|
This is the distribution of pugixml, which is a C++ XML processing library,
|
||||||
|
@ -26,7 +26,7 @@ The distribution contains the following folders:
|
||||||
|
|
||||||
This library is distributed under the MIT License:
|
This library is distributed under the MIT License:
|
||||||
|
|
||||||
Copyright (c) 2006-2019 Arseny Kapoulkine
|
Copyright (c) 2006-2022 Arseny Kapoulkine
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person
|
Permission is hereby granted, free of charge, to any person
|
||||||
obtaining a copy of this software and associated documentation
|
obtaining a copy of this software and associated documentation
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/**
|
/**
|
||||||
* pugixml parser - version 1.11
|
* pugixml parser - version 1.12
|
||||||
* --------------------------------------------------------
|
* --------------------------------------------------------
|
||||||
* Copyright (C) 2006-2020, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
|
* Copyright (C) 2006-2022, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
|
||||||
* Report bugs and download new versions at https://pugixml.org/
|
* Report bugs and download new versions at https://pugixml.org/
|
||||||
*
|
*
|
||||||
* This library is distributed under the MIT License. See notice at the end
|
* This library is distributed under the MIT License. See notice at the end
|
||||||
|
@ -52,7 +52,7 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Copyright (c) 2006-2020 Arseny Kapoulkine
|
* Copyright (c) 2006-2022 Arseny Kapoulkine
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person
|
* Permission is hereby granted, free of charge, to any person
|
||||||
* obtaining a copy of this software and associated documentation
|
* obtaining a copy of this software and associated documentation
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/**
|
/**
|
||||||
* pugixml parser - version 1.11
|
* pugixml parser - version 1.12
|
||||||
* --------------------------------------------------------
|
* --------------------------------------------------------
|
||||||
* Copyright (C) 2006-2020, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
|
* Copyright (C) 2006-2022, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
|
||||||
* Report bugs and download new versions at https://pugixml.org/
|
* Report bugs and download new versions at https://pugixml.org/
|
||||||
*
|
*
|
||||||
* This library is distributed under the MIT License. See notice at the end
|
* This library is distributed under the MIT License. See notice at the end
|
||||||
|
@ -132,8 +132,10 @@ using std::memset;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// In some environments MSVC is a compiler but the CRT lacks certain MSVC-specific features
|
// In some environments MSVC is a compiler but the CRT lacks certain MSVC-specific features
|
||||||
#if defined(_MSC_VER) && !defined(__S3E__)
|
#if defined(_MSC_VER) && !defined(__S3E__) && !defined(_WIN32_WCE)
|
||||||
# define PUGI__MSVC_CRT_VERSION _MSC_VER
|
# define PUGI__MSVC_CRT_VERSION _MSC_VER
|
||||||
|
#elif defined(_WIN32_WCE)
|
||||||
|
# define PUGI__MSVC_CRT_VERSION 1310 // MSVC7.1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Not all platforms have snprintf; we define a wrapper that uses snprintf if possible. This only works with buffers with a known size.
|
// Not all platforms have snprintf; we define a wrapper that uses snprintf if possible. This only works with buffers with a known size.
|
||||||
|
@ -526,7 +528,8 @@ PUGI__NS_BEGIN
|
||||||
xml_memory_page* page = xml_memory_page::construct(memory);
|
xml_memory_page* page = xml_memory_page::construct(memory);
|
||||||
assert(page);
|
assert(page);
|
||||||
|
|
||||||
page->allocator = _root->allocator;
|
assert(this == _root->allocator);
|
||||||
|
page->allocator = this;
|
||||||
|
|
||||||
return page;
|
return page;
|
||||||
}
|
}
|
||||||
|
@ -4732,7 +4735,7 @@ PUGI__NS_BEGIN
|
||||||
// we need to get length of entire file to load it in memory; the only (relatively) sane way to do it is via seek/tell trick
|
// we need to get length of entire file to load it in memory; the only (relatively) sane way to do it is via seek/tell trick
|
||||||
PUGI__FN xml_parse_status get_file_size(FILE* file, size_t& out_result)
|
PUGI__FN xml_parse_status get_file_size(FILE* file, size_t& out_result)
|
||||||
{
|
{
|
||||||
#if defined(PUGI__MSVC_CRT_VERSION) && PUGI__MSVC_CRT_VERSION >= 1400 && !defined(_WIN32_WCE)
|
#if defined(PUGI__MSVC_CRT_VERSION) && PUGI__MSVC_CRT_VERSION >= 1400
|
||||||
// there are 64-bit versions of fseek/ftell, let's use them
|
// there are 64-bit versions of fseek/ftell, let's use them
|
||||||
typedef __int64 length_type;
|
typedef __int64 length_type;
|
||||||
|
|
||||||
|
@ -6735,7 +6738,7 @@ namespace pugi
|
||||||
return const_cast<xml_node*>(&_wrap); // BCC5 workaround
|
return const_cast<xml_node*>(&_wrap); // BCC5 workaround
|
||||||
}
|
}
|
||||||
|
|
||||||
PUGI__FN const xml_node_iterator& xml_node_iterator::operator++()
|
PUGI__FN xml_node_iterator& xml_node_iterator::operator++()
|
||||||
{
|
{
|
||||||
assert(_wrap._root);
|
assert(_wrap._root);
|
||||||
_wrap._root = _wrap._root->next_sibling;
|
_wrap._root = _wrap._root->next_sibling;
|
||||||
|
@ -6749,7 +6752,7 @@ namespace pugi
|
||||||
return temp;
|
return temp;
|
||||||
}
|
}
|
||||||
|
|
||||||
PUGI__FN const xml_node_iterator& xml_node_iterator::operator--()
|
PUGI__FN xml_node_iterator& xml_node_iterator::operator--()
|
||||||
{
|
{
|
||||||
_wrap = _wrap._root ? _wrap.previous_sibling() : _parent.last_child();
|
_wrap = _wrap._root ? _wrap.previous_sibling() : _parent.last_child();
|
||||||
return *this;
|
return *this;
|
||||||
|
@ -6796,7 +6799,7 @@ namespace pugi
|
||||||
return const_cast<xml_attribute*>(&_wrap); // BCC5 workaround
|
return const_cast<xml_attribute*>(&_wrap); // BCC5 workaround
|
||||||
}
|
}
|
||||||
|
|
||||||
PUGI__FN const xml_attribute_iterator& xml_attribute_iterator::operator++()
|
PUGI__FN xml_attribute_iterator& xml_attribute_iterator::operator++()
|
||||||
{
|
{
|
||||||
assert(_wrap._attr);
|
assert(_wrap._attr);
|
||||||
_wrap._attr = _wrap._attr->next_attribute;
|
_wrap._attr = _wrap._attr->next_attribute;
|
||||||
|
@ -6810,7 +6813,7 @@ namespace pugi
|
||||||
return temp;
|
return temp;
|
||||||
}
|
}
|
||||||
|
|
||||||
PUGI__FN const xml_attribute_iterator& xml_attribute_iterator::operator--()
|
PUGI__FN xml_attribute_iterator& xml_attribute_iterator::operator--()
|
||||||
{
|
{
|
||||||
_wrap = _wrap._attr ? _wrap.previous_attribute() : _parent.last_attribute();
|
_wrap = _wrap._attr ? _wrap.previous_attribute() : _parent.last_attribute();
|
||||||
return *this;
|
return *this;
|
||||||
|
@ -6857,7 +6860,7 @@ namespace pugi
|
||||||
return const_cast<xml_node*>(&_wrap); // BCC5 workaround
|
return const_cast<xml_node*>(&_wrap); // BCC5 workaround
|
||||||
}
|
}
|
||||||
|
|
||||||
PUGI__FN const xml_named_node_iterator& xml_named_node_iterator::operator++()
|
PUGI__FN xml_named_node_iterator& xml_named_node_iterator::operator++()
|
||||||
{
|
{
|
||||||
assert(_wrap._root);
|
assert(_wrap._root);
|
||||||
_wrap = _wrap.next_sibling(_name);
|
_wrap = _wrap.next_sibling(_name);
|
||||||
|
@ -6871,7 +6874,7 @@ namespace pugi
|
||||||
return temp;
|
return temp;
|
||||||
}
|
}
|
||||||
|
|
||||||
PUGI__FN const xml_named_node_iterator& xml_named_node_iterator::operator--()
|
PUGI__FN xml_named_node_iterator& xml_named_node_iterator::operator--()
|
||||||
{
|
{
|
||||||
if (_wrap._root)
|
if (_wrap._root)
|
||||||
_wrap = _wrap.previous_sibling(_name);
|
_wrap = _wrap.previous_sibling(_name);
|
||||||
|
@ -7091,8 +7094,12 @@ namespace pugi
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// move allocation state
|
// move allocation state
|
||||||
doc->_root = other->_root;
|
// note that other->_root may point to the embedded document page, in which case we should keep original (empty) state
|
||||||
doc->_busy_size = other->_busy_size;
|
if (other->_root != PUGI__GETPAGE(other))
|
||||||
|
{
|
||||||
|
doc->_root = other->_root;
|
||||||
|
doc->_busy_size = other->_busy_size;
|
||||||
|
}
|
||||||
|
|
||||||
// move buffer state
|
// move buffer state
|
||||||
doc->buffer = other->buffer;
|
doc->buffer = other->buffer;
|
||||||
|
@ -8265,7 +8272,7 @@ PUGI__NS_BEGIN
|
||||||
}
|
}
|
||||||
|
|
||||||
// gets mantissa digits in the form of 0.xxxxx with 0. implied and the exponent
|
// gets mantissa digits in the form of 0.xxxxx with 0. implied and the exponent
|
||||||
#if defined(PUGI__MSVC_CRT_VERSION) && PUGI__MSVC_CRT_VERSION >= 1400 && !defined(_WIN32_WCE)
|
#if defined(PUGI__MSVC_CRT_VERSION) && PUGI__MSVC_CRT_VERSION >= 1400
|
||||||
PUGI__FN void convert_number_to_mantissa_exponent(double value, char (&buffer)[32], char** out_mantissa, int* out_exponent)
|
PUGI__FN void convert_number_to_mantissa_exponent(double value, char (&buffer)[32], char** out_mantissa, int* out_exponent)
|
||||||
{
|
{
|
||||||
// get base values
|
// get base values
|
||||||
|
@ -11822,15 +11829,17 @@ PUGI__NS_BEGIN
|
||||||
lexeme_t l = _lexer.current();
|
lexeme_t l = _lexer.current();
|
||||||
_lexer.next();
|
_lexer.next();
|
||||||
|
|
||||||
if (++_depth > xpath_ast_depth_limit)
|
|
||||||
return error_rec();
|
|
||||||
|
|
||||||
if (l == lex_double_slash)
|
if (l == lex_double_slash)
|
||||||
{
|
{
|
||||||
n = alloc_node(ast_step, n, axis_descendant_or_self, nodetest_type_node, 0);
|
n = alloc_node(ast_step, n, axis_descendant_or_self, nodetest_type_node, 0);
|
||||||
if (!n) return 0;
|
if (!n) return 0;
|
||||||
|
|
||||||
|
++_depth;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (++_depth > xpath_ast_depth_limit)
|
||||||
|
return error_rec();
|
||||||
|
|
||||||
n = parse_step(n);
|
n = parse_step(n);
|
||||||
if (!n) return 0;
|
if (!n) return 0;
|
||||||
}
|
}
|
||||||
|
@ -12995,7 +13004,7 @@ namespace pugi
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Copyright (c) 2006-2020 Arseny Kapoulkine
|
* Copyright (c) 2006-2022 Arseny Kapoulkine
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person
|
* Permission is hereby granted, free of charge, to any person
|
||||||
* obtaining a copy of this software and associated documentation
|
* obtaining a copy of this software and associated documentation
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/**
|
/**
|
||||||
* pugixml parser - version 1.11
|
* pugixml parser - version 1.12
|
||||||
* --------------------------------------------------------
|
* --------------------------------------------------------
|
||||||
* Copyright (C) 2006-2020, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
|
* Copyright (C) 2006-2022, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)
|
||||||
* Report bugs and download new versions at https://pugixml.org/
|
* Report bugs and download new versions at https://pugixml.org/
|
||||||
*
|
*
|
||||||
* This library is distributed under the MIT License. See notice at the end
|
* This library is distributed under the MIT License. See notice at the end
|
||||||
|
@ -11,10 +11,10 @@
|
||||||
* Copyright (C) 2003, by Kristen Wegner (kristen@tima.net)
|
* Copyright (C) 2003, by Kristen Wegner (kristen@tima.net)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef PUGIXML_VERSION
|
|
||||||
// Define version macro; evaluates to major * 1000 + minor * 10 + patch so that it's safe to use in less-than comparisons
|
// Define version macro; evaluates to major * 1000 + minor * 10 + patch so that it's safe to use in less-than comparisons
|
||||||
// Note: pugixml used major * 100 + minor * 10 + patch format up until 1.9 (which had version identifier 190); starting from pugixml 1.10, the minor version number is two digits
|
// Note: pugixml used major * 100 + minor * 10 + patch format up until 1.9 (which had version identifier 190); starting from pugixml 1.10, the minor version number is two digits
|
||||||
# define PUGIXML_VERSION 1110
|
#ifndef PUGIXML_VERSION
|
||||||
|
# define PUGIXML_VERSION 1120 // 1.12
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Include user configuration file (this can define various configuration macros)
|
// Include user configuration file (this can define various configuration macros)
|
||||||
|
@ -312,6 +312,8 @@ namespace pugi
|
||||||
It begin() const { return _begin; }
|
It begin() const { return _begin; }
|
||||||
It end() const { return _end; }
|
It end() const { return _end; }
|
||||||
|
|
||||||
|
bool empty() const { return _begin == _end; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
It _begin, _end;
|
It _begin, _end;
|
||||||
};
|
};
|
||||||
|
@ -851,10 +853,10 @@ namespace pugi
|
||||||
xml_node& operator*() const;
|
xml_node& operator*() const;
|
||||||
xml_node* operator->() const;
|
xml_node* operator->() const;
|
||||||
|
|
||||||
const xml_node_iterator& operator++();
|
xml_node_iterator& operator++();
|
||||||
xml_node_iterator operator++(int);
|
xml_node_iterator operator++(int);
|
||||||
|
|
||||||
const xml_node_iterator& operator--();
|
xml_node_iterator& operator--();
|
||||||
xml_node_iterator operator--(int);
|
xml_node_iterator operator--(int);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -893,10 +895,10 @@ namespace pugi
|
||||||
xml_attribute& operator*() const;
|
xml_attribute& operator*() const;
|
||||||
xml_attribute* operator->() const;
|
xml_attribute* operator->() const;
|
||||||
|
|
||||||
const xml_attribute_iterator& operator++();
|
xml_attribute_iterator& operator++();
|
||||||
xml_attribute_iterator operator++(int);
|
xml_attribute_iterator operator++(int);
|
||||||
|
|
||||||
const xml_attribute_iterator& operator--();
|
xml_attribute_iterator& operator--();
|
||||||
xml_attribute_iterator operator--(int);
|
xml_attribute_iterator operator--(int);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -929,10 +931,10 @@ namespace pugi
|
||||||
xml_node& operator*() const;
|
xml_node& operator*() const;
|
||||||
xml_node* operator->() const;
|
xml_node* operator->() const;
|
||||||
|
|
||||||
const xml_named_node_iterator& operator++();
|
xml_named_node_iterator& operator++();
|
||||||
xml_named_node_iterator operator++(int);
|
xml_named_node_iterator operator++(int);
|
||||||
|
|
||||||
const xml_named_node_iterator& operator--();
|
xml_named_node_iterator& operator--();
|
||||||
xml_named_node_iterator operator--(int);
|
xml_named_node_iterator operator--(int);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -1474,7 +1476,7 @@ namespace std
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Copyright (c) 2006-2020 Arseny Kapoulkine
|
* Copyright (c) 2006-2022 Arseny Kapoulkine
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person
|
* Permission is hereby granted, free of charge, to any person
|
||||||
* obtaining a copy of this software and associated documentation
|
* obtaining a copy of this software and associated documentation
|
||||||
|
|
Loading…
Reference in New Issue