summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 2bfa89e)
raw | patch | inline | side by side (parent: 2bfa89e)
author | Sebastian Harl <sh@tokkee.org> | |
Wed, 24 Mar 2010 22:08:34 +0000 (23:08 +0100) | ||
committer | Sebastian Harl <sh@tokkee.org> | |
Wed, 24 Mar 2010 22:08:34 +0000 (23:08 +0100) |
This function may be used for lookups using a custom compare function, i.e.
lookups that are not necessarily based on the name of the registered list
entry but some information specific to the used data-type.
lookups that are not necessarily based on the name of the registered list
entry but some information specific to the used data-type.
src/utils_llist.c | patch | blob | history | |
src/utils_llist.h | patch | blob | history |
diff --git a/src/utils_llist.c b/src/utils_llist.c
index bf5f7e4944e335c6660eb0226cd8d43faa9aa2a8..6a0c6f06411b76e7fa15083bb1d5fd850c9d48f0 100644 (file)
--- a/src/utils_llist.c
+++ b/src/utils_llist.c
return (l ? l->size : 0);
}
+static int llist_strcmp (llentry_t *e, void *ud)
+{
+ if ((e == NULL) || (ud == NULL))
+ return (-1);
+ return (strcmp (e->key, (const char *)ud));
+}
+
llentry_t *llist_search (llist_t *l, const char *key)
+{
+ return (llist_search_custom (l, llist_strcmp, (void *)key));
+}
+
+llentry_t *llist_search_custom (llist_t *l,
+ int (*compare) (llentry_t *, void *), void *user_data)
{
llentry_t *e;
if (l == NULL)
return (NULL);
- for (e = l->head; e != NULL; e = e->next)
- if (strcmp (key, e->key) == 0)
+ e = l->head;
+ while (e != NULL) {
+ llentry_t *next = e->next;
+
+ if (compare (e, user_data) == 0)
break;
+ e = next;
+ }
+
return (e);
}
diff --git a/src/utils_llist.h b/src/utils_llist.h
index c3753d83f25fe579c98af4e52fa7dbfa7fbdbecb..19d8d947bd66b94acead4079856a558107186f13 100644 (file)
--- a/src/utils_llist.h
+++ b/src/utils_llist.h
int llist_size (llist_t *l);
llentry_t *llist_search (llist_t *l, const char *key);
+llentry_t *llist_search_custom (llist_t *l,
+ int (*compare) (llentry_t *, void *), void *user_data);
llentry_t *llist_head (llist_t *l);
llentry_t *llist_tail (llist_t *l);