Changes in uspace/lib/c/include/adt/list.h [b72efe8:0a02653] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/lib/c/include/adt/list.h
rb72efe8 r0a02653 1 1 /* 2 2 * Copyright (c) 2001-2004 Jakub Jermar 3 * Copyright (c) 2011 Jiri Svoboda4 3 * All rights reserved. 5 4 * … … 37 36 #define LIBC_LIST_H_ 38 37 39 #include <assert.h>40 38 #include <unistd.h> 41 39 42 /** Doubly linked list link. */40 /** Doubly linked list head and link type. */ 43 41 typedef struct link { 44 42 struct link *prev; /**< Pointer to the previous item in the list. */ … … 46 44 } link_t; 47 45 48 /** Doubly linked list. */49 typedef struct list {50 link_t head; /**< List head. Does not have any data. */51 } list_t;52 53 46 /** Declare and initialize statically allocated list. 54 47 * … … 57 50 */ 58 51 #define LIST_INITIALIZE(name) \ 59 list_t name = { \ 60 .head = { \ 61 .prev = &(name).head, \ 62 .next = &(name).head \ 63 } \ 52 link_t name = { \ 53 .prev = &name, \ 54 .next = &name \ 64 55 } 65 56 … … 68 59 69 60 #define list_foreach(list, iterator) \ 70 for (link_t *iterator = (list).head.next; \ 71 iterator != &(list).head; iterator = iterator->next) 72 73 #define assert_link_not_used(link) \ 74 assert((link)->prev == NULL && (link)->next == NULL) 61 for (link_t *iterator = (list).next; \ 62 iterator != &(list); iterator = iterator->next) 75 63 76 64 /** Initialize doubly-linked circular list link … … 91 79 * Initialize doubly-linked circular list. 92 80 * 93 * @param list Pointer to list_t structure. 94 * 95 */ 96 static inline void list_initialize(list_t *list) 97 { 98 list->head.prev = &list->head; 99 list->head.next = &list->head; 81 * @param list Pointer to link_t structure representing the list. 82 * 83 */ 84 static inline void list_initialize(link_t *list) 85 { 86 list->prev = list; 87 list->next = list; 88 } 89 90 /** Add item to the beginning of doubly-linked circular list 91 * 92 * Add item to the beginning of doubly-linked circular list. 93 * 94 * @param link Pointer to link_t structure to be added. 95 * @param list Pointer to link_t structure representing the list. 96 * 97 */ 98 static inline void list_prepend(link_t *link, link_t *list) 99 { 100 link->next = list->next; 101 link->prev = list; 102 list->next->prev = link; 103 list->next = link; 104 } 105 106 /** Add item to the end of doubly-linked circular list 107 * 108 * Add item to the end of doubly-linked circular list. 109 * 110 * @param link Pointer to link_t structure to be added. 111 * @param list Pointer to link_t structure representing the list. 112 * 113 */ 114 static inline void list_append(link_t *link, link_t *list) 115 { 116 link->prev = list->prev; 117 link->next = list; 118 list->prev->next = link; 119 list->prev = link; 100 120 } 101 121 … … 103 123 * 104 124 */ 105 static inline void list_insert_before(link_t *lnew, link_t *lold) 106 { 107 lnew->next = lold; 108 lnew->prev = lold->prev; 109 lold->prev->next = lnew; 110 lold->prev = lnew; 125 static inline void list_insert_before(link_t *link, link_t *list) 126 { 127 list_append(link, list); 111 128 } 112 129 … … 114 131 * 115 132 */ 116 static inline void list_insert_after(link_t *lnew, link_t *lold) 117 { 118 lnew->prev = lold; 119 lnew->next = lold->next; 120 lold->next->prev = lnew; 121 lold->next = lnew; 122 } 123 124 /** Add item to the beginning of doubly-linked circular list 125 * 126 * Add item to the beginning of doubly-linked circular list. 127 * 128 * @param link Pointer to link_t structure to be added. 129 * @param list Pointer to list_t structure. 130 * 131 */ 132 static inline void list_prepend(link_t *link, list_t *list) 133 { 134 list_insert_after(link, &list->head); 135 } 136 137 /** Add item to the end of doubly-linked circular list 138 * 139 * Add item to the end of doubly-linked circular list. 140 * 141 * @param link Pointer to link_t structure to be added. 142 * @param list Pointer to list_t structure. 143 * 144 */ 145 static inline void list_append(link_t *link, list_t *list) 146 { 147 list_insert_before(link, &list->head); 133 static inline void list_insert_after(link_t *link, link_t *list) 134 { 135 list_prepend(list, link); 148 136 } 149 137 … … 167 155 * Query emptiness of doubly-linked circular list. 168 156 * 169 * @param list Pointer to lin s_t structure.170 * 171 */ 172 static inline int list_empty(li st_t *list)173 { 174 return (list-> head.next == &list->head);175 } 176 177 /** Get first item inlist.178 * 179 * @param list Pointer to li st_t structure.157 * @param list Pointer to link_t structure representing the list. 158 * 159 */ 160 static inline int list_empty(link_t *list) 161 { 162 return (list->next == list); 163 } 164 165 /** Get head item of a list. 166 * 167 * @param list Pointer to link_t structure representing the list. 180 168 * 181 169 * @return Head item of the list. … … 183 171 * 184 172 */ 185 static inline link_t *list_first(list_t *list) 186 { 187 return ((list->head.next == &list->head) ? NULL : list->head.next); 188 } 189 190 /** Get last item in list. 191 * 192 * @param list Pointer to list_t structure. 193 * 194 * @return Head item of the list. 195 * @return NULL if the list is empty. 196 * 197 */ 198 static inline link_t *list_last(list_t *list) 199 { 200 return ((list->head.prev == &list->head) ? NULL : list->head.prev); 173 static inline link_t *list_head(link_t *list) 174 { 175 return ((list->next == list) ? NULL : list->next); 201 176 } 202 177 … … 255 230 } 256 231 257 /** Get n-th item ina list.232 /** Get n-th item of a list. 258 233 * 259 234 * @param list Pointer to link_t structure representing the list. … … 264 239 * 265 240 */ 266 static inline link_t *list_nth(li st_t *list, unsigned int n)241 static inline link_t *list_nth(link_t *list, unsigned int n) 267 242 { 268 243 unsigned int cnt = 0; … … 278 253 } 279 254 280 extern int list_member(const link_t *, const li st_t *);281 extern void list_concat(li st_t *, list_t *);282 extern unsigned int list_count(const li st_t *);255 extern int list_member(const link_t *, const link_t *); 256 extern void list_concat(link_t *, link_t *); 257 extern unsigned int list_count(const link_t *); 283 258 284 259 #endif
Note:
See TracChangeset
for help on using the changeset viewer.