Go to the source code of this file.
|
#define | GTG_LIST_INIT(ptr) |
| initialize a list.
|
|
#define | GTG_LIST(name) |
| declare and initialize a list.
|
|
#define | gtg_list_entry(ptr, type, member) ((type *)((char *)(ptr) - (char *)(&((type *)0)->member))) |
| get the structure corresponding to a list entry
|
|
#define | gtg_list_for_each(pos, head) for (pos = (head)->next; pos != (head); pos = pos->next) |
|
#define | gtg_list_for_each_reverse(pos, head) for (pos = (head)->prev; pos != (head); pos = pos->prev) |
|
#define | gtg_list_for_each_safe(pos, n, head) |
|
#define | gtg_list_for_each_entry(pos, head, member) |
| iterate over list of given type
|
|
#define | gtg_list_for_each_entry_safe(pos, n, head, member) |
| iterate over list of given type safe against removal of list entry
|
|
◆ GTG_LIST
Value:
declare and initialize a list.
- Parameters
-
◆ gtg_list_entry
gtg_list_entry |
( |
|
ptr, |
|
|
|
type, |
|
|
|
member |
|
) |
| ((type *)((char *)(ptr) - (char *)(&((type *)0)->member))) |
get the structure corresponding to a list entry
- Parameters
-
ptr | pointer to the list entry (gtg_list_t) |
type | the type of the struct this is embedded in. |
member | the name of the struct gtg_list member within the struct. |
◆ gtg_list_for_each
#define gtg_list_for_each |
( |
|
pos, |
|
|
|
head |
|
) |
| for (pos = (head)->next; pos != (head); pos = pos->next) |
◆ gtg_list_for_each_entry
#define gtg_list_for_each_entry |
( |
|
pos, |
|
|
|
head, |
|
|
|
member |
|
) |
| |
Value:
&pos->member != (head); \
#define gtg_list_entry(ptr, type, member)
get the structure corresponding to a list entry
Definition GTGList.h:39
iterate over list of given type
gtg_list_for_each_entry(pos, head, member)
- Parameters
-
pos | the type * to use as a loop counter. |
head | the head for the list. |
member | the name of the struct gtg_list member within the struct. |
◆ gtg_list_for_each_entry_safe
#define gtg_list_for_each_entry_safe |
( |
|
pos, |
|
|
|
n, |
|
|
|
head, |
|
|
|
member |
|
) |
| |
Value:
&pos->member != (head); \
iterate over list of given type safe against removal of list entry
gtg_list_for_each_entry_safe(pos, n, head, member)
- Parameters
-
pos | the type * to use as a loop counter. |
n | another type * to use as temporary storage |
head | the head for the list. |
member | the name of the struct gtg_list member within the struct. |
◆ gtg_list_for_each_reverse
#define gtg_list_for_each_reverse |
( |
|
pos, |
|
|
|
head |
|
) |
| for (pos = (head)->prev; pos != (head); pos = pos->prev) |
◆ gtg_list_for_each_safe
#define gtg_list_for_each_safe |
( |
|
pos, |
|
|
|
n, |
|
|
|
head |
|
) |
| |
Value: for (pos = (head)->next, n = pos->next; pos != (head); \
pos = n, n = pos->next)
◆ GTG_LIST_INIT
Value: do { \
(ptr)->prev = (ptr); \
(ptr)->next = (ptr); \
} while(0)
initialize a list.
- Parameters
-
ptr | pointer to the list (gtg_list_t). |
◆ gtg_list_t
◆ __gtg_list_add()
◆ __gtg_list_del()
Delete a list entry by making the prev/next entries point to each other.
This is only for internal list manipulation where we know the prev/next entries already!
◆ gtg_list_add()
Insert a new entry after the specified head.
- Parameters
-
lnew | new entry to be added |
head | list head to add it after |
◆ gtg_list_add_tail()
Insert a new entry before the specified head (ie. at the tail of the list).
- Parameters
-
lnew | new entry to be added |
head | list head to add it after |
◆ gtg_list_del()
delete an entry from its list and reinitialize it.
- Parameters
-
entry | the element to delete from the list. |
◆ gtg_list_size()