summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorPaul Jakma <paul.jakma@sun.com>2006-06-15 12:43:09 +0000
committerPaul Jakma <paul.jakma@sun.com>2006-06-15 12:43:09 +0000
commitc024fd0c76bc305cd6b6bab0989226bd9ec5e763 (patch)
treefabd937784fd330d046244a8febb418ca8663b5c /lib
parent8ce5cfd13eb7f8474b3129a57c160273889c2573 (diff)
[lib] list_delete shouldn't duplicate list_delete_all_node
2006-06-15 Paul Jakma <paul.jakma@sun.com> * linklist.c: (list_delete) call list_delete_all_node, don't duplicate it.
Diffstat (limited to 'lib')
-rw-r--r--lib/ChangeLog2
-rw-r--r--lib/linklist.c11
2 files changed, 3 insertions, 10 deletions
diff --git a/lib/ChangeLog b/lib/ChangeLog
index b7c9f040..a9c3b8bf 100644
--- a/lib/ChangeLog
+++ b/lib/ChangeLog
@@ -3,6 +3,8 @@
* command.c: (cmd_describe_command_real) Fix leak, CID #38.
* memory.h: Experimental, have XFREE macro NULL out the freed
pointer.
+ * linklist.c: (list_delete) call list_delete_all_node, don't
+ duplicate it.
2006-05-28 Paul Jakma <paul.jakma@sun.com>
diff --git a/lib/linklist.c b/lib/linklist.c
index 71c4db82..11e16a8a 100644
--- a/lib/linklist.c
+++ b/lib/linklist.c
@@ -226,17 +226,8 @@ list_delete_all_node (struct list *list)
void
list_delete (struct list *list)
{
- struct listnode *node;
- struct listnode *next;
-
assert(list);
- for (node = list->head; node; node = next)
- {
- next = node->next;
- if (list->del)
- (*list->del) (node->data);
- listnode_free (node);
- }
+ list_delete_all_node (list);
list_free (list);
}