ucx/dlist.h

Thu, 16 Aug 2012 11:31:16 +0200

author
Mike Becker <universe@uap-core.de>
date
Thu, 16 Aug 2012 11:31:16 +0200
changeset 36
a9d656e4f7ce
parent 35
fdabd1240b69
child 67
27e67e725d35
permissions
-rw-r--r--

changed API of sort algorithms (no further hint for the algorithms used in preparation for the upcomming change from qsort to natural merge sort)

     1 /* 
     2  * 
     3  */
     5 #ifndef DLIST_H
     6 #define	DLIST_H
     8 #include "ucx.h"
     9 #include <stddef.h>
    11 #ifdef	__cplusplus
    12 extern "C" {
    13 #endif
    15 typedef struct UcxDlist UcxDlist;
    16 struct UcxDlist {
    17     void     *data;
    18     UcxDlist *next;
    19     UcxDlist *prev;
    20 };
    22 UcxDlist *ucx_dlist_clone(UcxDlist *l, copy_func fnc, void* data);
    23 int ucx_dlist_equals(UcxDlist *l1, UcxDlist *l2, cmp_func fnc, void* data);
    25 void ucx_dlist_free(UcxDlist *l);
    26 UcxDlist *ucx_dlist_append(UcxDlist *l, void *data);
    27 UcxDlist *ucx_dlist_prepend(UcxDlist *l, void *data);
    28 UcxDlist *ucx_dlist_concat(UcxDlist *l1, UcxDlist *l2);
    29 UcxDlist *ucx_dlist_last(UcxDlist *l);
    30 UcxDlist *ucx_dlist_get(UcxDlist *l, int index);
    31 size_t ucx_dlist_size(UcxDlist *l);
    33 UcxDlist *ucx_dlist_sort(UcxDlist *l, cmp_func fnc, void *data);
    35 /* dlist specific functions */
    36 UcxDlist *ucx_dlist_first(UcxDlist *l);
    37 UcxDlist *ucx_dlist_remove(UcxDlist *l, UcxDlist *e);
    39 #ifdef	__cplusplus
    40 }
    41 #endif
    43 #endif	/* DLIST_H */

mercurial