merge with 0.30.213
[util-vserver.git] / ensc_vector / list.h
1 // $Id: list.h 1896 2005-03-17 14:51:55Z ensc $    --*- c -*--
2
3 // Copyright (C) 2005 Enrico Scholz <enrico.scholz@sigma-chemnitz.de>
4 //  
5 // This program is free software; you can redistribute it and/or modify
6 // it under the terms of the GNU General Public License as published by
7 // the Free Software Foundation; version 2 of the License.
8 //  
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 // GNU General Public License for more details.
13 //  
14 // You should have received a copy of the GNU General Public License
15 // along with this program; if not, write to the Free Software
16 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
17 //  
18
19 #ifndef H_UTILVSERVER_VECTOR_LIST_H
20 #define H_UTILVSERVER_VECTOR_LIST_H
21
22 #include <stdlib.h>
23
24 struct ListItem;
25 struct List
26 {
27     struct ListItem     *root;
28     size_t              count;
29     size_t              elem_size;
30 };
31
32 typedef enum { listMOVE_FRONT, listSHIFT_ONCE }          ListSelfOrgMethod;
33
34 void    List_init(struct List *, size_t elem_size);
35 void    List_free(struct List *);
36 void *  List_add(struct List *, void const *key);
37 void *          List_at(struct List *, size_t idx);
38 void const *    List_at_const(struct List const *, size_t idx);
39
40 void const *    List_search(struct List const *, void const *key,
41                             int (*compare)(const void *, const void *));
42
43 void const *    List_searchSelfOrg(struct List const *, void const *key,
44                                    int (*compare)(const void *, const void *),
45                                    ListSelfOrgMethod method);
46
47 #endif  //  H_UTILVSERVER_VECTOR_LIST_H