nv_pair_list_prev: remove unused function
[oweals/opkg-lede.git] / libopkg / nv_pair_list.c
index a3010e2b3b28b6eaff5a72582d5cfc92ed4e02f7..0dbbae17f5bb5a8c775fe6eed414beb7cc04727c 100644 (file)
    General Public License for more details.
 */
 
-#include "includes.h"
-
 #include "nv_pair.h"
 #include "void_list.h"
 #include "nv_pair_list.h"
+#include "libbb/libbb.h"
 
-int nv_pair_list_elt_init(nv_pair_list_elt_t *elt, nv_pair_t *data)
+void nv_pair_list_init(nv_pair_list_t * list)
 {
-    return void_list_elt_init((void_list_elt_t *) elt, data);
+       void_list_init((void_list_t *) list);
 }
 
-void nv_pair_list_elt_deinit(nv_pair_list_elt_t *elt)
+void nv_pair_list_deinit(nv_pair_list_t * list)
 {
-    void_list_elt_deinit((void_list_elt_t *) elt);
+       nv_pair_list_elt_t *pos;
+       nv_pair_t *nv_pair;
+
+       while (!void_list_empty(list)) {
+               pos = nv_pair_list_pop(list);
+               if (!pos)
+                       break;
+               nv_pair = (nv_pair_t *) pos->data;
+               nv_pair_deinit(nv_pair);
+               /* malloced in nv_pair_list_append */
+               free(nv_pair);
+               pos->data = NULL;
+               free(pos);
+       }
+       void_list_deinit((void_list_t *) list);
 }
 
-int nv_pair_list_init(nv_pair_list_t *list)
+nv_pair_t *nv_pair_list_append(nv_pair_list_t * list, const char *name,
+                              const char *value)
 {
-    return void_list_init((void_list_t *) list);
+       /* freed in nv_pair_list_deinit */
+       nv_pair_t *nv_pair = xcalloc(1, sizeof(nv_pair_t));
+       nv_pair_init(nv_pair, name, value);
+       void_list_append((void_list_t *) list, nv_pair);
+
+       return nv_pair;
 }
 
-void nv_pair_list_deinit(nv_pair_list_t *list)
+void nv_pair_list_push(nv_pair_list_t * list, nv_pair_t * data)
 {
-    nv_pair_list_elt_t *iter;
-    nv_pair_t *nv_pair;
-
-    for (iter = list->head; iter; iter = iter->next) {
-       nv_pair = iter->data;
-       nv_pair_deinit(nv_pair);
-
-       /* malloced in nv_pair_list_append */
-       free(nv_pair);
-       iter->data = NULL;
-    }
-    void_list_deinit((void_list_t *) list);
+       void_list_push((void_list_t *) list, data);
 }
 
-nv_pair_t *nv_pair_list_append(nv_pair_list_t *list, const char *name, const char *value)
+nv_pair_list_elt_t *nv_pair_list_pop(nv_pair_list_t * list)
 {
-    int err;
-
-    /* freed in nv_pair_list_deinit */
-    nv_pair_t *nv_pair = malloc(sizeof(nv_pair_t));
-
-    if (nv_pair == NULL) {
-       fprintf(stderr, "%s: out of memory\n", __FUNCTION__);
-       return NULL;
-    }
-    nv_pair_init(nv_pair, name, value);
-
-    err = void_list_append((void_list_t *) list, nv_pair);
-    if (err) {
-       return NULL;
-    }
-
-    return nv_pair;
+       return (nv_pair_list_elt_t *) void_list_pop((void_list_t *) list);
 }
 
-int nv_pair_list_push(nv_pair_list_t *list, nv_pair_t *data)
+char *nv_pair_list_find(nv_pair_list_t * list, char *name)
 {
-    return void_list_push((void_list_t *) list, data);
+       nv_pair_list_elt_t *iter;
+       nv_pair_t *nv_pair;
+
+       list_for_each_entry(iter, &list->head, node) {
+               nv_pair = (nv_pair_t *) iter->data;
+               if (strcmp(nv_pair->name, name) == 0) {
+                       return nv_pair->value;
+               }
+       }
+       return NULL;
 }
 
-nv_pair_list_elt_t *nv_pair_list_pop(nv_pair_list_t *list)
+nv_pair_list_elt_t *nv_pair_list_first(nv_pair_list_t * list)
 {
-    return (nv_pair_list_elt_t *) void_list_pop((void_list_t *) list);
+       return (nv_pair_list_elt_t *) void_list_first((void_list_t *) list);
 }
 
-char *nv_pair_list_find(nv_pair_list_t *list, char *name)
+nv_pair_list_elt_t *nv_pair_list_next(nv_pair_list_t * list,
+                                     nv_pair_list_elt_t * node)
 {
-     nv_pair_list_elt_t *iter;
-     nv_pair_t *nv_pair;
-
-     for (iter = list->head; iter; iter = iter->next) {
-         nv_pair = iter->data;
-         if (strcmp(nv_pair->name, name) == 0) {
-              return nv_pair->value;
-         }
-     }    
-     return NULL;
+       return (nv_pair_list_elt_t *) void_list_next((void_list_t *) list,
+                                                    (void_list_elt_t *) node);
 }