summaryrefslogtreecommitdiffstats
path: root/lib/linklist.c
diff options
context:
space:
mode:
authorpaul <paul>2003-09-24 01:47:14 +0200
committerpaul <paul>2003-09-24 01:47:14 +0200
commit729606fea247f482231d78c5e70ae66db98a2678 (patch)
tree6ce91fe54890d3ae2dd219c2c05f08450c17de60 /lib/linklist.c
parent2003-09-24 sowmini.varadhan@sun.com (diff)
downloadfrr-729606fea247f482231d78c5e70ae66db98a2678.tar.xz
frr-729606fea247f482231d78c5e70ae66db98a2678.zip
2003-09-24 sowmini.varadhan@sun.com
* lib/linklist.c: (if_cmp_func) Fix handling of case where list->cmp returns 0.
Diffstat (limited to 'lib/linklist.c')
-rw-r--r--lib/linklist.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/lib/linklist.c b/lib/linklist.c
index 3cb10caf1..049ab0bb4 100644
--- a/lib/linklist.c
+++ b/lib/linklist.c
@@ -87,15 +87,17 @@ listnode_add_sort (struct list *list, void *val)
struct listnode *n;
struct listnode *new;
- new = listnode_new ();
- new->data = val;
if (list->cmp)
{
for (n = list->head; n; n = n->next)
{
+ if ((*list->cmp) (val, n->data) == 0)
+ return;
if ((*list->cmp) (val, n->data) < 0)
{
+ new = listnode_new ();
+ new->data = val;
new->next = n;
new->prev = n->prev;
@@ -110,6 +112,8 @@ listnode_add_sort (struct list *list, void *val)
}
}
+ new = listnode_new ();
+ new->data = val;
new->prev = list->tail;
if (list->tail)