forked from Bananymous/banan-os
				
			BAN: memcpy only if we already have a buffer
This commit is contained in:
		
							parent
							
								
									75ee592fb5
								
							
						
					
					
						commit
						c33c6c5785
					
				|  | @ -214,6 +214,7 @@ namespace BAN | ||||||
| 		void* new_data = BAN::allocator(new_cap); | 		void* new_data = BAN::allocator(new_cap); | ||||||
| 		if (new_data == nullptr) | 		if (new_data == nullptr) | ||||||
| 			return Error::FromString("String: Could not allocate memory"); | 			return Error::FromString("String: Could not allocate memory"); | ||||||
|  | 		if (m_data) | ||||||
| 			memcpy(new_data, m_data, m_size + 1); | 			memcpy(new_data, m_data, m_size + 1); | ||||||
| 		BAN::deallocator(m_data); | 		BAN::deallocator(m_data); | ||||||
| 		m_data = (char*)new_data; | 		m_data = (char*)new_data; | ||||||
|  |  | ||||||
|  | @ -31,7 +31,7 @@ namespace BAN | ||||||
| 		T& Front(); | 		T& Front(); | ||||||
| 
 | 
 | ||||||
| 	private: | 	private: | ||||||
| 		[[nodiscard]] ErrorOr<void> VerifyCapacity(size_type size); | 		[[nodiscard]] ErrorOr<void> EnsureCapacity(size_type size); | ||||||
| 
 | 
 | ||||||
| 	private: | 	private: | ||||||
| 		T*			m_data		= nullptr; | 		T*			m_data		= nullptr; | ||||||
|  | @ -50,7 +50,7 @@ namespace BAN | ||||||
| 	template<typename T> | 	template<typename T> | ||||||
| 	ErrorOr<void> Queue<T>::Push(const T& value) | 	ErrorOr<void> Queue<T>::Push(const T& value) | ||||||
| 	{ | 	{ | ||||||
| 		TRY(VerifyCapacity(m_size + 1)); | 		TRY(EnsureCapacity(m_size + 1)); | ||||||
| 		m_data[m_size++] = value; | 		m_data[m_size++] = value; | ||||||
| 		return {}; | 		return {}; | ||||||
| 	} | 	} | ||||||
|  | @ -90,19 +90,17 @@ namespace BAN | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	template<typename T> | 	template<typename T> | ||||||
| 	ErrorOr<void> Queue<T>::VerifyCapacity(size_type size) | 	ErrorOr<void> Queue<T>::EnsureCapacity(size_type size) | ||||||
| 	{ | 	{ | ||||||
| 		if (m_capacity > size) | 		if (m_capacity > size) | ||||||
| 			return {}; | 			return {}; | ||||||
| 
 |  | ||||||
| 		size_type new_cap = BAN::Math::max<size_type>(size, m_capacity * 3 / 2); | 		size_type new_cap = BAN::Math::max<size_type>(size, m_capacity * 3 / 2); | ||||||
| 		void* new_data = BAN::allocator(new_cap * sizeof(T)); | 		void* new_data = BAN::allocator(new_cap * sizeof(T)); | ||||||
| 		if (new_data == nullptr) | 		if (new_data == nullptr) | ||||||
| 			return Error::FromString("Queue: Could not allocate memory"); | 			return Error::FromString("Queue: Could not allocate memory"); | ||||||
| 
 | 		if (m_data) | ||||||
| 			memcpy(new_data, m_data, m_size * sizeof(T)); | 			memcpy(new_data, m_data, m_size * sizeof(T)); | ||||||
| 		BAN::deallocator(m_data); | 		BAN::deallocator(m_data); | ||||||
| 
 |  | ||||||
| 		m_data = (T*)new_data; | 		m_data = (T*)new_data; | ||||||
| 		m_capacity = new_cap; | 		m_capacity = new_cap; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -211,6 +211,7 @@ namespace BAN | ||||||
| 		void* new_data = BAN::allocator(new_cap * sizeof(T)); | 		void* new_data = BAN::allocator(new_cap * sizeof(T)); | ||||||
| 		if (new_data == nullptr) | 		if (new_data == nullptr) | ||||||
| 			return Error::FromString("Vector: Could not allocate memory"); | 			return Error::FromString("Vector: Could not allocate memory"); | ||||||
|  | 		if (m_data) | ||||||
| 			memcpy(new_data, m_data, m_size * sizeof(T)); | 			memcpy(new_data, m_data, m_size * sizeof(T)); | ||||||
| 		BAN::deallocator(m_data); | 		BAN::deallocator(m_data); | ||||||
| 		m_data = (T*)new_data; | 		m_data = (T*)new_data; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue