/* Copyright 2009, UCAR/Unidata and OPeNDAP, Inc. See the COPYRIGHT file for more information. */ #include #include #include #include "nclist.h" int nclistnull(void* e) {return e == NULL;} #ifndef TRUE #define TRUE 1 #endif #ifndef FALSE #define FALSE 0 #endif #define DEFAULTALLOC 16 #define ALLOCINCR 16 NClist* nclistnew(void) { NClist* l; /* if(!ncinitialized) { memset((void*)&ncDATANULL,0,sizeof(void*)); ncinitialized = 1; } */ l = (NClist*)malloc(sizeof(NClist)); if(l) { l->alloc=0; l->length=0; l->content=NULL; } return l; } int nclistfree(NClist* l) { if(l) { l->alloc = 0; if(l->content != NULL) {free(l->content); l->content = NULL;} free(l); } return TRUE; } int nclistsetalloc(NClist* l, unsigned long sz) { void** newcontent; if(l == NULL) return FALSE; if(sz <= 0) {sz = (l->length?2*l->length:DEFAULTALLOC);} if(l->alloc >= sz) {return TRUE;} newcontent=(void**)calloc(sz,sizeof(void*)); if(l->alloc > 0 && l->length > 0 && l->content != NULL) { memcpy((void*)newcontent,(void*)l->content,sizeof(void*)*l->length); } if(l->content != NULL) free(l->content); l->content=newcontent; l->alloc=sz; return TRUE; } int nclistsetlength(NClist* l, unsigned long sz) { if(l == NULL) return FALSE; if(sz > l->alloc && !nclistsetalloc(l,sz)) return FALSE; l->length = sz; return TRUE; } void* nclistget(NClist* l, unsigned long index) { if(l == NULL || l->length == 0) return NULL; if(index >= l->length) return NULL; return l->content[index]; } int nclistset(NClist* l, unsigned long index, void* elem) { if(l == NULL) return FALSE; if(index >= l->length) return FALSE; l->content[index] = elem; return TRUE; } /* Insert at position i of l; will push up elements i..|seq|. */ int nclistinsert(NClist* l, unsigned long index, void* elem) { int i; /* do not make unsigned */ if(l == NULL) return FALSE; if(index > l->length) return FALSE; nclistsetalloc(l,0); for(i=(int)l->length;i>index;i--) l->content[i] = l->content[i-1]; l->content[index] = elem; l->length++; return TRUE; } int nclistpush(NClist* l, void* elem) { if(l == NULL) return FALSE; if(l->length >= l->alloc) nclistsetalloc(l,0); l->content[l->length] = elem; l->length++; return TRUE; } void* nclistpop(NClist* l) { if(l == NULL || l->length == 0) return NULL; l->length--; return l->content[l->length]; } void* nclisttop(NClist* l) { if(l == NULL || l->length == 0) return NULL; return l->content[l->length - 1]; } void* nclistremove(NClist* l, unsigned long i) { unsigned long len; void* elem; if(l == NULL || (len=l->length) == 0) return NULL; if(i >= len) return NULL; elem = l->content[i]; for(i+=1;icontent[i-1] = l->content[i]; l->length--; return elem; } /* Duplicate and return the content (null terminate) */ void** nclistdup(NClist* l) { void** result = (void**)malloc(sizeof(void*)*(l->length+1)); memcpy((void*)result,(void*)l->content,sizeof(void*)*l->length); result[l->length] = (void*)0; return result; } int nclistcontains(NClist* l, void* elem) { unsigned long i; for(i=0;ilength) == 0) return 0; for(i=0;icontent[i]; if(elem == candidate) { for(i+=1;icontent[i-1] = l->content[i]; l->length--; found = 1; break; } } return found; } /* Extends nclist to include a unique operator which remove duplicate values; NULL values removed return value is always 1. */ int nclistunique(NClist* l) { unsigned long i,j,k,len; void** content; if(l == NULL || l->length == 0) return 1; len = l->length; content = l->content; for(i=0;ilength = len; return 1; } NClist* nclistclone(NClist* l) { NClist* clone = nclistnew(); *clone = *l; clone->content = nclistdup(l); return clone; }