mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2025-01-19 15:30:50 +00:00
4868a245b3
Empty structs are now (correctly) invalid. The hack of using an empty struct to represent a handle returned from a builtin has been unnecessary since opaque structs were implemented: now a pointer to an opaque struct can be used. This is mostly safe as handles are aways negative and thus attempting to dereference such a pointer should result in a VM error. It will be even safer once const is implemented and the pointers can be made constant (eg, typedef struct handle * const handle;)
24 lines
1.1 KiB
C
24 lines
1.1 KiB
C
#ifndef __ruamoko_hash_h
|
|
#define __ruamoko_hash_h
|
|
|
|
typedef struct _hashtab_t *hashtab_t;
|
|
|
|
@extern hashtab_t Hash_NewTable (int size, string gk (void *ele, void *data), void f (void *ele, void *data), void *ud);
|
|
@extern void Hash_SetHashCompare (hashtab_t tab, unsigned gh (void *ele, void *data), int cmp (void *ele1, void *ele2, void *data));
|
|
@extern void Hash_DelTable (hashtab_t tab);
|
|
@extern void Hash_FlushTable (hashtab_t tab);
|
|
@extern int Hash_Add (hashtab_t tab, void *ele);
|
|
@extern int Hash_AddElement (hashtab_t tab, void *ele);
|
|
@extern void *Hash_Find (hashtab_t tab, string key);
|
|
@extern void *Hash_FindElement (hashtab_t tab, void *ele);
|
|
@extern void **Hash_FindList (hashtab_t tab, string key);
|
|
@extern void **Hash_FindElementList (hashtab_t tab, void *ele);
|
|
@extern void *Hash_Del (hashtab_t tab, string key);
|
|
@extern void *Hash_DelElement (hashtab_t tab, void *ele);
|
|
@extern void Hash_Free (hashtab_t tab, void *ele);
|
|
@extern int Hash_String (string str);
|
|
@extern int Hash_Buffer (void *buf, int len);
|
|
@extern void **Hash_GetList (hashtab_t tab);
|
|
@extern void Hash_Stats (hashtab_t tab);
|
|
|
|
#endif // __ruamoko_hash_h
|