2018-12-07 05:13:56 +08:00
|
|
|
/* Copyright 2018, UCAR/Unidata and OPeNDAP, Inc.
|
2010-06-03 21:24:43 +08:00
|
|
|
See the COPYRIGHT file for more information. */
|
|
|
|
#ifndef NCLIST_H
|
|
|
|
#define NCLIST_H 1
|
|
|
|
|
|
|
|
/* Define the type of the elements in the list*/
|
|
|
|
|
|
|
|
#if defined(_CPLUSPLUS_) || defined(__CPLUSPLUS__)
|
2017-03-09 08:01:10 +08:00
|
|
|
extern "C" {
|
2010-06-03 21:24:43 +08:00
|
|
|
#endif
|
|
|
|
|
2017-03-09 08:01:10 +08:00
|
|
|
extern int nclistnull(void*);
|
2010-06-03 21:24:43 +08:00
|
|
|
|
|
|
|
typedef struct NClist {
|
2018-02-09 10:53:40 +08:00
|
|
|
size_t alloc;
|
|
|
|
size_t length;
|
2012-08-20 05:12:35 +08:00
|
|
|
void** content;
|
2010-06-03 21:24:43 +08:00
|
|
|
} NClist;
|
|
|
|
|
2017-03-09 08:01:10 +08:00
|
|
|
extern NClist* nclistnew(void);
|
|
|
|
extern int nclistfree(NClist*);
|
|
|
|
extern int nclistfreeall(NClist*);
|
2018-02-09 10:53:40 +08:00
|
|
|
extern int nclistsetalloc(NClist*,size_t);
|
|
|
|
extern int nclistsetlength(NClist*,size_t);
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2018-03-17 01:46:18 +08:00
|
|
|
/* Set the ith element; will overwrite previous contents; expand if needed */
|
2018-02-09 10:53:40 +08:00
|
|
|
extern int nclistset(NClist*,size_t,void*);
|
2010-06-03 21:24:43 +08:00
|
|
|
/* Get value at position i */
|
2018-02-09 10:53:40 +08:00
|
|
|
extern void* nclistget(NClist*,size_t);/* Return the ith element of l */
|
2010-06-03 21:24:43 +08:00
|
|
|
/* Insert at position i; will push up elements i..|seq|. */
|
2018-02-09 10:53:40 +08:00
|
|
|
extern int nclistinsert(NClist*,size_t,void*);
|
2010-06-03 21:24:43 +08:00
|
|
|
/* Remove element at position i; will move higher elements down */
|
2018-02-09 10:53:40 +08:00
|
|
|
extern void* nclistremove(NClist* l, size_t i);
|
2010-06-03 21:24:43 +08:00
|
|
|
|
|
|
|
/* Tail operations */
|
2017-03-09 08:01:10 +08:00
|
|
|
extern int nclistpush(NClist*,void*); /* Add at Tail */
|
|
|
|
extern void* nclistpop(NClist*);
|
|
|
|
extern void* nclisttop(NClist*);
|
2010-06-03 21:24:43 +08:00
|
|
|
|
|
|
|
/* Duplicate and return the content (null terminate) */
|
2017-03-09 08:01:10 +08:00
|
|
|
extern void** nclistdup(NClist*);
|
2010-06-03 21:24:43 +08:00
|
|
|
|
|
|
|
/* Look for value match */
|
2017-03-09 08:01:10 +08:00
|
|
|
extern int nclistcontains(NClist*, void*);
|
2010-12-16 05:45:05 +08:00
|
|
|
|
2011-11-14 12:20:19 +08:00
|
|
|
/* Remove element by value; only removes first encountered */
|
2017-03-09 08:01:10 +08:00
|
|
|
extern int nclistelemremove(NClist* l, void* elem);
|
2011-11-14 12:20:19 +08:00
|
|
|
|
2010-06-03 21:24:43 +08:00
|
|
|
/* remove duplicates */
|
2017-03-09 08:01:10 +08:00
|
|
|
extern int nclistunique(NClist*);
|
2010-12-16 05:45:05 +08:00
|
|
|
|
2010-06-03 21:24:43 +08:00
|
|
|
/* Create a clone of a list */
|
2017-03-09 08:01:10 +08:00
|
|
|
extern NClist* nclistclone(NClist*);
|
|
|
|
|
|
|
|
extern void* nclistextract(NClist*);
|
2010-06-03 21:24:43 +08:00
|
|
|
|
|
|
|
/* Following are always "in-lined"*/
|
2012-08-20 05:12:35 +08:00
|
|
|
#define nclistclear(l) nclistsetlength((l),0)
|
2010-06-03 21:24:43 +08:00
|
|
|
#define nclistextend(l,len) nclistsetalloc((l),(len)+(l->alloc))
|
2012-08-09 07:15:18 +08:00
|
|
|
#define nclistcontents(l) ((l)==NULL?NULL:(l)->content)
|
2012-08-20 05:12:35 +08:00
|
|
|
#define nclistlength(l) ((l)==NULL?0:(l)->length)
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2017-03-09 08:01:10 +08:00
|
|
|
#if defined(_CPLUSPLUS_) || defined(__CPLUSPLUS__)
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2010-06-03 21:24:43 +08:00
|
|
|
#endif /*NCLIST_H*/
|