/***
*    Copyright (C) 1999,2000  Dibyendu Majumdar.
*
*    This program is free software; you can redistribute it and/or modify
*    it under the terms of the GNU General Public License as published by
*    the Free Software Foundation; either version 2 of the License, or
*    (at your option) any later version.
*
*    This program is distributed in the hope that it will be useful,
*    but WITHOUT ANY WARRANTY; without even the implied warranty of
*    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
*    GNU General Public License for more details.
*
*    You should have received a copy of the GNU General Public License
*    along with this program; if not, write to the Free Software
*    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*
*    Author : Dibyendu Majumdar
*    Email  : dibyendu@mazumdar.demon.co.uk
*    Website: www.mazumdar.demon.co.uk
*/
#ifndef list_h
#define list_h

typedef struct link_t
{
	struct link_t *llink, *rlink ;
} link_t ;

typedef struct
{
	link_t  lhead ;
} list_t ;

void   list_init         ( list_t *list );
void   list_append       ( list_t *list, void *link );
void   list_prepend      ( list_t *list, void *link );
void   list_insert_after ( list_t *list, void *anchor, void *link );
void   list_insert_before( list_t *list, void *anchor, void *link );
void * list_first        ( list_t *list );
void * list_last         ( list_t *list );
void * list_next         ( list_t *list, void *link );
void * list_prev         ( list_t *list, void *link );
void   list_remove       ( list_t *list, void *link );
void   list_push         ( list_t *list, void *link );
void * list_pop          ( list_t *list );

#define list_push(list, link) list_append((list), (link))

#endif


syntax highlighted by Code2HTML, v. 0.9.1