Blame src/llist.h

Packit 3ae693
/*-*- Mode: C; c-basic-offset: 8 -*-*/
Packit 3ae693
Packit 3ae693
#ifndef foocanberrallistfoo
Packit 3ae693
#define foocanberrallistfoo
Packit 3ae693
Packit 3ae693
/***
Packit 3ae693
  This file is part of libcanberra.
Packit 3ae693
Packit 3ae693
  Copyright 2008 Lennart Poettering
Packit 3ae693
Packit 3ae693
  libcanberra is free software; you can redistribute it and/or modify
Packit 3ae693
  it under the terms of the GNU Lesser General Public License as
Packit 3ae693
  published by the Free Software Foundation, either version 2.1 of the
Packit 3ae693
  License, or (at your option) any later version.
Packit 3ae693
Packit 3ae693
  libcanberra is distributed in the hope that it will be useful, but
Packit 3ae693
  WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 3ae693
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Packit 3ae693
  Lesser General Public License for more details.
Packit 3ae693
Packit 3ae693
  You should have received a copy of the GNU Lesser General Public
Packit 3ae693
  License along with libcanberra. If not, see
Packit 3ae693
  <http://www.gnu.org/licenses/>.
Packit 3ae693
***/
Packit 3ae693
Packit 3ae693
#include "macro.h"
Packit 3ae693
Packit 3ae693
/* Some macros for maintaining doubly linked lists */
Packit 3ae693
Packit 3ae693
/* The head of the linked list. Use this in the structure that shall
Packit 3ae693
 * contain the head of the linked list */
Packit 3ae693
#define CA_LLIST_HEAD(t,name)                   \
Packit 3ae693
        t *name
Packit 3ae693
Packit 3ae693
/* The pointers in the linked list's items. Use this in the item structure */
Packit 3ae693
#define CA_LLIST_FIELDS(t)                      \
Packit 3ae693
        t *next, *prev
Packit 3ae693
Packit 3ae693
/* Initialize the list's head */
Packit 3ae693
#define CA_LLIST_HEAD_INIT(t,item)              \
Packit 3ae693
        do {                                    \
Packit 3ae693
                (item) = (t*) NULL; }           \
Packit 3ae693
        while(0)
Packit 3ae693
Packit 3ae693
/* Initialize a list item */
Packit 3ae693
#define CA_LLIST_INIT(t,item)                           \
Packit 3ae693
        do {                                            \
Packit 3ae693
                t *_item = (item);                      \
Packit 3ae693
                ca_assert(_item);                       \
Packit 3ae693
                _item->prev = _item->next = NULL;       \
Packit 3ae693
        } while(0)
Packit 3ae693
Packit 3ae693
/* Prepend an item to the list */
Packit 3ae693
#define CA_LLIST_PREPEND(t,head,item)                   \
Packit 3ae693
        do {                                            \
Packit 3ae693
                t **_head = &(head), *_item = (item);   \
Packit 3ae693
                ca_assert(_item);                       \
Packit 3ae693
                if ((_item->next = *_head))             \
Packit 3ae693
                        _item->next->prev = _item;      \
Packit 3ae693
                _item->prev = NULL;                     \
Packit 3ae693
                *_head = _item;                         \
Packit 3ae693
        } while (0)
Packit 3ae693
Packit 3ae693
/* Remove an item from the list */
Packit 3ae693
#define CA_LLIST_REMOVE(t,head,item)                            \
Packit 3ae693
        do {                                                    \
Packit 3ae693
                t **_head = &(head), *_item = (item);           \
Packit 3ae693
                ca_assert(_item);                               \
Packit 3ae693
                if (_item->next)                                \
Packit 3ae693
                        _item->next->prev = _item->prev;        \
Packit 3ae693
                if (_item->prev)                                \
Packit 3ae693
                        _item->prev->next = _item->next;        \
Packit 3ae693
                else {                                          \
Packit 3ae693
                        ca_assert(*_head == _item);             \
Packit 3ae693
                        *_head = _item->next;                   \
Packit 3ae693
                }                                               \
Packit 3ae693
                _item->next = _item->prev = NULL;               \
Packit 3ae693
        } while(0)
Packit 3ae693
Packit 3ae693
/* Find the head of the list */
Packit 3ae693
#define CA_LLIST_FIND_HEAD(t,item,head)                 \
Packit 3ae693
        do {                                            \
Packit 3ae693
                t **_head = (head), *_item = (item);    \
Packit 3ae693
                *_head = _item;                         \
Packit 3ae693
                ca_assert(_head);                       \
Packit 3ae693
                while ((*_head)->prev)                  \
Packit 3ae693
                        *_head = (*_head)->prev;        \
Packit 3ae693
        } while (0)
Packit 3ae693
Packit 3ae693
/* Insert an item after another one (a = where, b = what) */
Packit 3ae693
#define CA_LLIST_INSERT_AFTER(t,head,a,b)                       \
Packit 3ae693
        do {                                                    \
Packit 3ae693
                t **_head = &(head), *_a = (a), *_b = (b);      \
Packit 3ae693
                ca_assert(_b);                                  \
Packit 3ae693
                if (!_a) {                                      \
Packit 3ae693
                        if ((_b->next = *_head))                \
Packit 3ae693
                                _b->next->prev = _b;            \
Packit 3ae693
                        _b->prev = NULL;                        \
Packit 3ae693
                        *_head = _b;                            \
Packit 3ae693
                } else {                                        \
Packit 3ae693
                        if ((_b->next = _a->next))              \
Packit 3ae693
                                _b->next->prev = _b;            \
Packit 3ae693
                        _b->prev = _a;                          \
Packit 3ae693
                        _a->next = _b;                          \
Packit 3ae693
                }                                               \
Packit 3ae693
        } while (0)
Packit 3ae693
Packit 3ae693
#endif