Blender V4.3
BLI_ghash_utils.cc File Reference
#include <cstring>
#include "MEM_guardedalloc.h"
#include "BLI_ghash.h"
#include "BLI_hash_mm2a.hh"
#include "BLI_utildefines.h"
#include "BLI_strict_flags.h"

Go to the source code of this file.

Functions

Generic Key Hash & Comparison Functions
uint BLI_ghashutil_ptrhash (const void *key)
 
bool BLI_ghashutil_ptrcmp (const void *a, const void *b)
 
uint BLI_ghashutil_uinthash_v4 (const uint key[4])
 
uint BLI_ghashutil_uinthash_v4_murmur (const uint key[4])
 
bool BLI_ghashutil_uinthash_v4_cmp (const void *a, const void *b)
 
uint BLI_ghashutil_uinthash (uint key)
 
uint BLI_ghashutil_inthash_p (const void *ptr)
 
uint BLI_ghashutil_inthash_p_murmur (const void *ptr)
 
uint BLI_ghashutil_inthash_p_simple (const void *ptr)
 
bool BLI_ghashutil_intcmp (const void *a, const void *b)
 
size_t BLI_ghashutil_combine_hash (size_t hash_a, size_t hash_b)
 
uint BLI_ghashutil_strhash_n (const char *key, size_t n)
 
uint BLI_ghashutil_strhash_p (const void *ptr)
 
uint BLI_ghashutil_strhash_p_murmur (const void *ptr)
 
bool BLI_ghashutil_strcmp (const void *a, const void *b)
 
GHashPairBLI_ghashutil_pairalloc (const void *first, const void *second)
 
uint BLI_ghashutil_pairhash (const void *ptr)
 
bool BLI_ghashutil_paircmp (const void *a, const void *b)
 
void BLI_ghashutil_pairfree (void *ptr)
 
Convenience GHash Creation Functions
GHashBLI_ghash_ptr_new_ex (const char *info, const uint nentries_reserve)
 
GHashBLI_ghash_ptr_new (const char *info)
 
GHashBLI_ghash_str_new_ex (const char *info, const uint nentries_reserve)
 
GHashBLI_ghash_str_new (const char *info)
 
GHashBLI_ghash_int_new_ex (const char *info, const uint nentries_reserve)
 
GHashBLI_ghash_int_new (const char *info)
 
GHashBLI_ghash_pair_new_ex (const char *info, const uint nentries_reserve)
 
GHashBLI_ghash_pair_new (const char *info)
 
Convenience GSet Creation Functions
GSetBLI_gset_ptr_new_ex (const char *info, const uint nentries_reserve)
 
GSetBLI_gset_ptr_new (const char *info)
 
GSetBLI_gset_str_new_ex (const char *info, const uint nentries_reserve)
 
GSetBLI_gset_str_new (const char *info)
 
GSetBLI_gset_pair_new_ex (const char *info, const uint nentries_reserve)
 
GSetBLI_gset_pair_new (const char *info)
 
GSetBLI_gset_int_new_ex (const char *info, const uint nentries_reserve)
 
GSetBLI_gset_int_new (const char *info)
 

Detailed Description

Helper functions and implementations of standard data types for GHash (not its implementation).

Definition in file BLI_ghash_utils.cc.

Function Documentation

◆ BLI_ghash_int_new()

◆ BLI_ghash_int_new_ex()

GHash * BLI_ghash_int_new_ex ( const char * info,
const uint nentries_reserve )

◆ BLI_ghash_pair_new()

GHash * BLI_ghash_pair_new ( const char * info)

Definition at line 220 of file BLI_ghash_utils.cc.

References BLI_ghash_pair_new_ex().

◆ BLI_ghash_pair_new_ex()

GHash * BLI_ghash_pair_new_ex ( const char * info,
const uint nentries_reserve )

◆ BLI_ghash_ptr_new()

◆ BLI_ghash_ptr_new_ex()

◆ BLI_ghash_str_new()

◆ BLI_ghash_str_new_ex()

◆ BLI_ghashutil_combine_hash()

◆ BLI_ghashutil_intcmp()

◆ BLI_ghashutil_inthash_p()

◆ BLI_ghashutil_inthash_p_murmur()

uint BLI_ghashutil_inthash_p_murmur ( const void * ptr)

Definition at line 100 of file BLI_ghash_utils.cc.

