diff options
| -rw-r--r-- | src/pulsecore/idxset.c | 10 | ||||
| -rw-r--r-- | src/pulsecore/idxset.h | 10 | 
2 files changed, 14 insertions, 6 deletions
diff --git a/src/pulsecore/idxset.c b/src/pulsecore/idxset.c index 23fe0b5a..ee0137a3 100644 --- a/src/pulsecore/idxset.c +++ b/src/pulsecore/idxset.c @@ -42,8 +42,8 @@ typedef struct idxset_entry {  } idxset_entry;  struct pa_idxset { -    unsigned (*hash_func) (const void *p); -    int (*compare_func)(const void *a, const void *b); +    pa_hash_func_t hash_func; +    pa_compare_func_t compare_func;      unsigned hash_table_size, n_entries;      idxset_entry **hash_table, **array, *iterate_list_head, *iterate_list_tail; @@ -65,21 +65,21 @@ int pa_idxset_string_compare_func(const void *a, const void *b) {  }  unsigned pa_idxset_trivial_hash_func(const void *p) { -    return (unsigned) (long) p; +    return PA_PTR_TO_UINT(p);  }  int pa_idxset_trivial_compare_func(const void *a, const void *b) {      return a != b;  } -pa_idxset* pa_idxset_new(unsigned (*hash_func) (const void *p), int (*compare_func) (const void*a, const void*b)) { +pa_idxset* pa_idxset_new(pa_hash_func_t hash_func, pa_compare_func_t compare_func) {      pa_idxset *s;      s = pa_xnew(pa_idxset, 1);      s->hash_func = hash_func ? hash_func : pa_idxset_trivial_hash_func;      s->compare_func = compare_func ? compare_func : pa_idxset_trivial_compare_func;      s->hash_table_size = 127; -    s->hash_table = pa_xmalloc0(sizeof(idxset_entry*)*s->hash_table_size); +    s->hash_table = pa_xnew0(idxset_entry*, s->hash_table_size);      s->array = NULL;      s->array_size = 0;      s->index = 0; diff --git a/src/pulsecore/idxset.h b/src/pulsecore/idxset.h index 3d0bc75f..1765e843 100644 --- a/src/pulsecore/idxset.h +++ b/src/pulsecore/idxset.h @@ -41,10 +41,18 @@ int pa_idxset_trivial_compare_func(const void *a, const void *b);  unsigned pa_idxset_string_hash_func(const void *p);  int pa_idxset_string_compare_func(const void *a, const void *b); +#define PA_PTR_TO_UINT(p) ((unsigned int) (unsigned long) (p)) +#define PA_UINT_TO_PTR(u) ((void*) (unsigned long) (u)) +#define PA_PTR_TO_UINT32(p) ((uint32_t) PA_PTR_TO_UINT(p)) +#define PA_UINT32_TO_PTR(u) PA_UINT_TO_PTR(u) + +typedef unsigned (*pa_hash_func_t)(const void *p); +typedef int (*pa_compare_func_t)(const void *a, const void *b); +  typedef struct pa_idxset pa_idxset;  /* Instantiate a new idxset with the specified hash and comparison functions */ -pa_idxset* pa_idxset_new(unsigned (*hash_func) (const void *p), int (*compare_func) (const void*a, const void*b)); +pa_idxset* pa_idxset_new(pa_hash_func_t hash_func, pa_compare_func_t compare_func);  /* Free the idxset. When the idxset is not empty the specified function is called for every entry contained */  void pa_idxset_free(pa_idxset *s, void (*free_func) (void *p, void *userdata), void *userdata);  | 
