diff options
author | Lennart Poettering <lennart@poettering.net> | 2014-05-06 13:07:15 +0200 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2014-05-06 13:07:15 +0200 |
commit | 376cd3b89c62f580a6f576cecfbbb28d3944118f (patch) | |
tree | b3c38305268bf87703884743a3c04b302fbecb15 /src/shared | |
parent | 2db3e2023d1af9eab6ebecddbf64812be2b104f5 (diff) |
list: make LIST_FIND_TAIL work for empty lists
Diffstat (limited to 'src/shared')
-rw-r--r-- | src/shared/list.h | 22 |
1 files changed, 14 insertions, 8 deletions
diff --git a/src/shared/list.h b/src/shared/list.h index e55b91cea4..c020f7e936 100644 --- a/src/shared/list.h +++ b/src/shared/list.h @@ -75,20 +75,26 @@ #define LIST_FIND_HEAD(name,item,head) \ do { \ typeof(*(item)) *_item = (item); \ - assert(_item); \ - while (_item->name##_prev) \ - _item = _item->name##_prev; \ - (head) = _item; \ + if (!_item) \ + (head) = NULL; \ + else { \ + while (_item->name##_prev) \ + _item = _item->name##_prev; \ + (head) = _item; \ + } \ } while (false) /* Find the tail of the list */ #define LIST_FIND_TAIL(name,item,tail) \ do { \ typeof(*(item)) *_item = (item); \ - assert(_item); \ - while (_item->name##_next) \ - _item = _item->name##_next; \ - (tail) = _item; \ + if (!_item) \ + (tail) = NULL; \ + else { \ + while (_item->name##_next) \ + _item = _item->name##_next; \ + (tail) = _item; \ + } \ } while (false) /* Insert an item after another one (a = where, b = what) */ |