References BLI_hash_mm2(), and ptr.

Referenced by TEST(), TEST(), TEST(), and TEST().

◆ BLI_ghashutil_inthash_p_simple()

uint BLI_ghashutil_inthash_p_simple ( const void * ptr)

Definition at line 107 of file BLI_ghash_utils.cc.

References POINTER_AS_UINT, and ptr.

Referenced by DRW_viewport_data_create().

◆ BLI_ghashutil_pairalloc()

GHashPair * BLI_ghashutil_pairalloc ( const void * first,
const void * second )

Definition at line 155 of file BLI_ghash_utils.cc.

References GHashPair::first, and MEM_mallocN.

Referenced by bm_edgering_pair_calc().

◆ BLI_ghashutil_paircmp()

bool BLI_ghashutil_paircmp ( const void * a,
const void * b )

Definition at line 170 of file BLI_ghash_utils.cc.

References B, and b.

Referenced by BLI_ghash_pair_new_ex(), and BLI_gset_pair_new_ex().

◆ BLI_ghashutil_pairfree()

void BLI_ghashutil_pairfree ( void * ptr)

Definition at line 178 of file BLI_ghash_utils.cc.

References MEM_freeN(), and ptr.

◆ BLI_ghashutil_pairhash()

uint BLI_ghashutil_pairhash ( const void * ptr)

Definition at line 163 of file BLI_ghash_utils.cc.

References BLI_ghashutil_ptrhash(), hash, and ptr.

Referenced by BLI_ghash_pair_new_ex(), and BLI_gset_pair_new_ex().

◆ BLI_ghashutil_ptrcmp()

◆ BLI_ghashutil_ptrhash()

◆ BLI_ghashutil_strcmp()

◆ BLI_ghashutil_strhash_n()

uint BLI_ghashutil_strhash_n ( const char * key,
size_t n )

This function implements the widely used djb hash apparently posted by Daniel Bernstein to comp.lang.c some time ago. The 32 bit unsigned hash value starts at 5381 and for each byte 'c' in the string, is updated: hash = hash * 33 + c. This function uses the signed value of each byte.

NOTE: this is the same hash method that glib 2.34.0 uses.

Definition at line 122 of file BLI_ghash_utils.cc.

Referenced by UniqueName_Key::hash(), and Uniqueness_Key::hash().

◆ BLI_ghashutil_strhash_p()

◆ BLI_ghashutil_strhash_p_murmur()

◆ BLI_ghashutil_uinthash()

◆ BLI_ghashutil_uinthash_v4()

uint BLI_ghashutil_uinthash_v4 ( const uint key[4])

Definition at line 51 of file BLI_ghash_utils.cc.

References hash.

◆ BLI_ghashutil_uinthash_v4_cmp()

bool BLI_ghashutil_uinthash_v4_cmp ( const void * a,
const void * b )

Definition at line 69 of file BLI_ghash_utils.cc.

References b.

Referenced by TEST(), and TEST().

◆ BLI_ghashutil_uinthash_v4_murmur()

uint BLI_ghashutil_uinthash_v4_murmur ( const uint key[4])

Definition at line 64 of file BLI_ghash_utils.cc.

References BLI_hash_mm2().

◆ BLI_gset_int_new()

GSet * BLI_gset_int_new ( const char * info)

Definition at line 262 of file BLI_ghash_utils.cc.

References BLI_gset_int_new_ex().

Referenced by BKE_fcurves_calc_keyed_frames_ex().

◆ BLI_gset_int_new_ex()

GSet * BLI_gset_int_new_ex ( const char * info,
const uint nentries_reserve )

◆ BLI_gset_pair_new()

GSet * BLI_gset_pair_new ( const char * info)

Definition at line 253 of file BLI_ghash_utils.cc.

References BLI_gset_pair_new_ex().

Referenced by bm_edgering_pair_calc().

◆ BLI_gset_pair_new_ex()

GSet * BLI_gset_pair_new_ex ( const char * info,
const uint nentries_reserve )

◆ BLI_gset_ptr_new()

◆ BLI_gset_ptr_new_ex()

◆ BLI_gset_str_new()

GSet * BLI_gset_str_new ( const char * info)

◆ BLI_gset_str_new_ex()

GSet * BLI_gset_str_new_ex ( const char * info,
const uint nentries_reserve )