Fix DqnArray bugs
This commit is contained in:
		
							parent
							
								
									7e507ee470
								
							
						
					
					
						commit
						86d3418315
					
				
							
								
								
									
										16
									
								
								dqn.h
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								dqn.h
									
									
									
									
									
								
							| @ -170,6 +170,11 @@ using f32 = float; | |||||||
| // Produce a unique name with prefix and counter. i.e. where prefix is "data" then it gives "data1"
 | // Produce a unique name with prefix and counter. i.e. where prefix is "data" then it gives "data1"
 | ||||||
| #define DQN_UNIQUE_NAME(prefix) DQN_TOKEN_COMBINE2(prefix, __COUNTER__) | #define DQN_UNIQUE_NAME(prefix) DQN_TOKEN_COMBINE2(prefix, __COUNTER__) | ||||||
| 
 | 
 | ||||||
|  | #define DQN_DEFER_BLOCK(startFunc, ...) startFunc; for (isize i__ = 0; i__ < 1; i__++, __VA_ARGS__) | ||||||
|  | #define DQN_DEFER(endFunc) for (isize i__ = 0; i__ < 1; i__++, endFunc) | ||||||
|  | 
 | ||||||
|  | #define DQN_FOR_EACH(i, lim) for (isize (i) = 0; (i) < (isize)(lim); ++(i)) | ||||||
|  | 
 | ||||||
| // #Dqn Namespace
 | // #Dqn Namespace
 | ||||||
| namespace Dqn | namespace Dqn | ||||||
| { | { | ||||||
| @ -1179,7 +1184,7 @@ struct DqnArray | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| template <typename T> | template <typename T> | ||||||
| class DqnSmartArray : public DqnArray<T> | struct DqnSmartArray : public DqnArray<T> | ||||||
| { | { | ||||||
|     ~DqnSmartArray() { if (this->data && this->memAPI) this->memAPI->Free(this->data); } |     ~DqnSmartArray() { if (this->data && this->memAPI) this->memAPI->Free(this->data); } | ||||||
| }; | }; | ||||||
| @ -1402,7 +1407,7 @@ void DqnArray<T>::Free() | |||||||
| template <typename T> | template <typename T> | ||||||
| bool DqnArray<T>::Reserve(isize newMax) | bool DqnArray<T>::Reserve(isize newMax) | ||||||
| { | { | ||||||
|     if (newMax <= this->count) |     if (newMax <= this->max) | ||||||
|     { |     { | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| @ -1450,12 +1455,13 @@ bool DqnArray<T>::Grow(isize multiplier) | |||||||
| template <typename T> | template <typename T> | ||||||
| inline bool DqnArray__TryMakeEnoughSpace(DqnArray<T> *array, isize numNewItems) | inline bool DqnArray__TryMakeEnoughSpace(DqnArray<T> *array, isize numNewItems) | ||||||
| { | { | ||||||
|     bool result = true; |     i32 numToReserve = numNewItems; | ||||||
|     if (!array->data || (array->count + numNewItems) >= array->max) |     if ((array->count + numNewItems) >= array->max) | ||||||
|     { |     { | ||||||
|         result = array->Grow(); |         numToReserve = array->count + numNewItems; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     bool result = array->Reserve(numNewItems); | ||||||
|     return result; |     return result; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user