mirror of
https://github.com/Unidata/netcdf-c.git
synced 2025-01-06 15:34:44 +08:00
b02703aa24
After a long discussion, I implemented the rules at the end of that issue. They are documented in nccopy.1. Additionally, I added a new, per-variable, -c flag that allows for the direct setting of the chunking parameters for a variable. The form is -c var:c1,c2,...ck where var is the name of the variable (possibly a fully qualified name) and the ci are the chunksizes for that variable. It must be the case that the rank of the variable is k. If the new form is used as well as the old form, then the new form overrides the old form for the specified variable. Note that multiple occurrences of the new form -c flag may be specified. Misc. Other fixes 1. Added -M <size> option to nccopy to specify the minimum allowable chunksize. 2. Removed the unused variables from bigmeta.c (Issue https://github.com/Unidata/netcdf-c/issues/1079) 3. Fixed failure of nc_test4/tst_filter.sh by using the new -M flag (#1) to allow filter test on a small chunk size.
63 lines
1.7 KiB
C
63 lines
1.7 KiB
C
/* Copyright 2009, UCAR/Unidata and OPeNDAP, Inc.
|
|
See the COPYRIGHT file for more information. */
|
|
#ifndef LIST_H
|
|
#define LIST_H 1
|
|
|
|
/* Define the type of the elements in the list*/
|
|
|
|
#if defined(_CPLUSPLUS_) || defined(__CPLUSPLUS__)
|
|
#define EXTERNC extern "C"
|
|
#else
|
|
#define EXTERNC extern
|
|
#endif
|
|
|
|
EXTERNC int listnull(void*);
|
|
|
|
typedef struct List {
|
|
unsigned long alloc;
|
|
unsigned long length;
|
|
void** content;
|
|
} List;
|
|
|
|
EXTERNC List* listnew(void);
|
|
EXTERNC int listfree(List*);
|
|
EXTERNC int listsetalloc(List*,unsigned long);
|
|
EXTERNC int listsetlength(List*,unsigned long);
|
|
|
|
/* Set the ith element */
|
|
EXTERNC int listset(List*,unsigned long,void*);
|
|
/* Get value at position i */
|
|
EXTERNC void* listget(List*,unsigned long);/* Return the ith element of l */
|
|
/* Insert at position i; will push up elements i..|seq|. */
|
|
EXTERNC int listinsert(List*,unsigned long,void*);
|
|
/* Remove element at position i; will move higher elements down */
|
|
EXTERNC void* listremove(List* l, unsigned long i);
|
|
|
|
/* Tail operations */
|
|
EXTERNC int listpush(List*,void*); /* Add at Tail */
|
|
EXTERNC void* listpop(List*);
|
|
EXTERNC void* listtop(List*);
|
|
|
|
/* Duplicate and return the content (null terminate) */
|
|
EXTERNC void** listdup(List*);
|
|
|
|
/* Look for value match */
|
|
EXTERNC int listcontains(List*, void*);
|
|
|
|
/* Remove element by value; only removes first encountered */
|
|
EXTERNC int listelemremove(List* l, void* elem);
|
|
|
|
/* remove duplicates */
|
|
EXTERNC int listunique(List*);
|
|
|
|
/* Create a clone of a list */
|
|
EXTERNC List* listclone(List*);
|
|
|
|
/* Following are always "in-lined"*/
|
|
#define listclear(l) listsetlength((l),0)
|
|
#define listextend(l,len) listsetalloc((l),(len)+(l->alloc))
|
|
#define listcontents(l) ((l)==NULL?NULL:(l)->content)
|
|
#define listlength(l) ((l)==NULL?0:(int)(l)->length)
|
|
|
|
#endif /*LIST_H*/
|