forked from enlightenment/efl
parent
00c8c7e257
commit
bf66f6f712
|
@ -53,180 +53,61 @@ struct _Eina_Hash_Tuple
|
|||
|
||||
typedef unsigned int (*Eina_Key_Length)(const void *key);
|
||||
#define EINA_KEY_LENGTH(Function) ((Eina_Key_Length)Function)
|
||||
typedef int (*Eina_Key_Cmp)(const void *key1, int key1_length,
|
||||
const void *key2, int key2_length);
|
||||
typedef int (*Eina_Key_Cmp)(const void *key1, int key1_length, const void *key2, int key2_length);
|
||||
#define EINA_KEY_CMP(Function) ((Eina_Key_Cmp)Function)
|
||||
typedef int (*Eina_Key_Hash)(const void *key, int key_length);
|
||||
#define EINA_KEY_HASH(Function) ((Eina_Key_Hash)Function)
|
||||
|
||||
EAPI Eina_Hash *
|
||||
eina_hash_new(Eina_Key_Length key_length_cb,
|
||||
Eina_Key_Cmp
|
||||
key_cmp_cb,
|
||||
Eina_Key_Hash
|
||||
key_hash_cb,
|
||||
Eina_Free_Cb
|
||||
data_free_cb,
|
||||
int
|
||||
buckets_power_size) EINA_MALLOC EINA_WARN_UNUSED_RESULT
|
||||
EINA_ARG_NONNULL(2, 3);
|
||||
EAPI Eina_Hash *
|
||||
eina_hash_string_djb2_new(
|
||||
Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *
|
||||
eina_hash_string_superfast_new(
|
||||
Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *
|
||||
eina_hash_string_small_new(
|
||||
Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *
|
||||
eina_hash_int32_new(
|
||||
Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *
|
||||
eina_hash_int64_new(
|
||||
Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *
|
||||
eina_hash_pointer_new(
|
||||
Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *
|
||||
eina_hash_stringshared_new(
|
||||
Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *eina_hash_new(Eina_Key_Length key_length_cb, Eina_Key_Cmp key_cmp_cb, Eina_Key_Hash key_hash_cb, Eina_Free_Cb data_free_cb, int buckets_power_size) EINA_MALLOC EINA_WARN_UNUSED_RESULT EINA_ARG_NONNULL(2, 3);
|
||||
EAPI Eina_Hash *eina_hash_string_djb2_new(Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *eina_hash_string_superfast_new(Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *eina_hash_string_small_new(Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *eina_hash_int32_new(Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *eina_hash_int64_new(Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *eina_hash_pointer_new(Eina_Free_Cb data_free_cb);
|
||||
EAPI Eina_Hash *eina_hash_stringshared_new(Eina_Free_Cb data_free_cb);
|
||||
|
||||
EAPI Eina_Bool
|
||||
eina_hash_add(
|
||||
Eina_Hash *hash,
|
||||
const void *key,
|
||||
const void *data) EINA_ARG_NONNULL(1, 2, 3);
|
||||
EAPI Eina_Bool
|
||||
eina_hash_direct_add(
|
||||
Eina_Hash *hash,
|
||||
const void *key,
|
||||
const void *data) EINA_ARG_NONNULL(1, 2, 3);
|
||||
EAPI Eina_Bool
|
||||
eina_hash_del(
|
||||
Eina_Hash *hash,
|
||||
const void *key,
|
||||
const void *data) EINA_ARG_NONNULL(1);
|
||||
EAPI void *
|
||||
eina_hash_find(
|
||||
const Eina_Hash *hash,
|
||||
const void *key) EINA_ARG_NONNULL(1, 2);
|
||||
EAPI void *
|
||||
eina_hash_modify(
|
||||
Eina_Hash *hash,
|
||||
const void *key,
|
||||
const void *data) EINA_ARG_NONNULL(1, 2, 3);
|
||||
EAPI void *
|
||||
eina_hash_set(
|
||||
Eina_Hash *hash,
|
||||
const void *key,
|
||||
const void *data) EINA_ARG_NONNULL(1, 2, 3);
|
||||
EAPI Eina_Bool
|
||||
eina_hash_move(
|
||||
Eina_Hash *hash,
|
||||
const void *old_key,
|
||||
const void *new_key) EINA_ARG_NONNULL(1, 2, 3);
|
||||
EAPI Eina_Bool eina_hash_add(Eina_Hash *hash, const void *key, const void *data) EINA_ARG_NONNULL(1, 2, 3);
|
||||
EAPI Eina_Bool eina_hash_direct_add(Eina_Hash *hash, const void *key, const void *data) EINA_ARG_NONNULL(1, 2, 3);
|
||||
EAPI Eina_Bool eina_hash_del(Eina_Hash *hash, const void *key, const void *data) EINA_ARG_NONNULL(1);
|
||||
EAPI void *eina_hash_find(const Eina_Hash *hash, const void *key) EINA_ARG_NONNULL(1, 2);
|
||||
EAPI void *eina_hash_modify(Eina_Hash *hash, const void *key, const void *data) EINA_ARG_NONNULL(1, 2, 3);
|
||||
EAPI void *eina_hash_set(Eina_Hash *hash, const void *key, const void *data) EINA_ARG_NONNULL(1, 2, 3);
|
||||
EAPI Eina_Bool eina_hash_move(Eina_Hash *hash, const void *old_key, const void *new_key) EINA_ARG_NONNULL(1, 2, 3);
|
||||
|
||||
EAPI void
|
||||
eina_hash_free(
|
||||
Eina_Hash *hash) EINA_ARG_NONNULL(1);
|
||||
EAPI void
|
||||
eina_hash_free_buckets(
|
||||
Eina_Hash *hash) EINA_ARG_NONNULL(1);
|
||||
EAPI int
|
||||
eina_hash_population(
|
||||
const Eina_Hash *hash) EINA_ARG_NONNULL(1);
|
||||
EAPI void eina_hash_free(Eina_Hash *hash) EINA_ARG_NONNULL(1);
|
||||
EAPI void eina_hash_free_buckets(Eina_Hash *hash) EINA_ARG_NONNULL(1);
|
||||
EAPI int eina_hash_population(const Eina_Hash *hash) EINA_ARG_NONNULL(1);
|
||||
|
||||
EAPI Eina_Bool
|
||||
eina_hash_add_by_hash(
|
||||
Eina_Hash *hash,
|
||||
const
|
||||
void *key,
|
||||
int key_length,
|
||||
int key_hash,
|
||||
const
|
||||
void *data) EINA_ARG_NONNULL(1, 2, 5);
|
||||
EAPI Eina_Bool
|
||||
eina_hash_direct_add_by_hash(Eina_Hash *hash,
|
||||
const
|
||||
void *key,
|
||||
int key_length,
|
||||
int key_hash,
|
||||
const
|
||||
void *data) EINA_ARG_NONNULL(1, 2, 5);
|
||||
EAPI Eina_Bool eina_hash_add_by_hash(Eina_Hash *hash, const void *key, int key_length, int key_hash, const void *data) EINA_ARG_NONNULL(1, 2, 5);
|
||||
EAPI Eina_Bool eina_hash_direct_add_by_hash(Eina_Hash *hash, const void *key, int key_length, int key_hash, const void *data) EINA_ARG_NONNULL(1, 2, 5);
|
||||
|
||||
EAPI Eina_Bool
|
||||
eina_hash_del_by_key_hash(Eina_Hash *hash,
|
||||
const void *key,
|
||||
int key_length,
|
||||
int key_hash) EINA_ARG_NONNULL(1, 2);
|
||||
EAPI Eina_Bool eina_hash_del_by_key_hash(Eina_Hash *hash, const void *key, int key_length, int key_hash) EINA_ARG_NONNULL(1, 2);
|
||||
|
||||
EAPI Eina_Bool
|
||||
eina_hash_del_by_key(Eina_Hash *hash, const void *key) EINA_ARG_NONNULL(1, 2);
|
||||
EAPI Eina_Bool
|
||||
eina_hash_del_by_data(Eina_Hash *hash, const void *data) EINA_ARG_NONNULL(1, 2);
|
||||
EAPI Eina_Bool eina_hash_del_by_key(Eina_Hash *hash, const void *key) EINA_ARG_NONNULL(1, 2);
|
||||
EAPI Eina_Bool eina_hash_del_by_data(Eina_Hash *hash, const void *data) EINA_ARG_NONNULL(1, 2);
|
||||
|
||||
EAPI Eina_Bool
|
||||
eina_hash_del_by_hash(Eina_Hash *hash,
|
||||
const
|
||||
void *key,
|
||||
int key_length,
|
||||
int key_hash,
|
||||
const
|
||||
void *data) EINA_ARG_NONNULL(1);
|
||||
EAPI void *
|
||||
eina_hash_find_by_hash(const Eina_Hash *hash,
|
||||
const
|
||||
void *key,
|
||||
int key_length,
|
||||
int key_hash) EINA_ARG_NONNULL(1, 2);
|
||||
EAPI void *
|
||||
eina_hash_modify_by_hash(Eina_Hash *hash,
|
||||
const
|
||||
void *key,
|
||||
int key_length,
|
||||
int key_hash,
|
||||
const
|
||||
void *data) EINA_ARG_NONNULL(1, 2, 5);
|
||||
EAPI Eina_Bool eina_hash_del_by_hash(Eina_Hash *hash, const void *key, int key_length, int key_hash, const void *data) EINA_ARG_NONNULL(1);
|
||||
EAPI void *eina_hash_find_by_hash(const Eina_Hash *hash, const void *key, int key_length, int key_hash) EINA_ARG_NONNULL(1, 2);
|
||||
EAPI void *eina_hash_modify_by_hash(Eina_Hash *hash, const void *key, int key_length, int key_hash, const void *data) EINA_ARG_NONNULL(1, 2, 5);
|
||||
|
||||
EAPI Eina_Iterator *
|
||||
eina_hash_iterator_key_new(
|
||||
const Eina_Hash *hash) EINA_MALLOC EINA_ARG_NONNULL(1)
|
||||
EINA_WARN_UNUSED_RESULT;
|
||||
EAPI Eina_Iterator *
|
||||
eina_hash_iterator_data_new(
|
||||
const Eina_Hash *hash) EINA_MALLOC EINA_ARG_NONNULL(
|
||||
1) EINA_WARN_UNUSED_RESULT;
|
||||
EAPI Eina_Iterator *
|
||||
eina_hash_iterator_tuple_new(
|
||||
const Eina_Hash *hash) EINA_MALLOC EINA_ARG_NONNULL(
|
||||
1) EINA_WARN_UNUSED_RESULT;
|
||||
EAPI Eina_Iterator *eina_hash_iterator_key_new(const Eina_Hash *hash) EINA_MALLOC EINA_ARG_NONNULL(1) EINA_WARN_UNUSED_RESULT;
|
||||
EAPI Eina_Iterator *eina_hash_iterator_data_new(const Eina_Hash *hash) EINA_MALLOC EINA_ARG_NONNULL(1) EINA_WARN_UNUSED_RESULT;
|
||||
EAPI Eina_Iterator *eina_hash_iterator_tuple_new(const Eina_Hash *hash) EINA_MALLOC EINA_ARG_NONNULL(1) EINA_WARN_UNUSED_RESULT;
|
||||
|
||||
typedef Eina_Bool (*Eina_Hash_Foreach)(const Eina_Hash *hash, const void *key,
|
||||
void *data, void *fdata);
|
||||
EAPI void
|
||||
eina_hash_foreach(const Eina_Hash *hash,
|
||||
Eina_Hash_Foreach
|
||||
cb,
|
||||
const
|
||||
void *fdata) EINA_ARG_NONNULL(1, 2);
|
||||
typedef Eina_Bool (*Eina_Hash_Foreach)(const Eina_Hash *hash, const void *key, void *data, void *fdata);
|
||||
EAPI void eina_hash_foreach(const Eina_Hash *hash, Eina_Hash_Foreach cb, const void *fdata) EINA_ARG_NONNULL(1, 2);
|
||||
|
||||
/* Paul Hsieh (http://www.azillionmonkeys.com/qed/hash.html) hash function
|
||||
used by WebCore (http://webkit.org/blog/8/hashtables-part-2/) */
|
||||
EAPI int
|
||||
eina_hash_superfast(const char *key, int len) EINA_ARG_NONNULL(1);
|
||||
/* Paul Hsieh (http://www.azillionmonkeys.com/qed/hash.html) hash function used by WebCore (http://webkit.org/blog/8/hashtables-part-2/) */
|
||||
EAPI int eina_hash_superfast(const char *key, int len) EINA_ARG_NONNULL(1);
|
||||
|
||||
/* Hash function first reported by dan bernstein many years ago in comp.lang.c */
|
||||
static inline int
|
||||
eina_hash_djb2(const char *key, int len) EINA_ARG_NONNULL(1);
|
||||
static inline int
|
||||
eina_hash_djb2_len(const char *key, int *plen) EINA_ARG_NONNULL(1, 2);
|
||||
static inline int eina_hash_djb2(const char *key, int len) EINA_ARG_NONNULL(1);
|
||||
static inline int eina_hash_djb2_len(const char *key, int *plen) EINA_ARG_NONNULL(1, 2);
|
||||
|
||||
/* Hash function from http://www.concentric.net/~Ttwang/tech/inthash.htm */
|
||||
static inline int
|
||||
eina_hash_int32(const unsigned int *pkey, int len) EINA_ARG_NONNULL(1);
|
||||
static inline int
|
||||
eina_hash_int64(const unsigned long int *pkey, int len) EINA_ARG_NONNULL(1);
|
||||
static inline int eina_hash_int32(const unsigned int *pkey, int len) EINA_ARG_NONNULL(1);
|
||||
static inline int eina_hash_int64(const unsigned long int *pkey, int len) EINA_ARG_NONNULL(1);
|
||||
|
||||
#include "eina_inline_hash.x"
|
||||
|
||||
|
|
Loading…
Reference in New Issue