/* 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