libdebian-installer
list.h
1 /*
2  * list.h
3  *
4  * Copyright (C) 2003 Bastian Blank <waldi@debian.org>
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program. If not, see <http://www.gnu.org/licenses/>.
18  */
19 
20 #ifndef DEBIAN_INSTALLER__LIST_H
21 #define DEBIAN_INSTALLER__LIST_H
22 
23 #include <debian-installer/mem_chunk.h>
24 
25 typedef struct di_list di_list;
26 typedef struct di_list_node di_list_node;
27 
36 struct di_list
37 {
40 };
41 
46 {
49  void *data;
50 };
51 
57 di_list *di_list_alloc (void);
58 
66 void di_list_destroy (di_list *list, di_destroy_notify destroy_func) __attribute__ ((nonnull(1)));
67 
73 void di_list_free (di_list *list);
74 
83 void di_list_append (di_list *list, void *data) __attribute__ ((nonnull(1)));
84 
93 void di_list_append_chunk (di_list *list, void *data, di_mem_chunk *mem_chunk) __attribute__ ((nonnull(1,3)));
94 
103 void di_list_prepend (di_list *list, void *data) __attribute__ ((nonnull(1)));
104 
116 void di_list_prepend_chunk (di_list *list, void *data, di_mem_chunk *mem_chunk) __attribute__ ((nonnull(1,3)));
117 
119 #endif
di_list_free
void di_list_free(di_list *list)
Definition: list.c:50
di_list_node::next
di_list_node * next
Definition: list.h:47
di_list_prepend_chunk
void di_list_prepend_chunk(di_list *list, void *data, di_mem_chunk *mem_chunk) __attribute__((nonnull(1
di_destroy_notify
void di_destroy_notify(void *data)
Definition: types.h:50
di_mem_chunk
a mem chunk
Definition: mem_chunk.c:46
di_list
Double-linked list.
Definition: list.h:36
di_list_node::data
void * data
Definition: list.h:49
di_mem_chunk_alloc
void * di_mem_chunk_alloc(di_mem_chunk *mem_chunk)
Definition: mem_chunk.c:120
di_new
#define di_new(struct_type, n_structs)
Definition: mem.h:73
di_free
void di_free(void *mem)
Definition: mem.c:60
di_list::head
di_list_node * head
Definition: list.h:38
di_list_node::prev
di_list_node * prev
Definition: list.h:48
di_list_append_chunk
void di_list_append_chunk(di_list *list, void *data, di_mem_chunk *mem_chunk) __attribute__((nonnull(1
di_list_alloc
di_list * di_list_alloc(void)
Definition: list.c:26
di_list::bottom
di_list_node * bottom
Definition: list.h:39
di_list_append
void di_list_append(di_list *list, void *data)
Definition: list.c:69
di_list_node
Node of a double-linked list.
Definition: list.h:45
di_list_prepend
void di_list_prepend(di_list *list, void *data)
Definition: list.c:93
di_list_destroy
void di_list_destroy(di_list *list, di_destroy_notify destroy_func)
Definition: list.c:35
di_new0
#define di_new0(struct_type, n_structs)
Definition: mem.h:79
di_hash_table::mem_chunk
di_mem_chunk * mem_chunk
Definition: hash.c:46