Add rvalue copy and assignment to MemoryPoolAllocator and StdAllocator.
This commit is contained in:
parent
49aa0fc15d
commit
683010b02d
@ -222,7 +222,6 @@ public:
|
|||||||
{
|
{
|
||||||
RAPIDJSON_NOEXCEPT_ASSERT(rhs.shared_->refcount > 0);
|
RAPIDJSON_NOEXCEPT_ASSERT(rhs.shared_->refcount > 0);
|
||||||
++rhs.shared_->refcount;
|
++rhs.shared_->refcount;
|
||||||
|
|
||||||
this->~MemoryPoolAllocator();
|
this->~MemoryPoolAllocator();
|
||||||
baseAllocator_ = rhs.baseAllocator_;
|
baseAllocator_ = rhs.baseAllocator_;
|
||||||
chunk_capacity_ = rhs.chunk_capacity_;
|
chunk_capacity_ = rhs.chunk_capacity_;
|
||||||
@ -230,10 +229,35 @@ public:
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if RAPIDJSON_HAS_CXX11_RVALUE_REFS
|
||||||
|
MemoryPoolAllocator(MemoryPoolAllocator&& rhs) RAPIDJSON_NOEXCEPT :
|
||||||
|
chunk_capacity_(rhs.chunk_capacity_),
|
||||||
|
baseAllocator_(rhs.baseAllocator_),
|
||||||
|
shared_(rhs.shared_)
|
||||||
|
{
|
||||||
|
RAPIDJSON_NOEXCEPT_ASSERT(rhs.shared_->refcount > 0);
|
||||||
|
rhs.shared_ = 0;
|
||||||
|
}
|
||||||
|
MemoryPoolAllocator& operator=(MemoryPoolAllocator&& rhs) RAPIDJSON_NOEXCEPT
|
||||||
|
{
|
||||||
|
RAPIDJSON_NOEXCEPT_ASSERT(rhs.shared_->refcount > 0);
|
||||||
|
this->~MemoryPoolAllocator();
|
||||||
|
baseAllocator_ = rhs.baseAllocator_;
|
||||||
|
chunk_capacity_ = rhs.chunk_capacity_;
|
||||||
|
shared_ = rhs.shared_;
|
||||||
|
rhs.shared_ = 0;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//! Destructor.
|
//! Destructor.
|
||||||
/*! This deallocates all memory chunks, excluding the user-supplied buffer.
|
/*! This deallocates all memory chunks, excluding the user-supplied buffer.
|
||||||
*/
|
*/
|
||||||
~MemoryPoolAllocator() RAPIDJSON_NOEXCEPT {
|
~MemoryPoolAllocator() RAPIDJSON_NOEXCEPT {
|
||||||
|
if (!shared_) {
|
||||||
|
// do nothing if moved
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (shared_->refcount > 1) {
|
if (shared_->refcount > 1) {
|
||||||
--shared_->refcount;
|
--shared_->refcount;
|
||||||
return;
|
return;
|
||||||
@ -449,6 +473,17 @@ public:
|
|||||||
baseAllocator_(rhs.baseAllocator_)
|
baseAllocator_(rhs.baseAllocator_)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
|
#if RAPIDJSON_HAS_CXX11_RVALUE_REFS
|
||||||
|
StdAllocator(StdAllocator&& rhs) RAPIDJSON_NOEXCEPT :
|
||||||
|
allocator_type(std::move(rhs)),
|
||||||
|
baseAllocator_(std::move(rhs.baseAllocator_))
|
||||||
|
{ }
|
||||||
|
#endif
|
||||||
|
#if RAPIDJSON_HAS_CXX11
|
||||||
|
using propagate_on_container_move_assignment = std::true_type;
|
||||||
|
using propagate_on_container_swap = std::true_type;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* implicit */
|
/* implicit */
|
||||||
StdAllocator(const BaseAllocator& allocator) RAPIDJSON_NOEXCEPT :
|
StdAllocator(const BaseAllocator& allocator) RAPIDJSON_NOEXCEPT :
|
||||||
allocator_type(),
|
allocator_type(),
|
||||||
@ -549,6 +584,10 @@ public:
|
|||||||
deallocate<value_type>(p, n);
|
deallocate<value_type>(p, n);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if RAPIDJSON_HAS_CXX11
|
||||||
|
using is_always_equal = std::is_empty<BaseAllocator>;
|
||||||
|
#endif
|
||||||
|
|
||||||
template<typename U>
|
template<typename U>
|
||||||
bool operator==(const StdAllocator<U, BaseAllocator>& rhs) const RAPIDJSON_NOEXCEPT
|
bool operator==(const StdAllocator<U, BaseAllocator>& rhs) const RAPIDJSON_NOEXCEPT
|
||||||
{
|
{
|
||||||
@ -561,6 +600,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
//! rapidjson Allocator concept
|
//! rapidjson Allocator concept
|
||||||
|
static const bool kNeedFree = BaseAllocator::kNeedFree;
|
||||||
void* Malloc(size_t size)
|
void* Malloc(size_t size)
|
||||||
{
|
{
|
||||||
return baseAllocator_.Malloc(size);
|
return baseAllocator_.Malloc(size);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user