mirror of
				https://github.com/eledio-devices/thirdparty-ArduinoJson.git
				synced 2025-10-31 16:14:11 +01:00 
			
		
		
		
	Changed BasicJsonDocument's copy-constructor to copy the capacity
This commit is contained in:
		| @@ -22,7 +22,8 @@ class AllocatorOwner { | ||||
|   } | ||||
|  | ||||
|   void deallocate(void* ptr) { | ||||
|     _allocator.deallocate(ptr); | ||||
|     if (ptr) | ||||
|       _allocator.deallocate(ptr); | ||||
|   } | ||||
|  | ||||
|   void* reallocate(void* ptr, size_t new_size) { | ||||
| @@ -43,27 +44,36 @@ class BasicJsonDocument : AllocatorOwner<TAllocator>, public JsonDocument { | ||||
|   explicit BasicJsonDocument(size_t capa, TAllocator alloc = TAllocator()) | ||||
|       : AllocatorOwner<TAllocator>(alloc), JsonDocument(allocPool(capa)) {} | ||||
|  | ||||
|   // Copy-constructor | ||||
|   BasicJsonDocument(const BasicJsonDocument& src) | ||||
|       : AllocatorOwner<TAllocator>(src), | ||||
|         JsonDocument(allocPool(src.memoryUsage())) { | ||||
|     set(src); | ||||
|       : AllocatorOwner<TAllocator>(src), JsonDocument() { | ||||
|     copyAssignFrom(src); | ||||
|   } | ||||
|  | ||||
|   // Move-constructor | ||||
| #if ARDUINOJSON_HAS_RVALUE_REFERENCES | ||||
|   BasicJsonDocument(BasicJsonDocument&& src) : AllocatorOwner<TAllocator>(src) { | ||||
|     moveAssignFrom(src); | ||||
|   } | ||||
| #endif | ||||
|  | ||||
|   BasicJsonDocument(const JsonDocument& src) { | ||||
|     copyAssignFrom(src); | ||||
|   } | ||||
|  | ||||
|   // Construct from variant, array, or object | ||||
|   template <typename T> | ||||
|   BasicJsonDocument(const T& src, | ||||
|                     typename enable_if<IsVisitable<T>::value>::type* = 0) | ||||
|   BasicJsonDocument( | ||||
|       const T& src, | ||||
|       typename enable_if< | ||||
|           is_same<T, VariantRef>::value || is_same<T, VariantConstRef>::value || | ||||
|           is_same<T, ArrayRef>::value || is_same<T, ArrayConstRef>::value || | ||||
|           is_same<T, ObjectRef>::value || | ||||
|           is_same<T, ObjectConstRef>::value>::type* = 0) | ||||
|       : JsonDocument(allocPool(src.memoryUsage())) { | ||||
|     set(src); | ||||
|   } | ||||
|  | ||||
| #if ARDUINOJSON_HAS_RVALUE_REFERENCES | ||||
|   BasicJsonDocument(BasicJsonDocument&& src) | ||||
|       : AllocatorOwner<TAllocator>(src), JsonDocument(src) { | ||||
|     src._data.setNull(); | ||||
|     src._pool = MemoryPool(0, 0); | ||||
|   } | ||||
| #endif | ||||
|  | ||||
|   // disambiguate | ||||
|   BasicJsonDocument(VariantRef src) | ||||
|       : JsonDocument(allocPool(src.memoryUsage())) { | ||||
| @@ -75,8 +85,7 @@ class BasicJsonDocument : AllocatorOwner<TAllocator>, public JsonDocument { | ||||
|   } | ||||
|  | ||||
|   BasicJsonDocument& operator=(const BasicJsonDocument& src) { | ||||
|     reallocPoolIfTooSmall(src.memoryUsage()); | ||||
|     set(src); | ||||
|     copyAssignFrom(src); | ||||
|     return *this; | ||||
|   } | ||||
|  | ||||
| @@ -111,7 +120,7 @@ class BasicJsonDocument : AllocatorOwner<TAllocator>, public JsonDocument { | ||||
|  | ||||
|   bool garbageCollect() { | ||||
|     // make a temporary clone and move assign | ||||
|     BasicJsonDocument<TAllocator> tmp(capacity(), allocator()); | ||||
|     BasicJsonDocument<TAllocator> tmp(*this); | ||||
|     if (!tmp.capacity()) | ||||
|       return false; | ||||
|     tmp.set(*this); | ||||
| @@ -138,6 +147,11 @@ class BasicJsonDocument : AllocatorOwner<TAllocator>, public JsonDocument { | ||||
|     this->deallocate(memoryPool().buffer()); | ||||
|   } | ||||
|  | ||||
|   void copyAssignFrom(const JsonDocument& src) { | ||||
|     reallocPoolIfTooSmall(src.capacity()); | ||||
|     set(src); | ||||
|   } | ||||
|  | ||||
|   void moveAssignFrom(BasicJsonDocument& src) { | ||||
|     freePool(); | ||||
|     _data = src._data; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user