X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/77b991d5e8d3a4c462f313fdd97989777415b498..725184f3bce66a3eff87cc3a01e5d96477a5d28a:/src/xbt/dict_private.h diff --git a/src/xbt/dict_private.h b/src/xbt/dict_private.h index 7869357aeb..9ec22a9c34 100644 --- a/src/xbt/dict_private.h +++ b/src/xbt/dict_private.h @@ -20,11 +20,16 @@ typedef struct xbt_dictelm_ *xbt_dictelm_t; +#define MAX_FILL_PERCENT 80 + typedef struct xbt_dictelm_ { char *key; int key_len; + unsigned int hash_code; + void *content; - void_f_pvoid_t *free_f; + void_f_pvoid_t free_f; + xbt_dictelm_t next; } s_xbt_dictelm_t; @@ -32,22 +37,21 @@ typedef struct xbt_dict_ { xbt_dictelm_t *table; int table_size; int count; + int fill; } s_xbt_dict_t; typedef struct xbt_dict_cursor_ s_xbt_dict_cursor_t; extern xbt_mallocator_t dict_elm_mallocator; -extern void* dict_elm_mallocator_new_f(void); -extern void dict_elm_mallocator_free_f(void* elem); -extern void dict_elm_mallocator_reset_f(void* elem); +extern void *dict_elm_mallocator_new_f(void); +extern void dict_elm_mallocator_free_f(void *elem); +extern void dict_elm_mallocator_reset_f(void *elem); /*####[ Function prototypes ]################################################*/ -xbt_dictelm_t xbt_dictelm_new(const char *key, - int key_len, - void *content, - void_f_pvoid_t free_f, - xbt_dictelm_t next); +xbt_dictelm_t xbt_dictelm_new(const char *key, int key_len, + unsigned int hash_code, void *content, + void_f_pvoid_t free_f); void xbt_dictelm_free(xbt_dictelm_t element); void xbt_dict_add_element(xbt_dict_t dict, xbt_dictelm_t element); -#endif /* _XBT_DICT_PRIVATE_H_ */ +#endif /* _XBT_DICT_PRIVATE_H_ */