1 /* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
3 * Authors: Jeffrey Stedfast <fejj@ximian.com>
5 * Copyright 2003 Ximian, Inc. (www.ximian.com)
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
32 #endif /* __cplusplus */
34 typedef struct _ListNode
{
35 struct _ListNode
*next
;
36 struct _ListNode
*prev
;
45 #define LIST_INITIALIZER(l) { (ListNode *) &l.tail, NULL, (ListNode *) &l.head }
47 void list_init (List
*list
);
49 int list_is_empty (List
*list
);
51 int list_length (List
*list
);
53 ListNode
*list_unlink_head (List
*list
);
54 ListNode
*list_unlink_tail (List
*list
);
56 ListNode
*list_prepend_node (List
*list
, ListNode
*node
);
57 ListNode
*list_append_node (List
*list
, ListNode
*node
);
59 ListNode
*list_node_unlink (ListNode
*node
);
63 #endif /* __cplusplus */
65 #endif /* __LIST_H__ */