changeset 1295:114ec0ab161c draft

Add free functions for predefined llist types.
author Rob Landley <rob@landley.net>
date Wed, 21 May 2014 06:57:43 -0500
parents 88abd5b68a17
children 314b1486d502
files lib/lib.h lib/llist.c
diffstat 2 files changed, 22 insertions(+), 2 deletions(-) [+]
line wrap: on
line diff
--- a/lib/lib.h	Wed May 21 05:12:38 2014 -0500
+++ b/lib/lib.h	Wed May 21 06:57:43 2014 -0500
@@ -24,7 +24,9 @@
   char *data;
 };
 
-void llist_traverse(void *list, void (*using)(void *data));
+void llist_free_arg(void *node);
+void llist_free_double(void *node);
+void llist_traverse(void *list, void (*using)(void *node));
 void *llist_pop(void *list);  // actually void **list
 void *dlist_pop(void *list);  // actually struct double_list **list
 void dlist_add_nomalloc(struct double_list **list, struct double_list *new);
--- a/lib/llist.c	Wed May 21 05:12:38 2014 -0500
+++ b/lib/llist.c	Wed May 21 06:57:43 2014 -0500
@@ -5,8 +5,26 @@
 
 #include "toys.h"
 
+// Callback function to free data pointer of double_list or arg_list
+
+void llist_free_arg(void *node)
+{
+  struct arg_list *d = node;
+
+  free(d->arg);
+  free(d);
+}
+
+void llist_free_double(void *node)
+{
+  struct double_list *d = node;
+
+  free(d->data);
+  free(d);
+}
+
 // Call a function (such as free()) on each element of a linked list.
-void llist_traverse(void *list, void (*using)(void *data))
+void llist_traverse(void *list, void (*using)(void *node))
 {
   void *old = list;