| /* Copyright (C) 2001, 2002, 2003 Red Hat, Inc. |
| Written by Ulrich Drepper <drepper@redhat.com>, 2001. |
| |
| This program is Open Source software; you can redistribute it and/or |
| modify it under the terms of the Open Software License version 1.0 as |
| published by the Open Source Initiative. |
| |
| You should have received a copy of the Open Software License along |
| with this program; if not, you may obtain a copy of the Open Software |
| License version 1.0 from http://www.opensource.org/licenses/osl.php or |
| by writing the Open Source Initiative c/o Lawrence Rosen, Esq., |
| 3001 King Ranch Road, Ukiah, CA 95482. */ |
| |
| #ifndef LIST_H |
| #define LIST_H 1 |
| |
| /* Add element to the end of a circular, double-linked list. */ |
| #define CDBL_LIST_ADD_REAR(first, newp) \ |
| do { \ |
| __typeof (newp) _newp = (newp); \ |
| assert (_newp->next == NULL); \ |
| assert (_newp->previous == NULL); \ |
| if (unlikely ((first) == NULL)) \ |
| (first) = _newp->next = _newp->previous = _newp; \ |
| else \ |
| { \ |
| _newp->next = (first); \ |
| _newp->previous = (first)->previous; \ |
| _newp->previous->next = _newp->next->previous = _newp; \ |
| } \ |
| } while (0) |
| |
| /* Remove element from circular, double-linked list. */ |
| #define CDBL_LIST_DEL(first, elem) \ |
| do { \ |
| __typeof (elem) _elem = (elem); \ |
| /* Check whether the element is indeed on the list. */ \ |
| assert (first != NULL && _elem != NULL \ |
| && (first != elem \ |
| || ({ __typeof (elem) _runp = first->next; \ |
| while (_runp != first) \ |
| if (_runp == _elem) \ |
| break; \ |
| else \ |
| _runp = _runp->next; \ |
| _runp == _elem; }))); \ |
| if (unlikely (_elem->next == _elem)) \ |
| first = NULL; \ |
| else \ |
| { \ |
| _elem->next->previous = _elem->previous; \ |
| _elem->previous->next = _elem->next; \ |
| if (unlikely (first == _elem)) \ |
| first = _elem->next; \ |
| } \ |
| assert ((_elem->next = _elem->previous = NULL, 1)); \ |
| } while (0) |
| |
| |
| /* Add element to the front of a single-linked list. */ |
| #define SNGL_LIST_PUSH(first, newp) \ |
| do { \ |
| __typeof (newp) _newp = (newp); \ |
| assert (_newp->next == NULL); \ |
| _newp->next = first; \ |
| first = _newp; \ |
| } while (0) |
| |
| |
| /* Add element to the rear of a circular single-linked list. */ |
| #define CSNGL_LIST_ADD_REAR(first, newp) \ |
| do { \ |
| __typeof (newp) _newp = (newp); \ |
| assert (_newp->next == NULL); \ |
| if (unlikely ((first) == NULL)) \ |
| (first) = _newp->next = _newp; \ |
| else \ |
| { \ |
| _newp->next = (first)->next; \ |
| (first) = (first)->next = _newp; \ |
| } \ |
| } while (0) |
| |
| |
| #endif /* list.h */ |