Merge pull request #1866 from ylavic/std_allocator_traits
Make StdAllocator C++17-20 compatible.
This commit is contained in:
commit
b996a23714
@ -19,6 +19,10 @@
|
|||||||
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
|
#if RAPIDJSON_HAS_CXX11
|
||||||
|
#include <type_traits>
|
||||||
|
#endif
|
||||||
|
|
||||||
RAPIDJSON_NAMESPACE_BEGIN
|
RAPIDJSON_NAMESPACE_BEGIN
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
@ -420,6 +424,11 @@ class StdAllocator :
|
|||||||
public std::allocator<T>
|
public std::allocator<T>
|
||||||
{
|
{
|
||||||
typedef std::allocator<T> allocator_type;
|
typedef std::allocator<T> allocator_type;
|
||||||
|
#if RAPIDJSON_HAS_CXX11
|
||||||
|
typedef std::allocator_traits<allocator_type> traits_type;
|
||||||
|
#else
|
||||||
|
typedef allocator_type traits_type;
|
||||||
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
typedef BaseAllocator BaseAllocatorType;
|
typedef BaseAllocator BaseAllocatorType;
|
||||||
@ -449,29 +458,51 @@ public:
|
|||||||
~StdAllocator() RAPIDJSON_NOEXCEPT
|
~StdAllocator() RAPIDJSON_NOEXCEPT
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
typedef typename allocator_type::value_type value_type;
|
|
||||||
typedef typename allocator_type::pointer pointer;
|
|
||||||
typedef typename allocator_type::const_pointer const_pointer;
|
|
||||||
typedef typename allocator_type::reference reference;
|
|
||||||
typedef typename allocator_type::const_reference const_reference;
|
|
||||||
typedef typename allocator_type::size_type size_type;
|
|
||||||
typedef typename allocator_type::difference_type difference_type;
|
|
||||||
|
|
||||||
template<typename U>
|
template<typename U>
|
||||||
struct rebind {
|
struct rebind {
|
||||||
typedef StdAllocator<U, BaseAllocator> other;
|
typedef StdAllocator<U, BaseAllocator> other;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef typename traits_type::size_type size_type;
|
||||||
|
typedef typename traits_type::difference_type difference_type;
|
||||||
|
|
||||||
|
typedef typename traits_type::value_type value_type;
|
||||||
|
typedef typename traits_type::pointer pointer;
|
||||||
|
typedef typename traits_type::const_pointer const_pointer;
|
||||||
|
|
||||||
#if RAPIDJSON_HAS_CXX11
|
#if RAPIDJSON_HAS_CXX11
|
||||||
using allocator_type::max_size;
|
|
||||||
using allocator_type::address;
|
typedef typename std::add_lvalue_reference<value_type>::type &reference;
|
||||||
using allocator_type::construct;
|
typedef typename std::add_lvalue_reference<typename std::add_const<value_type>::type>::type &const_reference;
|
||||||
using allocator_type::destroy;
|
|
||||||
#else
|
pointer address(reference r) const RAPIDJSON_NOEXCEPT
|
||||||
size_t max_size() const RAPIDJSON_NOEXCEPT
|
|
||||||
{
|
{
|
||||||
return allocator_type::max_size();
|
return std::addressof(r);
|
||||||
}
|
}
|
||||||
|
const_pointer address(const_reference r) const RAPIDJSON_NOEXCEPT
|
||||||
|
{
|
||||||
|
return std::addressof(r);
|
||||||
|
}
|
||||||
|
|
||||||
|
size_type max_size() const RAPIDJSON_NOEXCEPT
|
||||||
|
{
|
||||||
|
return traits_type::max_size(*this);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename ...Args>
|
||||||
|
void construct(pointer p, Args&&... args)
|
||||||
|
{
|
||||||
|
traits_type::construct(*this, p, std::forward<Args>(args)...);
|
||||||
|
}
|
||||||
|
void destroy(pointer p)
|
||||||
|
{
|
||||||
|
traits_type::destroy(*this, p);
|
||||||
|
}
|
||||||
|
|
||||||
|
#else // !RAPIDJSON_HAS_CXX11
|
||||||
|
|
||||||
|
typedef typename allocator_type::reference reference;
|
||||||
|
typedef typename allocator_type::const_reference const_reference;
|
||||||
|
|
||||||
pointer address(reference r) const RAPIDJSON_NOEXCEPT
|
pointer address(reference r) const RAPIDJSON_NOEXCEPT
|
||||||
{
|
{
|
||||||
@ -482,6 +513,11 @@ public:
|
|||||||
return allocator_type::address(r);
|
return allocator_type::address(r);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
size_type max_size() const RAPIDJSON_NOEXCEPT
|
||||||
|
{
|
||||||
|
return allocator_type::max_size();
|
||||||
|
}
|
||||||
|
|
||||||
void construct(pointer p, const_reference r)
|
void construct(pointer p, const_reference r)
|
||||||
{
|
{
|
||||||
allocator_type::construct(p, r);
|
allocator_type::construct(p, r);
|
||||||
@ -490,7 +526,8 @@ public:
|
|||||||
{
|
{
|
||||||
allocator_type::destroy(p);
|
allocator_type::destroy(p);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
#endif // !RAPIDJSON_HAS_CXX11
|
||||||
|
|
||||||
template <typename U>
|
template <typename U>
|
||||||
U* allocate(size_type n = 1, const void* = 0)
|
U* allocate(size_type n = 1, const void* = 0)
|
||||||
@ -578,13 +615,13 @@ public:
|
|||||||
~StdAllocator() RAPIDJSON_NOEXCEPT
|
~StdAllocator() RAPIDJSON_NOEXCEPT
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
typedef typename allocator_type::value_type value_type;
|
|
||||||
|
|
||||||
template<typename U>
|
template<typename U>
|
||||||
struct rebind {
|
struct rebind {
|
||||||
typedef StdAllocator<U, BaseAllocator> other;
|
typedef StdAllocator<U, BaseAllocator> other;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef typename allocator_type::value_type value_type;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
template <typename, typename>
|
template <typename, typename>
|
||||||
friend class StdAllocator; // access to StdAllocator<!T>.*
|
friend class StdAllocator; // access to StdAllocator<!T>.*
|
||||||
|
@ -124,6 +124,19 @@
|
|||||||
#define RAPIDJSON_NAMESPACE_END }
|
#define RAPIDJSON_NAMESPACE_END }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
// __cplusplus macro
|
||||||
|
|
||||||
|
//!@cond RAPIDJSON_HIDDEN_FROM_DOXYGEN
|
||||||
|
|
||||||
|
#if defined(_MSC_VER)
|
||||||
|
#define RAPIDJSON_CPLUSPLUS _MSVC_LANG
|
||||||
|
#else
|
||||||
|
#define RAPIDJSON_CPLUSPLUS __cplusplus
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//!@endcond
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
// RAPIDJSON_HAS_STDSTRING
|
// RAPIDJSON_HAS_STDSTRING
|
||||||
|
|
||||||
@ -411,7 +424,7 @@ RAPIDJSON_NAMESPACE_END
|
|||||||
|
|
||||||
// Prefer C++11 static_assert, if available
|
// Prefer C++11 static_assert, if available
|
||||||
#ifndef RAPIDJSON_STATIC_ASSERT
|
#ifndef RAPIDJSON_STATIC_ASSERT
|
||||||
#if __cplusplus >= 201103L || ( defined(_MSC_VER) && _MSC_VER >= 1800 )
|
#if RAPIDJSON_CPLUSPLUS >= 201103L || ( defined(_MSC_VER) && _MSC_VER >= 1800 )
|
||||||
#define RAPIDJSON_STATIC_ASSERT(x) \
|
#define RAPIDJSON_STATIC_ASSERT(x) \
|
||||||
static_assert(x, RAPIDJSON_STRINGIFY(x))
|
static_assert(x, RAPIDJSON_STRINGIFY(x))
|
||||||
#endif // C++11
|
#endif // C++11
|
||||||
@ -542,7 +555,7 @@ RAPIDJSON_NAMESPACE_END
|
|||||||
// C++11 features
|
// C++11 features
|
||||||
|
|
||||||
#ifndef RAPIDJSON_HAS_CXX11
|
#ifndef RAPIDJSON_HAS_CXX11
|
||||||
#define RAPIDJSON_HAS_CXX11 (__cplusplus >= 201103L)
|
#define RAPIDJSON_HAS_CXX11 (RAPIDJSON_CPLUSPLUS >= 201103L)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef RAPIDJSON_HAS_CXX11_RVALUE_REFS
|
#ifndef RAPIDJSON_HAS_CXX11_RVALUE_REFS
|
||||||
@ -610,9 +623,17 @@ RAPIDJSON_NAMESPACE_END
|
|||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
// C++17 features
|
// C++17 features
|
||||||
|
|
||||||
#if defined(__has_cpp_attribute)
|
#ifndef RAPIDJSON_HAS_CXX17
|
||||||
# if __has_cpp_attribute(fallthrough)
|
#define RAPIDJSON_HAS_CXX17 (RAPIDJSON_CPLUSPLUS >= 201703L)
|
||||||
# define RAPIDJSON_DELIBERATE_FALLTHROUGH [[fallthrough]]
|
#endif
|
||||||
|
|
||||||
|
#if RAPIDJSON_HAS_CXX17
|
||||||
|
# define RAPIDJSON_DELIBERATE_FALLTHROUGH [[fallthrough]]
|
||||||
|
#elif defined(__has_cpp_attribute)
|
||||||
|
# if __has_cpp_attribute(clang::fallthrough)
|
||||||
|
# define RAPIDJSON_DELIBERATE_FALLTHROUGH [[clang::fallthrough]]
|
||||||
|
# elif __has_cpp_attribute(fallthrough)
|
||||||
|
# define RAPIDJSON_DELIBERATE_FALLTHROUGH __attribute__((fallthrough))
|
||||||
# else
|
# else
|
||||||
# define RAPIDJSON_DELIBERATE_FALLTHROUGH
|
# define RAPIDJSON_DELIBERATE_FALLTHROUGH
|
||||||
# endif
|
# endif
|
||||||
|
@ -107,12 +107,12 @@ void TestStdAllocator(const Allocator& a) {
|
|||||||
arr[i] = 0x0f0f0f0f;
|
arr[i] = 0x0f0f0f0f;
|
||||||
}
|
}
|
||||||
ia.deallocate(arr, 10);
|
ia.deallocate(arr, 10);
|
||||||
arr = (int *)ia.Malloc(10 * sizeof(int));
|
arr = Malloc<int>(ia, 10);
|
||||||
EXPECT_TRUE(arr != 0);
|
EXPECT_TRUE(arr != 0);
|
||||||
for (int i = 0; i < 10; ++i) {
|
for (int i = 0; i < 10; ++i) {
|
||||||
arr[i] = 0x0f0f0f0f;
|
arr[i] = 0x0f0f0f0f;
|
||||||
}
|
}
|
||||||
arr = (int *)ia.Realloc(arr, 10 * sizeof(int), 20 * sizeof(int));
|
arr = Realloc<int>(ia, arr, 10, 20);
|
||||||
EXPECT_TRUE(arr != 0);
|
EXPECT_TRUE(arr != 0);
|
||||||
for (int i = 0; i < 10; ++i) {
|
for (int i = 0; i < 10; ++i) {
|
||||||
EXPECT_EQ(arr[i], 0x0f0f0f0f);
|
EXPECT_EQ(arr[i], 0x0f0f0f0f);
|
||||||
@ -120,7 +120,7 @@ void TestStdAllocator(const Allocator& a) {
|
|||||||
for (int i = 10; i < 20; i++) {
|
for (int i = 10; i < 20; i++) {
|
||||||
arr[i] = 0x0f0f0f0f;
|
arr[i] = 0x0f0f0f0f;
|
||||||
}
|
}
|
||||||
ia.Free(arr);
|
Free<int>(ia, arr, 20);
|
||||||
|
|
||||||
int cons = 0, dest = 0;
|
int cons = 0, dest = 0;
|
||||||
StdAllocator<TestStdAllocatorData, Allocator> da(a);
|
StdAllocator<TestStdAllocatorData, Allocator> da(a);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user