Blame lib/list.h

Packit 032894
/* Copyright (C) 2001, 2002, 2003 Red Hat, Inc.
Packit 032894
   This file is part of elfutils.
Packit 032894
   Written by Ulrich Drepper <drepper@redhat.com>, 2001.
Packit 032894
Packit 032894
   This file is free software; you can redistribute it and/or modify
Packit 032894
   it under the terms of either
Packit 032894
Packit 032894
     * the GNU Lesser General Public License as published by the Free
Packit 032894
       Software Foundation; either version 3 of the License, or (at
Packit 032894
       your option) any later version
Packit 032894
Packit 032894
   or
Packit 032894
Packit 032894
     * the GNU General Public License as published by the Free
Packit 032894
       Software Foundation; either version 2 of the License, or (at
Packit 032894
       your option) any later version
Packit 032894
Packit 032894
   or both in parallel, as here.
Packit 032894
Packit 032894
   elfutils is distributed in the hope that it will be useful, but
Packit 032894
   WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 032894
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 032894
   General Public License for more details.
Packit 032894
Packit 032894
   You should have received copies of the GNU General Public License and
Packit 032894
   the GNU Lesser General Public License along with this program.  If
Packit 032894
   not, see <http://www.gnu.org/licenses/>.  */
Packit 032894
Packit 032894
#ifndef LIST_H
Packit 032894
#define LIST_H	1
Packit 032894
Packit 032894
/* Add element to the end of a circular, double-linked list.  */
Packit 032894
#define CDBL_LIST_ADD_REAR(first, newp) \
Packit 032894
  do {									      \
Packit 032894
    __typeof (newp) _newp = (newp);					      \
Packit 032894
    assert (_newp->next == NULL);					      \
Packit 032894
    assert (_newp->previous == NULL);					      \
Packit 032894
    if (unlikely ((first) == NULL))					      \
Packit 032894
      (first) = _newp->next = _newp->previous = _newp;			      \
Packit 032894
    else								      \
Packit 032894
      {									      \
Packit 032894
	_newp->next = (first);						      \
Packit 032894
	_newp->previous = (first)->previous;				      \
Packit 032894
	_newp->previous->next = _newp->next->previous = _newp;		      \
Packit 032894
      }									      \
Packit 032894
  } while (0)
Packit 032894
Packit 032894
/* Remove element from circular, double-linked list.  */
Packit 032894
#define CDBL_LIST_DEL(first, elem) \
Packit 032894
  do {									      \
Packit 032894
    __typeof (elem) _elem = (elem);					      \
Packit 032894
    /* Check whether the element is indeed on the list.  */		      \
Packit 032894
    assert (first != NULL && _elem != NULL				      \
Packit 032894
	    && (first != elem						      \
Packit 032894
		|| ({ __typeof (elem) _runp = first->next;		      \
Packit 032894
		      while (_runp != first)				      \
Packit 032894
			if (_runp == _elem)				      \
Packit 032894
			  break;					      \
Packit 032894
			else						      \
Packit 032894
		          _runp = _runp->next;				      \
Packit 032894
		      _runp == _elem; })));				      \
Packit 032894
    if (unlikely (_elem->next == _elem))				      \
Packit 032894
      first = NULL;							      \
Packit 032894
    else								      \
Packit 032894
      {									      \
Packit 032894
	_elem->next->previous = _elem->previous;			      \
Packit 032894
	_elem->previous->next = _elem->next;				      \
Packit 032894
	if (unlikely (first == _elem))					      \
Packit 032894
	  first = _elem->next;						      \
Packit 032894
      }									      \
Packit 032894
     assert ((_elem->next = _elem->previous = NULL, 1));		      \
Packit 032894
  } while (0)
Packit 032894
Packit 032894
Packit 032894
/* Add element to the front of a single-linked list.  */
Packit 032894
#define SNGL_LIST_PUSH(first, newp) \
Packit 032894
  do {									      \
Packit 032894
    __typeof (newp) _newp = (newp);					      \
Packit 032894
    assert (_newp->next == NULL);					      \
Packit 032894
    _newp->next = first;						      \
Packit 032894
    first = _newp;							      \
Packit 032894
  } while (0)
Packit 032894
Packit 032894
Packit 032894
/* Add element to the rear of a circular single-linked list.  */
Packit 032894
#define CSNGL_LIST_ADD_REAR(first, newp) \
Packit 032894
  do {									      \
Packit 032894
    __typeof (newp) _newp = (newp);					      \
Packit 032894
    assert (_newp->next == NULL);					      \
Packit 032894
    if (unlikely ((first) == NULL))					      \
Packit 032894
      (first) = _newp->next = _newp;					      \
Packit 032894
    else								      \
Packit 032894
      {									      \
Packit 032894
	_newp->next = (first)->next;					      \
Packit 032894
	(first) = (first)->next = _newp;				      \
Packit 032894
      }									      \
Packit 032894
  } while (0)
Packit 032894
Packit 032894
Packit 032894
#endif	/* list.h */