D-Bus 1.12.20
dbus-list.h
1/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
2/* dbus-list.h Generic linked list utility (internal to D-Bus implementation)
3 *
4 * Copyright (C) 2002, 2003 Red Hat, Inc.
5 *
6 * Licensed under the Academic Free License version 2.1
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 *
22 */
23
24#ifndef DBUS_LIST_H
25#define DBUS_LIST_H
26
27#include <dbus/dbus-internals.h>
28#include <dbus/dbus-memory.h>
29#include <dbus/dbus-types.h>
30#include <dbus/dbus-sysdeps.h>
31
33
35{
38 void *data;
39};
40DBUS_PRIVATE_EXPORT
42 void *data);
43DBUS_PRIVATE_EXPORT
45 void *data);
46dbus_bool_t _dbus_list_insert_before (DBusList **list,
47 DBusList *before_this_link,
48 void *data);
49DBUS_PRIVATE_EXPORT
51 DBusList *after_this_link,
52 void *data);
53DBUS_PRIVATE_EXPORT
55 DBusList *before_this_link,
56 DBusList *link);
57DBUS_PRIVATE_EXPORT
59 DBusList *after_this_link,
60 DBusList *link);
61DBUS_PRIVATE_EXPORT
63 void *data);
64DBUS_PRIVATE_EXPORT
66 void *data);
67DBUS_PRIVATE_EXPORT
69 DBusList *link);
70DBUS_PRIVATE_EXPORT
72 void *data);
73DBUS_PRIVATE_EXPORT
74void _dbus_list_clear (DBusList **list);
75DBUS_PRIVATE_EXPORT
77DBUS_PRIVATE_EXPORT
79DBUS_PRIVATE_EXPORT
80void* _dbus_list_get_last (DBusList **list);
81DBUS_PRIVATE_EXPORT
82void* _dbus_list_get_first (DBusList **list);
83DBUS_PRIVATE_EXPORT
84void* _dbus_list_pop_first (DBusList **list);
85DBUS_PRIVATE_EXPORT
86void* _dbus_list_pop_last (DBusList **list);
87DBUS_PRIVATE_EXPORT
89DBUS_PRIVATE_EXPORT
91 DBusList **dest);
92DBUS_PRIVATE_EXPORT
94DBUS_PRIVATE_EXPORT
96DBUS_PRIVATE_EXPORT
98DBUS_PRIVATE_EXPORT
99void _dbus_list_unlink (DBusList **list,
100 DBusList *link);
101DBUS_PRIVATE_EXPORT
103 DBusList *link);
104DBUS_PRIVATE_EXPORT
106 DBusList *link);
107DBUS_PRIVATE_EXPORT
109
110
111DBUS_PRIVATE_EXPORT
112void _dbus_list_foreach (DBusList **list,
113 DBusForeachFunction function,
114 void *data);
115
116#define _dbus_list_get_next_link(list, link) ((link)->next == *(list) ? NULL : (link)->next)
117#define _dbus_list_get_prev_link(list, link) ((link) == *(list) ? NULL : (link)->prev)
118
119/* if DBUS_ENABLE_STATS */
120DBUS_PRIVATE_EXPORT
121void _dbus_list_get_stats (dbus_uint32_t *in_use_p,
122 dbus_uint32_t *in_free_list_p,
123 dbus_uint32_t *allocated_p);
124
126
127#endif /* DBUS_LIST_H */
void(* DBusForeachFunction)(void *element, void *data)
Used to iterate over each item in a collection, such as a DBusList.
DBUS_PRIVATE_EXPORT DBusList * _dbus_list_get_first_link(DBusList **list)
Gets the first link in the list.
Definition: dbus-list.c:567
DBUS_PRIVATE_EXPORT void _dbus_list_insert_before_link(DBusList **list, DBusList *before_this_link, DBusList *link)
Inserts a link into the list before the given existing link.
Definition: dbus-list.c:376
DBUS_PRIVATE_EXPORT dbus_bool_t _dbus_list_copy(DBusList **list, DBusList **dest)
Copies a list.
Definition: dbus-list.c:697
DBUS_PRIVATE_EXPORT DBusList * _dbus_list_pop_first_link(DBusList **list)
Removes the first link in the list and returns it.
Definition: dbus-list.c:628
DBUS_PRIVATE_EXPORT dbus_bool_t _dbus_list_length_is_one(DBusList **list)
Check whether length is exactly one.
Definition: dbus-list.c:783
DBUS_PRIVATE_EXPORT void * _dbus_list_get_last(DBusList **list)
Gets the last data in the list.
Definition: dbus-list.c:596
DBUS_PRIVATE_EXPORT dbus_bool_t _dbus_list_remove(DBusList **list, void *data)
Removes a value from the list.
Definition: dbus-list.c:415
DBUS_PRIVATE_EXPORT void _dbus_list_append_link(DBusList **list, DBusList *link)
Appends a link to the list.
Definition: dbus-list.c:315
DBUS_PRIVATE_EXPORT void _dbus_list_insert_after_link(DBusList **list, DBusList *after_this_link, DBusList *link)
Inserts a link into the list after the given existing link.
Definition: dbus-list.c:394
DBUS_PRIVATE_EXPORT dbus_bool_t _dbus_list_insert_after(DBusList **list, DBusList *after_this_link, void *data)
Inserts data into the list after the given existing link.
Definition: dbus-list.c:348
DBUS_PRIVATE_EXPORT void _dbus_list_remove_link(DBusList **list, DBusList *link)
Removes a link from the list.
Definition: dbus-list.c:527
DBUS_PRIVATE_EXPORT void * _dbus_list_get_first(DBusList **list)
Gets the first data in the list.
Definition: dbus-list.c:612
DBUS_PRIVATE_EXPORT DBusList * _dbus_list_get_last_link(DBusList **list)
Gets the last link in the list.
Definition: dbus-list.c:580
DBUS_PRIVATE_EXPORT void _dbus_list_unlink(DBusList **list, DBusList *link)
Removes the given link from the list, but doesn't free it.
Definition: dbus-list.c:499
DBUS_PRIVATE_EXPORT DBusList * _dbus_list_find_last(DBusList **list, void *data)
Finds a value in the list.
Definition: dbus-list.c:472
DBUS_PRIVATE_EXPORT void * _dbus_list_pop_last(DBusList **list)
Removes the last value in the list and returns it.
Definition: dbus-list.c:672
DBUS_PRIVATE_EXPORT void _dbus_list_free_link(DBusList *link)
Frees a linked list node allocated with _dbus_list_alloc_link.
Definition: dbus-list.c:254
DBUS_PRIVATE_EXPORT void * _dbus_list_pop_first(DBusList **list)
Removes the first value in the list and returns it.
Definition: dbus-list.c:649
DBUS_PRIVATE_EXPORT void _dbus_list_foreach(DBusList **list, DBusForeachFunction function, void *data)
Calls the given function for each element in the list.
Definition: dbus-list.c:759
DBUS_PRIVATE_EXPORT int _dbus_list_get_length(DBusList **list)
Gets the length of a list.
Definition: dbus-list.c:730
DBUS_PRIVATE_EXPORT void _dbus_list_clear(DBusList **list)
Frees all links in the list and sets the list head to NULL.
Definition: dbus-list.c:542
DBUS_PRIVATE_EXPORT void _dbus_list_prepend_link(DBusList **list, DBusList *link)
Prepends a link to the list.
Definition: dbus-list.c:333
DBUS_PRIVATE_EXPORT dbus_bool_t _dbus_list_prepend(DBusList **list, void *data)
Prepends a value to the list.
Definition: dbus-list.c:292
DBUS_PRIVATE_EXPORT DBusList * _dbus_list_alloc_link(void *data)
Allocates a linked list node.
Definition: dbus-list.c:242
DBUS_PRIVATE_EXPORT dbus_bool_t _dbus_list_remove_last(DBusList **list, void *data)
Removes a value from the list.
Definition: dbus-list.c:446
DBUS_PRIVATE_EXPORT dbus_bool_t _dbus_list_append(DBusList **list, void *data)
Appends a value to the list.
Definition: dbus-list.c:270
#define DBUS_BEGIN_DECLS
Macro used prior to declaring functions in the D-Bus header files.
#define DBUS_END_DECLS
Macro used after declaring functions in the D-Bus header files.
dbus_uint32_t dbus_bool_t
A boolean, valid values are TRUE and FALSE.
Definition: dbus-types.h:35
A node in a linked list.
Definition: dbus-list.h:35
void * data
Data stored at this element.
Definition: dbus-list.h:38
DBusList * next
Next list node.
Definition: dbus-list.h:37
DBusList * prev
Previous list node.
Definition: dbus-list.h:36