/* * Copyright (C) 2016 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef _LIST_H_ #define _LIST_H_ #include <stdbool.h> struct link_t { struct link_t *prev, *next; } typedef link_t; #define list_iterate(list, cur_link, tmp_link) \ for ((cur_link) = (list)->next, \ (tmp_link) = (cur_link) ? (cur_link)->next : NULL; \ (cur_link) != NULL && (cur_link) != (list); \ (cur_link) = (tmp_link), (tmp_link) = (cur_link)->next) #define DECLARE_LIST(list) \ link_t list = { .prev = &list, .next = &list } static inline void list_init(struct link_t *list) { list->prev = list->next = list; } static inline void list_add_tail(struct link_t *list, struct link_t *item) { if (!list->next) list_init(list); item->prev = list->prev; item->next = list; list->prev->next = item; list->prev = item; } static inline void list_delete(struct link_t *item) { item->prev->next = item->next; item->next->prev = item->prev; item->next = item->prev = item; } static inline bool list_is_empty(struct link_t *list) { return !list->next || list->next == list; } #endif