Move \ingroup onto same line to be more compact and make it clear the file is in the group.
		
			
				
	
	
		
			126 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			126 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * This program is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU General Public License
 | |
|  * as published by the Free Software Foundation; either version 2
 | |
|  * of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program; if not, write to the Free Software Foundation,
 | |
|  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | |
|  */
 | |
| 
 | |
| /** \file \ingroup bli
 | |
|  *
 | |
|  * Primitive generic buffer library.
 | |
|  *
 | |
|  * - Automatically grow as needed.
 | |
|  *   (currently never shrinks).
 | |
|  * - Can be passed between functions.
 | |
|  * - Supports using stack memory by default,
 | |
|  *   falling back to heap as needed.
 | |
|  *
 | |
|  * Usage examples:
 | |
|  * \code{.c}
 | |
|  * BLI_buffer_declare_static(int, my_int_array, BLI_BUFFER_NOP, 32);
 | |
|  *
 | |
|  * BLI_buffer_append(my_int_array, int, 42);
 | |
|  * assert(my_int_array.count == 1);
 | |
|  * assert(BLI_buffer_at(my_int_array, int, 0) == 42);
 | |
|  *
 | |
|  * BLI_buffer_free(&my_int_array);
 | |
|  * \endcode
 | |
|  *
 | |
|  * \note this more or less fills same purpose as #BLI_array,
 | |
|  * but supports resizing the array outside of the function
 | |
|  * it was declared in.
 | |
|  */
 | |
| 
 | |
| #include <string.h>
 | |
| 
 | |
| #include "MEM_guardedalloc.h"
 | |
| 
 | |
| #include "BLI_buffer.h"
 | |
| #include "BLI_utildefines.h"
 | |
| 
 | |
| #include "BLI_strict_flags.h"
 | |
| 
 | |
| static void *buffer_alloc(BLI_Buffer *buffer, const size_t len)
 | |
| {
 | |
| 	return MEM_mallocN(buffer->elem_size * len, "BLI_Buffer.data");
 | |
| }
 | |
| 
 | |
| static void *buffer_realloc(BLI_Buffer *buffer, const size_t len)
 | |
| {
 | |
| 	return MEM_reallocN_id(buffer->data, buffer->elem_size * len, "BLI_Buffer.data");
 | |
| }
 | |
| 
 | |
| void BLI_buffer_resize(BLI_Buffer *buffer, const size_t new_count)
 | |
| {
 | |
| 	if (UNLIKELY(new_count > buffer->alloc_count)) {
 | |
| 		if (buffer->flag & BLI_BUFFER_USE_STATIC) {
 | |
| 			void *orig = buffer->data;
 | |
| 
 | |
| 			buffer->data = buffer_alloc(buffer, new_count);
 | |
| 			memcpy(buffer->data, orig, buffer->elem_size * buffer->count);
 | |
| 			buffer->alloc_count = new_count;
 | |
| 			buffer->flag &= ~BLI_BUFFER_USE_STATIC;
 | |
| 		}
 | |
| 		else {
 | |
| 			if (buffer->alloc_count && (new_count < buffer->alloc_count * 2)) {
 | |
| 				buffer->alloc_count *= 2;
 | |
| 			}
 | |
| 			else {
 | |
| 				buffer->alloc_count = new_count;
 | |
| 			}
 | |
| 
 | |
| 			buffer->data = buffer_realloc(buffer, buffer->alloc_count);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	buffer->count = new_count;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Similar to #BLI_buffer_resize, but use when the existing data can be:
 | |
|  * - Ignored (malloc'd)
 | |
|  * - Cleared (when BLI_BUFFER_USE_CALLOC is set)
 | |
|  */
 | |
| void BLI_buffer_reinit(BLI_Buffer *buffer, const size_t new_count)
 | |
| {
 | |
| 	if (UNLIKELY(new_count > buffer->alloc_count)) {
 | |
| 		if ((buffer->flag & BLI_BUFFER_USE_STATIC) == 0) {
 | |
| 			if (buffer->data) {
 | |
| 				MEM_freeN(buffer->data);
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		if (buffer->alloc_count && (new_count < buffer->alloc_count * 2)) {
 | |
| 			buffer->alloc_count *= 2;
 | |
| 		}
 | |
| 		else {
 | |
| 			buffer->alloc_count = new_count;
 | |
| 		}
 | |
| 
 | |
| 		buffer->flag &= ~BLI_BUFFER_USE_STATIC;
 | |
| 		buffer->data = buffer_alloc(buffer, buffer->alloc_count);
 | |
| 	}
 | |
| 
 | |
| 	buffer->count = new_count;
 | |
| }
 | |
| 
 | |
| /* callers use BLI_buffer_free */
 | |
| void _bli_buffer_free(BLI_Buffer *buffer)
 | |
| {
 | |
| 	if ((buffer->flag & BLI_BUFFER_USE_STATIC) == 0) {
 | |
| 		if (buffer->data) {
 | |
| 			MEM_freeN(buffer->data);
 | |
| 		}
 | |
| 	}
 | |
| 	memset(buffer, 0, sizeof(*buffer));
 | |
| }
 |