aboutsummaryrefslogtreecommitdiff
path: root/generic/List.h
blob: 46ee00e621f24e98c2027b3cb1479056786576a9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*
 * List.h -- Header of list module.
 *
 * Authors		: Patrick Lecoanet.
 * Creation date	: Tue Mar 15 17:24:51 1994
 *
 * $Id$
 */

/*
 *  Copyright (c) 1993 - 1999 CENA, Patrick Lecoanet --
 *
 * This code is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Library General Public
 * License as published by the Free Software Foundation; either
 * version 2 of the License, or (at your option) any later version.
 *
 * This code 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
 * Library General Public License for more details.
 *
 * You should have received a copy of the GNU Library General Public
 * License along with this code; if not, write to the Free
 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 */


#ifndef _List_h
#define _List_h


#ifdef __CPLUSPLUS__
extern "C" {
#endif


/*
 **********************************************************************************
 *
 * Included files
 *
 **********************************************************************************
 */


/*
 **********************************************************************************
 *
 * Constants
 *
 **********************************************************************************
 */

#define	RadarListHead	0
#define RadarListTail	(~(1 << ((8*sizeof(int)) - 1)))


/*
 **********************************************************************************
 *
 * New types
 *
 **********************************************************************************
 */

typedef void	*RadarList;


/*
 **********************************************************************************
 *
 * Prototypes
 *
 **********************************************************************************
 */

RadarList	RadarListNew(int	/* initial_size */,
			     int	/* element_size */);
RadarList	RadarListDuplicate(RadarList	/* list */);
void		RadarListEmpty(RadarList	/* list */);
RadarList	RadarListFromArray(void	*/* array */,
				   int	/* array_size */,
				   int	/* element_size */);
void		*RadarListArray(RadarList	/* list */);
void		RadarListFree(RadarList	/* list */);
int		RadarListSize(RadarList	/* list */);
void		RadarListAssertSize(RadarList	/* list */,
				    int		/* size */);
void		RadarListCopy(RadarList	/* to */,
			      RadarList	/* from */);
void		RadarListAppend(RadarList	/* to */,
				RadarList	/* from */);
void		RadarListAdd(RadarList	/* list */,
			     void	*/* value */,
			     int	/* index */);
void		*RadarListAt(RadarList	/* list */,
			     int	/* index */);
void		RadarListAtPut(RadarList	/* list */,
			       void		*/* value */,
			       int		/* index */);
void		RadarListDelete(RadarList	/* list */,
				int		/* index */);
void		RadarListTruncate(RadarList	/* list */,
				  int		/* index */);
int		RadarListDo(RadarList	/* list */,
			    void	*data,
			    int		(*/* to_do */)(void */* value */,
			                               void */*data*/));


#ifdef __CPLUSPLUS__
}
#endif

#endif /* _List_h */