Lines Matching refs:list

23 #define ISC_LIST_INIT(list) \
24 do { (list).head = NULL; (list).tail = NULL; } while (0)
36 #define ISC_LIST_HEAD(list) ((list).head)
37 #define ISC_LIST_TAIL(list) ((list).tail)
38 #define ISC_LIST_EMPTY(list) ISC_TF((list).head == NULL)
40 #define __ISC_LIST_PREPENDUNSAFE(list, elt, link) \
42 if ((list).head != NULL) \
43 (list).head->link.prev = (elt); \
45 (list).tail = (elt); \
47 (elt)->link.next = (list).head; \
48 (list).head = (elt); \
51 #define ISC_LIST_PREPEND(list, elt, link) \
54 __ISC_LIST_PREPENDUNSAFE(list, elt, link); \
57 #define ISC_LIST_INITANDPREPEND(list, elt, link) \
58 __ISC_LIST_PREPENDUNSAFE(list, elt, link)
60 #define __ISC_LIST_APPENDUNSAFE(list, elt, link) \
62 if ((list).tail != NULL) \
63 (list).tail->link.next = (elt); \
65 (list).head = (elt); \
66 (elt)->link.prev = (list).tail; \
68 (list).tail = (elt); \
71 #define ISC_LIST_APPEND(list, elt, link) \
74 __ISC_LIST_APPENDUNSAFE(list, elt, link); \
77 #define ISC_LIST_INITANDAPPEND(list, elt, link) \
78 __ISC_LIST_APPENDUNSAFE(list, elt, link)
80 #define __ISC_LIST_UNLINKUNSAFE_TYPE(list, elt, link, type) \
85 ISC_INSIST((list).tail == (elt)); \
86 (list).tail = (elt)->link.prev; \
91 ISC_INSIST((list).head == (elt)); \
92 (list).head = (elt)->link.next; \
96 ISC_INSIST((list).head != (elt)); \
97 ISC_INSIST((list).tail != (elt)); \
100 #define __ISC_LIST_UNLINKUNSAFE(list, elt, link) \
101 __ISC_LIST_UNLINKUNSAFE_TYPE(list, elt, link, void)
103 #define ISC_LIST_UNLINK_TYPE(list, elt, link, type) \
106 __ISC_LIST_UNLINKUNSAFE_TYPE(list, elt, link, type); \
108 #define ISC_LIST_UNLINK(list, elt, link) \
109 ISC_LIST_UNLINK_TYPE(list, elt, link, void)
114 #define __ISC_LIST_INSERTBEFOREUNSAFE(list, before, elt, link) \
117 ISC_LIST_PREPEND(list, elt, link); \
126 #define ISC_LIST_INSERTBEFORE(list, before, elt, link) \
130 __ISC_LIST_INSERTBEFOREUNSAFE(list, before, elt, link); \
133 #define __ISC_LIST_INSERTAFTERUNSAFE(list, after, elt, link) \
136 ISC_LIST_APPEND(list, elt, link); \
145 #define ISC_LIST_INSERTAFTER(list, after, elt, link) \
149 __ISC_LIST_INSERTAFTERUNSAFE(list, after, elt, link); \
178 #define ISC_LIST_ENQUEUE(list, elt, link) ISC_LIST_APPEND(list, elt, link)
179 #define __ISC_LIST_ENQUEUEUNSAFE(list, elt, link) \
180 __ISC_LIST_APPENDUNSAFE(list, elt, link)
181 #define ISC_LIST_DEQUEUE(list, elt, link) \
182 ISC_LIST_UNLINK_TYPE(list, elt, link, void)
183 #define ISC_LIST_DEQUEUE_TYPE(list, elt, link, type) \
184 ISC_LIST_UNLINK_TYPE(list, elt, link, type)
185 #define __ISC_LIST_DEQUEUEUNSAFE(list, elt, link) \
186 __ISC_LIST_UNLINKUNSAFE_TYPE(list, elt, link, void)
187 #define __ISC_LIST_DEQUEUEUNSAFE_TYPE(list, elt, link, type) \
188 __ISC_LIST_UNLINKUNSAFE_TYPE(list, elt, link, type)