Temporary changes to dlinklist to keep the implementation static whilst
[ira/wip.git] / lib / util / dlinklist.h
index 693b43dd27e083152b9c6d189c115930872badd0..c1f01e616ae2ea1147e8370905f024a8f2a0b15f 100644 (file)
@@ -51,6 +51,22 @@ do { \
        if ((p) != (list)) (p)->next = (p)->prev = NULL; \
 } while (0)
 
+#define DLIST_HEAD(p, result_head) \
+do { \
+       (result_head) = (p); \
+       while (DLIST_PREV(result_head)) (result_head) = (result_head)->prev; \
+} while(0)
+
+/* return the last element in the list */
+#define DLIST_TAIL(list, result_tail) \
+do { \
+       (result_tail) = (list); \
+       while ((result_tail) && (result_tail)->next) (result_tail) = (result_tail)->next; \
+} while (0);
+
+/* return the previous element in the list. */
+#define DLIST_PREV(p) ((p)?(p)->prev:NULL)
+
 /* promote an element to the top of the list */
 #define DLIST_PROMOTE(list, p) \
 do { \