1 /* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
4 * $Id: list.h 2096 2001-07-31 01:00:39Z warmenhoven $
6 * Copyright (C) 1998-2001, Denis V. Dmitrienko <denis@null.net> and
7 * Bill Soudan <soudan@kde.org>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
34 #define icq_ListEnqueue(plist, p) \
35 icq_ListInsert(plist, 0, p)
37 #define icq_ListDequeue(plist) \
38 icq_ListRemoveNode(plist, plist->head)
40 typedef struct icq_ListNode_s icq_ListNode
;
41 typedef struct icq_List_s icq_List
;
42 typedef int (*icq_ListCompareFunc
)(void *o1
, void *o2
);
47 icq_ListNode
*previous
;
56 icq_ListCompareFunc compare_function
;
59 icq_List
*icq_ListNew(void);
60 void icq_ListDelete(icq_List
*plist
, void (*item_free_f
)(void *));
61 void icq_ListFree(icq_List
*plist
, void (*item_free_f
)(void *));
62 void icq_ListInsertSorted(icq_List
*plist
, void *pitem
);
63 void icq_ListInsert(icq_List
*plist
, icq_ListNode
*pnode
, void *pitem
);
64 void *icq_ListRemove(icq_List
*plist
, void *pitem
);
65 void *icq_ListTraverse(icq_List
*plist
, int (*item_f
)(void *, va_list), ...);
66 int icq_ListDump(icq_List
*plist
);
67 void *icq_ListFirst(icq_List
*plist
);
68 void *icq_ListLast(icq_List
*plist
);
69 void *icq_ListAt(icq_List
*plist
, int num
);
70 icq_ListNode
*icq_ListFind(icq_List
*plist
, void *pitem
);
71 void *icq_ListRemoveNode(icq_List
*plist
, icq_ListNode
*p
);