/* BLURB lgpl

                           Coda File System
                              Release 5

          Copyright (c) 1987-1999 Carnegie Mellon University
                  Additional copyrights listed below

This  code  is  distributed "AS IS" without warranty of any kind under
the  terms of the  GNU  Library General Public Licence  Version 2,  as
shown in the file LICENSE. The technical and financial contributors to
Coda are listed in the file CREDITS.

                        Additional copyrights
                           none currently

#*/

#ifndef _DLLIST_H_
#define _DLLIST_H_

/* based on linux kernel code lists. */

struct list_head {
	struct list_head *next, *prev;
};

#define list_entry(ptr, type, member) \
	((type *)((char *)(ptr)-(unsigned long)(&((type *)0)->member)))

#define list_init(head) do { \
    struct list_head *h = head; \
    h->prev = h->next = h; } while(0);

#define list_add(entry, head) do { \
    struct list_head *h = head, *e = entry; \
    h->next->prev = e; \
    e->next = h->next; \
    e->prev = h; \
    h->next = e; } while(0);

#define list_del(entry) do { \
    struct list_head *e = entry; \
    e->prev->next = e->next; \
    e->next->prev = e->prev; \
    e->prev = e->next = e; } while(0);

#define list_empty(head) ((head)->next == head)
#define list_for_each(ptr, head) \
    for (ptr = (head)->next; ptr != head; ptr = ptr->next)

#endif /* _DLLIST_H_ */



syntax highlighted by Code2HTML, v. 0.9.1