1
/* Abstract sequential list data type, with out-of-memory checking.
2
Copyright (C) 2009-2012 Free Software Foundation, Inc.
3
Written by Bruno Haible <bruno@clisp.org>, 2009.
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; either version 3 of the License, or
8
(at your option) any later version.
10
This program is distributed in the hope that it will be useful,
11
but WITHOUT ANY WARRANTY; without even the implied warranty of
12
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
GNU General Public License for more details.
15
You should have received a copy of the GNU General Public License
16
along with this program. If not, see <http://www.gnu.org/licenses/>. */
28
/* These functions are thin wrappers around the corresponding functions with
29
_nx_ infix from gl_list.h. Upon out-of-memory, they invoke xalloc_die (),
30
instead of returning an error indicator. */
31
extern gl_list_t gl_list_create_empty (gl_list_implementation_t implementation,
32
gl_listelement_equals_fn equals_fn,
33
gl_listelement_hashcode_fn hashcode_fn,
34
gl_listelement_dispose_fn dispose_fn,
35
bool allow_duplicates);
36
extern gl_list_t gl_list_create (gl_list_implementation_t implementation,
37
gl_listelement_equals_fn equals_fn,
38
gl_listelement_hashcode_fn hashcode_fn,
39
gl_listelement_dispose_fn dispose_fn,
40
bool allow_duplicates,
41
size_t count, const void **contents);
42
extern void gl_list_node_set_value (gl_list_t list, gl_list_node_t node,
44
extern gl_list_node_t gl_list_set_at (gl_list_t list, size_t position,
46
extern gl_list_node_t gl_list_add_first (gl_list_t list, const void *elt);
47
extern gl_list_node_t gl_list_add_last (gl_list_t list, const void *elt);
48
extern gl_list_node_t gl_list_add_before (gl_list_t list, gl_list_node_t node,
50
extern gl_list_node_t gl_list_add_after (gl_list_t list, gl_list_node_t node,
52
extern gl_list_node_t gl_list_add_at (gl_list_t list, size_t position,
54
extern gl_list_node_t gl_sortedlist_add (gl_list_t list,
55
gl_listelement_compar_fn compar,
60
# define gl_list_create_empty gl_list_create_empty_inline
61
static inline gl_list_t
62
gl_list_create_empty (gl_list_implementation_t implementation,
63
gl_listelement_equals_fn equals_fn,
64
gl_listelement_hashcode_fn hashcode_fn,
65
gl_listelement_dispose_fn dispose_fn,
66
bool allow_duplicates)
69
gl_list_nx_create_empty (implementation, equals_fn, hashcode_fn, dispose_fn,
76
# define gl_list_create gl_list_create_inline
77
static inline gl_list_t
78
gl_list_create (gl_list_implementation_t implementation,
79
gl_listelement_equals_fn equals_fn,
80
gl_listelement_hashcode_fn hashcode_fn,
81
gl_listelement_dispose_fn dispose_fn,
82
bool allow_duplicates,
83
size_t count, const void **contents)
86
gl_list_nx_create (implementation, equals_fn, hashcode_fn, dispose_fn,
87
allow_duplicates, count, contents);
93
# define gl_list_node_set_value gl_list_node_set_value_inline
95
gl_list_node_set_value (gl_list_t list, gl_list_node_t node, const void *elt)
97
int result = gl_list_node_nx_set_value (list, node, elt);
102
# define gl_list_set_at gl_list_set_at_inline
103
static inline gl_list_node_t
104
gl_list_set_at (gl_list_t list, size_t position, const void *elt)
106
gl_list_node_t result = gl_list_nx_set_at (list, position, elt);
112
# define gl_list_add_first gl_list_add_first_inline
113
static inline gl_list_node_t
114
gl_list_add_first (gl_list_t list, const void *elt)
116
gl_list_node_t result = gl_list_nx_add_first (list, elt);
122
# define gl_list_add_last gl_list_add_last_inline
123
static inline gl_list_node_t
124
gl_list_add_last (gl_list_t list, const void *elt)
126
gl_list_node_t result = gl_list_nx_add_last (list, elt);
132
# define gl_list_add_before gl_list_add_before_inline
133
static inline gl_list_node_t
134
gl_list_add_before (gl_list_t list, gl_list_node_t node, const void *elt)
136
gl_list_node_t result = gl_list_nx_add_before (list, node, elt);
142
# define gl_list_add_after gl_list_add_after_inline
143
static inline gl_list_node_t
144
gl_list_add_after (gl_list_t list, gl_list_node_t node, const void *elt)
146
gl_list_node_t result = gl_list_nx_add_after (list, node, elt);
152
# define gl_list_add_at gl_list_add_at_inline
153
static inline gl_list_node_t
154
gl_list_add_at (gl_list_t list, size_t position, const void *elt)
156
gl_list_node_t result = gl_list_nx_add_at (list, position, elt);
162
# define gl_sortedlist_add gl_sortedlist_add_inline
163
static inline gl_list_node_t
164
gl_sortedlist_add (gl_list_t list, gl_listelement_compar_fn compar,
167
gl_list_node_t result = gl_sortedlist_nx_add (list, compar, elt);
179
#endif /* _GL_XLIST_H */