Blender V4.3
gsqueue.c File Reference

A generic structure queue (a queue for fixed length generally small) structures. More...

#include <string.h>
#include "MEM_guardedalloc.h"
#include "BLI_gsqueue.h"
#include "BLI_utildefines.h"
#include "BLI_strict_flags.h"

Go to the source code of this file.

Classes

struct  QueueChunk
 
struct  _GSQueue
 

Macros

#define CHUNK_SIZE_DEFAULT   (1 << 16)
 
#define CHUNK_ELEM_MIN   32
 

Functions

static void * queue_get_first_elem (GSQueue *queue)
 
static void * queue_get_last_elem (GSQueue *queue)
 
static size_t queue_chunk_elem_max_calc (const size_t elem_size, size_t chunk_size)
 
GSQueueBLI_gsqueue_new (const size_t elem_size)
 
static void queue_free_chunk (struct QueueChunk *data)
 
void BLI_gsqueue_free (GSQueue *queue)
 
void BLI_gsqueue_push (GSQueue *queue, const void *item)
 
void BLI_gsqueue_pop (GSQueue *queue, void *r_item)
 
size_t BLI_gsqueue_len (const GSQueue *queue)
 
bool BLI_gsqueue_is_empty (const GSQueue *queue)
 

Detailed Description

A generic structure queue (a queue for fixed length generally small) structures.

Definition in file gsqueue.c.

Macro Definition Documentation

◆ CHUNK_ELEM_MIN

#define CHUNK_ELEM_MIN   32

Definition at line 24 of file gsqueue.c.

Referenced by queue_chunk_elem_max_calc().

◆ CHUNK_SIZE_DEFAULT

#define CHUNK_SIZE_DEFAULT   (1 << 16)

Definition at line 22 of file gsqueue.c.

Referenced by BLI_gsqueue_new().

Function Documentation

◆ BLI_gsqueue_free()

void BLI_gsqueue_free ( GSQueue * queue)

Free the queue's data and the queue itself.

Definition at line 93 of file gsqueue.c.

References MEM_freeN(), and queue_free_chunk().

Referenced by BLI_thread_queue_free(), unsubdivide_face_center_vertex_tag(), unsubdivide_init_elem_ids(), and unsubdivide_tag_disconnected_mesh_element().

◆ BLI_gsqueue_is_empty()

bool BLI_gsqueue_is_empty ( const GSQueue * queue)

◆ BLI_gsqueue_len()

size_t BLI_gsqueue_len ( const GSQueue * queue)

Definition at line 157 of file gsqueue.c.

Referenced by BLI_thread_queue_len().

◆ BLI_gsqueue_new()

◆ BLI_gsqueue_pop()

void BLI_gsqueue_pop ( GSQueue * queue,
void * r_item )

Retrieves and removes the first element from the queue. The value is copies to r_item, which must be at least elem_size bytes.

Does not reduce amount of allocated memory.

Definition at line 134 of file gsqueue.c.

References BLI_assert, BLI_gsqueue_is_empty(), QueueChunk::next, NULL, queue_get_first_elem(), and UNLIKELY.

Referenced by BLI_thread_queue_pop(), BLI_thread_queue_pop_timeout(), unsubdivide_face_center_vertex_tag(), unsubdivide_init_elem_ids(), and unsubdivide_tag_disconnected_mesh_element().

◆ BLI_gsqueue_push()

void BLI_gsqueue_push ( GSQueue * queue,
const void * item )

Copies the source value onto the end of the queue

Note
This copies GSQueue.elem_size bytes from item, (the pointer itself is not stored).
Parameters
itemsource data to be copied to the queue.

Definition at line 100 of file gsqueue.c.

References BLI_assert, MEM_mallocN, QueueChunk::next, NULL, queue_get_last_elem(), and UNLIKELY.

Referenced by BLI_thread_queue_push(), unsubdivide_face_center_vertex_tag(), unsubdivide_init_elem_ids(), and unsubdivide_tag_disconnected_mesh_element().

◆ queue_chunk_elem_max_calc()

static size_t queue_chunk_elem_max_calc ( const size_t elem_size,
size_t chunk_size )
static
Returns
number of elements per chunk, optimized for slop-space.

Definition at line 55 of file gsqueue.c.

References BLI_assert, CHUNK_ELEM_MIN, MEM_SIZE_OVERHEAD, and UNLIKELY.

Referenced by BLI_gsqueue_new().

◆ queue_free_chunk()

static void queue_free_chunk ( struct QueueChunk * data)
static

Definition at line 84 of file gsqueue.c.

References MEM_freeN(), and QueueChunk::next.

Referenced by BLI_gsqueue_free().

◆ queue_get_first_elem()

static void * queue_get_first_elem ( GSQueue * queue)
static

Definition at line 42 of file gsqueue.c.

Referenced by BLI_gsqueue_pop().

◆ queue_get_last_elem()

static void * queue_get_last_elem ( GSQueue * queue)
static

Definition at line 47 of file gsqueue.c.

Referenced by BLI_gsqueue_push().