Blame lib/list.h

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