X-Git-Url: http://git.madism.org/?a=blobdiff_plain;f=lib%2Flist.c;h=1dd865ffcc28e2a4717c4ae9d93c736b3323cb00;hb=b0a700a4558d9bb59395ddcf08565a5e709841e1;hp=e921b204431d2ad923836868af965839c4b4247d;hpb=98ccd0a3050f3dda6c8995e1894b46b8cb7f6ba5;p=apps%2Fmadmutt.git diff --git a/lib/list.c b/lib/list.c index e921b20..1dd865f 100644 --- a/lib/list.c +++ b/lib/list.c @@ -13,9 +13,10 @@ #include "list.h" #include "mem.h" +#include "str.h" list2_t* list_new (void) { - return (safe_calloc (1, sizeof (list2_t))); + return (mem_calloc (1, sizeof (list2_t))); } void list_del (list2_t** l, list_del_t* del) { @@ -25,21 +26,21 @@ void list_del (list2_t** l, list_del_t* del) { if (del) for (i = 0; i < (*l)->length; i++) del (&(*l)->data[i]); - FREE(&(*l)->data); - FREE(l); + mem_free(&(*l)->data); + mem_free(l); } void list_push_back (list2_t** l, void* p) { if (!*l) *l = list_new (); - safe_realloc (&(*l)->data, (++(*l)->length)*sizeof(void*)); + mem_realloc (&(*l)->data, (++(*l)->length)*sizeof(void*)); (*l)->data[(*l)->length-1] = p; } void list_push_front (list2_t** l, void* p) { if (!*l) *l = list_new (); - safe_realloc (&(*l)->data, (++(*l)->length)*sizeof(void*)); + mem_realloc (&(*l)->data, (++(*l)->length)*sizeof(void*)); if ((*l)->length > 1) memmove (&(*l)->data[1], &(*l)->data[0], ((*l)->length-1)*sizeof(void*)); (*l)->data[0] = p; @@ -50,7 +51,7 @@ void* list_pop_back (list2_t* l) { if (list_empty(l)) return (NULL); p = l->data[l->length-1]; - safe_realloc (&l->data, --(l->length)*sizeof(void*)); + mem_realloc (&l->data, --(l->length)*sizeof(void*)); return (p); } @@ -60,7 +61,7 @@ void* list_pop_front (list2_t* l) { return (NULL); p = l->data[0]; memmove (&l->data[0], &l->data[1], (--(l->length))*sizeof(void*)); - safe_realloc (&l->data, l->length*sizeof(void*)); + mem_realloc (&l->data, l->length*sizeof(void*)); return (p); } @@ -72,7 +73,7 @@ void* list_pop_idx (list2_t* l, int c) { return (list_pop_back (l)); p = l->data[c]; memmove (&l->data[c], &l->data[c+1], (l->length-c)*sizeof(void*)); - safe_realloc (&l->data, (--(l->length))*sizeof(void*)); + mem_realloc (&l->data, (--(l->length))*sizeof(void*)); return (p); } @@ -82,7 +83,7 @@ list2_t* list_cpy (list2_t* l) { return (NULL); ret = list_new (); ret->length = l->length; - ret->data = safe_malloc (l->length*sizeof(void*)); + ret->data = mem_malloc (l->length*sizeof(void*)); memcpy (ret->data, l->data, l->length*sizeof(void*)); return (ret); } @@ -94,7 +95,7 @@ list2_t* list_dup (list2_t* l, void* (*dup) (void*)) { return (NULL); ret = list_new (); ret->length = l->length; - ret->data = safe_malloc (l->length*sizeof(void*)); + ret->data = mem_malloc (l->length*sizeof(void*)); for (i = 0; i < l->length; i++) ret->data[i] = dup (l->data[i]); return (ret); @@ -109,3 +110,19 @@ int list_lookup (list2_t* l, int (*cmp) (const void*, const void*), const void* return (i); return (-1); } + +list2_t* list_from_str (const char* str, const char* delim) { + list2_t* ret = NULL; + char* tmp = NULL, *p = NULL; + + if (!str || !*str || !delim || !*delim) + return (NULL); + + tmp = str_dup (str); + for (p = strtok (tmp, delim); p; p = strtok (NULL, delim)) { + list_push_back (&ret, str_dup (p)); + } + mem_free (&tmp); + return (ret); +} +