1/* Copyright 2009, UCAR/Unidata and OPeNDAP, Inc.
2   See the COPYRIGHT file for more information. */
3#ifndef LIST_H
4#define LIST_H 1
5
6/* Define the type of the elements in the list*/
7
8#if defined(_CPLUSPLUS_) || defined(__CPLUSPLUS__)
9#define EXTERNC extern "C"
10#else
11#define EXTERNC extern
12#endif
13
14EXTERNC int listnull(void*);
15
16typedef struct List {
17  unsigned long alloc;
18  unsigned long length;
19  void** content;
20List;
21
22EXTERNC Listlistnew(void);
23EXTERNC int listfree(List*);
24EXTERNC int listsetalloc(List*,unsigned long);
25EXTERNC int listsetlength(List*,unsigned long);
26
27/* Set the ith element */
28EXTERNC int listset(List*,unsigned long,void*);
29/* Get value at position i */
30EXTERNC void* listget(List*,unsigned long);/* Return the ith element of l */
31/* Insert at position i; will push up elements i..|seq|. */
32EXTERNC int listinsert(List*,unsigned long,void*);
33/* Remove element at position i; will move higher elements down */
34EXTERNC void* listremove(Listl, unsigned long i);
35
36/* Tail operations */
37EXTERNC int listpush(List*,void*); /* Add at Tail */
38EXTERNC void* listpop(List*);
39EXTERNC void* listtop(List*);
40
41/* Duplicate and return the content (null terminate) */
42EXTERNC void** listdup(List*);
43
44/* Look for value match */
45EXTERNC int listcontains(List*, void*);
46
47/* Remove element by value; only removes first encountered */
48EXTERNC int listelemremove(Listl, void* elem);
49
50/* remove duplicates */
51EXTERNC int listunique(List*);
52
53/* Create a clone of a list */
54EXTERNC Listlistclone(List*);
55
56/* Following are always "in-lined"*/
57#define listclear(llistsetlength((l),0)
58#define listextend(l,lenlistsetalloc((l),(len)+(l->alloc))
59#define listcontents(l)  ((l)==NULL?NULL:(l)->content)
60#define listlength(l)  ((l)==NULL?0:(int)(l)->length)
61
62#endif /*LIST_H*/


HyperKWIC - Version 7.20DA executed at 11:37 on 27 Oct 2017 | Polyhedron Solutions - INTERNAL USE | COMMERCIAL (Any O/S) SN 4AKIed