aboutsummaryrefslogtreecommitdiffstats
path: root/utils
diff options
context:
space:
mode:
authorseanbright <seanbright@f38db490-d61c-443f-a65b-d21fe96a405b>2008-11-07 22:39:30 +0000
committerseanbright <seanbright@f38db490-d61c-443f-a65b-d21fe96a405b>2008-11-07 22:39:30 +0000
commita7a95954c816e072bd44fb884029853a3585db33 (patch)
tree80eea1f19a98b0f9ca3ab09f32d0eea8aa0f85d5 /utils
parentf7be936f69d32c2b9aedb70d25395cb51c01eea6 (diff)
Add ability to pass arbitrary data to the ao2_callback_fn (called from
ao2_callback and ao2_find). Currently, passing OBJ_POINTER to either of these mandates that the passed 'arg' is a hashable object, making searching for an ao2 object based on outside criteria difficult. Reviewed by Russell and Mark M. via ReviewBoard: http://reviewboard.digium.com/r/36/ git-svn-id: http://svn.digium.com/svn/asterisk/trunk@155401 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'utils')
-rw-r--r--utils/hashtest2.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/utils/hashtest2.c b/utils/hashtest2.c
index 3b0c62699..41582998c 100644
--- a/utils/hashtest2.c
+++ b/utils/hashtest2.c
@@ -80,7 +80,7 @@ static int hash_string(const void *obj, const int flags)
return total;
}
-static int hashtab_compare_strings(void *a, void *b, int flags)
+static int hashtab_compare_strings(void *a, void *b, void *data, int flags)
{
const struct ht_element *ae = a, *be = b;
return !strcmp(ae->key, be->key) ? CMP_MATCH | CMP_STOP : 0;
@@ -137,7 +137,7 @@ static void add_element(void)
els_added++; /* unprotected, sometimes off, but, not really important, either */
}
-static int do_nothing_cb(void *obj, void *arg, int flags)
+static int do_nothing_cb(void *obj, void *arg, void *data, int flags)
{
return 0;
}
@@ -147,7 +147,7 @@ static void traverse_elements(void)
#ifdef DEBUG
printf("Traverse hashtab\n");
#endif
- ao2_callback(glob_hashtab, OBJ_NODATA, do_nothing_cb, NULL);
+ ao2_callback(glob_hashtab, OBJ_NODATA, do_nothing_cb, NULL, NULL);
els_traversals++; /* unprotected, sometimes off, but, not really important, either */
}
@@ -164,7 +164,7 @@ static void * del_element(unsigned int *seedp)
printf("- %s", keybuf);
#endif
lookup.key = keybuf;
- el = ao2_find(glob_hashtab, &lookup, OBJ_POINTER);
+ el = ao2_find(glob_hashtab, &lookup, NULL, OBJ_POINTER);
if (el) {
#ifdef DEBUG
printf("...YES (el=%x)\n", (unsigned long)el);
@@ -190,7 +190,7 @@ static int lookup_element(unsigned int *seedp)
x = my_rand(0,glob_highwater-1,seedp);
sprintf(keybuf, "key%08d", x);
lookup.key = keybuf;
- el = ao2_find(glob_hashtab, &lookup, OBJ_POINTER);
+ el = ao2_find(glob_hashtab, &lookup, NULL, OBJ_POINTER);
els_lookedup++;
if (el) {
els_found++;