diff --git a/libsrc/attr.c b/libsrc/attr.c new file mode 100644 index 0000000000..59caf8c3f1 --- /dev/null +++ b/libsrc/attr.c @@ -0,0 +1,2297 @@ +#line 5 "attr.m4" +/* Do not edit this file. It is produced from the corresponding .m4 source */ +#line 7 +/* + * Copyright 2018, University Corporation for Atmospheric Research + * See netcdf/COPYRIGHT file for copying and redistribution conditions. + */ + +#if HAVE_CONFIG_H +#include +#endif + +#include "nc3internal.h" +#include "ncdispatch.h" +#include "nc3dispatch.h" +#include +#include +#include +#include "ncx.h" +#include "fbits.h" +#include "rnd.h" +#include "ncutf8.h" + +/* + * Free attr + * Formerly +NC_free_attr() + */ +void +free_NC_attr(NC_attr *attrp) +{ + + if(attrp == NULL) + return; + free_NC_string(attrp->name); + free(attrp); +} + + +/* + * How much space will 'nelems' of 'type' take in + * external representation (as the values of an attribute)? + */ +static size_t +ncx_len_NC_attrV(nc_type type, size_t nelems) +{ + switch(type) { + case NC_BYTE: + case NC_CHAR: + return ncx_len_char(nelems); + case NC_SHORT: + return ncx_len_short(nelems); + case NC_INT: + return ncx_len_int(nelems); + case NC_FLOAT: + return ncx_len_float(nelems); + case NC_DOUBLE: + return ncx_len_double(nelems); + case NC_UBYTE: + return ncx_len_ubyte(nelems); + case NC_USHORT: + return ncx_len_ushort(nelems); + case NC_UINT: + return ncx_len_uint(nelems); + case NC_INT64: + return ncx_len_int64(nelems); + case NC_UINT64: + return ncx_len_uint64(nelems); + default: + assert("ncx_len_NC_attr bad type" == 0); + } + return 0; +} + + +NC_attr * +new_x_NC_attr( + NC_string *strp, + nc_type type, + size_t nelems) +{ + NC_attr *attrp; + const size_t xsz = ncx_len_NC_attrV(type, nelems); + size_t sz = M_RNDUP(sizeof(NC_attr)); + + assert(!(xsz == 0 && nelems != 0)); + + sz += xsz; + + attrp = (NC_attr *) malloc(sz); + if(attrp == NULL ) + return NULL; + + attrp->xsz = xsz; + + attrp->name = strp; + attrp->type = type; + attrp->nelems = nelems; + if(xsz != 0) + attrp->xvalue = (char *)attrp + M_RNDUP(sizeof(NC_attr)); + else + attrp->xvalue = NULL; + + return(attrp); +} + + +/* + * Formerly +NC_new_attr(name,type,count,value) + */ +static NC_attr * +new_NC_attr( + const char *uname, + nc_type type, + size_t nelems) +{ + NC_string *strp = NULL; + NC_attr *attrp = NULL; + char *name = NULL; + int stat = NC_NOERR; + + stat = nc_utf8_normalize((const unsigned char *)uname,(unsigned char**)&name); + if(stat != NC_NOERR) + goto done; + assert(name != NULL && *name != 0); + + strp = new_NC_string(strlen(name), name); + if(strp == NULL) + goto done; + + attrp = new_x_NC_attr(strp, type, nelems); + if(attrp == NULL) + { + free_NC_string(strp); + goto done; + } +done: + if(name) free(name); + return (attrp); +} + + +static NC_attr * +dup_NC_attr(const NC_attr *rattrp) +{ + NC_attr *attrp = new_NC_attr(rattrp->name->cp, + rattrp->type, rattrp->nelems); + if(attrp == NULL) + return NULL; + if(attrp->xvalue != NULL && rattrp->xvalue != NULL) + (void) memcpy(attrp->xvalue, rattrp->xvalue, rattrp->xsz); + return attrp; +} + +/* attrarray */ + +/* + * Free the stuff "in" (referred to by) an NC_attrarray. + * Leaves the array itself allocated. + */ +void +free_NC_attrarrayV0(NC_attrarray *ncap) +{ + assert(ncap != NULL); + + if(ncap->nelems == 0) + return; + + assert(ncap->value != NULL); + + { + NC_attr **app = ncap->value; + NC_attr *const *const end = &app[ncap->nelems]; + for( /*NADA*/; app < end; app++) + { + free_NC_attr(*app); + *app = NULL; + } + } + ncap->nelems = 0; +} + + +/* + * Free NC_attrarray values. + * formerly +NC_free_array() + */ +void +free_NC_attrarrayV(NC_attrarray *ncap) +{ + assert(ncap != NULL); + + if(ncap->nalloc == 0) + return; + + assert(ncap->value != NULL); + + free_NC_attrarrayV0(ncap); + + free(ncap->value); + ncap->value = NULL; + ncap->nalloc = 0; +} + + +int +dup_NC_attrarrayV(NC_attrarray *ncap, const NC_attrarray *ref) +{ + int status = NC_NOERR; + + assert(ref != NULL); + assert(ncap != NULL); + + if(ref->nelems != 0) + { + const size_t sz = ref->nelems * sizeof(NC_attr *); + ncap->value = (NC_attr **) malloc(sz); + if(ncap->value == NULL) + return NC_ENOMEM; + + (void) memset(ncap->value, 0, sz); + ncap->nalloc = ref->nelems; + } + + ncap->nelems = 0; + { + NC_attr **app = ncap->value; + const NC_attr **drpp = (const NC_attr **)ref->value; + NC_attr *const *const end = &app[ref->nelems]; + for( /*NADA*/; app < end; drpp++, app++, ncap->nelems++) + { + *app = dup_NC_attr(*drpp); + if(*app == NULL) + { + status = NC_ENOMEM; + break; + } + } + } + + if(status != NC_NOERR) + { + free_NC_attrarrayV(ncap); + return status; + } + + assert(ncap->nelems == ref->nelems); + + return NC_NOERR; +} + + +/* + * Add a new handle on the end of an array of handles + * Formerly +NC_incr_array(array, tail) + */ +static int +incr_NC_attrarray(NC_attrarray *ncap, NC_attr *newelemp) +{ + NC_attr **vp; + + assert(ncap != NULL); + + if(ncap->nalloc == 0) + { + assert(ncap->nelems == 0); + vp = (NC_attr **) malloc(NC_ARRAY_GROWBY * sizeof(NC_attr *)); + if(vp == NULL) + return NC_ENOMEM; + + ncap->value = vp; + ncap->nalloc = NC_ARRAY_GROWBY; + } + else if(ncap->nelems +1 > ncap->nalloc) + { + vp = (NC_attr **) realloc(ncap->value, + (ncap->nalloc + NC_ARRAY_GROWBY) * sizeof(NC_attr *)); + if(vp == NULL) + return NC_ENOMEM; + + ncap->value = vp; + ncap->nalloc += NC_ARRAY_GROWBY; + } + + if(newelemp != NULL) + { + ncap->value[ncap->nelems] = newelemp; + ncap->nelems++; + } + return NC_NOERR; +} + + +NC_attr * +elem_NC_attrarray(const NC_attrarray *ncap, size_t elem) +{ + assert(ncap != NULL); + /* cast needed for braindead systems with signed size_t */ + if(ncap->nelems == 0 || (unsigned long) elem >= ncap->nelems) + return NULL; + + assert(ncap->value != NULL); + + return ncap->value[elem]; +} + +/* End attarray per se */ + +/* + * Given ncp and varid, return ptr to array of attributes + * else NULL on error + */ +static NC_attrarray * +NC_attrarray0(NC3_INFO* ncp, int varid) +{ + NC_attrarray *ap; + + if(varid == NC_GLOBAL) /* Global attribute, attach to cdf */ + { + ap = &ncp->attrs; + } + else if(varid >= 0 && (size_t) varid < ncp->vars.nelems) + { + NC_var **vpp; + vpp = (NC_var **)ncp->vars.value; + vpp += varid; + ap = &(*vpp)->attrs; + } else { + ap = NULL; + } + return(ap); +} + + +/* + * Step thru NC_ATTRIBUTE array, seeking match on name. + * return match or NULL if Not Found or out of memory. + */ +NC_attr ** +NC_findattr(const NC_attrarray *ncap, const char *uname) +{ + NC_attr **attrpp = NULL; + size_t attrid; + size_t slen; + char *name = NULL; + int stat = NC_NOERR; + + assert(ncap != NULL); + + if(ncap->nelems == 0) + goto done; + + /* normalized version of uname */ + stat = nc_utf8_normalize((const unsigned char *)uname,(unsigned char**)&name); + if(stat != NC_NOERR) + goto done; /* TODO: need better way to indicate no memory */ + slen = strlen(name); + + attrpp = (NC_attr **) ncap->value; + for(attrid = 0; attrid < ncap->nelems; attrid++, attrpp++) + { + if(strlen((*attrpp)->name->cp) == slen && + strncmp((*attrpp)->name->cp, name, slen) == 0) + goto done; + } + attrpp = NULL; /* not found */ +done: + if(name) free(name); + return (attrpp); /* Normal return */ +} + + +/* + * Look up by ncid, varid and name, return NULL if not found + */ +static int +NC_lookupattr(int ncid, + int varid, + const char *name, /* attribute name */ + NC_attr **attrpp) /* modified on return */ +{ + int status; + NC* nc; + NC3_INFO *ncp; + NC_attrarray *ncap; + NC_attr **tmp; + + status = NC_check_id(ncid, &nc); + if(status != NC_NOERR) + return status; + ncp = NC3_DATA(nc); + + ncap = NC_attrarray0(ncp, varid); + if(ncap == NULL) + return NC_ENOTVAR; + + if(name == NULL) + return NC_EBADNAME; + + tmp = NC_findattr(ncap, name); + if(tmp == NULL) + return NC_ENOTATT; + + if(attrpp != NULL) + *attrpp = *tmp; + + return NC_NOERR; +} + +/* Public */ + +int +NC3_inq_attname(int ncid, int varid, int attnum, char *name) +{ + int status; + NC* nc; + NC3_INFO *ncp; + NC_attrarray *ncap; + NC_attr *attrp; + + status = NC_check_id(ncid, &nc); + if(status != NC_NOERR) + return status; + ncp = NC3_DATA(nc); + + ncap = NC_attrarray0(ncp, varid); + if(ncap == NULL) + return NC_ENOTVAR; + + attrp = elem_NC_attrarray(ncap, (size_t)attnum); + if(attrp == NULL) + return NC_ENOTATT; + + (void) strncpy(name, attrp->name->cp, attrp->name->nchars); + name[attrp->name->nchars] = 0; + + return NC_NOERR; +} + + +int +NC3_inq_attid(int ncid, int varid, const char *name, int *attnump) +{ + int status; + NC *nc; + NC3_INFO* ncp; + NC_attrarray *ncap; + NC_attr **attrpp; + + status = NC_check_id(ncid, &nc); + if(status != NC_NOERR) + return status; + ncp = NC3_DATA(nc); + + ncap = NC_attrarray0(ncp, varid); + if(ncap == NULL) + return NC_ENOTVAR; + + + attrpp = NC_findattr(ncap, name); + if(attrpp == NULL) + return NC_ENOTATT; + + if(attnump != NULL) + *attnump = (int)(attrpp - ncap->value); + + return NC_NOERR; +} + +int +NC3_inq_att(int ncid, + int varid, + const char *name, /* input, attribute name */ + nc_type *datatypep, + size_t *lenp) +{ + int status; + NC_attr *attrp; + + status = NC_lookupattr(ncid, varid, name, &attrp); + if(status != NC_NOERR) + return status; + + if(datatypep != NULL) + *datatypep = attrp->type; + if(lenp != NULL) + *lenp = attrp->nelems; + + return NC_NOERR; +} + + +int +NC3_rename_att( int ncid, int varid, const char *name, const char *unewname) +{ + int status = NC_NOERR; + NC *nc = NULL; + NC3_INFO* ncp = NULL; + NC_attrarray *ncap = NULL; + NC_attr **tmp = NULL; + NC_attr *attrp = NULL; + NC_string *newStr, *old; + char *newname = NULL; /* normalized version */ + +/* start sortof inline clone of NC_lookupattr() */ + + status = NC_check_id(ncid, &nc); + if(status != NC_NOERR) + goto done; + ncp = NC3_DATA(nc); + + if(NC_readonly(ncp)) + {status = NC_EPERM; goto done;} + + ncap = NC_attrarray0(ncp, varid); + if(ncap == NULL) + {status = NC_ENOTVAR; goto done;} + + status = NC_check_name(unewname); + if(status != NC_NOERR) + goto done; + + tmp = NC_findattr(ncap, name); + if(tmp == NULL) + {status = NC_ENOTATT; goto done;} + attrp = *tmp; +/* end inline clone NC_lookupattr() */ + + if(NC_findattr(ncap, unewname) != NULL) + {status = NC_ENAMEINUSE; goto done;} /* name in use */ + + old = attrp->name; + status = nc_utf8_normalize((const unsigned char *)unewname,(unsigned char**)&newname); + if(status != NC_NOERR) + goto done; + if(NC_indef(ncp)) + { + newStr = new_NC_string(strlen(newname), newname); + if( newStr == NULL) + {status = NC_ENOMEM; goto done;} + attrp->name = newStr; + free_NC_string(old); + goto done; + } + /* else not in define mode */ + + /* If new name is longer than old, then complain, + but otherwise, no change (test is same as set_NC_string)*/ + if(old->nchars < strlen(newname)) + {status = NC_ENOTINDEFINE; goto done;} + + status = set_NC_string(old, newname); + if( status != NC_NOERR) + goto done; + + set_NC_hdirty(ncp); + + if(NC_doHsync(ncp)) + { + status = NC_sync(ncp); + if(status != NC_NOERR) + goto done; + } +done: + if(newname) free(newname); + return status; +} + +int +NC3_del_att(int ncid, int varid, const char *uname) +{ + int status = NC_NOERR; + NC *nc = NULL; + NC3_INFO* ncp = NULL; + NC_attrarray *ncap = NULL; + NC_attr **attrpp = NULL; + NC_attr *old = NULL; + int attrid; + size_t slen; + char* name = NULL; + + status = NC_check_id(ncid, &nc); + if(status != NC_NOERR) + goto done; + ncp = NC3_DATA(nc); + + if(!NC_indef(ncp)) + {status = NC_ENOTINDEFINE; goto done;} + + ncap = NC_attrarray0(ncp, varid); + if(ncap == NULL) + {status = NC_ENOTVAR; goto done;} + + status = nc_utf8_normalize((const unsigned char *)uname,(unsigned char**)&name); + if(status != NC_NOERR) + goto done; + +/* start sortof inline NC_findattr() */ + slen = strlen(name); + + attrpp = (NC_attr **) ncap->value; + for(attrid = 0; (size_t) attrid < ncap->nelems; attrid++, attrpp++) + { + if( slen == (*attrpp)->name->nchars && + strncmp(name, (*attrpp)->name->cp, slen) == 0) + { + old = *attrpp; + break; + } + } + if( (size_t) attrid == ncap->nelems ) + {status = NC_ENOTATT; goto done;} +/* end inline NC_findattr() */ + + /* shuffle down */ + for(attrid++; (size_t) attrid < ncap->nelems; attrid++) + { + *attrpp = *(attrpp + 1); + attrpp++; + } + *attrpp = NULL; + /* decrement count */ + ncap->nelems--; + + free_NC_attr(old); + +done: + if(name) free(name); + return status; +} + +#line 713 + +static int +#line 714 +ncx_pad_putn_Iuchar(void **xpp, size_t nelems, const uchar *tp, nc_type type, void *fillp) +#line 714 +{ +#line 714 + switch(type) { +#line 714 + case NC_CHAR: +#line 714 + return NC_ECHAR; +#line 714 + case NC_BYTE: +#line 714 + return ncx_pad_putn_schar_uchar(xpp, nelems, tp, fillp); +#line 714 + case NC_SHORT: +#line 714 + return ncx_pad_putn_short_uchar(xpp, nelems, tp, fillp); +#line 714 + case NC_INT: +#line 714 + return ncx_putn_int_uchar(xpp, nelems, tp, fillp); +#line 714 + case NC_FLOAT: +#line 714 + return ncx_putn_float_uchar(xpp, nelems, tp, fillp); +#line 714 + case NC_DOUBLE: +#line 714 + return ncx_putn_double_uchar(xpp, nelems, tp, fillp); +#line 714 + case NC_UBYTE: +#line 714 + return ncx_pad_putn_uchar_uchar(xpp, nelems, tp, fillp); +#line 714 + case NC_USHORT: +#line 714 + return ncx_putn_ushort_uchar(xpp, nelems, tp, fillp); +#line 714 + case NC_UINT: +#line 714 + return ncx_putn_uint_uchar(xpp, nelems, tp, fillp); +#line 714 + case NC_INT64: +#line 714 + return ncx_putn_longlong_uchar(xpp, nelems, tp, fillp); +#line 714 + case NC_UINT64: +#line 714 + return ncx_putn_ulonglong_uchar(xpp, nelems, tp, fillp); +#line 714 + default: +#line 714 + assert("ncx_pad_putn_Iuchar invalid type" == 0); +#line 714 + } +#line 714 + return NC_EBADTYPE; +#line 714 +} +#line 714 + +static int +#line 715 +ncx_pad_getn_Iuchar(const void **xpp, size_t nelems, uchar *tp, nc_type type) +#line 715 +{ +#line 715 + switch(type) { +#line 715 + case NC_CHAR: +#line 715 + return NC_ECHAR; +#line 715 + case NC_BYTE: +#line 715 + return ncx_pad_getn_schar_uchar(xpp, nelems, tp); +#line 715 + case NC_SHORT: +#line 715 + return ncx_pad_getn_short_uchar(xpp, nelems, tp); +#line 715 + case NC_INT: +#line 715 + return ncx_getn_int_uchar(xpp, nelems, tp); +#line 715 + case NC_FLOAT: +#line 715 + return ncx_getn_float_uchar(xpp, nelems, tp); +#line 715 + case NC_DOUBLE: +#line 715 + return ncx_getn_double_uchar(xpp, nelems, tp); +#line 715 + case NC_UBYTE: +#line 715 + return ncx_pad_getn_uchar_uchar(xpp, nelems, tp); +#line 715 + case NC_USHORT: +#line 715 + return ncx_getn_ushort_uchar(xpp, nelems, tp); +#line 715 + case NC_UINT: +#line 715 + return ncx_getn_uint_uchar(xpp, nelems, tp); +#line 715 + case NC_INT64: +#line 715 + return ncx_getn_longlong_uchar(xpp, nelems, tp); +#line 715 + case NC_UINT64: +#line 715 + return ncx_getn_ulonglong_uchar(xpp, nelems, tp); +#line 715 + default: +#line 715 + assert("ncx_pad_getn_Iuchar invalid type" == 0); +#line 715 + } +#line 715 + return NC_EBADTYPE; +#line 715 +} +#line 715 + + +static int +#line 717 +ncx_pad_putn_Ischar(void **xpp, size_t nelems, const schar *tp, nc_type type, void *fillp) +#line 717 +{ +#line 717 + switch(type) { +#line 717 + case NC_CHAR: +#line 717 + return NC_ECHAR; +#line 717 + case NC_BYTE: +#line 717 + return ncx_pad_putn_schar_schar(xpp, nelems, tp, fillp); +#line 717 + case NC_SHORT: +#line 717 + return ncx_pad_putn_short_schar(xpp, nelems, tp, fillp); +#line 717 + case NC_INT: +#line 717 + return ncx_putn_int_schar(xpp, nelems, tp, fillp); +#line 717 + case NC_FLOAT: +#line 717 + return ncx_putn_float_schar(xpp, nelems, tp, fillp); +#line 717 + case NC_DOUBLE: +#line 717 + return ncx_putn_double_schar(xpp, nelems, tp, fillp); +#line 717 + case NC_UBYTE: +#line 717 + return ncx_pad_putn_uchar_schar(xpp, nelems, tp, fillp); +#line 717 + case NC_USHORT: +#line 717 + return ncx_putn_ushort_schar(xpp, nelems, tp, fillp); +#line 717 + case NC_UINT: +#line 717 + return ncx_putn_uint_schar(xpp, nelems, tp, fillp); +#line 717 + case NC_INT64: +#line 717 + return ncx_putn_longlong_schar(xpp, nelems, tp, fillp); +#line 717 + case NC_UINT64: +#line 717 + return ncx_putn_ulonglong_schar(xpp, nelems, tp, fillp); +#line 717 + default: +#line 717 + assert("ncx_pad_putn_Ischar invalid type" == 0); +#line 717 + } +#line 717 + return NC_EBADTYPE; +#line 717 +} +#line 717 + +static int +#line 718 +ncx_pad_getn_Ischar(const void **xpp, size_t nelems, schar *tp, nc_type type) +#line 718 +{ +#line 718 + switch(type) { +#line 718 + case NC_CHAR: +#line 718 + return NC_ECHAR; +#line 718 + case NC_BYTE: +#line 718 + return ncx_pad_getn_schar_schar(xpp, nelems, tp); +#line 718 + case NC_SHORT: +#line 718 + return ncx_pad_getn_short_schar(xpp, nelems, tp); +#line 718 + case NC_INT: +#line 718 + return ncx_getn_int_schar(xpp, nelems, tp); +#line 718 + case NC_FLOAT: +#line 718 + return ncx_getn_float_schar(xpp, nelems, tp); +#line 718 + case NC_DOUBLE: +#line 718 + return ncx_getn_double_schar(xpp, nelems, tp); +#line 718 + case NC_UBYTE: +#line 718 + return ncx_pad_getn_uchar_schar(xpp, nelems, tp); +#line 718 + case NC_USHORT: +#line 718 + return ncx_getn_ushort_schar(xpp, nelems, tp); +#line 718 + case NC_UINT: +#line 718 + return ncx_getn_uint_schar(xpp, nelems, tp); +#line 718 + case NC_INT64: +#line 718 + return ncx_getn_longlong_schar(xpp, nelems, tp); +#line 718 + case NC_UINT64: +#line 718 + return ncx_getn_ulonglong_schar(xpp, nelems, tp); +#line 718 + default: +#line 718 + assert("ncx_pad_getn_Ischar invalid type" == 0); +#line 718 + } +#line 718 + return NC_EBADTYPE; +#line 718 +} +#line 718 + + +static int +#line 720 +ncx_pad_putn_Ishort(void **xpp, size_t nelems, const short *tp, nc_type type, void *fillp) +#line 720 +{ +#line 720 + switch(type) { +#line 720 + case NC_CHAR: +#line 720 + return NC_ECHAR; +#line 720 + case NC_BYTE: +#line 720 + return ncx_pad_putn_schar_short(xpp, nelems, tp, fillp); +#line 720 + case NC_SHORT: +#line 720 + return ncx_pad_putn_short_short(xpp, nelems, tp, fillp); +#line 720 + case NC_INT: +#line 720 + return ncx_putn_int_short(xpp, nelems, tp, fillp); +#line 720 + case NC_FLOAT: +#line 720 + return ncx_putn_float_short(xpp, nelems, tp, fillp); +#line 720 + case NC_DOUBLE: +#line 720 + return ncx_putn_double_short(xpp, nelems, tp, fillp); +#line 720 + case NC_UBYTE: +#line 720 + return ncx_pad_putn_uchar_short(xpp, nelems, tp, fillp); +#line 720 + case NC_USHORT: +#line 720 + return ncx_putn_ushort_short(xpp, nelems, tp, fillp); +#line 720 + case NC_UINT: +#line 720 + return ncx_putn_uint_short(xpp, nelems, tp, fillp); +#line 720 + case NC_INT64: +#line 720 + return ncx_putn_longlong_short(xpp, nelems, tp, fillp); +#line 720 + case NC_UINT64: +#line 720 + return ncx_putn_ulonglong_short(xpp, nelems, tp, fillp); +#line 720 + default: +#line 720 + assert("ncx_pad_putn_Ishort invalid type" == 0); +#line 720 + } +#line 720 + return NC_EBADTYPE; +#line 720 +} +#line 720 + +static int +#line 721 +ncx_pad_getn_Ishort(const void **xpp, size_t nelems, short *tp, nc_type type) +#line 721 +{ +#line 721 + switch(type) { +#line 721 + case NC_CHAR: +#line 721 + return NC_ECHAR; +#line 721 + case NC_BYTE: +#line 721 + return ncx_pad_getn_schar_short(xpp, nelems, tp); +#line 721 + case NC_SHORT: +#line 721 + return ncx_pad_getn_short_short(xpp, nelems, tp); +#line 721 + case NC_INT: +#line 721 + return ncx_getn_int_short(xpp, nelems, tp); +#line 721 + case NC_FLOAT: +#line 721 + return ncx_getn_float_short(xpp, nelems, tp); +#line 721 + case NC_DOUBLE: +#line 721 + return ncx_getn_double_short(xpp, nelems, tp); +#line 721 + case NC_UBYTE: +#line 721 + return ncx_pad_getn_uchar_short(xpp, nelems, tp); +#line 721 + case NC_USHORT: +#line 721 + return ncx_getn_ushort_short(xpp, nelems, tp); +#line 721 + case NC_UINT: +#line 721 + return ncx_getn_uint_short(xpp, nelems, tp); +#line 721 + case NC_INT64: +#line 721 + return ncx_getn_longlong_short(xpp, nelems, tp); +#line 721 + case NC_UINT64: +#line 721 + return ncx_getn_ulonglong_short(xpp, nelems, tp); +#line 721 + default: +#line 721 + assert("ncx_pad_getn_Ishort invalid type" == 0); +#line 721 + } +#line 721 + return NC_EBADTYPE; +#line 721 +} +#line 721 + + +static int +#line 723 +ncx_pad_putn_Iint(void **xpp, size_t nelems, const int *tp, nc_type type, void *fillp) +#line 723 +{ +#line 723 + switch(type) { +#line 723 + case NC_CHAR: +#line 723 + return NC_ECHAR; +#line 723 + case NC_BYTE: +#line 723 + return ncx_pad_putn_schar_int(xpp, nelems, tp, fillp); +#line 723 + case NC_SHORT: +#line 723 + return ncx_pad_putn_short_int(xpp, nelems, tp, fillp); +#line 723 + case NC_INT: +#line 723 + return ncx_putn_int_int(xpp, nelems, tp, fillp); +#line 723 + case NC_FLOAT: +#line 723 + return ncx_putn_float_int(xpp, nelems, tp, fillp); +#line 723 + case NC_DOUBLE: +#line 723 + return ncx_putn_double_int(xpp, nelems, tp, fillp); +#line 723 + case NC_UBYTE: +#line 723 + return ncx_pad_putn_uchar_int(xpp, nelems, tp, fillp); +#line 723 + case NC_USHORT: +#line 723 + return ncx_putn_ushort_int(xpp, nelems, tp, fillp); +#line 723 + case NC_UINT: +#line 723 + return ncx_putn_uint_int(xpp, nelems, tp, fillp); +#line 723 + case NC_INT64: +#line 723 + return ncx_putn_longlong_int(xpp, nelems, tp, fillp); +#line 723 + case NC_UINT64: +#line 723 + return ncx_putn_ulonglong_int(xpp, nelems, tp, fillp); +#line 723 + default: +#line 723 + assert("ncx_pad_putn_Iint invalid type" == 0); +#line 723 + } +#line 723 + return NC_EBADTYPE; +#line 723 +} +#line 723 + +static int +#line 724 +ncx_pad_getn_Iint(const void **xpp, size_t nelems, int *tp, nc_type type) +#line 724 +{ +#line 724 + switch(type) { +#line 724 + case NC_CHAR: +#line 724 + return NC_ECHAR; +#line 724 + case NC_BYTE: +#line 724 + return ncx_pad_getn_schar_int(xpp, nelems, tp); +#line 724 + case NC_SHORT: +#line 724 + return ncx_pad_getn_short_int(xpp, nelems, tp); +#line 724 + case NC_INT: +#line 724 + return ncx_getn_int_int(xpp, nelems, tp); +#line 724 + case NC_FLOAT: +#line 724 + return ncx_getn_float_int(xpp, nelems, tp); +#line 724 + case NC_DOUBLE: +#line 724 + return ncx_getn_double_int(xpp, nelems, tp); +#line 724 + case NC_UBYTE: +#line 724 + return ncx_pad_getn_uchar_int(xpp, nelems, tp); +#line 724 + case NC_USHORT: +#line 724 + return ncx_getn_ushort_int(xpp, nelems, tp); +#line 724 + case NC_UINT: +#line 724 + return ncx_getn_uint_int(xpp, nelems, tp); +#line 724 + case NC_INT64: +#line 724 + return ncx_getn_longlong_int(xpp, nelems, tp); +#line 724 + case NC_UINT64: +#line 724 + return ncx_getn_ulonglong_int(xpp, nelems, tp); +#line 724 + default: +#line 724 + assert("ncx_pad_getn_Iint invalid type" == 0); +#line 724 + } +#line 724 + return NC_EBADTYPE; +#line 724 +} +#line 724 + + +static int +#line 726 +ncx_pad_putn_Ifloat(void **xpp, size_t nelems, const float *tp, nc_type type, void *fillp) +#line 726 +{ +#line 726 + switch(type) { +#line 726 + case NC_CHAR: +#line 726 + return NC_ECHAR; +#line 726 + case NC_BYTE: +#line 726 + return ncx_pad_putn_schar_float(xpp, nelems, tp, fillp); +#line 726 + case NC_SHORT: +#line 726 + return ncx_pad_putn_short_float(xpp, nelems, tp, fillp); +#line 726 + case NC_INT: +#line 726 + return ncx_putn_int_float(xpp, nelems, tp, fillp); +#line 726 + case NC_FLOAT: +#line 726 + return ncx_putn_float_float(xpp, nelems, tp, fillp); +#line 726 + case NC_DOUBLE: +#line 726 + return ncx_putn_double_float(xpp, nelems, tp, fillp); +#line 726 + case NC_UBYTE: +#line 726 + return ncx_pad_putn_uchar_float(xpp, nelems, tp, fillp); +#line 726 + case NC_USHORT: +#line 726 + return ncx_putn_ushort_float(xpp, nelems, tp, fillp); +#line 726 + case NC_UINT: +#line 726 + return ncx_putn_uint_float(xpp, nelems, tp, fillp); +#line 726 + case NC_INT64: +#line 726 + return ncx_putn_longlong_float(xpp, nelems, tp, fillp); +#line 726 + case NC_UINT64: +#line 726 + return ncx_putn_ulonglong_float(xpp, nelems, tp, fillp); +#line 726 + default: +#line 726 + assert("ncx_pad_putn_Ifloat invalid type" == 0); +#line 726 + } +#line 726 + return NC_EBADTYPE; +#line 726 +} +#line 726 + +static int +#line 727 +ncx_pad_getn_Ifloat(const void **xpp, size_t nelems, float *tp, nc_type type) +#line 727 +{ +#line 727 + switch(type) { +#line 727 + case NC_CHAR: +#line 727 + return NC_ECHAR; +#line 727 + case NC_BYTE: +#line 727 + return ncx_pad_getn_schar_float(xpp, nelems, tp); +#line 727 + case NC_SHORT: +#line 727 + return ncx_pad_getn_short_float(xpp, nelems, tp); +#line 727 + case NC_INT: +#line 727 + return ncx_getn_int_float(xpp, nelems, tp); +#line 727 + case NC_FLOAT: +#line 727 + return ncx_getn_float_float(xpp, nelems, tp); +#line 727 + case NC_DOUBLE: +#line 727 + return ncx_getn_double_float(xpp, nelems, tp); +#line 727 + case NC_UBYTE: +#line 727 + return ncx_pad_getn_uchar_float(xpp, nelems, tp); +#line 727 + case NC_USHORT: +#line 727 + return ncx_getn_ushort_float(xpp, nelems, tp); +#line 727 + case NC_UINT: +#line 727 + return ncx_getn_uint_float(xpp, nelems, tp); +#line 727 + case NC_INT64: +#line 727 + return ncx_getn_longlong_float(xpp, nelems, tp); +#line 727 + case NC_UINT64: +#line 727 + return ncx_getn_ulonglong_float(xpp, nelems, tp); +#line 727 + default: +#line 727 + assert("ncx_pad_getn_Ifloat invalid type" == 0); +#line 727 + } +#line 727 + return NC_EBADTYPE; +#line 727 +} +#line 727 + + +static int +#line 729 +ncx_pad_putn_Idouble(void **xpp, size_t nelems, const double *tp, nc_type type, void *fillp) +#line 729 +{ +#line 729 + switch(type) { +#line 729 + case NC_CHAR: +#line 729 + return NC_ECHAR; +#line 729 + case NC_BYTE: +#line 729 + return ncx_pad_putn_schar_double(xpp, nelems, tp, fillp); +#line 729 + case NC_SHORT: +#line 729 + return ncx_pad_putn_short_double(xpp, nelems, tp, fillp); +#line 729 + case NC_INT: +#line 729 + return ncx_putn_int_double(xpp, nelems, tp, fillp); +#line 729 + case NC_FLOAT: +#line 729 + return ncx_putn_float_double(xpp, nelems, tp, fillp); +#line 729 + case NC_DOUBLE: +#line 729 + return ncx_putn_double_double(xpp, nelems, tp, fillp); +#line 729 + case NC_UBYTE: +#line 729 + return ncx_pad_putn_uchar_double(xpp, nelems, tp, fillp); +#line 729 + case NC_USHORT: +#line 729 + return ncx_putn_ushort_double(xpp, nelems, tp, fillp); +#line 729 + case NC_UINT: +#line 729 + return ncx_putn_uint_double(xpp, nelems, tp, fillp); +#line 729 + case NC_INT64: +#line 729 + return ncx_putn_longlong_double(xpp, nelems, tp, fillp); +#line 729 + case NC_UINT64: +#line 729 + return ncx_putn_ulonglong_double(xpp, nelems, tp, fillp); +#line 729 + default: +#line 729 + assert("ncx_pad_putn_Idouble invalid type" == 0); +#line 729 + } +#line 729 + return NC_EBADTYPE; +#line 729 +} +#line 729 + +static int +#line 730 +ncx_pad_getn_Idouble(const void **xpp, size_t nelems, double *tp, nc_type type) +#line 730 +{ +#line 730 + switch(type) { +#line 730 + case NC_CHAR: +#line 730 + return NC_ECHAR; +#line 730 + case NC_BYTE: +#line 730 + return ncx_pad_getn_schar_double(xpp, nelems, tp); +#line 730 + case NC_SHORT: +#line 730 + return ncx_pad_getn_short_double(xpp, nelems, tp); +#line 730 + case NC_INT: +#line 730 + return ncx_getn_int_double(xpp, nelems, tp); +#line 730 + case NC_FLOAT: +#line 730 + return ncx_getn_float_double(xpp, nelems, tp); +#line 730 + case NC_DOUBLE: +#line 730 + return ncx_getn_double_double(xpp, nelems, tp); +#line 730 + case NC_UBYTE: +#line 730 + return ncx_pad_getn_uchar_double(xpp, nelems, tp); +#line 730 + case NC_USHORT: +#line 730 + return ncx_getn_ushort_double(xpp, nelems, tp); +#line 730 + case NC_UINT: +#line 730 + return ncx_getn_uint_double(xpp, nelems, tp); +#line 730 + case NC_INT64: +#line 730 + return ncx_getn_longlong_double(xpp, nelems, tp); +#line 730 + case NC_UINT64: +#line 730 + return ncx_getn_ulonglong_double(xpp, nelems, tp); +#line 730 + default: +#line 730 + assert("ncx_pad_getn_Idouble invalid type" == 0); +#line 730 + } +#line 730 + return NC_EBADTYPE; +#line 730 +} +#line 730 + + +#ifdef IGNORE +static int +#line 733 +ncx_pad_putn_Ilong(void **xpp, size_t nelems, const long *tp, nc_type type, void *fillp) +#line 733 +{ +#line 733 + switch(type) { +#line 733 + case NC_CHAR: +#line 733 + return NC_ECHAR; +#line 733 + case NC_BYTE: +#line 733 + return ncx_pad_putn_schar_long(xpp, nelems, tp, fillp); +#line 733 + case NC_SHORT: +#line 733 + return ncx_pad_putn_short_long(xpp, nelems, tp, fillp); +#line 733 + case NC_INT: +#line 733 + return ncx_putn_int_long(xpp, nelems, tp, fillp); +#line 733 + case NC_FLOAT: +#line 733 + return ncx_putn_float_long(xpp, nelems, tp, fillp); +#line 733 + case NC_DOUBLE: +#line 733 + return ncx_putn_double_long(xpp, nelems, tp, fillp); +#line 733 + case NC_UBYTE: +#line 733 + return ncx_pad_putn_uchar_long(xpp, nelems, tp, fillp); +#line 733 + case NC_USHORT: +#line 733 + return ncx_putn_ushort_long(xpp, nelems, tp, fillp); +#line 733 + case NC_UINT: +#line 733 + return ncx_putn_uint_long(xpp, nelems, tp, fillp); +#line 733 + case NC_INT64: +#line 733 + return ncx_putn_longlong_long(xpp, nelems, tp, fillp); +#line 733 + case NC_UINT64: +#line 733 + return ncx_putn_ulonglong_long(xpp, nelems, tp, fillp); +#line 733 + default: +#line 733 + assert("ncx_pad_putn_Ilong invalid type" == 0); +#line 733 + } +#line 733 + return NC_EBADTYPE; +#line 733 +} +#line 733 + +static int +#line 734 +ncx_pad_getn_Ilong(const void **xpp, size_t nelems, long *tp, nc_type type) +#line 734 +{ +#line 734 + switch(type) { +#line 734 + case NC_CHAR: +#line 734 + return NC_ECHAR; +#line 734 + case NC_BYTE: +#line 734 + return ncx_pad_getn_schar_long(xpp, nelems, tp); +#line 734 + case NC_SHORT: +#line 734 + return ncx_pad_getn_short_long(xpp, nelems, tp); +#line 734 + case NC_INT: +#line 734 + return ncx_getn_int_long(xpp, nelems, tp); +#line 734 + case NC_FLOAT: +#line 734 + return ncx_getn_float_long(xpp, nelems, tp); +#line 734 + case NC_DOUBLE: +#line 734 + return ncx_getn_double_long(xpp, nelems, tp); +#line 734 + case NC_UBYTE: +#line 734 + return ncx_pad_getn_uchar_long(xpp, nelems, tp); +#line 734 + case NC_USHORT: +#line 734 + return ncx_getn_ushort_long(xpp, nelems, tp); +#line 734 + case NC_UINT: +#line 734 + return ncx_getn_uint_long(xpp, nelems, tp); +#line 734 + case NC_INT64: +#line 734 + return ncx_getn_longlong_long(xpp, nelems, tp); +#line 734 + case NC_UINT64: +#line 734 + return ncx_getn_ulonglong_long(xpp, nelems, tp); +#line 734 + default: +#line 734 + assert("ncx_pad_getn_Ilong invalid type" == 0); +#line 734 + } +#line 734 + return NC_EBADTYPE; +#line 734 +} +#line 734 + +#endif + +static int +#line 737 +ncx_pad_putn_Ilonglong(void **xpp, size_t nelems, const longlong *tp, nc_type type, void *fillp) +#line 737 +{ +#line 737 + switch(type) { +#line 737 + case NC_CHAR: +#line 737 + return NC_ECHAR; +#line 737 + case NC_BYTE: +#line 737 + return ncx_pad_putn_schar_longlong(xpp, nelems, tp, fillp); +#line 737 + case NC_SHORT: +#line 737 + return ncx_pad_putn_short_longlong(xpp, nelems, tp, fillp); +#line 737 + case NC_INT: +#line 737 + return ncx_putn_int_longlong(xpp, nelems, tp, fillp); +#line 737 + case NC_FLOAT: +#line 737 + return ncx_putn_float_longlong(xpp, nelems, tp, fillp); +#line 737 + case NC_DOUBLE: +#line 737 + return ncx_putn_double_longlong(xpp, nelems, tp, fillp); +#line 737 + case NC_UBYTE: +#line 737 + return ncx_pad_putn_uchar_longlong(xpp, nelems, tp, fillp); +#line 737 + case NC_USHORT: +#line 737 + return ncx_putn_ushort_longlong(xpp, nelems, tp, fillp); +#line 737 + case NC_UINT: +#line 737 + return ncx_putn_uint_longlong(xpp, nelems, tp, fillp); +#line 737 + case NC_INT64: +#line 737 + return ncx_putn_longlong_longlong(xpp, nelems, tp, fillp); +#line 737 + case NC_UINT64: +#line 737 + return ncx_putn_ulonglong_longlong(xpp, nelems, tp, fillp); +#line 737 + default: +#line 737 + assert("ncx_pad_putn_Ilonglong invalid type" == 0); +#line 737 + } +#line 737 + return NC_EBADTYPE; +#line 737 +} +#line 737 + +static int +#line 738 +ncx_pad_getn_Ilonglong(const void **xpp, size_t nelems, longlong *tp, nc_type type) +#line 738 +{ +#line 738 + switch(type) { +#line 738 + case NC_CHAR: +#line 738 + return NC_ECHAR; +#line 738 + case NC_BYTE: +#line 738 + return ncx_pad_getn_schar_longlong(xpp, nelems, tp); +#line 738 + case NC_SHORT: +#line 738 + return ncx_pad_getn_short_longlong(xpp, nelems, tp); +#line 738 + case NC_INT: +#line 738 + return ncx_getn_int_longlong(xpp, nelems, tp); +#line 738 + case NC_FLOAT: +#line 738 + return ncx_getn_float_longlong(xpp, nelems, tp); +#line 738 + case NC_DOUBLE: +#line 738 + return ncx_getn_double_longlong(xpp, nelems, tp); +#line 738 + case NC_UBYTE: +#line 738 + return ncx_pad_getn_uchar_longlong(xpp, nelems, tp); +#line 738 + case NC_USHORT: +#line 738 + return ncx_getn_ushort_longlong(xpp, nelems, tp); +#line 738 + case NC_UINT: +#line 738 + return ncx_getn_uint_longlong(xpp, nelems, tp); +#line 738 + case NC_INT64: +#line 738 + return ncx_getn_longlong_longlong(xpp, nelems, tp); +#line 738 + case NC_UINT64: +#line 738 + return ncx_getn_ulonglong_longlong(xpp, nelems, tp); +#line 738 + default: +#line 738 + assert("ncx_pad_getn_Ilonglong invalid type" == 0); +#line 738 + } +#line 738 + return NC_EBADTYPE; +#line 738 +} +#line 738 + + +static int +#line 740 +ncx_pad_putn_Iushort(void **xpp, size_t nelems, const ushort *tp, nc_type type, void *fillp) +#line 740 +{ +#line 740 + switch(type) { +#line 740 + case NC_CHAR: +#line 740 + return NC_ECHAR; +#line 740 + case NC_BYTE: +#line 740 + return ncx_pad_putn_schar_ushort(xpp, nelems, tp, fillp); +#line 740 + case NC_SHORT: +#line 740 + return ncx_pad_putn_short_ushort(xpp, nelems, tp, fillp); +#line 740 + case NC_INT: +#line 740 + return ncx_putn_int_ushort(xpp, nelems, tp, fillp); +#line 740 + case NC_FLOAT: +#line 740 + return ncx_putn_float_ushort(xpp, nelems, tp, fillp); +#line 740 + case NC_DOUBLE: +#line 740 + return ncx_putn_double_ushort(xpp, nelems, tp, fillp); +#line 740 + case NC_UBYTE: +#line 740 + return ncx_pad_putn_uchar_ushort(xpp, nelems, tp, fillp); +#line 740 + case NC_USHORT: +#line 740 + return ncx_putn_ushort_ushort(xpp, nelems, tp, fillp); +#line 740 + case NC_UINT: +#line 740 + return ncx_putn_uint_ushort(xpp, nelems, tp, fillp); +#line 740 + case NC_INT64: +#line 740 + return ncx_putn_longlong_ushort(xpp, nelems, tp, fillp); +#line 740 + case NC_UINT64: +#line 740 + return ncx_putn_ulonglong_ushort(xpp, nelems, tp, fillp); +#line 740 + default: +#line 740 + assert("ncx_pad_putn_Iushort invalid type" == 0); +#line 740 + } +#line 740 + return NC_EBADTYPE; +#line 740 +} +#line 740 + +static int +#line 741 +ncx_pad_getn_Iushort(const void **xpp, size_t nelems, ushort *tp, nc_type type) +#line 741 +{ +#line 741 + switch(type) { +#line 741 + case NC_CHAR: +#line 741 + return NC_ECHAR; +#line 741 + case NC_BYTE: +#line 741 + return ncx_pad_getn_schar_ushort(xpp, nelems, tp); +#line 741 + case NC_SHORT: +#line 741 + return ncx_pad_getn_short_ushort(xpp, nelems, tp); +#line 741 + case NC_INT: +#line 741 + return ncx_getn_int_ushort(xpp, nelems, tp); +#line 741 + case NC_FLOAT: +#line 741 + return ncx_getn_float_ushort(xpp, nelems, tp); +#line 741 + case NC_DOUBLE: +#line 741 + return ncx_getn_double_ushort(xpp, nelems, tp); +#line 741 + case NC_UBYTE: +#line 741 + return ncx_pad_getn_uchar_ushort(xpp, nelems, tp); +#line 741 + case NC_USHORT: +#line 741 + return ncx_getn_ushort_ushort(xpp, nelems, tp); +#line 741 + case NC_UINT: +#line 741 + return ncx_getn_uint_ushort(xpp, nelems, tp); +#line 741 + case NC_INT64: +#line 741 + return ncx_getn_longlong_ushort(xpp, nelems, tp); +#line 741 + case NC_UINT64: +#line 741 + return ncx_getn_ulonglong_ushort(xpp, nelems, tp); +#line 741 + default: +#line 741 + assert("ncx_pad_getn_Iushort invalid type" == 0); +#line 741 + } +#line 741 + return NC_EBADTYPE; +#line 741 +} +#line 741 + + +static int +#line 743 +ncx_pad_putn_Iuint(void **xpp, size_t nelems, const uint *tp, nc_type type, void *fillp) +#line 743 +{ +#line 743 + switch(type) { +#line 743 + case NC_CHAR: +#line 743 + return NC_ECHAR; +#line 743 + case NC_BYTE: +#line 743 + return ncx_pad_putn_schar_uint(xpp, nelems, tp, fillp); +#line 743 + case NC_SHORT: +#line 743 + return ncx_pad_putn_short_uint(xpp, nelems, tp, fillp); +#line 743 + case NC_INT: +#line 743 + return ncx_putn_int_uint(xpp, nelems, tp, fillp); +#line 743 + case NC_FLOAT: +#line 743 + return ncx_putn_float_uint(xpp, nelems, tp, fillp); +#line 743 + case NC_DOUBLE: +#line 743 + return ncx_putn_double_uint(xpp, nelems, tp, fillp); +#line 743 + case NC_UBYTE: +#line 743 + return ncx_pad_putn_uchar_uint(xpp, nelems, tp, fillp); +#line 743 + case NC_USHORT: +#line 743 + return ncx_putn_ushort_uint(xpp, nelems, tp, fillp); +#line 743 + case NC_UINT: +#line 743 + return ncx_putn_uint_uint(xpp, nelems, tp, fillp); +#line 743 + case NC_INT64: +#line 743 + return ncx_putn_longlong_uint(xpp, nelems, tp, fillp); +#line 743 + case NC_UINT64: +#line 743 + return ncx_putn_ulonglong_uint(xpp, nelems, tp, fillp); +#line 743 + default: +#line 743 + assert("ncx_pad_putn_Iuint invalid type" == 0); +#line 743 + } +#line 743 + return NC_EBADTYPE; +#line 743 +} +#line 743 + +static int +#line 744 +ncx_pad_getn_Iuint(const void **xpp, size_t nelems, uint *tp, nc_type type) +#line 744 +{ +#line 744 + switch(type) { +#line 744 + case NC_CHAR: +#line 744 + return NC_ECHAR; +#line 744 + case NC_BYTE: +#line 744 + return ncx_pad_getn_schar_uint(xpp, nelems, tp); +#line 744 + case NC_SHORT: +#line 744 + return ncx_pad_getn_short_uint(xpp, nelems, tp); +#line 744 + case NC_INT: +#line 744 + return ncx_getn_int_uint(xpp, nelems, tp); +#line 744 + case NC_FLOAT: +#line 744 + return ncx_getn_float_uint(xpp, nelems, tp); +#line 744 + case NC_DOUBLE: +#line 744 + return ncx_getn_double_uint(xpp, nelems, tp); +#line 744 + case NC_UBYTE: +#line 744 + return ncx_pad_getn_uchar_uint(xpp, nelems, tp); +#line 744 + case NC_USHORT: +#line 744 + return ncx_getn_ushort_uint(xpp, nelems, tp); +#line 744 + case NC_UINT: +#line 744 + return ncx_getn_uint_uint(xpp, nelems, tp); +#line 744 + case NC_INT64: +#line 744 + return ncx_getn_longlong_uint(xpp, nelems, tp); +#line 744 + case NC_UINT64: +#line 744 + return ncx_getn_ulonglong_uint(xpp, nelems, tp); +#line 744 + default: +#line 744 + assert("ncx_pad_getn_Iuint invalid type" == 0); +#line 744 + } +#line 744 + return NC_EBADTYPE; +#line 744 +} +#line 744 + + +static int +#line 746 +ncx_pad_putn_Iulonglong(void **xpp, size_t nelems, const ulonglong *tp, nc_type type, void *fillp) +#line 746 +{ +#line 746 + switch(type) { +#line 746 + case NC_CHAR: +#line 746 + return NC_ECHAR; +#line 746 + case NC_BYTE: +#line 746 + return ncx_pad_putn_schar_ulonglong(xpp, nelems, tp, fillp); +#line 746 + case NC_SHORT: +#line 746 + return ncx_pad_putn_short_ulonglong(xpp, nelems, tp, fillp); +#line 746 + case NC_INT: +#line 746 + return ncx_putn_int_ulonglong(xpp, nelems, tp, fillp); +#line 746 + case NC_FLOAT: +#line 746 + return ncx_putn_float_ulonglong(xpp, nelems, tp, fillp); +#line 746 + case NC_DOUBLE: +#line 746 + return ncx_putn_double_ulonglong(xpp, nelems, tp, fillp); +#line 746 + case NC_UBYTE: +#line 746 + return ncx_pad_putn_uchar_ulonglong(xpp, nelems, tp, fillp); +#line 746 + case NC_USHORT: +#line 746 + return ncx_putn_ushort_ulonglong(xpp, nelems, tp, fillp); +#line 746 + case NC_UINT: +#line 746 + return ncx_putn_uint_ulonglong(xpp, nelems, tp, fillp); +#line 746 + case NC_INT64: +#line 746 + return ncx_putn_longlong_ulonglong(xpp, nelems, tp, fillp); +#line 746 + case NC_UINT64: +#line 746 + return ncx_putn_ulonglong_ulonglong(xpp, nelems, tp, fillp); +#line 746 + default: +#line 746 + assert("ncx_pad_putn_Iulonglong invalid type" == 0); +#line 746 + } +#line 746 + return NC_EBADTYPE; +#line 746 +} +#line 746 + +static int +#line 747 +ncx_pad_getn_Iulonglong(const void **xpp, size_t nelems, ulonglong *tp, nc_type type) +#line 747 +{ +#line 747 + switch(type) { +#line 747 + case NC_CHAR: +#line 747 + return NC_ECHAR; +#line 747 + case NC_BYTE: +#line 747 + return ncx_pad_getn_schar_ulonglong(xpp, nelems, tp); +#line 747 + case NC_SHORT: +#line 747 + return ncx_pad_getn_short_ulonglong(xpp, nelems, tp); +#line 747 + case NC_INT: +#line 747 + return ncx_getn_int_ulonglong(xpp, nelems, tp); +#line 747 + case NC_FLOAT: +#line 747 + return ncx_getn_float_ulonglong(xpp, nelems, tp); +#line 747 + case NC_DOUBLE: +#line 747 + return ncx_getn_double_ulonglong(xpp, nelems, tp); +#line 747 + case NC_UBYTE: +#line 747 + return ncx_pad_getn_uchar_ulonglong(xpp, nelems, tp); +#line 747 + case NC_USHORT: +#line 747 + return ncx_getn_ushort_ulonglong(xpp, nelems, tp); +#line 747 + case NC_UINT: +#line 747 + return ncx_getn_uint_ulonglong(xpp, nelems, tp); +#line 747 + case NC_INT64: +#line 747 + return ncx_getn_longlong_ulonglong(xpp, nelems, tp); +#line 747 + case NC_UINT64: +#line 747 + return ncx_getn_ulonglong_ulonglong(xpp, nelems, tp); +#line 747 + default: +#line 747 + assert("ncx_pad_getn_Iulonglong invalid type" == 0); +#line 747 + } +#line 747 + return NC_EBADTYPE; +#line 747 +} +#line 747 + + + +/* Common dispatcher for put cases */ +static int +dispatchput(void **xpp, size_t nelems, const void* tp, + nc_type atype, nc_type memtype, void *fillp) +{ + switch (memtype) { + case NC_CHAR: + return ncx_pad_putn_text(xpp,nelems, (char *)tp); + case NC_BYTE: + return ncx_pad_putn_Ischar(xpp, nelems, (schar*)tp, atype, fillp); + case NC_SHORT: + return ncx_pad_putn_Ishort(xpp, nelems, (short*)tp, atype, fillp); + case NC_INT: + return ncx_pad_putn_Iint(xpp, nelems, (int*)tp, atype, fillp); + case NC_FLOAT: + return ncx_pad_putn_Ifloat(xpp, nelems, (float*)tp, atype, fillp); + case NC_DOUBLE: + return ncx_pad_putn_Idouble(xpp, nelems, (double*)tp, atype, fillp); + case NC_UBYTE: /*Synthetic*/ + return ncx_pad_putn_Iuchar(xpp,nelems, (uchar *)tp, atype, fillp); + case NC_INT64: + return ncx_pad_putn_Ilonglong(xpp, nelems, (longlong*)tp, atype, fillp); + case NC_USHORT: + return ncx_pad_putn_Iushort(xpp, nelems, (ushort*)tp, atype, fillp); + case NC_UINT: + return ncx_pad_putn_Iuint(xpp, nelems, (uint*)tp, atype, fillp); + case NC_UINT64: + return ncx_pad_putn_Iulonglong(xpp, nelems, (ulonglong*)tp, atype, fillp); + case NC_NAT: + return NC_EBADTYPE; + default: + break; + } + return NC_EBADTYPE; +} + +int +NC3_put_att( + int ncid, + int varid, + const char *name, + nc_type type, + size_t nelems, + const void *value, + nc_type memtype) +{ + int status; + NC *nc; + NC3_INFO* ncp; + NC_attrarray *ncap; + NC_attr **attrpp; + NC_attr *old = NULL; + NC_attr *attrp; + unsigned char fill[8]; /* fill value in internal representation */ + + status = NC_check_id(ncid, &nc); + if(status != NC_NOERR) + return status; + ncp = NC3_DATA(nc); + + if(NC_readonly(ncp)) + return NC_EPERM; + + ncap = NC_attrarray0(ncp, varid); + if(ncap == NULL) + return NC_ENOTVAR; + + if (name == NULL) + return NC_EBADNAME; + + /* check NC_EBADTYPE */ + status = nc3_cktype(nc->mode, type); + if(status != NC_NOERR) + return status; + + if(memtype == NC_NAT) memtype = type; + + if(memtype != NC_CHAR && type == NC_CHAR) + return NC_ECHAR; + if(memtype == NC_CHAR && type != NC_CHAR) + return NC_ECHAR; + + /* cast needed for braindead systems with signed size_t */ + if((unsigned long) nelems > X_INT_MAX) /* backward compat */ + return NC_EINVAL; /* Invalid nelems */ + + if(nelems != 0 && value == NULL) + return NC_EINVAL; /* Null arg */ + + /* Temporarily removed to preserve extant + workflows (NCO based and others). See + + https://github.com/Unidata/netcdf-c/issues/843 + + for more information. */ + +#if 0 + if (varid != NC_GLOBAL && !strcmp(name, _FillValue)) { + /* Fill value must be of the same data type */ + if (type != ncp->vars.value[varid]->type) return NC_EBADTYPE; + + /* Fill value must have exactly one value */ + if (nelems != 1) return NC_EINVAL; + + /* Only allow for variables defined in initial define mode */ + if (ncp->old != NULL && varid < ncp->old->vars.nelems) + return NC_ELATEFILL; /* try put attribute for an old variable */ + } +#endif + + attrpp = NC_findattr(ncap, name); + + /* 4 cases: exists X indef */ + + status = NC3_inq_default_fill_value(type, &fill); + if (status != NC_NOERR) return status; + + if(attrpp != NULL) { /* name in use */ + if(!NC_indef(ncp)) { + const size_t xsz = ncx_len_NC_attrV(type, nelems); + attrp = *attrpp; /* convenience */ + + if(xsz > attrp->xsz) return NC_ENOTINDEFINE; + /* else, we can reuse existing without redef */ + + attrp->xsz = xsz; + attrp->type = type; + attrp->nelems = nelems; + + if(nelems != 0) { + void *xp = attrp->xvalue; + /* for CDF-1 and CDF-2, NC_BYTE is treated the same type as uchar memtype */ + if (!fIsSet(ncp->flags,NC_64BIT_DATA) && type == NC_BYTE && memtype == NC_UBYTE) { + status = NC3_inq_default_fill_value(NC_UBYTE, &fill); + if (status != NC_NOERR) return status; + status = dispatchput(&xp, nelems, value, memtype, memtype, &fill); + } else + status = dispatchput(&xp, nelems, value, type, memtype, &fill); + } + + set_NC_hdirty(ncp); + + if(NC_doHsync(ncp)) { + const int lstatus = NC_sync(ncp); + /* + * N.B.: potentially overrides NC_ERANGE + * set by ncx_pad_putn_I$1 + */ + if(lstatus != NC_NOERR) return lstatus; + } + + return status; + } + /* else, redefine using existing array slot */ + old = *attrpp; + } else { + if(!NC_indef(ncp)) return NC_ENOTINDEFINE; + } + + status = NC_check_name(name); + if(status != NC_NOERR) return status; + + attrp = new_NC_attr(name, type, nelems); + if(attrp == NULL) return NC_ENOMEM; + + if(nelems != 0) { + void *xp = attrp->xvalue; + /* for CDF-1 and CDF-2, NC_BYTE is treated the same type as uchar memtype */ + if (!fIsSet(ncp->flags,NC_64BIT_DATA) && type == NC_BYTE && memtype == NC_UBYTE) { + status = NC3_inq_default_fill_value(NC_UBYTE, &fill); + if (status != NC_NOERR) return status; + status = dispatchput(&xp, nelems, (const void*)value, memtype, memtype, &fill); + } else + status = dispatchput(&xp, nelems, (const void*)value, type, memtype, &fill); + } + + if(attrpp != NULL) { + *attrpp = attrp; + if(old != NULL) + free_NC_attr(old); + } else { + const int lstatus = incr_NC_attrarray(ncap, attrp); + /* + * N.B.: potentially overrides NC_ERANGE + * set by ncx_pad_putn_I$1 + */ + if(lstatus != NC_NOERR) { + free_NC_attr(attrp); + return lstatus; + } + } + return status; +} + +int +NC3_get_att( + int ncid, + int varid, + const char *name, + void *value, + nc_type memtype) +{ + int status; + NC *nc; + NC3_INFO* ncp; + NC_attr *attrp; + const void *xp; + + status = NC_check_id(ncid, &nc); + if(status != NC_NOERR) + return status; + ncp = NC3_DATA(nc); + + status = NC_lookupattr(ncid, varid, name, &attrp); + if(status != NC_NOERR) return status; + + if(attrp->nelems == 0) return NC_NOERR; + + if(memtype == NC_NAT) memtype = attrp->type; + + if(memtype != NC_CHAR && attrp->type == NC_CHAR) + return NC_ECHAR; + if(memtype == NC_CHAR && attrp->type != NC_CHAR) + return NC_ECHAR; + + xp = attrp->xvalue; + switch (memtype) { + case NC_CHAR: + return ncx_pad_getn_text(&xp, attrp->nelems, (char *)value); + case NC_BYTE: + return ncx_pad_getn_Ischar(&xp,attrp->nelems,(schar*)value,attrp->type); + case NC_SHORT: + return ncx_pad_getn_Ishort(&xp,attrp->nelems,(short*)value,attrp->type); + case NC_INT: + return ncx_pad_getn_Iint(&xp,attrp->nelems,(int*)value,attrp->type); + case NC_FLOAT: + return ncx_pad_getn_Ifloat(&xp,attrp->nelems,(float*)value,attrp->type); + case NC_DOUBLE: + return ncx_pad_getn_Idouble(&xp,attrp->nelems,(double*)value,attrp->type); + case NC_INT64: + return ncx_pad_getn_Ilonglong(&xp,attrp->nelems,(longlong*)value,attrp->type); + case NC_UBYTE: /* Synthetic */ + /* for CDF-1 and CDF-2, NC_BYTE is treated the same type as uchar memtype */ + if (!fIsSet(ncp->flags,NC_64BIT_DATA) && attrp->type == NC_BYTE) + return ncx_pad_getn_Iuchar(&xp, attrp->nelems, (uchar *)value, NC_UBYTE); + else + return ncx_pad_getn_Iuchar(&xp, attrp->nelems, (uchar *)value, attrp->type); + case NC_USHORT: + return ncx_pad_getn_Iushort(&xp,attrp->nelems,(ushort*)value,attrp->type); + case NC_UINT: + return ncx_pad_getn_Iuint(&xp,attrp->nelems,(uint*)value,attrp->type); + case NC_UINT64: + return ncx_pad_getn_Iulonglong(&xp,attrp->nelems,(ulonglong*)value,attrp->type); + case NC_NAT: + return NC_EBADTYPE; + default: + break; + } + status = NC_EBADTYPE; + return status; +} diff --git a/libsrc/ncx.c b/libsrc/ncx.c new file mode 100644 index 0000000000..48cdc8391b --- /dev/null +++ b/libsrc/ncx.c @@ -0,0 +1,39531 @@ +#line 6 "ncx.m4" +/* Do not edit this file. It is produced from the corresponding .m4 source */ +#line 8 +/* + * Copyright (C) 2014, Northwestern University and Argonne National Laboratory + * See COPYRIGHT notice in top-level directory. + */ +/* $Id: ncx.m4 2601 2016-11-07 04:54:42Z wkliao $ */ + +#ifdef __GNUC__ +#pragma GCC diagnostic ignored "-Wunused-parameter" +#endif + +#line 22 + +#line 26 + + +#line 34 + +#line 41 + +#line 41 +#if HAVE_CONFIG_H +#line 41 +#include +#line 41 +#endif + +#include +#include +#include +#include + +#line 53 + +#line 53 +#pragma GCC diagnostic ignored "-Wdeprecated" +#line 53 +#include "ncx.h" +#line 53 +#include "nc3dispatch.h" + +#line 72 + + + + +#ifdef HAVE_INTTYPES_H +#include /* uint16_t, uint32_t, uint64_t */ +#elif defined(HAVE_STDINT_H) +#include /* uint16_t, uint32_t, uint64_t */ +#endif + +#line 103 + +#line 121 + +/* + * The only error code returned from subroutines in this file is NC_ERANGE, + * if errors are detected. + */ + +/* + * An external data representation interface. + */ + +/* alias poorly named limits.h macros */ +#define SHORT_MAX SHRT_MAX +#define SHORT_MIN SHRT_MIN +#define USHORT_MAX USHRT_MAX +#ifndef LLONG_MAX +# define LLONG_MAX 9223372036854775807LL +# define LLONG_MIN (-LLONG_MAX - 1LL) +# define ULLONG_MAX 18446744073709551615ULL +#endif +#ifndef LONG_LONG_MAX +#define LONG_LONG_MAX LLONG_MAX +#endif +#ifndef LONGLONG_MAX +#define LONGLONG_MAX LONG_LONG_MAX +#endif +#ifndef LONG_LONG_MIN +#define LONG_LONG_MIN LLONG_MIN +#endif +#ifndef LONGLONG_MIN +#define LONGLONG_MIN LONG_LONG_MIN +#endif +#ifndef ULONG_LONG_MAX +#define ULONG_LONG_MAX ULLONG_MAX +#endif +#ifndef ULONGLONG_MAX +#define ULONGLONG_MAX ULONG_LONG_MAX +#endif +#include +#ifndef FLT_MAX /* This POSIX macro missing on some systems */ +# ifndef NO_IEEE_FLOAT +# define FLT_MAX 3.40282347e+38f +# else +# error "You will need to define FLT_MAX" +# endif +#endif +/* alias poorly named float.h macros */ +#define FLOAT_MAX FLT_MAX +#define FLOAT_MIN (-FLT_MAX) +#define DOUBLE_MAX DBL_MAX +#define DOUBLE_MIN (-DBL_MAX) +#define FLOAT_MAX_EXP FLT_MAX_EXP +#define DOUBLE_MAX_EXP DBL_MAX_EXP +#include +#define UCHAR_MIN 0 +#define Min(a,b) ((a) < (b) ? (a) : (b)) +#define Max(a,b) ((a) > (b) ? (a) : (b)) + +#ifndef SIZEOF_UCHAR +#ifdef SIZEOF_UNSIGNED_CHAR +#define SIZEOF_UCHAR SIZEOF_UNSIGNED_CHAR +#else +#error "unknown SIZEOF_UCHAR" +#endif +#endif + +#ifndef SIZEOF_USHORT +#ifdef SIZEOF_UNSIGNED_SHORT_INT +#define SIZEOF_USHORT SIZEOF_UNSIGNED_SHORT_INT +#elif defined(SIZEOF_UNSIGNED_SHORT) +#define SIZEOF_USHORT SIZEOF_UNSIGNED_SHORT +#else +#error "unknown SIZEOF_USHORT" +#endif +#endif + +#ifndef SIZEOF_UINT +#ifdef SIZEOF_UNSIGNED_INT +#define SIZEOF_UINT SIZEOF_UNSIGNED_INT +#else +#error "unknown SIZEOF_UINT" +#endif +#endif + +#ifndef SIZEOF_LONGLONG +#ifdef SIZEOF_LONG_LONG +#define SIZEOF_LONGLONG SIZEOF_LONG_LONG +#else +#error "unknown SIZEOF_LONGLONG" +#endif +#endif + +#ifndef SIZEOF_INT64 +#ifdef SIZEOF_LONG_LONG +#define SIZEOF_INT64 SIZEOF_LONG_LONG +#elif defined(SIZEOF_LONGLONG) +#define SIZEOF_INT64 SIZEOF_LONGLONG +#else +#error "unknown SIZEOF_INT64" +#endif +#endif + +#ifndef SIZEOF_ULONGLONG +#ifdef SIZEOF_UNSIGNED_LONG_LONG +#define SIZEOF_ULONGLONG SIZEOF_UNSIGNED_LONG_LONG +#else +#error "unknown SIZEOF_ULONGLONG" +#endif +#endif + +#ifndef SIZEOF_UINT64 +#ifdef SIZEOF_UNSIGNED_LONG_LONG +#define SIZEOF_UINT64 SIZEOF_UNSIGNED_LONG_LONG +#elif defined(SIZEOF_ULONGLONG) +#define SIZEOF_UINT64 SIZEOF_ULONGLONG +#else +#error "unknown SIZEOF_UINT64" +#endif +#endif + +/* + * If the machine's float domain is "smaller" than the external one + * use the machine domain + */ +#if defined(FLT_MAX_EXP) && FLT_MAX_EXP < 128 /* 128 is X_FLT_MAX_EXP */ +#undef X_FLOAT_MAX +# define X_FLOAT_MAX FLT_MAX +#undef X_FLOAT_MIN +# define X_FLOAT_MIN (-X_FLOAT_MAX) +#endif + +#if defined(_SX) && _SX != 0 /* NEC SUPER UX */ +#define LOOPCNT 256 /* must be no longer than hardware vector length */ +#if _INT64 +#undef INT_MAX /* workaround cpp bug */ +#define INT_MAX X_INT_MAX +#undef INT_MIN /* workaround cpp bug */ +#define INT_MIN X_INT_MIN +#undef LONG_MAX /* workaround cpp bug */ +#define LONG_MAX X_INT_MAX +#undef LONG_MIN /* workaround cpp bug */ +#define LONG_MIN X_INT_MIN +#elif _LONG64 +#undef LONG_MAX /* workaround cpp bug */ +#define LONG_MAX 4294967295L +#undef LONG_MIN /* workaround cpp bug */ +#define LONG_MIN -4294967295L +#endif +#if !_FLOAT0 +#error "FLOAT1 and FLOAT2 not supported" +#endif +#endif /* _SX */ + +static const char nada[X_ALIGN] = {0, 0, 0, 0}; + +#ifndef WORDS_BIGENDIAN +/* LITTLE_ENDIAN: DEC and intel */ +/* + * Routines to convert to BIG ENDIAN. + * Optimize the swapn?b() and swap?b() routines aggressively. + */ + +#define SWAP2(a) ( (((a) & 0xff) << 8) | \ + (((a) >> 8) & 0xff) ) + +#define SWAP4(a) ( ((a) << 24) | \ + (((a) << 8) & 0x00ff0000) | \ + (((a) >> 8) & 0x0000ff00) | \ + (((a) >> 24) & 0x000000ff) ) + +#define SWAP8(a) ( (((a) & 0x00000000000000FFULL) << 56) | \ + (((a) & 0x000000000000FF00ULL) << 40) | \ + (((a) & 0x0000000000FF0000ULL) << 24) | \ + (((a) & 0x00000000FF000000ULL) << 8) | \ + (((a) & 0x000000FF00000000ULL) >> 8) | \ + (((a) & 0x0000FF0000000000ULL) >> 24) | \ + (((a) & 0x00FF000000000000ULL) >> 40) | \ + (((a) & 0xFF00000000000000ULL) >> 56) ) + +#if defined(_MSC_VER) && _MSC_VER < 1900 +#define inline __inline +#endif + +inline static void +swapn2b(void *dst, const void *src, size_t nn) +{ + /* it is OK if dst == src */ + int i; + uint16_t *op = (uint16_t*) dst; + uint16_t *ip = (uint16_t*) src; + for (i=0; i 0) + * { + * *op++ = *(++ip); + * *op++ = *(ip++ -1); + * } + */ + while (nn > 3) + { + *op++ = *(++ip); + *op++ = *(ip++ -1); + *op++ = *(++ip); + *op++ = *(ip++ -1); + *op++ = *(++ip); + *op++ = *(ip++ -1); + *op++ = *(++ip); + *op++ = *(ip++ -1); + nn -= 4; + } + while (nn-- > 0) + { + *op++ = *(++ip); + *op++ = *(ip++ -1); + } +#endif +} + +# ifndef vax +inline static void +swap4b(void *dst, const void *src) +{ + /* copy over, make the below swap in-place */ + uint32_t tmp = *(uint32_t*)src; + tmp = SWAP4(tmp); + memcpy(dst, &tmp, 4); + + /* Codes below will cause "break strict-aliasing rules" in gcc + uint32_t *op = (uint32_t*)dst; + *op = *(uint32_t*)src; + *op = SWAP4(*op); + */ + + /* Below are copied from netCDF-4. + * See https://bugtracking.unidata.ucar.edu/browse/NCF-338 + * Quote "One issue we are wrestling with is how compilers optimize this + * code. For some reason, we are actually needing to add an artificial + * move to a 4 byte space to get it to work. I think what is happening is + * that the optimizer is bit shifting within a double, which is incorrect. + * The following code actually does work correctly. + * This is in Linux land, gcc. + * + * However, the above in-place byte-swap does not appear affected by this. + */ +#if 0 + uint32_t *ip = (uint32_t*)src; + uint32_t tempOut; /* cannot use pointer when gcc O2 optimizer is used */ + tempOut = SWAP4(*ip); + + *(float *)dst = *(float *)(&tempOut); +#endif + + /* OLD implementation that results in four load and four store CPU + instructions + char *op = dst; + const char *ip = src; + op[0] = ip[3]; + op[1] = ip[2]; + op[2] = ip[1]; + op[3] = ip[0]; + */ + +} +# endif /* !vax */ + +inline static void +swapn4b(void *dst, const void *src, size_t nn) +{ + int i; + uint32_t *op = (uint32_t*) dst; + uint32_t *ip = (uint32_t*) src; + for (i=0; i 0) + * { + * op[0] = ip[3]; + * op[1] = ip[2]; + * op[2] = ip[1]; + * op[3] = ip[0]; + * op += 4; + * ip += 4; + * } + */ + while (nn > 3) + { + op[0] = ip[3]; + op[1] = ip[2]; + op[2] = ip[1]; + op[3] = ip[0]; + op[4] = ip[7]; + op[5] = ip[6]; + op[6] = ip[5]; + op[7] = ip[4]; + op[8] = ip[11]; + op[9] = ip[10]; + op[10] = ip[9]; + op[11] = ip[8]; + op[12] = ip[15]; + op[13] = ip[14]; + op[14] = ip[13]; + op[15] = ip[12]; + op += 16; + ip += 16; + nn -= 4; + } + while (nn-- > 0) + { + op[0] = ip[3]; + op[1] = ip[2]; + op[2] = ip[1]; + op[3] = ip[0]; + op += 4; + ip += 4; + } +#endif +} + +# ifndef vax +inline static void +swap8b(void *dst, const void *src) +{ +#ifdef FLOAT_WORDS_BIGENDIAN + /* copy over, make the below swap in-place */ + *(uint64_t*)dst = *(uint64_t*)src; + + uint32_t *op = (uint32_t*)dst; + *op = SWAP4(*op); + op = (uint32_t*)((char*)dst+4); + *op = SWAP4(*op); +#else + uint64_t tmp = *(uint64_t*)src; + tmp = SWAP8(tmp); + memcpy(dst, &tmp, 8); + + /* Codes below will cause "break strict-aliasing rules" in gcc + uint64_t *op = (uint64_t*)dst; + *op = *(uint64_t*)src; + *op = SWAP8(*op); + */ +#endif + +#if 0 + char *op = dst; + const char *ip = src; +# ifndef FLOAT_WORDS_BIGENDIAN + op[0] = ip[7]; + op[1] = ip[6]; + op[2] = ip[5]; + op[3] = ip[4]; + op[4] = ip[3]; + op[5] = ip[2]; + op[6] = ip[1]; + op[7] = ip[0]; +# else + op[0] = ip[3]; + op[1] = ip[2]; + op[2] = ip[1]; + op[3] = ip[0]; + op[4] = ip[7]; + op[5] = ip[6]; + op[6] = ip[5]; + op[7] = ip[4]; +#endif +#endif +} +# endif /* !vax */ + +# ifndef vax +inline static void +swapn8b(void *dst, const void *src, size_t nn) +{ +#ifdef FLOAT_WORDS_BIGENDIAN + int i; + uint64_t *dst_p = (uint64_t*) dst; + uint64_t *src_p = (uint64_t*) src; + for (i=0; i 0) + * { + * op[0] = ip[7]; + * op[1] = ip[6]; + * op[2] = ip[5]; + * op[3] = ip[4]; + * op[4] = ip[3]; + * op[5] = ip[2]; + * op[6] = ip[1]; + * op[7] = ip[0]; + * op += 8; + * ip += 8; + * } + */ +# ifndef FLOAT_WORDS_BIGENDIAN + while (nn > 1) + { + op[0] = ip[7]; + op[1] = ip[6]; + op[2] = ip[5]; + op[3] = ip[4]; + op[4] = ip[3]; + op[5] = ip[2]; + op[6] = ip[1]; + op[7] = ip[0]; + op[8] = ip[15]; + op[9] = ip[14]; + op[10] = ip[13]; + op[11] = ip[12]; + op[12] = ip[11]; + op[13] = ip[10]; + op[14] = ip[9]; + op[15] = ip[8]; + op += 16; + ip += 16; + nn -= 2; + } + while (nn-- > 0) + { + op[0] = ip[7]; + op[1] = ip[6]; + op[2] = ip[5]; + op[3] = ip[4]; + op[4] = ip[3]; + op[5] = ip[2]; + op[6] = ip[1]; + op[7] = ip[0]; + op += 8; + ip += 8; + } +# else + while (nn-- > 0) + { + op[0] = ip[3]; + op[1] = ip[2]; + op[2] = ip[1]; + op[3] = ip[0]; + op[4] = ip[7]; + op[5] = ip[6]; + op[6] = ip[5]; + op[7] = ip[4]; + op += 8; + ip += 8; + } +#endif +#endif +} +# endif /* !vax */ + +#endif /* LITTLE_ENDIAN */ + +#line 630 + +#line 634 + +#line 646 + +#line 661 + + +/* + * Primitive numeric conversion functions. + */ + +#line 689 + +#line 737 + +#line 770 + +#line 816 + +/* x_schar */ +/* x_uchar */ + +/* We don't implement any x_schar and x_uchar primitives. */ + + +/* external NC_SHORT --------------------------------------------------------*/ + +#if SHORT_MAX == X_SHORT_MAX +typedef short ix_short; +#define SIZEOF_IX_SHORT SIZEOF_SHORT +#define IX_SHORT_MAX SHORT_MAX +#elif INT_MAX >= X_SHORT_MAX +typedef int ix_short; +#define SIZEOF_IX_SHORT SIZEOF_INT +#define IX_SHORT_MAX INT_MAX +#elif LONG_MAX >= X_SHORT_MAX +typedef long ix_short; +#define SIZEOF_IX_SHORT SIZEOF_LONG +#define IX_SHORT_MAX LONG_MAX +#elif LLONG_MAX >= X_SHORT_MAX +typedef long long ix_short; +#define SIZEOF_IX_SHORT SIZEOF_LONGLONG +#define IX_SHORT_MAX LLONG_MAX +#else +#error "ix_short implementation" +#endif + +static void +get_ix_short(const void *xp, ix_short *ip) +{ + const uchar *cp = (const uchar *) xp; + *ip = (ix_short)(*cp++ << 8); +#if SIZEOF_IX_SHORT > X_SIZEOF_SHORT + if (*ip & 0x8000) + { + /* extern is negative */ + *ip |= (~(0xffff)); /* N.B. Assumes "twos complement" */ + } +#endif + *ip = (ix_short)(*ip | *cp); +} + +static void +put_ix_short(void *xp, const ix_short *ip) +{ + uchar *cp = (uchar *) xp; + *cp++ = (uchar)((*ip) >> 8); + *cp = (uchar)((*ip) & 0xff); +} + +static int +#line 868 +ncx_get_short_schar(const void *xp, schar *ip) +#line 868 +{ +#line 868 + int err=NC_NOERR; +#line 868 + ix_short xx = 0; +#line 868 + get_ix_short(xp, &xx); +#line 868 + +#line 868 +#if IX_SHORT_MAX > SCHAR_MAX +#line 868 + if (xx > SCHAR_MAX || xx < SCHAR_MIN) { +#line 868 +#ifdef ERANGE_FILL +#line 868 + *ip = NC_FILL_BYTE; +#line 868 + return NC_ERANGE; +#line 868 +#else +#line 868 + err = NC_ERANGE; +#line 868 +#endif +#line 868 + } +#line 868 +#endif +#line 868 + +#line 868 + +#line 868 + *ip = (schar) xx; +#line 868 + return err; +#line 868 +} +#line 868 + +static int +#line 869 +ncx_get_short_short(const void *xp, short *ip) +#line 869 +{ +#line 869 + int err=NC_NOERR; +#line 869 +#if SIZEOF_IX_SHORT == SIZEOF_SHORT && IX_SHORT_MAX == SHORT_MAX +#line 869 + get_ix_short(xp, (ix_short *)ip); +#line 869 +#else +#line 869 + ix_short xx = 0; +#line 869 + get_ix_short(xp, &xx); +#line 869 + +#line 869 +#if IX_SHORT_MAX > SHORT_MAX +#line 869 + if (xx > SHORT_MAX || xx < SHORT_MIN) { +#line 869 +#ifdef ERANGE_FILL +#line 869 + *ip = NC_FILL_SHORT; +#line 869 + return NC_ERANGE; +#line 869 +#else +#line 869 + err = NC_ERANGE; +#line 869 +#endif +#line 869 + } +#line 869 +#endif +#line 869 + +#line 869 + +#line 869 + *ip = (short) xx; +#line 869 +#endif +#line 869 + return err; +#line 869 +} +#line 869 + +static int +#line 870 +ncx_get_short_int(const void *xp, int *ip) +#line 870 +{ +#line 870 + int err=NC_NOERR; +#line 870 +#if SIZEOF_IX_SHORT == SIZEOF_INT && IX_SHORT_MAX == INT_MAX +#line 870 + get_ix_short(xp, (ix_short *)ip); +#line 870 +#else +#line 870 + ix_short xx = 0; +#line 870 + get_ix_short(xp, &xx); +#line 870 + +#line 870 +#if IX_SHORT_MAX > INT_MAX +#line 870 + if (xx > INT_MAX || xx < INT_MIN) { +#line 870 +#ifdef ERANGE_FILL +#line 870 + *ip = NC_FILL_INT; +#line 870 + return NC_ERANGE; +#line 870 +#else +#line 870 + err = NC_ERANGE; +#line 870 +#endif +#line 870 + } +#line 870 +#endif +#line 870 + +#line 870 + +#line 870 + *ip = (int) xx; +#line 870 +#endif +#line 870 + return err; +#line 870 +} +#line 870 + +static int +#line 871 +ncx_get_short_long(const void *xp, long *ip) +#line 871 +{ +#line 871 + int err=NC_NOERR; +#line 871 +#if SIZEOF_IX_SHORT == SIZEOF_LONG && IX_SHORT_MAX == LONG_MAX +#line 871 + get_ix_short(xp, (ix_short *)ip); +#line 871 +#else +#line 871 + ix_short xx = 0; +#line 871 + get_ix_short(xp, &xx); +#line 871 + +#line 871 +#if IX_SHORT_MAX > LONG_MAX +#line 871 + if (xx > LONG_MAX || xx < LONG_MIN) { +#line 871 +#ifdef ERANGE_FILL +#line 871 + *ip = NC_FILL_INT; +#line 871 + return NC_ERANGE; +#line 871 +#else +#line 871 + err = NC_ERANGE; +#line 871 +#endif +#line 871 + } +#line 871 +#endif +#line 871 + +#line 871 + +#line 871 + *ip = (long) xx; +#line 871 +#endif +#line 871 + return err; +#line 871 +} +#line 871 + +static int +#line 872 +ncx_get_short_longlong(const void *xp, longlong *ip) +#line 872 +{ +#line 872 + int err=NC_NOERR; +#line 872 +#if SIZEOF_IX_SHORT == SIZEOF_LONGLONG && IX_SHORT_MAX == LONGLONG_MAX +#line 872 + get_ix_short(xp, (ix_short *)ip); +#line 872 +#else +#line 872 + ix_short xx = 0; +#line 872 + get_ix_short(xp, &xx); +#line 872 + +#line 872 +#if IX_SHORT_MAX > LONGLONG_MAX +#line 872 + if (xx > LONGLONG_MAX || xx < LONGLONG_MIN) { +#line 872 +#ifdef ERANGE_FILL +#line 872 + *ip = NC_FILL_INT64; +#line 872 + return NC_ERANGE; +#line 872 +#else +#line 872 + err = NC_ERANGE; +#line 872 +#endif +#line 872 + } +#line 872 +#endif +#line 872 + +#line 872 + +#line 872 + *ip = (longlong) xx; +#line 872 +#endif +#line 872 + return err; +#line 872 +} +#line 872 + +static int +#line 873 +ncx_get_short_ushort(const void *xp, ushort *ip) +#line 873 +{ +#line 873 + int err=NC_NOERR; +#line 873 + ix_short xx = 0; +#line 873 + get_ix_short(xp, &xx); +#line 873 + +#line 873 +#if IX_SHORT_MAX > USHORT_MAX +#line 873 + if (xx > USHORT_MAX) { +#line 873 +#ifdef ERANGE_FILL +#line 873 + *ip = NC_FILL_USHORT; +#line 873 + return NC_ERANGE; +#line 873 +#else +#line 873 + err = NC_ERANGE; +#line 873 +#endif +#line 873 + } +#line 873 +#endif +#line 873 + +#line 873 + if (xx < 0) { +#line 873 +#ifdef ERANGE_FILL +#line 873 + *ip = NC_FILL_USHORT; +#line 873 + return NC_ERANGE; +#line 873 +#else +#line 873 + err = NC_ERANGE; /* because ip is unsigned */ +#line 873 +#endif +#line 873 + } +#line 873 + *ip = (ushort) xx; +#line 873 + return err; +#line 873 +} +#line 873 + +static int +#line 874 +ncx_get_short_uchar(const void *xp, uchar *ip) +#line 874 +{ +#line 874 + int err=NC_NOERR; +#line 874 + ix_short xx = 0; +#line 874 + get_ix_short(xp, &xx); +#line 874 + +#line 874 +#if IX_SHORT_MAX > UCHAR_MAX +#line 874 + if (xx > UCHAR_MAX) { +#line 874 +#ifdef ERANGE_FILL +#line 874 + *ip = NC_FILL_UBYTE; +#line 874 + return NC_ERANGE; +#line 874 +#else +#line 874 + err = NC_ERANGE; +#line 874 +#endif +#line 874 + } +#line 874 +#endif +#line 874 + +#line 874 + if (xx < 0) { +#line 874 +#ifdef ERANGE_FILL +#line 874 + *ip = NC_FILL_UBYTE; +#line 874 + return NC_ERANGE; +#line 874 +#else +#line 874 + err = NC_ERANGE; /* because ip is unsigned */ +#line 874 +#endif +#line 874 + } +#line 874 + *ip = (uchar) xx; +#line 874 + return err; +#line 874 +} +#line 874 + +static int +#line 875 +ncx_get_short_uint(const void *xp, uint *ip) +#line 875 +{ +#line 875 + int err=NC_NOERR; +#line 875 + ix_short xx = 0; +#line 875 + get_ix_short(xp, &xx); +#line 875 + +#line 875 +#if IX_SHORT_MAX > UINT_MAX +#line 875 + if (xx > UINT_MAX) { +#line 875 +#ifdef ERANGE_FILL +#line 875 + *ip = NC_FILL_UINT; +#line 875 + return NC_ERANGE; +#line 875 +#else +#line 875 + err = NC_ERANGE; +#line 875 +#endif +#line 875 + } +#line 875 +#endif +#line 875 + +#line 875 + if (xx < 0) { +#line 875 +#ifdef ERANGE_FILL +#line 875 + *ip = NC_FILL_UINT; +#line 875 + return NC_ERANGE; +#line 875 +#else +#line 875 + err = NC_ERANGE; /* because ip is unsigned */ +#line 875 +#endif +#line 875 + } +#line 875 + *ip = (uint) xx; +#line 875 + return err; +#line 875 +} +#line 875 + +static int +#line 876 +ncx_get_short_ulonglong(const void *xp, ulonglong *ip) +#line 876 +{ +#line 876 + int err=NC_NOERR; +#line 876 + ix_short xx = 0; +#line 876 + get_ix_short(xp, &xx); +#line 876 + +#line 876 +#if IX_SHORT_MAX > ULONGLONG_MAX +#line 876 + if (xx > ULONGLONG_MAX) { +#line 876 +#ifdef ERANGE_FILL +#line 876 + *ip = NC_FILL_UINT64; +#line 876 + return NC_ERANGE; +#line 876 +#else +#line 876 + err = NC_ERANGE; +#line 876 +#endif +#line 876 + } +#line 876 +#endif +#line 876 + +#line 876 + if (xx < 0) { +#line 876 +#ifdef ERANGE_FILL +#line 876 + *ip = NC_FILL_UINT64; +#line 876 + return NC_ERANGE; +#line 876 +#else +#line 876 + err = NC_ERANGE; /* because ip is unsigned */ +#line 876 +#endif +#line 876 + } +#line 876 + *ip = (ulonglong) xx; +#line 876 + return err; +#line 876 +} +#line 876 + +static int +#line 877 +ncx_get_short_float(const void *xp, float *ip) +#line 877 +{ +#line 877 + ix_short xx = 0; +#line 877 + get_ix_short(xp, &xx); +#line 877 + *ip = (float)xx; +#line 877 + return NC_NOERR; +#line 877 +} +#line 877 + +static int +#line 878 +ncx_get_short_double(const void *xp, double *ip) +#line 878 +{ +#line 878 + ix_short xx = 0; +#line 878 + get_ix_short(xp, &xx); +#line 878 + *ip = (double)xx; +#line 878 + return NC_NOERR; +#line 878 +} +#line 878 + + +static int +ncx_put_short_schar(void *xp, const schar *ip, void *fillp) +{ + uchar *cp = (uchar *) xp; + if (*ip & 0x80) + *cp++ = 0xff; + else + *cp++ = 0; + *cp = (uchar)*ip; + return NC_NOERR; +} + +static int +ncx_put_short_uchar(void *xp, const uchar *ip, void *fillp) +{ + uchar *cp = (uchar *) xp; + *cp++ = 0; + *cp = *ip; + return NC_NOERR; +} + +static int +#line 901 +ncx_put_short_short(void *xp, const short *ip, void *fillp) +#line 901 +{ +#line 901 + int err=NC_NOERR; +#line 901 +#if SIZEOF_IX_SHORT == SIZEOF_SHORT && IX_SHORT_MAX == SHORT_MAX +#line 901 + put_ix_short(xp, (const ix_short *)ip); +#line 901 +#else +#line 901 + ix_short xx = NC_FILL_SHORT; +#line 901 + +#line 901 +#if IX_SHORT_MAX < SHORT_MAX +#line 901 + if (*ip > IX_SHORT_MAX || *ip < X_SHORT_MIN) { +#line 901 + +#line 901 +#ifdef ERANGE_FILL +#line 901 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 901 +#endif +#line 901 + err = NC_ERANGE; +#line 901 + } +#line 901 +#ifdef ERANGE_FILL +#line 901 + else +#line 901 +#endif +#line 901 +#endif +#line 901 + xx = (ix_short)*ip; +#line 901 + +#line 901 + put_ix_short(xp, &xx); +#line 901 +#endif +#line 901 + return err; +#line 901 +} +#line 901 + +static int +#line 902 +ncx_put_short_int(void *xp, const int *ip, void *fillp) +#line 902 +{ +#line 902 + int err=NC_NOERR; +#line 902 +#if SIZEOF_IX_SHORT == SIZEOF_INT && IX_SHORT_MAX == INT_MAX +#line 902 + put_ix_short(xp, (const ix_short *)ip); +#line 902 +#else +#line 902 + ix_short xx = NC_FILL_SHORT; +#line 902 + +#line 902 +#if IX_SHORT_MAX < INT_MAX +#line 902 + if (*ip > IX_SHORT_MAX || *ip < X_SHORT_MIN) { +#line 902 + +#line 902 +#ifdef ERANGE_FILL +#line 902 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 902 +#endif +#line 902 + err = NC_ERANGE; +#line 902 + } +#line 902 +#ifdef ERANGE_FILL +#line 902 + else +#line 902 +#endif +#line 902 +#endif +#line 902 + xx = (ix_short)*ip; +#line 902 + +#line 902 + put_ix_short(xp, &xx); +#line 902 +#endif +#line 902 + return err; +#line 902 +} +#line 902 + +static int +#line 903 +ncx_put_short_long(void *xp, const long *ip, void *fillp) +#line 903 +{ +#line 903 + int err=NC_NOERR; +#line 903 +#if SIZEOF_IX_SHORT == SIZEOF_LONG && IX_SHORT_MAX == LONG_MAX +#line 903 + put_ix_short(xp, (const ix_short *)ip); +#line 903 +#else +#line 903 + ix_short xx = NC_FILL_SHORT; +#line 903 + +#line 903 +#if IX_SHORT_MAX < LONG_MAX +#line 903 + if (*ip > IX_SHORT_MAX || *ip < X_SHORT_MIN) { +#line 903 + +#line 903 +#ifdef ERANGE_FILL +#line 903 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 903 +#endif +#line 903 + err = NC_ERANGE; +#line 903 + } +#line 903 +#ifdef ERANGE_FILL +#line 903 + else +#line 903 +#endif +#line 903 +#endif +#line 903 + xx = (ix_short)*ip; +#line 903 + +#line 903 + put_ix_short(xp, &xx); +#line 903 +#endif +#line 903 + return err; +#line 903 +} +#line 903 + +static int +#line 904 +ncx_put_short_longlong(void *xp, const longlong *ip, void *fillp) +#line 904 +{ +#line 904 + int err=NC_NOERR; +#line 904 +#if SIZEOF_IX_SHORT == SIZEOF_LONGLONG && IX_SHORT_MAX == LONGLONG_MAX +#line 904 + put_ix_short(xp, (const ix_short *)ip); +#line 904 +#else +#line 904 + ix_short xx = NC_FILL_SHORT; +#line 904 + +#line 904 +#if IX_SHORT_MAX < LONGLONG_MAX +#line 904 + if (*ip > IX_SHORT_MAX || *ip < X_SHORT_MIN) { +#line 904 + +#line 904 +#ifdef ERANGE_FILL +#line 904 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 904 +#endif +#line 904 + err = NC_ERANGE; +#line 904 + } +#line 904 +#ifdef ERANGE_FILL +#line 904 + else +#line 904 +#endif +#line 904 +#endif +#line 904 + xx = (ix_short)*ip; +#line 904 + +#line 904 + put_ix_short(xp, &xx); +#line 904 +#endif +#line 904 + return err; +#line 904 +} +#line 904 + +static int +#line 905 +ncx_put_short_ushort(void *xp, const ushort *ip, void *fillp) +#line 905 +{ +#line 905 + int err=NC_NOERR; +#line 905 + ix_short xx = NC_FILL_SHORT; +#line 905 + +#line 905 +#if IX_SHORT_MAX < USHORT_MAX +#line 905 + if (*ip > IX_SHORT_MAX) { +#line 905 + +#line 905 +#ifdef ERANGE_FILL +#line 905 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 905 +#endif +#line 905 + err = NC_ERANGE; +#line 905 + } +#line 905 +#ifdef ERANGE_FILL +#line 905 + else +#line 905 +#endif +#line 905 +#endif +#line 905 + xx = (ix_short)*ip; +#line 905 + +#line 905 + put_ix_short(xp, &xx); +#line 905 + return err; +#line 905 +} +#line 905 + +static int +#line 906 +ncx_put_short_uint(void *xp, const uint *ip, void *fillp) +#line 906 +{ +#line 906 + int err=NC_NOERR; +#line 906 + ix_short xx = NC_FILL_SHORT; +#line 906 + +#line 906 +#if IX_SHORT_MAX < UINT_MAX +#line 906 + if (*ip > IX_SHORT_MAX) { +#line 906 + +#line 906 +#ifdef ERANGE_FILL +#line 906 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 906 +#endif +#line 906 + err = NC_ERANGE; +#line 906 + } +#line 906 +#ifdef ERANGE_FILL +#line 906 + else +#line 906 +#endif +#line 906 +#endif +#line 906 + xx = (ix_short)*ip; +#line 906 + +#line 906 + put_ix_short(xp, &xx); +#line 906 + return err; +#line 906 +} +#line 906 + +static int +#line 907 +ncx_put_short_ulonglong(void *xp, const ulonglong *ip, void *fillp) +#line 907 +{ +#line 907 + int err=NC_NOERR; +#line 907 + ix_short xx = NC_FILL_SHORT; +#line 907 + +#line 907 +#if IX_SHORT_MAX < ULONGLONG_MAX +#line 907 + if (*ip > IX_SHORT_MAX) { +#line 907 + +#line 907 +#ifdef ERANGE_FILL +#line 907 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 907 +#endif +#line 907 + err = NC_ERANGE; +#line 907 + } +#line 907 +#ifdef ERANGE_FILL +#line 907 + else +#line 907 +#endif +#line 907 +#endif +#line 907 + xx = (ix_short)*ip; +#line 907 + +#line 907 + put_ix_short(xp, &xx); +#line 907 + return err; +#line 907 +} +#line 907 + +static int +#line 908 +ncx_put_short_float(void *xp, const float *ip, void *fillp) +#line 908 +{ +#line 908 + int err=NC_NOERR; +#line 908 + ix_short xx = NC_FILL_SHORT; +#line 908 + +#line 908 + if (*ip > (double)X_SHORT_MAX || *ip < (double)X_SHORT_MIN) { +#line 908 + +#line 908 +#ifdef ERANGE_FILL +#line 908 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 908 +#endif +#line 908 + err = NC_ERANGE; +#line 908 + } +#line 908 +#ifdef ERANGE_FILL +#line 908 + else +#line 908 +#endif +#line 908 + xx = (ix_short)*ip; +#line 908 + +#line 908 + put_ix_short(xp, &xx); +#line 908 + return err; +#line 908 +} +#line 908 + +static int +#line 909 +ncx_put_short_double(void *xp, const double *ip, void *fillp) +#line 909 +{ +#line 909 + int err=NC_NOERR; +#line 909 + ix_short xx = NC_FILL_SHORT; +#line 909 + +#line 909 + if (*ip > X_SHORT_MAX || *ip < X_SHORT_MIN) { +#line 909 + +#line 909 +#ifdef ERANGE_FILL +#line 909 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 909 +#endif +#line 909 + err = NC_ERANGE; +#line 909 + } +#line 909 +#ifdef ERANGE_FILL +#line 909 + else +#line 909 +#endif +#line 909 + xx = (ix_short)*ip; +#line 909 + +#line 909 + put_ix_short(xp, &xx); +#line 909 + return err; +#line 909 +} +#line 909 + + +/* external NC_USHORT -------------------------------------------------------*/ + +#if USHORT_MAX == X_USHORT_MAX +typedef unsigned short ix_ushort; +#define SIZEOF_IX_USHORT SIZEOF_USHORT +#define IX_USHORT_MAX USHORT_MAX +#elif UINT_MAX >= X_USHORT_MAX +typedef unsigned int ix_ushort; +#define SIZEOF_IX_USHORT SIZEOF_UINT +#define IX_USHORT_MAX UINT_MAX +#elif ULONG_MAX >= X_USHORT_MAX +typedef unsigned long ix_ushort; +#define SIZEOF_IX_USHORT SIZEOF_ULONG +#define IX_USHORT_MAX ULONG_MAX +#elif ULLONG_MAX >= X_USHORT_MAX +typedef unsigned long long ix_ushort; +#define SIZEOF_IX_USHORT SIZEOF_ULONGLONG +#define IX_USHORT_MAX ULLONG_MAX +#else +#error "ix_ushort implementation" +#endif + +static void +get_ix_ushort(const void *xp, ix_ushort *ip) +{ + const uchar *cp = (const uchar *) xp; + *ip = (ix_ushort)(*cp++ << 8); +#if SIZEOF_IX_SHORT > X_SIZEOF_SHORT + if (*ip & 0x8000) + { + /* extern is negative */ + *ip |= (~(0xffff)); /* N.B. Assumes "twos complement" */ + } +#endif + *ip = (ix_ushort)(*ip | *cp); +} + +static void +put_ix_ushort(void *xp, const ix_ushort *ip) +{ + uchar *cp = (uchar *) xp; + *cp++ = (uchar)((*ip) >> 8); + *cp = (uchar)((*ip) & 0xff); +} + +static int +#line 956 +ncx_get_ushort_schar(const void *xp, schar *ip) +#line 956 +{ +#line 956 + int err=NC_NOERR; +#line 956 + ix_ushort xx = 0; +#line 956 + get_ix_ushort(xp, &xx); +#line 956 + +#line 956 +#if IX_USHORT_MAX > SCHAR_MAX +#line 956 + if (xx > SCHAR_MAX) { +#line 956 +#ifdef ERANGE_FILL +#line 956 + *ip = NC_FILL_BYTE; +#line 956 + return NC_ERANGE; +#line 956 +#else +#line 956 + err = NC_ERANGE; +#line 956 +#endif +#line 956 + } +#line 956 +#endif +#line 956 + +#line 956 + +#line 956 + *ip = (schar) xx; +#line 956 + return err; +#line 956 +} +#line 956 + +static int +#line 957 +ncx_get_ushort_short(const void *xp, short *ip) +#line 957 +{ +#line 957 + int err=NC_NOERR; +#line 957 + ix_ushort xx = 0; +#line 957 + get_ix_ushort(xp, &xx); +#line 957 + +#line 957 +#if IX_USHORT_MAX > SHORT_MAX +#line 957 + if (xx > SHORT_MAX) { +#line 957 +#ifdef ERANGE_FILL +#line 957 + *ip = NC_FILL_SHORT; +#line 957 + return NC_ERANGE; +#line 957 +#else +#line 957 + err = NC_ERANGE; +#line 957 +#endif +#line 957 + } +#line 957 +#endif +#line 957 + +#line 957 + +#line 957 + *ip = (short) xx; +#line 957 + return err; +#line 957 +} +#line 957 + +static int +#line 958 +ncx_get_ushort_int(const void *xp, int *ip) +#line 958 +{ +#line 958 + int err=NC_NOERR; +#line 958 + ix_ushort xx = 0; +#line 958 + get_ix_ushort(xp, &xx); +#line 958 + +#line 958 +#if IX_USHORT_MAX > INT_MAX +#line 958 + if (xx > INT_MAX) { +#line 958 +#ifdef ERANGE_FILL +#line 958 + *ip = NC_FILL_INT; +#line 958 + return NC_ERANGE; +#line 958 +#else +#line 958 + err = NC_ERANGE; +#line 958 +#endif +#line 958 + } +#line 958 +#endif +#line 958 + +#line 958 + +#line 958 + *ip = (int) xx; +#line 958 + return err; +#line 958 +} +#line 958 + +static int +#line 959 +ncx_get_ushort_long(const void *xp, long *ip) +#line 959 +{ +#line 959 + int err=NC_NOERR; +#line 959 + ix_ushort xx = 0; +#line 959 + get_ix_ushort(xp, &xx); +#line 959 + +#line 959 +#if IX_USHORT_MAX > LONG_MAX +#line 959 + if (xx > LONG_MAX) { +#line 959 +#ifdef ERANGE_FILL +#line 959 + *ip = NC_FILL_INT; +#line 959 + return NC_ERANGE; +#line 959 +#else +#line 959 + err = NC_ERANGE; +#line 959 +#endif +#line 959 + } +#line 959 +#endif +#line 959 + +#line 959 + +#line 959 + *ip = (long) xx; +#line 959 + return err; +#line 959 +} +#line 959 + +static int +#line 960 +ncx_get_ushort_longlong(const void *xp, longlong *ip) +#line 960 +{ +#line 960 + int err=NC_NOERR; +#line 960 + ix_ushort xx = 0; +#line 960 + get_ix_ushort(xp, &xx); +#line 960 + +#line 960 +#if IX_USHORT_MAX > LONGLONG_MAX +#line 960 + if (xx > LONGLONG_MAX) { +#line 960 +#ifdef ERANGE_FILL +#line 960 + *ip = NC_FILL_INT64; +#line 960 + return NC_ERANGE; +#line 960 +#else +#line 960 + err = NC_ERANGE; +#line 960 +#endif +#line 960 + } +#line 960 +#endif +#line 960 + +#line 960 + +#line 960 + *ip = (longlong) xx; +#line 960 + return err; +#line 960 +} +#line 960 + +static int +#line 961 +ncx_get_ushort_ushort(const void *xp, ushort *ip) +#line 961 +{ +#line 961 + int err=NC_NOERR; +#line 961 +#if SIZEOF_IX_USHORT == SIZEOF_USHORT && IX_USHORT_MAX == USHORT_MAX +#line 961 + get_ix_ushort(xp, (ix_ushort *)ip); +#line 961 +#else +#line 961 + ix_ushort xx = 0; +#line 961 + get_ix_ushort(xp, &xx); +#line 961 + +#line 961 +#if IX_USHORT_MAX > USHORT_MAX +#line 961 + if (xx > USHORT_MAX) { +#line 961 +#ifdef ERANGE_FILL +#line 961 + *ip = NC_FILL_USHORT; +#line 961 + return NC_ERANGE; +#line 961 +#else +#line 961 + err = NC_ERANGE; +#line 961 +#endif +#line 961 + } +#line 961 +#endif +#line 961 + +#line 961 + +#line 961 + *ip = (ushort) xx; +#line 961 +#endif +#line 961 + return err; +#line 961 +} +#line 961 + +static int +#line 962 +ncx_get_ushort_uchar(const void *xp, uchar *ip) +#line 962 +{ +#line 962 + int err=NC_NOERR; +#line 962 +#if SIZEOF_IX_USHORT == SIZEOF_UCHAR && IX_USHORT_MAX == UCHAR_MAX +#line 962 + get_ix_ushort(xp, (ix_ushort *)ip); +#line 962 +#else +#line 962 + ix_ushort xx = 0; +#line 962 + get_ix_ushort(xp, &xx); +#line 962 + +#line 962 +#if IX_USHORT_MAX > UCHAR_MAX +#line 962 + if (xx > UCHAR_MAX) { +#line 962 +#ifdef ERANGE_FILL +#line 962 + *ip = NC_FILL_UBYTE; +#line 962 + return NC_ERANGE; +#line 962 +#else +#line 962 + err = NC_ERANGE; +#line 962 +#endif +#line 962 + } +#line 962 +#endif +#line 962 + +#line 962 + +#line 962 + *ip = (uchar) xx; +#line 962 +#endif +#line 962 + return err; +#line 962 +} +#line 962 + +static int +#line 963 +ncx_get_ushort_uint(const void *xp, uint *ip) +#line 963 +{ +#line 963 + int err=NC_NOERR; +#line 963 +#if SIZEOF_IX_USHORT == SIZEOF_UINT && IX_USHORT_MAX == UINT_MAX +#line 963 + get_ix_ushort(xp, (ix_ushort *)ip); +#line 963 +#else +#line 963 + ix_ushort xx = 0; +#line 963 + get_ix_ushort(xp, &xx); +#line 963 + +#line 963 +#if IX_USHORT_MAX > UINT_MAX +#line 963 + if (xx > UINT_MAX) { +#line 963 +#ifdef ERANGE_FILL +#line 963 + *ip = NC_FILL_UINT; +#line 963 + return NC_ERANGE; +#line 963 +#else +#line 963 + err = NC_ERANGE; +#line 963 +#endif +#line 963 + } +#line 963 +#endif +#line 963 + +#line 963 + +#line 963 + *ip = (uint) xx; +#line 963 +#endif +#line 963 + return err; +#line 963 +} +#line 963 + +static int +#line 964 +ncx_get_ushort_ulonglong(const void *xp, ulonglong *ip) +#line 964 +{ +#line 964 + int err=NC_NOERR; +#line 964 +#if SIZEOF_IX_USHORT == SIZEOF_ULONGLONG && IX_USHORT_MAX == ULONGLONG_MAX +#line 964 + get_ix_ushort(xp, (ix_ushort *)ip); +#line 964 +#else +#line 964 + ix_ushort xx = 0; +#line 964 + get_ix_ushort(xp, &xx); +#line 964 + +#line 964 +#if IX_USHORT_MAX > ULONGLONG_MAX +#line 964 + if (xx > ULONGLONG_MAX) { +#line 964 +#ifdef ERANGE_FILL +#line 964 + *ip = NC_FILL_UINT64; +#line 964 + return NC_ERANGE; +#line 964 +#else +#line 964 + err = NC_ERANGE; +#line 964 +#endif +#line 964 + } +#line 964 +#endif +#line 964 + +#line 964 + +#line 964 + *ip = (ulonglong) xx; +#line 964 +#endif +#line 964 + return err; +#line 964 +} +#line 964 + +static int +#line 965 +ncx_get_ushort_float(const void *xp, float *ip) +#line 965 +{ +#line 965 + ix_ushort xx = 0; +#line 965 + get_ix_ushort(xp, &xx); +#line 965 + *ip = (float)xx; +#line 965 + return NC_NOERR; +#line 965 +} +#line 965 + +static int +#line 966 +ncx_get_ushort_double(const void *xp, double *ip) +#line 966 +{ +#line 966 + ix_ushort xx = 0; +#line 966 + get_ix_ushort(xp, &xx); +#line 966 + *ip = (double)xx; +#line 966 + return NC_NOERR; +#line 966 +} +#line 966 + + +static int +ncx_put_ushort_schar(void *xp, const schar *ip, void *fillp) +{ + int err=NC_NOERR; + uchar *cp; + if (*ip < 0) { +#ifdef ERANGE_FILL + if (fillp != NULL) memcpy(xp, fillp, 2); +#ifndef WORDS_BIGENDIAN + swapn2b(xp, xp, 1); +#endif + return NC_ERANGE; +#else + err = NC_ERANGE; +#endif + } + + cp = (uchar *) xp; + if (*ip & 0x80) + *cp++ = 0xff; + else + *cp++ = 0; + *cp = (uchar)*ip; + + return err; +} + +static int +ncx_put_ushort_uchar(void *xp, const uchar *ip, void *fillp) +{ + uchar *cp = (uchar *) xp; + *cp++ = 0; + *cp = *ip; + return NC_NOERR; +} + +static int +#line 1004 +ncx_put_ushort_short(void *xp, const short *ip, void *fillp) +#line 1004 +{ +#line 1004 + int err=NC_NOERR; +#line 1004 + ix_ushort xx = NC_FILL_USHORT; +#line 1004 + +#line 1004 +#if IX_USHORT_MAX < SHORT_MAX +#line 1004 + if (*ip > IX_USHORT_MAX) { +#line 1004 + +#line 1004 +#ifdef ERANGE_FILL +#line 1004 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1004 +#endif +#line 1004 + err = NC_ERANGE; +#line 1004 + } +#line 1004 +#ifdef ERANGE_FILL +#line 1004 + else +#line 1004 +#endif +#line 1004 +#endif +#line 1004 + if (*ip < 0) { +#line 1004 + +#line 1004 +#ifdef ERANGE_FILL +#line 1004 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1004 +#endif +#line 1004 + err = NC_ERANGE; /* because xp is unsigned */ +#line 1004 + } +#line 1004 +#ifdef ERANGE_FILL +#line 1004 + else +#line 1004 +#endif +#line 1004 + xx = (ix_ushort)*ip; +#line 1004 + +#line 1004 + put_ix_ushort(xp, &xx); +#line 1004 + return err; +#line 1004 +} +#line 1004 + +static int +#line 1005 +ncx_put_ushort_int(void *xp, const int *ip, void *fillp) +#line 1005 +{ +#line 1005 + int err=NC_NOERR; +#line 1005 + ix_ushort xx = NC_FILL_USHORT; +#line 1005 + +#line 1005 +#if IX_USHORT_MAX < INT_MAX +#line 1005 + if (*ip > IX_USHORT_MAX) { +#line 1005 + +#line 1005 +#ifdef ERANGE_FILL +#line 1005 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1005 +#endif +#line 1005 + err = NC_ERANGE; +#line 1005 + } +#line 1005 +#ifdef ERANGE_FILL +#line 1005 + else +#line 1005 +#endif +#line 1005 +#endif +#line 1005 + if (*ip < 0) { +#line 1005 + +#line 1005 +#ifdef ERANGE_FILL +#line 1005 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1005 +#endif +#line 1005 + err = NC_ERANGE; /* because xp is unsigned */ +#line 1005 + } +#line 1005 +#ifdef ERANGE_FILL +#line 1005 + else +#line 1005 +#endif +#line 1005 + xx = (ix_ushort)*ip; +#line 1005 + +#line 1005 + put_ix_ushort(xp, &xx); +#line 1005 + return err; +#line 1005 +} +#line 1005 + +static int +#line 1006 +ncx_put_ushort_long(void *xp, const long *ip, void *fillp) +#line 1006 +{ +#line 1006 + int err=NC_NOERR; +#line 1006 + ix_ushort xx = NC_FILL_USHORT; +#line 1006 + +#line 1006 +#if IX_USHORT_MAX < LONG_MAX +#line 1006 + if (*ip > IX_USHORT_MAX) { +#line 1006 + +#line 1006 +#ifdef ERANGE_FILL +#line 1006 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1006 +#endif +#line 1006 + err = NC_ERANGE; +#line 1006 + } +#line 1006 +#ifdef ERANGE_FILL +#line 1006 + else +#line 1006 +#endif +#line 1006 +#endif +#line 1006 + if (*ip < 0) { +#line 1006 + +#line 1006 +#ifdef ERANGE_FILL +#line 1006 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1006 +#endif +#line 1006 + err = NC_ERANGE; /* because xp is unsigned */ +#line 1006 + } +#line 1006 +#ifdef ERANGE_FILL +#line 1006 + else +#line 1006 +#endif +#line 1006 + xx = (ix_ushort)*ip; +#line 1006 + +#line 1006 + put_ix_ushort(xp, &xx); +#line 1006 + return err; +#line 1006 +} +#line 1006 + +static int +#line 1007 +ncx_put_ushort_longlong(void *xp, const longlong *ip, void *fillp) +#line 1007 +{ +#line 1007 + int err=NC_NOERR; +#line 1007 + ix_ushort xx = NC_FILL_USHORT; +#line 1007 + +#line 1007 +#if IX_USHORT_MAX < LONGLONG_MAX +#line 1007 + if (*ip > IX_USHORT_MAX) { +#line 1007 + +#line 1007 +#ifdef ERANGE_FILL +#line 1007 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1007 +#endif +#line 1007 + err = NC_ERANGE; +#line 1007 + } +#line 1007 +#ifdef ERANGE_FILL +#line 1007 + else +#line 1007 +#endif +#line 1007 +#endif +#line 1007 + if (*ip < 0) { +#line 1007 + +#line 1007 +#ifdef ERANGE_FILL +#line 1007 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1007 +#endif +#line 1007 + err = NC_ERANGE; /* because xp is unsigned */ +#line 1007 + } +#line 1007 +#ifdef ERANGE_FILL +#line 1007 + else +#line 1007 +#endif +#line 1007 + xx = (ix_ushort)*ip; +#line 1007 + +#line 1007 + put_ix_ushort(xp, &xx); +#line 1007 + return err; +#line 1007 +} +#line 1007 + +static int +#line 1008 +ncx_put_ushort_ushort(void *xp, const ushort *ip, void *fillp) +#line 1008 +{ +#line 1008 + int err=NC_NOERR; +#line 1008 +#if SIZEOF_IX_USHORT == SIZEOF_USHORT && IX_USHORT_MAX == USHORT_MAX +#line 1008 + put_ix_ushort(xp, (const ix_ushort *)ip); +#line 1008 +#else +#line 1008 + ix_ushort xx = NC_FILL_USHORT; +#line 1008 + +#line 1008 +#if IX_USHORT_MAX < USHORT_MAX +#line 1008 + if (*ip > IX_USHORT_MAX) { +#line 1008 + +#line 1008 +#ifdef ERANGE_FILL +#line 1008 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1008 +#endif +#line 1008 + err = NC_ERANGE; +#line 1008 + } +#line 1008 +#ifdef ERANGE_FILL +#line 1008 + else +#line 1008 +#endif +#line 1008 +#endif +#line 1008 + xx = (ix_ushort)*ip; +#line 1008 + +#line 1008 + put_ix_ushort(xp, &xx); +#line 1008 +#endif +#line 1008 + return err; +#line 1008 +} +#line 1008 + +static int +#line 1009 +ncx_put_ushort_uint(void *xp, const uint *ip, void *fillp) +#line 1009 +{ +#line 1009 + int err=NC_NOERR; +#line 1009 +#if SIZEOF_IX_USHORT == SIZEOF_UINT && IX_USHORT_MAX == UINT_MAX +#line 1009 + put_ix_ushort(xp, (const ix_ushort *)ip); +#line 1009 +#else +#line 1009 + ix_ushort xx = NC_FILL_USHORT; +#line 1009 + +#line 1009 +#if IX_USHORT_MAX < UINT_MAX +#line 1009 + if (*ip > IX_USHORT_MAX) { +#line 1009 + +#line 1009 +#ifdef ERANGE_FILL +#line 1009 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1009 +#endif +#line 1009 + err = NC_ERANGE; +#line 1009 + } +#line 1009 +#ifdef ERANGE_FILL +#line 1009 + else +#line 1009 +#endif +#line 1009 +#endif +#line 1009 + xx = (ix_ushort)*ip; +#line 1009 + +#line 1009 + put_ix_ushort(xp, &xx); +#line 1009 +#endif +#line 1009 + return err; +#line 1009 +} +#line 1009 + +static int +#line 1010 +ncx_put_ushort_ulonglong(void *xp, const ulonglong *ip, void *fillp) +#line 1010 +{ +#line 1010 + int err=NC_NOERR; +#line 1010 +#if SIZEOF_IX_USHORT == SIZEOF_ULONGLONG && IX_USHORT_MAX == ULONGLONG_MAX +#line 1010 + put_ix_ushort(xp, (const ix_ushort *)ip); +#line 1010 +#else +#line 1010 + ix_ushort xx = NC_FILL_USHORT; +#line 1010 + +#line 1010 +#if IX_USHORT_MAX < ULONGLONG_MAX +#line 1010 + if (*ip > IX_USHORT_MAX) { +#line 1010 + +#line 1010 +#ifdef ERANGE_FILL +#line 1010 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1010 +#endif +#line 1010 + err = NC_ERANGE; +#line 1010 + } +#line 1010 +#ifdef ERANGE_FILL +#line 1010 + else +#line 1010 +#endif +#line 1010 +#endif +#line 1010 + xx = (ix_ushort)*ip; +#line 1010 + +#line 1010 + put_ix_ushort(xp, &xx); +#line 1010 +#endif +#line 1010 + return err; +#line 1010 +} +#line 1010 + +static int +#line 1011 +ncx_put_ushort_float(void *xp, const float *ip, void *fillp) +#line 1011 +{ +#line 1011 + int err=NC_NOERR; +#line 1011 + ix_ushort xx = NC_FILL_USHORT; +#line 1011 + +#line 1011 + if (*ip > (double)X_USHORT_MAX || *ip < 0) { +#line 1011 + +#line 1011 +#ifdef ERANGE_FILL +#line 1011 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1011 +#endif +#line 1011 + err = NC_ERANGE; +#line 1011 + } +#line 1011 +#ifdef ERANGE_FILL +#line 1011 + else +#line 1011 +#endif +#line 1011 + xx = (ix_ushort)*ip; +#line 1011 + +#line 1011 + put_ix_ushort(xp, &xx); +#line 1011 + return err; +#line 1011 +} +#line 1011 + +static int +#line 1012 +ncx_put_ushort_double(void *xp, const double *ip, void *fillp) +#line 1012 +{ +#line 1012 + int err=NC_NOERR; +#line 1012 + ix_ushort xx = NC_FILL_USHORT; +#line 1012 + +#line 1012 + if (*ip > X_USHORT_MAX || *ip < 0) { +#line 1012 + +#line 1012 +#ifdef ERANGE_FILL +#line 1012 + if (fillp != NULL) memcpy(&xx, fillp, 2); +#line 1012 +#endif +#line 1012 + err = NC_ERANGE; +#line 1012 + } +#line 1012 +#ifdef ERANGE_FILL +#line 1012 + else +#line 1012 +#endif +#line 1012 + xx = (ix_ushort)*ip; +#line 1012 + +#line 1012 + put_ix_ushort(xp, &xx); +#line 1012 + return err; +#line 1012 +} +#line 1012 + + +/* external NC_INT ----------------------------------------------------------*/ + +#if SHORT_MAX == X_INT_MAX +typedef short ix_int; +#define SIZEOF_IX_INT SIZEOF_SHORT +#define IX_INT_MAX SHORT_MAX +#elif INT_MAX >= X_INT_MAX +typedef int ix_int; +#define SIZEOF_IX_INT SIZEOF_INT +#define IX_INT_MAX INT_MAX +#elif LONG_MAX >= X_INT_MAX +typedef long ix_int; +#define SIZEOF_IX_INT SIZEOF_LONG +#define IX_INT_MAX LONG_MAX +#else +#error "ix_int implementation" +#endif + + +static void +get_ix_int(const void *xp, ix_int *ip) +{ + const uchar *cp = (const uchar *) xp; + +#if INT_MAX >= X_INT_MAX + *ip = (ix_int)((unsigned)(*cp++) << 24); +#else + *ip = *cp++ << 24; +#endif +#if SIZEOF_IX_INT > X_SIZEOF_INT + if (*ip & 0x80000000) + { + /* extern is negative */ + *ip |= (~(0xffffffff)); /* N.B. Assumes "twos complement" */ + } +#endif + *ip |= (*cp++ << 16); + *ip |= (*cp++ << 8); + *ip |= *cp; +} + +static void +put_ix_int(void *xp, const ix_int *ip) +{ + uchar *cp = (uchar *) xp; + + *cp++ = (uchar)( (*ip) >> 24); + *cp++ = (uchar)(((*ip) & 0x00ff0000) >> 16); + *cp++ = (uchar)(((*ip) & 0x0000ff00) >> 8); + *cp = (uchar)( (*ip) & 0x000000ff); +} + +#if X_SIZEOF_INT != SIZEOF_INT +static int +#line 1067 +ncx_get_int_int(const void *xp, int *ip) +#line 1067 +{ +#line 1067 + int err=NC_NOERR; +#line 1067 +#if SIZEOF_IX_INT == SIZEOF_INT && IX_INT_MAX == INT_MAX +#line 1067 + get_ix_int(xp, (ix_int *)ip); +#line 1067 +#else +#line 1067 + ix_int xx = 0; +#line 1067 + get_ix_int(xp, &xx); +#line 1067 + +#line 1067 +#if IX_INT_MAX > INT_MAX +#line 1067 + if (xx > INT_MAX || xx < INT_MIN) { +#line 1067 +#ifdef ERANGE_FILL +#line 1067 + *ip = NC_FILL_INT; +#line 1067 + return NC_ERANGE; +#line 1067 +#else +#line 1067 + err = NC_ERANGE; +#line 1067 +#endif +#line 1067 + } +#line 1067 +#endif +#line 1067 + +#line 1067 + +#line 1067 + *ip = (int) xx; +#line 1067 +#endif +#line 1067 + return err; +#line 1067 +} +#line 1067 + +#endif +static int +#line 1069 +ncx_get_int_schar(const void *xp, schar *ip) +#line 1069 +{ +#line 1069 + int err=NC_NOERR; +#line 1069 + ix_int xx = 0; +#line 1069 + get_ix_int(xp, &xx); +#line 1069 + +#line 1069 +#if IX_INT_MAX > SCHAR_MAX +#line 1069 + if (xx > SCHAR_MAX || xx < SCHAR_MIN) { +#line 1069 +#ifdef ERANGE_FILL +#line 1069 + *ip = NC_FILL_BYTE; +#line 1069 + return NC_ERANGE; +#line 1069 +#else +#line 1069 + err = NC_ERANGE; +#line 1069 +#endif +#line 1069 + } +#line 1069 +#endif +#line 1069 + +#line 1069 + +#line 1069 + *ip = (schar) xx; +#line 1069 + return err; +#line 1069 +} +#line 1069 + +static int +#line 1070 +ncx_get_int_short(const void *xp, short *ip) +#line 1070 +{ +#line 1070 + int err=NC_NOERR; +#line 1070 +#if SIZEOF_IX_INT == SIZEOF_SHORT && IX_INT_MAX == SHORT_MAX +#line 1070 + get_ix_int(xp, (ix_int *)ip); +#line 1070 +#else +#line 1070 + ix_int xx = 0; +#line 1070 + get_ix_int(xp, &xx); +#line 1070 + +#line 1070 +#if IX_INT_MAX > SHORT_MAX +#line 1070 + if (xx > SHORT_MAX || xx < SHORT_MIN) { +#line 1070 +#ifdef ERANGE_FILL +#line 1070 + *ip = NC_FILL_SHORT; +#line 1070 + return NC_ERANGE; +#line 1070 +#else +#line 1070 + err = NC_ERANGE; +#line 1070 +#endif +#line 1070 + } +#line 1070 +#endif +#line 1070 + +#line 1070 + +#line 1070 + *ip = (short) xx; +#line 1070 +#endif +#line 1070 + return err; +#line 1070 +} +#line 1070 + +static int +#line 1071 +ncx_get_int_long(const void *xp, long *ip) +#line 1071 +{ +#line 1071 + int err=NC_NOERR; +#line 1071 +#if SIZEOF_IX_INT == SIZEOF_LONG && IX_INT_MAX == LONG_MAX +#line 1071 + get_ix_int(xp, (ix_int *)ip); +#line 1071 +#else +#line 1071 + ix_int xx = 0; +#line 1071 + get_ix_int(xp, &xx); +#line 1071 + +#line 1071 +#if IX_INT_MAX > LONG_MAX +#line 1071 + if (xx > LONG_MAX || xx < LONG_MIN) { +#line 1071 +#ifdef ERANGE_FILL +#line 1071 + *ip = NC_FILL_INT; +#line 1071 + return NC_ERANGE; +#line 1071 +#else +#line 1071 + err = NC_ERANGE; +#line 1071 +#endif +#line 1071 + } +#line 1071 +#endif +#line 1071 + +#line 1071 + +#line 1071 + *ip = (long) xx; +#line 1071 +#endif +#line 1071 + return err; +#line 1071 +} +#line 1071 + +static int +#line 1072 +ncx_get_int_longlong(const void *xp, longlong *ip) +#line 1072 +{ +#line 1072 + int err=NC_NOERR; +#line 1072 +#if SIZEOF_IX_INT == SIZEOF_LONGLONG && IX_INT_MAX == LONGLONG_MAX +#line 1072 + get_ix_int(xp, (ix_int *)ip); +#line 1072 +#else +#line 1072 + ix_int xx = 0; +#line 1072 + get_ix_int(xp, &xx); +#line 1072 + +#line 1072 +#if IX_INT_MAX > LONGLONG_MAX +#line 1072 + if (xx > LONGLONG_MAX || xx < LONGLONG_MIN) { +#line 1072 +#ifdef ERANGE_FILL +#line 1072 + *ip = NC_FILL_INT64; +#line 1072 + return NC_ERANGE; +#line 1072 +#else +#line 1072 + err = NC_ERANGE; +#line 1072 +#endif +#line 1072 + } +#line 1072 +#endif +#line 1072 + +#line 1072 + +#line 1072 + *ip = (longlong) xx; +#line 1072 +#endif +#line 1072 + return err; +#line 1072 +} +#line 1072 + +static int +#line 1073 +ncx_get_int_ushort(const void *xp, ushort *ip) +#line 1073 +{ +#line 1073 + int err=NC_NOERR; +#line 1073 + ix_int xx = 0; +#line 1073 + get_ix_int(xp, &xx); +#line 1073 + +#line 1073 +#if IX_INT_MAX > USHORT_MAX +#line 1073 + if (xx > USHORT_MAX) { +#line 1073 +#ifdef ERANGE_FILL +#line 1073 + *ip = NC_FILL_USHORT; +#line 1073 + return NC_ERANGE; +#line 1073 +#else +#line 1073 + err = NC_ERANGE; +#line 1073 +#endif +#line 1073 + } +#line 1073 +#endif +#line 1073 + +#line 1073 + if (xx < 0) { +#line 1073 +#ifdef ERANGE_FILL +#line 1073 + *ip = NC_FILL_USHORT; +#line 1073 + return NC_ERANGE; +#line 1073 +#else +#line 1073 + err = NC_ERANGE; /* because ip is unsigned */ +#line 1073 +#endif +#line 1073 + } +#line 1073 + *ip = (ushort) xx; +#line 1073 + return err; +#line 1073 +} +#line 1073 + +static int +#line 1074 +ncx_get_int_uchar(const void *xp, uchar *ip) +#line 1074 +{ +#line 1074 + int err=NC_NOERR; +#line 1074 + ix_int xx = 0; +#line 1074 + get_ix_int(xp, &xx); +#line 1074 + +#line 1074 +#if IX_INT_MAX > UCHAR_MAX +#line 1074 + if (xx > UCHAR_MAX) { +#line 1074 +#ifdef ERANGE_FILL +#line 1074 + *ip = NC_FILL_UBYTE; +#line 1074 + return NC_ERANGE; +#line 1074 +#else +#line 1074 + err = NC_ERANGE; +#line 1074 +#endif +#line 1074 + } +#line 1074 +#endif +#line 1074 + +#line 1074 + if (xx < 0) { +#line 1074 +#ifdef ERANGE_FILL +#line 1074 + *ip = NC_FILL_UBYTE; +#line 1074 + return NC_ERANGE; +#line 1074 +#else +#line 1074 + err = NC_ERANGE; /* because ip is unsigned */ +#line 1074 +#endif +#line 1074 + } +#line 1074 + *ip = (uchar) xx; +#line 1074 + return err; +#line 1074 +} +#line 1074 + +static int +#line 1075 +ncx_get_int_uint(const void *xp, uint *ip) +#line 1075 +{ +#line 1075 + int err=NC_NOERR; +#line 1075 + ix_int xx = 0; +#line 1075 + get_ix_int(xp, &xx); +#line 1075 + +#line 1075 +#if IX_INT_MAX > UINT_MAX +#line 1075 + if (xx > UINT_MAX) { +#line 1075 +#ifdef ERANGE_FILL +#line 1075 + *ip = NC_FILL_UINT; +#line 1075 + return NC_ERANGE; +#line 1075 +#else +#line 1075 + err = NC_ERANGE; +#line 1075 +#endif +#line 1075 + } +#line 1075 +#endif +#line 1075 + +#line 1075 + if (xx < 0) { +#line 1075 +#ifdef ERANGE_FILL +#line 1075 + *ip = NC_FILL_UINT; +#line 1075 + return NC_ERANGE; +#line 1075 +#else +#line 1075 + err = NC_ERANGE; /* because ip is unsigned */ +#line 1075 +#endif +#line 1075 + } +#line 1075 + *ip = (uint) xx; +#line 1075 + return err; +#line 1075 +} +#line 1075 + +static int +#line 1076 +ncx_get_int_ulonglong(const void *xp, ulonglong *ip) +#line 1076 +{ +#line 1076 + int err=NC_NOERR; +#line 1076 + ix_int xx = 0; +#line 1076 + get_ix_int(xp, &xx); +#line 1076 + +#line 1076 +#if IX_INT_MAX > ULONGLONG_MAX +#line 1076 + if (xx > ULONGLONG_MAX) { +#line 1076 +#ifdef ERANGE_FILL +#line 1076 + *ip = NC_FILL_UINT64; +#line 1076 + return NC_ERANGE; +#line 1076 +#else +#line 1076 + err = NC_ERANGE; +#line 1076 +#endif +#line 1076 + } +#line 1076 +#endif +#line 1076 + +#line 1076 + if (xx < 0) { +#line 1076 +#ifdef ERANGE_FILL +#line 1076 + *ip = NC_FILL_UINT64; +#line 1076 + return NC_ERANGE; +#line 1076 +#else +#line 1076 + err = NC_ERANGE; /* because ip is unsigned */ +#line 1076 +#endif +#line 1076 + } +#line 1076 + *ip = (ulonglong) xx; +#line 1076 + return err; +#line 1076 +} +#line 1076 + +static int +#line 1077 +ncx_get_int_float(const void *xp, float *ip) +#line 1077 +{ +#line 1077 + ix_int xx = 0; +#line 1077 + get_ix_int(xp, &xx); +#line 1077 + *ip = (float)xx; +#line 1077 + return NC_NOERR; +#line 1077 +} +#line 1077 + +static int +#line 1078 +ncx_get_int_double(const void *xp, double *ip) +#line 1078 +{ +#line 1078 + ix_int xx = 0; +#line 1078 + get_ix_int(xp, &xx); +#line 1078 + *ip = (double)xx; +#line 1078 + return NC_NOERR; +#line 1078 +} +#line 1078 + + +static int +ncx_put_int_schar(void *xp, const schar *ip, void *fillp) +{ + uchar *cp = (uchar *) xp; + if (*ip & 0x80) + { + *cp++ = 0xff; + *cp++ = 0xff; + *cp++ = 0xff; + } + else + { + *cp++ = 0x00; + *cp++ = 0x00; + *cp++ = 0x00; + } + *cp = (uchar)*ip; + return NC_NOERR; +} + +static int +ncx_put_int_uchar(void *xp, const uchar *ip, void *fillp) +{ + uchar *cp = (uchar *) xp; + *cp++ = 0x00; + *cp++ = 0x00; + *cp++ = 0x00; + *cp = *ip; + return NC_NOERR; +} + +#if X_SIZEOF_INT != SIZEOF_INT +static int +#line 1112 +ncx_put_int_int(void *xp, const int *ip, void *fillp) +#line 1112 +{ +#line 1112 + int err=NC_NOERR; +#line 1112 +#if SIZEOF_IX_INT == SIZEOF_INT && IX_INT_MAX == INT_MAX +#line 1112 + put_ix_int(xp, (const ix_int *)ip); +#line 1112 +#else +#line 1112 + ix_int xx = NC_FILL_INT; +#line 1112 + +#line 1112 +#if IX_INT_MAX < INT_MAX +#line 1112 + if (*ip > IX_INT_MAX || *ip < X_INT_MIN) { +#line 1112 + +#line 1112 +#ifdef ERANGE_FILL +#line 1112 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1112 +#endif +#line 1112 + err = NC_ERANGE; +#line 1112 + } +#line 1112 +#ifdef ERANGE_FILL +#line 1112 + else +#line 1112 +#endif +#line 1112 +#endif +#line 1112 + xx = (ix_int)*ip; +#line 1112 + +#line 1112 + put_ix_int(xp, &xx); +#line 1112 +#endif +#line 1112 + return err; +#line 1112 +} +#line 1112 + +#endif +static int +#line 1114 +ncx_put_int_short(void *xp, const short *ip, void *fillp) +#line 1114 +{ +#line 1114 + int err=NC_NOERR; +#line 1114 +#if SIZEOF_IX_INT == SIZEOF_SHORT && IX_INT_MAX == SHORT_MAX +#line 1114 + put_ix_int(xp, (const ix_int *)ip); +#line 1114 +#else +#line 1114 + ix_int xx = NC_FILL_INT; +#line 1114 + +#line 1114 +#if IX_INT_MAX < SHORT_MAX +#line 1114 + if (*ip > IX_INT_MAX || *ip < X_INT_MIN) { +#line 1114 + +#line 1114 +#ifdef ERANGE_FILL +#line 1114 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1114 +#endif +#line 1114 + err = NC_ERANGE; +#line 1114 + } +#line 1114 +#ifdef ERANGE_FILL +#line 1114 + else +#line 1114 +#endif +#line 1114 +#endif +#line 1114 + xx = (ix_int)*ip; +#line 1114 + +#line 1114 + put_ix_int(xp, &xx); +#line 1114 +#endif +#line 1114 + return err; +#line 1114 +} +#line 1114 + +static int +#line 1115 +ncx_put_int_long(void *xp, const long *ip, void *fillp) +#line 1115 +{ +#line 1115 + int err=NC_NOERR; +#line 1115 +#if SIZEOF_IX_INT == SIZEOF_LONG && IX_INT_MAX == LONG_MAX +#line 1115 + put_ix_int(xp, (const ix_int *)ip); +#line 1115 +#else +#line 1115 + ix_int xx = NC_FILL_INT; +#line 1115 + +#line 1115 +#if IX_INT_MAX < LONG_MAX +#line 1115 + if (*ip > IX_INT_MAX || *ip < X_INT_MIN) { +#line 1115 + +#line 1115 +#ifdef ERANGE_FILL +#line 1115 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1115 +#endif +#line 1115 + err = NC_ERANGE; +#line 1115 + } +#line 1115 +#ifdef ERANGE_FILL +#line 1115 + else +#line 1115 +#endif +#line 1115 +#endif +#line 1115 + xx = (ix_int)*ip; +#line 1115 + +#line 1115 + put_ix_int(xp, &xx); +#line 1115 +#endif +#line 1115 + return err; +#line 1115 +} +#line 1115 + +static int +#line 1116 +ncx_put_int_longlong(void *xp, const longlong *ip, void *fillp) +#line 1116 +{ +#line 1116 + int err=NC_NOERR; +#line 1116 +#if SIZEOF_IX_INT == SIZEOF_LONGLONG && IX_INT_MAX == LONGLONG_MAX +#line 1116 + put_ix_int(xp, (const ix_int *)ip); +#line 1116 +#else +#line 1116 + ix_int xx = NC_FILL_INT; +#line 1116 + +#line 1116 +#if IX_INT_MAX < LONGLONG_MAX +#line 1116 + if (*ip > IX_INT_MAX || *ip < X_INT_MIN) { +#line 1116 + +#line 1116 +#ifdef ERANGE_FILL +#line 1116 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1116 +#endif +#line 1116 + err = NC_ERANGE; +#line 1116 + } +#line 1116 +#ifdef ERANGE_FILL +#line 1116 + else +#line 1116 +#endif +#line 1116 +#endif +#line 1116 + xx = (ix_int)*ip; +#line 1116 + +#line 1116 + put_ix_int(xp, &xx); +#line 1116 +#endif +#line 1116 + return err; +#line 1116 +} +#line 1116 + +static int +#line 1117 +ncx_put_int_ushort(void *xp, const ushort *ip, void *fillp) +#line 1117 +{ +#line 1117 + int err=NC_NOERR; +#line 1117 + ix_int xx = NC_FILL_INT; +#line 1117 + +#line 1117 +#if IX_INT_MAX < USHORT_MAX +#line 1117 + if (*ip > IX_INT_MAX) { +#line 1117 + +#line 1117 +#ifdef ERANGE_FILL +#line 1117 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1117 +#endif +#line 1117 + err = NC_ERANGE; +#line 1117 + } +#line 1117 +#ifdef ERANGE_FILL +#line 1117 + else +#line 1117 +#endif +#line 1117 +#endif +#line 1117 + xx = (ix_int)*ip; +#line 1117 + +#line 1117 + put_ix_int(xp, &xx); +#line 1117 + return err; +#line 1117 +} +#line 1117 + +static int +#line 1118 +ncx_put_int_uint(void *xp, const uint *ip, void *fillp) +#line 1118 +{ +#line 1118 + int err=NC_NOERR; +#line 1118 + ix_int xx = NC_FILL_INT; +#line 1118 + +#line 1118 +#if IX_INT_MAX < UINT_MAX +#line 1118 + if (*ip > IX_INT_MAX) { +#line 1118 + +#line 1118 +#ifdef ERANGE_FILL +#line 1118 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1118 +#endif +#line 1118 + err = NC_ERANGE; +#line 1118 + } +#line 1118 +#ifdef ERANGE_FILL +#line 1118 + else +#line 1118 +#endif +#line 1118 +#endif +#line 1118 + xx = (ix_int)*ip; +#line 1118 + +#line 1118 + put_ix_int(xp, &xx); +#line 1118 + return err; +#line 1118 +} +#line 1118 + +static int +#line 1119 +ncx_put_int_ulonglong(void *xp, const ulonglong *ip, void *fillp) +#line 1119 +{ +#line 1119 + int err=NC_NOERR; +#line 1119 + ix_int xx = NC_FILL_INT; +#line 1119 + +#line 1119 +#if IX_INT_MAX < ULONGLONG_MAX +#line 1119 + if (*ip > IX_INT_MAX) { +#line 1119 + +#line 1119 +#ifdef ERANGE_FILL +#line 1119 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1119 +#endif +#line 1119 + err = NC_ERANGE; +#line 1119 + } +#line 1119 +#ifdef ERANGE_FILL +#line 1119 + else +#line 1119 +#endif +#line 1119 +#endif +#line 1119 + xx = (ix_int)*ip; +#line 1119 + +#line 1119 + put_ix_int(xp, &xx); +#line 1119 + return err; +#line 1119 +} +#line 1119 + +static int +#line 1120 +ncx_put_int_float(void *xp, const float *ip, void *fillp) +#line 1120 +{ +#line 1120 + int err=NC_NOERR; +#line 1120 + ix_int xx = NC_FILL_INT; +#line 1120 + +#line 1120 + if (*ip > (double)X_INT_MAX || *ip < (double)X_INT_MIN) { +#line 1120 + +#line 1120 +#ifdef ERANGE_FILL +#line 1120 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1120 +#endif +#line 1120 + err = NC_ERANGE; +#line 1120 + } +#line 1120 +#ifdef ERANGE_FILL +#line 1120 + else +#line 1120 +#endif +#line 1120 + xx = (ix_int)*ip; +#line 1120 + +#line 1120 + put_ix_int(xp, &xx); +#line 1120 + return err; +#line 1120 +} +#line 1120 + +static int +#line 1121 +ncx_put_int_double(void *xp, const double *ip, void *fillp) +#line 1121 +{ +#line 1121 + int err=NC_NOERR; +#line 1121 + ix_int xx = NC_FILL_INT; +#line 1121 + +#line 1121 + if (*ip > X_INT_MAX || *ip < X_INT_MIN) { +#line 1121 + +#line 1121 +#ifdef ERANGE_FILL +#line 1121 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1121 +#endif +#line 1121 + err = NC_ERANGE; +#line 1121 + } +#line 1121 +#ifdef ERANGE_FILL +#line 1121 + else +#line 1121 +#endif +#line 1121 + xx = (ix_int)*ip; +#line 1121 + +#line 1121 + put_ix_int(xp, &xx); +#line 1121 + return err; +#line 1121 +} +#line 1121 + + + +/* external NC_UINT ---------------------------------------------------------*/ + +#if USHORT_MAX == X_UINT_MAX +typedef ushort ix_uint; +#define SIZEOF_IX_UINT SIZEOF_USHORT +#define IX_UINT_MAX USHORT_MAX +#elif UINT_MAX >= X_UINT_MAX +typedef uint ix_uint; +#define SIZEOF_IX_UINT SIZEOF_UINT +#define IX_UINT_MAX UINT_MAX +#elif ULONG_MAX >= X_UINT_MAX +typedef ulong ix_uint; +#define SIZEOF_IX_UINT SIZEOF_ULONG +#define IX_UINT_MAX ULONG_MAX +#else +#error "ix_uint implementation" +#endif + + +static void +get_ix_uint(const void *xp, ix_uint *ip) +{ + const uchar *cp = (const uchar *) xp; + + *ip = (ix_uint)(*cp++ << 24); + *ip = (ix_uint)(*ip | (ix_uint)(*cp++ << 16)); + *ip = (ix_uint)(*ip | (ix_uint)(*cp++ << 8)); + *ip = (ix_uint)(*ip | *cp); +} + +static void +put_ix_uint(void *xp, const ix_uint *ip) +{ + uchar *cp = (uchar *) xp; + + *cp++ = (uchar)((*ip) >> 24); + *cp++ = (uchar)(((*ip) & 0x00ff0000) >> 16); + *cp++ = (uchar)(((*ip) & 0x0000ff00) >> 8); + *cp = (uchar)( (*ip) & 0x000000ff); +} + +#if X_SIZEOF_UINT != SIZEOF_UINT +static int +#line 1166 +ncx_get_uint_uint(const void *xp, uint *ip) +#line 1166 +{ +#line 1166 + int err=NC_NOERR; +#line 1166 +#if SIZEOF_IX_UINT == SIZEOF_UINT && IX_UINT_MAX == UINT_MAX +#line 1166 + get_ix_uint(xp, (ix_uint *)ip); +#line 1166 +#else +#line 1166 + ix_uint xx = 0; +#line 1166 + get_ix_uint(xp, &xx); +#line 1166 + +#line 1166 +#if IX_UINT_MAX > UINT_MAX +#line 1166 + if (xx > UINT_MAX) { +#line 1166 +#ifdef ERANGE_FILL +#line 1166 + *ip = NC_FILL_UINT; +#line 1166 + return NC_ERANGE; +#line 1166 +#else +#line 1166 + err = NC_ERANGE; +#line 1166 +#endif +#line 1166 + } +#line 1166 +#endif +#line 1166 + +#line 1166 + +#line 1166 + *ip = (uint) xx; +#line 1166 +#endif +#line 1166 + return err; +#line 1166 +} +#line 1166 + +#endif + +static int +#line 1169 +ncx_get_uint_schar(const void *xp, schar *ip) +#line 1169 +{ +#line 1169 + int err=NC_NOERR; +#line 1169 + ix_uint xx = 0; +#line 1169 + get_ix_uint(xp, &xx); +#line 1169 + +#line 1169 +#if IX_UINT_MAX > SCHAR_MAX +#line 1169 + if (xx > SCHAR_MAX) { +#line 1169 +#ifdef ERANGE_FILL +#line 1169 + *ip = NC_FILL_BYTE; +#line 1169 + return NC_ERANGE; +#line 1169 +#else +#line 1169 + err = NC_ERANGE; +#line 1169 +#endif +#line 1169 + } +#line 1169 +#endif +#line 1169 + +#line 1169 + +#line 1169 + *ip = (schar) xx; +#line 1169 + return err; +#line 1169 +} +#line 1169 + +static int +#line 1170 +ncx_get_uint_short(const void *xp, short *ip) +#line 1170 +{ +#line 1170 + int err=NC_NOERR; +#line 1170 + ix_uint xx = 0; +#line 1170 + get_ix_uint(xp, &xx); +#line 1170 + +#line 1170 +#if IX_UINT_MAX > SHORT_MAX +#line 1170 + if (xx > SHORT_MAX) { +#line 1170 +#ifdef ERANGE_FILL +#line 1170 + *ip = NC_FILL_SHORT; +#line 1170 + return NC_ERANGE; +#line 1170 +#else +#line 1170 + err = NC_ERANGE; +#line 1170 +#endif +#line 1170 + } +#line 1170 +#endif +#line 1170 + +#line 1170 + +#line 1170 + *ip = (short) xx; +#line 1170 + return err; +#line 1170 +} +#line 1170 + +static int +#line 1171 +ncx_get_uint_int(const void *xp, int *ip) +#line 1171 +{ +#line 1171 + int err=NC_NOERR; +#line 1171 + ix_uint xx = 0; +#line 1171 + get_ix_uint(xp, &xx); +#line 1171 + +#line 1171 +#if IX_UINT_MAX > INT_MAX +#line 1171 + if (xx > INT_MAX) { +#line 1171 +#ifdef ERANGE_FILL +#line 1171 + *ip = NC_FILL_INT; +#line 1171 + return NC_ERANGE; +#line 1171 +#else +#line 1171 + err = NC_ERANGE; +#line 1171 +#endif +#line 1171 + } +#line 1171 +#endif +#line 1171 + +#line 1171 + +#line 1171 + *ip = (int) xx; +#line 1171 + return err; +#line 1171 +} +#line 1171 + +static int +#line 1172 +ncx_get_uint_long(const void *xp, long *ip) +#line 1172 +{ +#line 1172 + int err=NC_NOERR; +#line 1172 + ix_uint xx = 0; +#line 1172 + get_ix_uint(xp, &xx); +#line 1172 + +#line 1172 +#if IX_UINT_MAX > LONG_MAX +#line 1172 + if (xx > LONG_MAX) { +#line 1172 +#ifdef ERANGE_FILL +#line 1172 + *ip = NC_FILL_INT; +#line 1172 + return NC_ERANGE; +#line 1172 +#else +#line 1172 + err = NC_ERANGE; +#line 1172 +#endif +#line 1172 + } +#line 1172 +#endif +#line 1172 + +#line 1172 + +#line 1172 + *ip = (long) xx; +#line 1172 + return err; +#line 1172 +} +#line 1172 + +static int +#line 1173 +ncx_get_uint_longlong(const void *xp, longlong *ip) +#line 1173 +{ +#line 1173 + int err=NC_NOERR; +#line 1173 + ix_uint xx = 0; +#line 1173 + get_ix_uint(xp, &xx); +#line 1173 + +#line 1173 +#if IX_UINT_MAX > LONGLONG_MAX +#line 1173 + if (xx > LONGLONG_MAX) { +#line 1173 +#ifdef ERANGE_FILL +#line 1173 + *ip = NC_FILL_INT64; +#line 1173 + return NC_ERANGE; +#line 1173 +#else +#line 1173 + err = NC_ERANGE; +#line 1173 +#endif +#line 1173 + } +#line 1173 +#endif +#line 1173 + +#line 1173 + +#line 1173 + *ip = (longlong) xx; +#line 1173 + return err; +#line 1173 +} +#line 1173 + +static int +#line 1174 +ncx_get_uint_ushort(const void *xp, ushort *ip) +#line 1174 +{ +#line 1174 + int err=NC_NOERR; +#line 1174 +#if SIZEOF_IX_UINT == SIZEOF_USHORT && IX_UINT_MAX == USHORT_MAX +#line 1174 + get_ix_uint(xp, (ix_uint *)ip); +#line 1174 +#else +#line 1174 + ix_uint xx = 0; +#line 1174 + get_ix_uint(xp, &xx); +#line 1174 + +#line 1174 +#if IX_UINT_MAX > USHORT_MAX +#line 1174 + if (xx > USHORT_MAX) { +#line 1174 +#ifdef ERANGE_FILL +#line 1174 + *ip = NC_FILL_USHORT; +#line 1174 + return NC_ERANGE; +#line 1174 +#else +#line 1174 + err = NC_ERANGE; +#line 1174 +#endif +#line 1174 + } +#line 1174 +#endif +#line 1174 + +#line 1174 + +#line 1174 + *ip = (ushort) xx; +#line 1174 +#endif +#line 1174 + return err; +#line 1174 +} +#line 1174 + +static int +#line 1175 +ncx_get_uint_uchar(const void *xp, uchar *ip) +#line 1175 +{ +#line 1175 + int err=NC_NOERR; +#line 1175 +#if SIZEOF_IX_UINT == SIZEOF_UCHAR && IX_UINT_MAX == UCHAR_MAX +#line 1175 + get_ix_uint(xp, (ix_uint *)ip); +#line 1175 +#else +#line 1175 + ix_uint xx = 0; +#line 1175 + get_ix_uint(xp, &xx); +#line 1175 + +#line 1175 +#if IX_UINT_MAX > UCHAR_MAX +#line 1175 + if (xx > UCHAR_MAX) { +#line 1175 +#ifdef ERANGE_FILL +#line 1175 + *ip = NC_FILL_UBYTE; +#line 1175 + return NC_ERANGE; +#line 1175 +#else +#line 1175 + err = NC_ERANGE; +#line 1175 +#endif +#line 1175 + } +#line 1175 +#endif +#line 1175 + +#line 1175 + +#line 1175 + *ip = (uchar) xx; +#line 1175 +#endif +#line 1175 + return err; +#line 1175 +} +#line 1175 + +static int +#line 1176 +ncx_get_uint_ulonglong(const void *xp, ulonglong *ip) +#line 1176 +{ +#line 1176 + int err=NC_NOERR; +#line 1176 +#if SIZEOF_IX_UINT == SIZEOF_ULONGLONG && IX_UINT_MAX == ULONGLONG_MAX +#line 1176 + get_ix_uint(xp, (ix_uint *)ip); +#line 1176 +#else +#line 1176 + ix_uint xx = 0; +#line 1176 + get_ix_uint(xp, &xx); +#line 1176 + +#line 1176 +#if IX_UINT_MAX > ULONGLONG_MAX +#line 1176 + if (xx > ULONGLONG_MAX) { +#line 1176 +#ifdef ERANGE_FILL +#line 1176 + *ip = NC_FILL_UINT64; +#line 1176 + return NC_ERANGE; +#line 1176 +#else +#line 1176 + err = NC_ERANGE; +#line 1176 +#endif +#line 1176 + } +#line 1176 +#endif +#line 1176 + +#line 1176 + +#line 1176 + *ip = (ulonglong) xx; +#line 1176 +#endif +#line 1176 + return err; +#line 1176 +} +#line 1176 + +static int +#line 1177 +ncx_get_uint_float(const void *xp, float *ip) +#line 1177 +{ +#line 1177 + ix_uint xx = 0; +#line 1177 + get_ix_uint(xp, &xx); +#line 1177 + *ip = (float)xx; +#line 1177 + return NC_NOERR; +#line 1177 +} +#line 1177 + +static int +#line 1178 +ncx_get_uint_double(const void *xp, double *ip) +#line 1178 +{ +#line 1178 + ix_uint xx = 0; +#line 1178 + get_ix_uint(xp, &xx); +#line 1178 + *ip = (double)xx; +#line 1178 + return NC_NOERR; +#line 1178 +} +#line 1178 + + +static int +ncx_put_uint_schar(void *xp, const schar *ip, void *fillp) +{ + uchar *cp; + if (*ip < 0) { +#ifdef ERANGE_FILL + if (fillp != NULL) memcpy(xp, fillp, 4); +#ifndef WORDS_BIGENDIAN + swapn4b(xp, xp, 1); +#endif +#endif + return NC_ERANGE; + } + + cp = (uchar *) xp; + *cp++ = 0x00; + *cp++ = 0x00; + *cp++ = 0x00; + *cp = (uchar)*ip; + + return NC_NOERR; +} + +static int +ncx_put_uint_uchar(void *xp, const uchar *ip, void *fillp) +{ + uchar *cp = (uchar *) xp; + *cp++ = 0x00; + *cp++ = 0x00; + *cp++ = 0x00; + *cp = *ip; + return NC_NOERR; +} + +#if X_SIZEOF_UINT != SIZEOF_UINT +static int +#line 1215 +ncx_put_uint_uint(void *xp, const uint *ip, void *fillp) +#line 1215 +{ +#line 1215 + int err=NC_NOERR; +#line 1215 +#if SIZEOF_IX_UINT == SIZEOF_UINT && IX_UINT_MAX == UINT_MAX +#line 1215 + put_ix_uint(xp, (const ix_uint *)ip); +#line 1215 +#else +#line 1215 + ix_uint xx = NC_FILL_UINT; +#line 1215 + +#line 1215 +#if IX_UINT_MAX < UINT_MAX +#line 1215 + if (*ip > IX_UINT_MAX) { +#line 1215 + +#line 1215 +#ifdef ERANGE_FILL +#line 1215 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1215 +#endif +#line 1215 + err = NC_ERANGE; +#line 1215 + } +#line 1215 +#ifdef ERANGE_FILL +#line 1215 + else +#line 1215 +#endif +#line 1215 +#endif +#line 1215 + xx = (ix_uint)*ip; +#line 1215 + +#line 1215 + put_ix_uint(xp, &xx); +#line 1215 +#endif +#line 1215 + return err; +#line 1215 +} +#line 1215 + +#endif + +static int +#line 1218 +ncx_put_uint_short(void *xp, const short *ip, void *fillp) +#line 1218 +{ +#line 1218 + int err=NC_NOERR; +#line 1218 + ix_uint xx = NC_FILL_UINT; +#line 1218 + +#line 1218 +#if IX_UINT_MAX < SHORT_MAX +#line 1218 + if (*ip > IX_UINT_MAX) { +#line 1218 + +#line 1218 +#ifdef ERANGE_FILL +#line 1218 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1218 +#endif +#line 1218 + err = NC_ERANGE; +#line 1218 + } +#line 1218 +#ifdef ERANGE_FILL +#line 1218 + else +#line 1218 +#endif +#line 1218 +#endif +#line 1218 + if (*ip < 0) { +#line 1218 + +#line 1218 +#ifdef ERANGE_FILL +#line 1218 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1218 +#endif +#line 1218 + err = NC_ERANGE; /* because xp is unsigned */ +#line 1218 + } +#line 1218 +#ifdef ERANGE_FILL +#line 1218 + else +#line 1218 +#endif +#line 1218 + xx = (ix_uint)*ip; +#line 1218 + +#line 1218 + put_ix_uint(xp, &xx); +#line 1218 + return err; +#line 1218 +} +#line 1218 + +static int +#line 1219 +ncx_put_uint_int(void *xp, const int *ip, void *fillp) +#line 1219 +{ +#line 1219 + int err=NC_NOERR; +#line 1219 + ix_uint xx = NC_FILL_UINT; +#line 1219 + +#line 1219 +#if IX_UINT_MAX < INT_MAX +#line 1219 + if (*ip > IX_UINT_MAX) { +#line 1219 + +#line 1219 +#ifdef ERANGE_FILL +#line 1219 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1219 +#endif +#line 1219 + err = NC_ERANGE; +#line 1219 + } +#line 1219 +#ifdef ERANGE_FILL +#line 1219 + else +#line 1219 +#endif +#line 1219 +#endif +#line 1219 + if (*ip < 0) { +#line 1219 + +#line 1219 +#ifdef ERANGE_FILL +#line 1219 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1219 +#endif +#line 1219 + err = NC_ERANGE; /* because xp is unsigned */ +#line 1219 + } +#line 1219 +#ifdef ERANGE_FILL +#line 1219 + else +#line 1219 +#endif +#line 1219 + xx = (ix_uint)*ip; +#line 1219 + +#line 1219 + put_ix_uint(xp, &xx); +#line 1219 + return err; +#line 1219 +} +#line 1219 + +static int +#line 1220 +ncx_put_uint_long(void *xp, const long *ip, void *fillp) +#line 1220 +{ +#line 1220 + int err=NC_NOERR; +#line 1220 + ix_uint xx = NC_FILL_UINT; +#line 1220 + +#line 1220 +#if IX_UINT_MAX < LONG_MAX +#line 1220 + if (*ip > IX_UINT_MAX) { +#line 1220 + +#line 1220 +#ifdef ERANGE_FILL +#line 1220 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1220 +#endif +#line 1220 + err = NC_ERANGE; +#line 1220 + } +#line 1220 +#ifdef ERANGE_FILL +#line 1220 + else +#line 1220 +#endif +#line 1220 +#endif +#line 1220 + if (*ip < 0) { +#line 1220 + +#line 1220 +#ifdef ERANGE_FILL +#line 1220 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1220 +#endif +#line 1220 + err = NC_ERANGE; /* because xp is unsigned */ +#line 1220 + } +#line 1220 +#ifdef ERANGE_FILL +#line 1220 + else +#line 1220 +#endif +#line 1220 + xx = (ix_uint)*ip; +#line 1220 + +#line 1220 + put_ix_uint(xp, &xx); +#line 1220 + return err; +#line 1220 +} +#line 1220 + +static int +#line 1221 +ncx_put_uint_longlong(void *xp, const longlong *ip, void *fillp) +#line 1221 +{ +#line 1221 + int err=NC_NOERR; +#line 1221 + ix_uint xx = NC_FILL_UINT; +#line 1221 + +#line 1221 +#if IX_UINT_MAX < LONGLONG_MAX +#line 1221 + if (*ip > IX_UINT_MAX) { +#line 1221 + +#line 1221 +#ifdef ERANGE_FILL +#line 1221 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1221 +#endif +#line 1221 + err = NC_ERANGE; +#line 1221 + } +#line 1221 +#ifdef ERANGE_FILL +#line 1221 + else +#line 1221 +#endif +#line 1221 +#endif +#line 1221 + if (*ip < 0) { +#line 1221 + +#line 1221 +#ifdef ERANGE_FILL +#line 1221 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1221 +#endif +#line 1221 + err = NC_ERANGE; /* because xp is unsigned */ +#line 1221 + } +#line 1221 +#ifdef ERANGE_FILL +#line 1221 + else +#line 1221 +#endif +#line 1221 + xx = (ix_uint)*ip; +#line 1221 + +#line 1221 + put_ix_uint(xp, &xx); +#line 1221 + return err; +#line 1221 +} +#line 1221 + +static int +#line 1222 +ncx_put_uint_ushort(void *xp, const ushort *ip, void *fillp) +#line 1222 +{ +#line 1222 + int err=NC_NOERR; +#line 1222 +#if SIZEOF_IX_UINT == SIZEOF_USHORT && IX_UINT_MAX == USHORT_MAX +#line 1222 + put_ix_uint(xp, (const ix_uint *)ip); +#line 1222 +#else +#line 1222 + ix_uint xx = NC_FILL_UINT; +#line 1222 + +#line 1222 +#if IX_UINT_MAX < USHORT_MAX +#line 1222 + if (*ip > IX_UINT_MAX) { +#line 1222 + +#line 1222 +#ifdef ERANGE_FILL +#line 1222 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1222 +#endif +#line 1222 + err = NC_ERANGE; +#line 1222 + } +#line 1222 +#ifdef ERANGE_FILL +#line 1222 + else +#line 1222 +#endif +#line 1222 +#endif +#line 1222 + xx = (ix_uint)*ip; +#line 1222 + +#line 1222 + put_ix_uint(xp, &xx); +#line 1222 +#endif +#line 1222 + return err; +#line 1222 +} +#line 1222 + +static int +#line 1223 +ncx_put_uint_ulonglong(void *xp, const ulonglong *ip, void *fillp) +#line 1223 +{ +#line 1223 + int err=NC_NOERR; +#line 1223 +#if SIZEOF_IX_UINT == SIZEOF_ULONGLONG && IX_UINT_MAX == ULONGLONG_MAX +#line 1223 + put_ix_uint(xp, (const ix_uint *)ip); +#line 1223 +#else +#line 1223 + ix_uint xx = NC_FILL_UINT; +#line 1223 + +#line 1223 +#if IX_UINT_MAX < ULONGLONG_MAX +#line 1223 + if (*ip > IX_UINT_MAX) { +#line 1223 + +#line 1223 +#ifdef ERANGE_FILL +#line 1223 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1223 +#endif +#line 1223 + err = NC_ERANGE; +#line 1223 + } +#line 1223 +#ifdef ERANGE_FILL +#line 1223 + else +#line 1223 +#endif +#line 1223 +#endif +#line 1223 + xx = (ix_uint)*ip; +#line 1223 + +#line 1223 + put_ix_uint(xp, &xx); +#line 1223 +#endif +#line 1223 + return err; +#line 1223 +} +#line 1223 + +static int +#line 1224 +ncx_put_uint_float(void *xp, const float *ip, void *fillp) +#line 1224 +{ +#line 1224 + int err=NC_NOERR; +#line 1224 + ix_uint xx = NC_FILL_UINT; +#line 1224 + +#line 1224 + if (*ip > (double)X_UINT_MAX || *ip < 0) { +#line 1224 + +#line 1224 +#ifdef ERANGE_FILL +#line 1224 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1224 +#endif +#line 1224 + err = NC_ERANGE; +#line 1224 + } +#line 1224 +#ifdef ERANGE_FILL +#line 1224 + else +#line 1224 +#endif +#line 1224 + xx = (ix_uint)*ip; +#line 1224 + +#line 1224 + put_ix_uint(xp, &xx); +#line 1224 + return err; +#line 1224 +} +#line 1224 + +static int +#line 1225 +ncx_put_uint_double(void *xp, const double *ip, void *fillp) +#line 1225 +{ +#line 1225 + int err=NC_NOERR; +#line 1225 + ix_uint xx = NC_FILL_UINT; +#line 1225 + +#line 1225 + if (*ip > X_UINT_MAX || *ip < 0) { +#line 1225 + +#line 1225 +#ifdef ERANGE_FILL +#line 1225 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1225 +#endif +#line 1225 + err = NC_ERANGE; +#line 1225 + } +#line 1225 +#ifdef ERANGE_FILL +#line 1225 + else +#line 1225 +#endif +#line 1225 + xx = (ix_uint)*ip; +#line 1225 + +#line 1225 + put_ix_uint(xp, &xx); +#line 1225 + return err; +#line 1225 +} +#line 1225 + + + +/* external NC_FLOAT --------------------------------------------------------*/ + +#if X_SIZEOF_FLOAT == SIZEOF_FLOAT && !defined(NO_IEEE_FLOAT) + +inline static void +get_ix_float(const void *xp, float *ip) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(ip, xp, SIZEOF_FLOAT); +#else + swap4b(ip, xp); +#endif +} + +inline static void +put_ix_float(void *xp, const float *ip) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(xp, ip, X_SIZEOF_FLOAT); +#else + swap4b(xp, ip); +#endif +} + +#elif defined(vax) && vax != 0 + +/* What IEEE single precision floating point looks like on a Vax */ +struct ieee_single { + unsigned int exp_hi : 7; + unsigned int sign : 1; + unsigned int mant_hi : 7; + unsigned int exp_lo : 1; + unsigned int mant_lo_hi : 8; + unsigned int mant_lo_lo : 8; +}; + +/* Vax single precision floating point */ +struct vax_single { + unsigned int mantissa1 : 7; + unsigned int exp : 8; + unsigned int sign : 1; + unsigned int mantissa2 : 16; +}; + +#define VAX_SNG_BIAS 0x81 +#define IEEE_SNG_BIAS 0x7f + +static struct sgl_limits { + struct vax_single s; + struct ieee_single ieee; +} max = { + { 0x7f, 0xff, 0x0, 0xffff }, /* Max Vax */ + { 0x7f, 0x0, 0x0, 0x1, 0x0, 0x0 } /* Max IEEE */ +}; +static struct sgl_limits min = { + { 0x0, 0x0, 0x0, 0x0 }, /* Min Vax */ + { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0 } /* Min IEEE */ +}; + +#line 1339 +static void +get_ix_float(const void *xp, float *ip) +{ + struct vax_single *const vsp = (struct vax_single *) ip; +#line 1342 + const struct ieee_single *const isp = +#line 1342 + (const struct ieee_single *) xp; +#line 1342 + unsigned exp = isp->exp_hi << 1 | isp->exp_lo; +#line 1342 + +#line 1342 + switch(exp) { +#line 1342 + case 0 : +#line 1342 + /* ieee subnormal */ +#line 1342 + if (isp->mant_hi == min.ieee.mant_hi +#line 1342 + && isp->mant_lo_hi == min.ieee.mant_lo_hi +#line 1342 + && isp->mant_lo_lo == min.ieee.mant_lo_lo) +#line 1342 + { +#line 1342 + *vsp = min.s; +#line 1342 + } +#line 1342 + else +#line 1342 + { +#line 1342 + unsigned mantissa = (isp->mant_hi << 16) +#line 1342 + | isp->mant_lo_hi << 8 +#line 1342 + | isp->mant_lo_lo; +#line 1342 + unsigned tmp = mantissa >> 20; +#line 1342 + if (tmp >= 4) { +#line 1342 + vsp->exp = 2; +#line 1342 + } else if (tmp >= 2) { +#line 1342 + vsp->exp = 1; +#line 1342 + } else { +#line 1342 + *vsp = min.s; +#line 1342 + break; +#line 1342 + } /* else */ +#line 1342 + tmp = mantissa - (1 << (20 + vsp->exp )); +#line 1342 + tmp <<= 3 - vsp->exp; +#line 1342 + vsp->mantissa2 = tmp; +#line 1342 + vsp->mantissa1 = (tmp >> 16); +#line 1342 + } +#line 1342 + break; +#line 1342 + case 0xfe : +#line 1342 + case 0xff : +#line 1342 + *vsp = max.s; +#line 1342 + break; +#line 1342 + default : +#line 1342 + vsp->exp = exp - IEEE_SNG_BIAS + VAX_SNG_BIAS; +#line 1342 + vsp->mantissa2 = isp->mant_lo_hi << 8 | isp->mant_lo_lo; +#line 1342 + vsp->mantissa1 = isp->mant_hi; +#line 1342 + } +#line 1342 + +#line 1342 + vsp->sign = isp->sign; +#line 1342 + +} + +#line 1396 + +static void +put_ix_float(void *xp, const float *ip) +{ + const struct vax_single *const vsp = +#line 1400 + (const struct vax_single *)ip; +#line 1400 + struct ieee_single *const isp = (struct ieee_single *) xp; +#line 1400 + +#line 1400 + switch(vsp->exp){ +#line 1400 + case 0 : +#line 1400 + /* all vax float with zero exponent map to zero */ +#line 1400 + *isp = min.ieee; +#line 1400 + break; +#line 1400 + case 2 : +#line 1400 + case 1 : +#line 1400 + { +#line 1400 + /* These will map to subnormals */ +#line 1400 + unsigned mantissa = (vsp->mantissa1 << 16) +#line 1400 + | vsp->mantissa2; +#line 1400 + mantissa >>= 3 - vsp->exp; +#line 1400 + mantissa += (1 << (20 + vsp->exp)); +#line 1400 + isp->mant_lo_lo = mantissa; +#line 1400 + isp->mant_lo_hi = mantissa >> 8; +#line 1400 + isp->mant_hi = mantissa >> 16; +#line 1400 + isp->exp_lo = 0; +#line 1400 + isp->exp_hi = 0; +#line 1400 + } +#line 1400 + break; +#line 1400 + case 0xff : /* max.s.exp */ +#line 1400 + if (vsp->mantissa2 == max.s.mantissa2 && +#line 1400 + vsp->mantissa1 == max.s.mantissa1) +#line 1400 + { +#line 1400 + /* map largest vax float to ieee infinity */ +#line 1400 + *isp = max.ieee; +#line 1400 + break; +#line 1400 + } /* else, fall thru */ +#line 1400 + default : +#line 1400 + { +#line 1400 + unsigned exp = vsp->exp - VAX_SNG_BIAS + IEEE_SNG_BIAS; +#line 1400 + isp->exp_hi = exp >> 1; +#line 1400 + isp->exp_lo = exp; +#line 1400 + isp->mant_lo_lo = vsp->mantissa2; +#line 1400 + isp->mant_lo_hi = vsp->mantissa2 >> 8; +#line 1400 + isp->mant_hi = vsp->mantissa1; +#line 1400 + } +#line 1400 + } +#line 1400 + +#line 1400 + isp->sign = vsp->sign; +#line 1400 + +} + + /* vax */ +#elif defined(_CRAY) && !defined(__crayx1) + +/* + * Return the number of bytes until the next "word" boundary + * N.B. This is based on the very weird YMP address structure, + * which puts the address within a word in the leftmost 3 bits + * of the address. + */ +static size_t +word_align(const void *vp) +{ + const size_t rem = ((size_t)vp >> (64 - 3)) & 0x7; + return (rem != 0); +} + +struct ieee_single_hi { + unsigned int sign : 1; + unsigned int exp : 8; + unsigned int mant :23; + unsigned int pad :32; +}; +typedef struct ieee_single_hi ieee_single_hi; + +struct ieee_single_lo { + unsigned int pad :32; + unsigned int sign : 1; + unsigned int exp : 8; + unsigned int mant :23; +}; +typedef struct ieee_single_lo ieee_single_lo; + +static const int ieee_single_bias = 0x7f; + +struct ieee_double { + unsigned int sign : 1; + unsigned int exp :11; + unsigned int mant :52; +}; +typedef struct ieee_double ieee_double; + +static const int ieee_double_bias = 0x3ff; + +#if defined(NO_IEEE_FLOAT) + +struct cray_single { + unsigned int sign : 1; + unsigned int exp :15; + unsigned int mant :48; +}; +typedef struct cray_single cray_single; + +static const int cs_ieis_bias = 0x4000 - 0x7f; + +static const int cs_id_bias = 0x4000 - 0x3ff; + +#line 1535 + +static void +get_ix_float(const void *xp, float *ip) +{ + + if (word_align(xp) == 0) + { + const ieee_single_hi *isp = (const ieee_single_hi *) xp; + cray_single *csp = (cray_single *) ip; +#line 1543 + +#line 1543 + if (isp->exp == 0) +#line 1543 + { +#line 1543 + /* ieee subnormal */ +#line 1543 + *ip = (double)isp->mant; +#line 1543 + if (isp->mant != 0) +#line 1543 + { +#line 1543 + csp->exp -= (ieee_single_bias + 22); +#line 1543 + } +#line 1543 + } +#line 1543 + else +#line 1543 + { +#line 1543 + csp->exp = isp->exp + cs_ieis_bias + 1; +#line 1543 + csp->mant = isp->mant << (48 - 1 - 23); +#line 1543 + csp->mant |= (1 << (48 - 1)); +#line 1543 + } +#line 1543 + csp->sign = isp->sign; +#line 1543 + +#line 1543 + + } + else + { + const ieee_single_lo *isp = (const ieee_single_lo *) xp; + cray_single *csp = (cray_single *) ip; +#line 1548 + +#line 1548 + if (isp->exp == 0) +#line 1548 + { +#line 1548 + /* ieee subnormal */ +#line 1548 + *ip = (double)isp->mant; +#line 1548 + if (isp->mant != 0) +#line 1548 + { +#line 1548 + csp->exp -= (ieee_single_bias + 22); +#line 1548 + } +#line 1548 + } +#line 1548 + else +#line 1548 + { +#line 1548 + csp->exp = isp->exp + cs_ieis_bias + 1; +#line 1548 + csp->mant = isp->mant << (48 - 1 - 23); +#line 1548 + csp->mant |= (1 << (48 - 1)); +#line 1548 + } +#line 1548 + csp->sign = isp->sign; +#line 1548 + +#line 1548 + + } +} + +static void +put_ix_float(void *xp, const float *ip) +{ + if (word_align(xp) == 0) + { + ieee_single_hi *isp = (ieee_single_hi*)xp; + const cray_single *csp = (const cray_single *) ip; +#line 1558 + int ieee_exp = csp->exp - cs_ieis_bias -1; +#line 1558 + +#line 1558 + isp->sign = csp->sign; +#line 1558 + +#line 1558 + if (ieee_exp >= 0xff) +#line 1558 + { +#line 1558 + /* NC_ERANGE => ieee Inf */ +#line 1558 + isp->exp = 0xff; +#line 1558 + isp->mant = 0x0; +#line 1558 + } +#line 1558 + else if (ieee_exp > 0) +#line 1558 + { +#line 1558 + /* normal ieee representation */ +#line 1558 + isp->exp = ieee_exp; +#line 1558 + /* assumes cray rep is in normal form */ +#line 1558 + assert(csp->mant & 0x800000000000); +#line 1558 + isp->mant = (((csp->mant << 1) & +#line 1558 + 0xffffffffffff) >> (48 - 23)); +#line 1558 + } +#line 1558 + else if (ieee_exp > -23) +#line 1558 + { +#line 1558 + /* ieee subnormal, right shift */ +#line 1558 + const int rshift = (48 - 23 - ieee_exp); +#line 1558 + +#line 1558 + isp->mant = csp->mant >> rshift; +#line 1558 + +#line 1558 +#if 0 +#line 1558 + if (csp->mant & (1 << (rshift -1))) +#line 1558 + { +#line 1558 + /* round up */ +#line 1558 + isp->mant++; +#line 1558 + } +#line 1558 +#endif +#line 1558 + +#line 1558 + isp->exp = 0; +#line 1558 + } +#line 1558 + else +#line 1558 + { +#line 1558 + /* smaller than ieee can represent */ +#line 1558 + isp->exp = 0; +#line 1558 + isp->mant = 0; +#line 1558 + } +#line 1558 + + } + else + { + ieee_single_lo *isp = (ieee_single_lo*)xp; + const cray_single *csp = (const cray_single *) ip; +#line 1563 + int ieee_exp = csp->exp - cs_ieis_bias -1; +#line 1563 + +#line 1563 + isp->sign = csp->sign; +#line 1563 + +#line 1563 + if (ieee_exp >= 0xff) +#line 1563 + { +#line 1563 + /* NC_ERANGE => ieee Inf */ +#line 1563 + isp->exp = 0xff; +#line 1563 + isp->mant = 0x0; +#line 1563 + } +#line 1563 + else if (ieee_exp > 0) +#line 1563 + { +#line 1563 + /* normal ieee representation */ +#line 1563 + isp->exp = ieee_exp; +#line 1563 + /* assumes cray rep is in normal form */ +#line 1563 + assert(csp->mant & 0x800000000000); +#line 1563 + isp->mant = (((csp->mant << 1) & +#line 1563 + 0xffffffffffff) >> (48 - 23)); +#line 1563 + } +#line 1563 + else if (ieee_exp > -23) +#line 1563 + { +#line 1563 + /* ieee subnormal, right shift */ +#line 1563 + const int rshift = (48 - 23 - ieee_exp); +#line 1563 + +#line 1563 + isp->mant = csp->mant >> rshift; +#line 1563 + +#line 1563 +#if 0 +#line 1563 + if (csp->mant & (1 << (rshift -1))) +#line 1563 + { +#line 1563 + /* round up */ +#line 1563 + isp->mant++; +#line 1563 + } +#line 1563 +#endif +#line 1563 + +#line 1563 + isp->exp = 0; +#line 1563 + } +#line 1563 + else +#line 1563 + { +#line 1563 + /* smaller than ieee can represent */ +#line 1563 + isp->exp = 0; +#line 1563 + isp->mant = 0; +#line 1563 + } +#line 1563 + + } +} + +#else + /* IEEE Cray with only doubles */ +static void +get_ix_float(const void *xp, float *ip) +{ + + ieee_double *idp = (ieee_double *) ip; + + if (word_align(xp) == 0) + { + const ieee_single_hi *isp = (const ieee_single_hi *) xp; + if (isp->exp == 0 && isp->mant == 0) + { + idp->exp = 0; + idp->mant = 0; + } + else + { + idp->exp = isp->exp + (ieee_double_bias - ieee_single_bias); + idp->mant = isp->mant << (52 - 23); + } + idp->sign = isp->sign; + } + else + { + const ieee_single_lo *isp = (const ieee_single_lo *) xp; + if (isp->exp == 0 && isp->mant == 0) + { + idp->exp = 0; + idp->mant = 0; + } + else + { + idp->exp = isp->exp + (ieee_double_bias - ieee_single_bias); + idp->mant = isp->mant << (52 - 23); + } + idp->sign = isp->sign; + } +} + +static void +put_ix_float(void *xp, const float *ip) +{ + const ieee_double *idp = (const ieee_double *) ip; + if (word_align(xp) == 0) + { + ieee_single_hi *isp = (ieee_single_hi*)xp; + if (idp->exp > (ieee_double_bias - ieee_single_bias)) + isp->exp = idp->exp - (ieee_double_bias - ieee_single_bias); + else + isp->exp = 0; + isp->mant = idp->mant >> (52 - 23); + isp->sign = idp->sign; + } + else + { + ieee_single_lo *isp = (ieee_single_lo*)xp; + if (idp->exp > (ieee_double_bias - ieee_single_bias)) + isp->exp = idp->exp - (ieee_double_bias - ieee_single_bias); + else + isp->exp = 0; + isp->mant = idp->mant >> (52 - 23); + isp->sign = idp->sign; + } +} +#endif + +#else +#error "ix_float implementation" +#endif + +#if X_SIZEOF_FLOAT != SIZEOF_FLOAT || defined(NO_IEEE_FLOAT) +static int +ncx_get_float_float(const void *xp, float *ip, void *fillp) +{ + /* TODO */ + get_ix_float(xp, ip); + return NC_NOERR; +} +#endif + +#define ix_float float + +static int +#line 1650 +ncx_get_float_schar(const void *xp, schar *ip) +#line 1650 +{ +#line 1650 + ix_float xx = 0; +#line 1650 + get_ix_float(xp, &xx); +#line 1650 + if (xx > (double)SCHAR_MAX || xx < (double)SCHAR_MIN) { +#line 1650 +#ifdef ERANGE_FILL +#line 1650 + *ip = NC_FILL_BYTE; +#line 1650 +#endif +#line 1650 + return NC_ERANGE; +#line 1650 + } +#line 1650 + *ip = (schar)xx; +#line 1650 + return NC_NOERR; +#line 1650 +} +#line 1650 + +static int +#line 1651 +ncx_get_float_short(const void *xp, short *ip) +#line 1651 +{ +#line 1651 + ix_float xx = 0; +#line 1651 + get_ix_float(xp, &xx); +#line 1651 + if (xx > (double)SHORT_MAX || xx < (double)SHORT_MIN) { +#line 1651 +#ifdef ERANGE_FILL +#line 1651 + *ip = NC_FILL_SHORT; +#line 1651 +#endif +#line 1651 + return NC_ERANGE; +#line 1651 + } +#line 1651 + *ip = (short)xx; +#line 1651 + return NC_NOERR; +#line 1651 +} +#line 1651 + +static int +#line 1652 +ncx_get_float_int(const void *xp, int *ip) +#line 1652 +{ +#line 1652 + ix_float xx = 0; +#line 1652 + get_ix_float(xp, &xx); +#line 1652 + if (xx > (double)INT_MAX || xx < (double)INT_MIN) { +#line 1652 +#ifdef ERANGE_FILL +#line 1652 + *ip = NC_FILL_INT; +#line 1652 +#endif +#line 1652 + return NC_ERANGE; +#line 1652 + } +#line 1652 + *ip = (int)xx; +#line 1652 + return NC_NOERR; +#line 1652 +} +#line 1652 + +static int +#line 1653 +ncx_get_float_long(const void *xp, long *ip) +#line 1653 +{ +#line 1653 + ix_float xx = 0; +#line 1653 + get_ix_float(xp, &xx); +#line 1653 + if (xx > (double)LONG_MAX || xx < (double)LONG_MIN) { +#line 1653 +#ifdef ERANGE_FILL +#line 1653 + *ip = NC_FILL_INT; +#line 1653 +#endif +#line 1653 + return NC_ERANGE; +#line 1653 + } +#line 1653 + *ip = (long)xx; +#line 1653 + return NC_NOERR; +#line 1653 +} +#line 1653 + +static int +#line 1654 +ncx_get_float_double(const void *xp, double *ip) +#line 1654 +{ +#line 1654 + ix_float xx = 0; +#line 1654 + get_ix_float(xp, &xx); +#line 1654 + *ip = (double)xx; +#line 1654 + return NC_NOERR; +#line 1654 +} +#line 1654 + +static int +#line 1655 +ncx_get_float_longlong(const void *xp, longlong *ip) +#line 1655 +{ +#line 1655 + ix_float xx = 0; +#line 1655 + get_ix_float(xp, &xx); +#line 1655 + if (xx == LONGLONG_MAX) *ip = LONGLONG_MAX; +#line 1655 + else if (xx == LONGLONG_MIN) *ip = LONGLONG_MIN; +#line 1655 + else if (xx > (double)LONGLONG_MAX || xx < (double)LONGLONG_MIN) { +#line 1655 +#ifdef ERANGE_FILL +#line 1655 + *ip = NC_FILL_INT64; +#line 1655 +#endif +#line 1655 + return NC_ERANGE; +#line 1655 + } +#line 1655 + else *ip = (longlong)xx; +#line 1655 + return NC_NOERR; +#line 1655 +} +#line 1655 + +static int +#line 1656 +ncx_get_float_uchar(const void *xp, uchar *ip) +#line 1656 +{ +#line 1656 + ix_float xx = 0; +#line 1656 + get_ix_float(xp, &xx); +#line 1656 + if (xx > (double)UCHAR_MAX || xx < 0) { +#line 1656 +#ifdef ERANGE_FILL +#line 1656 + *ip = NC_FILL_UBYTE; +#line 1656 +#endif +#line 1656 + return NC_ERANGE; +#line 1656 + } +#line 1656 + *ip = (uchar)xx; +#line 1656 + return NC_NOERR; +#line 1656 +} +#line 1656 + +static int +#line 1657 +ncx_get_float_ushort(const void *xp, ushort *ip) +#line 1657 +{ +#line 1657 + ix_float xx = 0; +#line 1657 + get_ix_float(xp, &xx); +#line 1657 + if (xx > (double)USHORT_MAX || xx < 0) { +#line 1657 +#ifdef ERANGE_FILL +#line 1657 + *ip = NC_FILL_USHORT; +#line 1657 +#endif +#line 1657 + return NC_ERANGE; +#line 1657 + } +#line 1657 + *ip = (ushort)xx; +#line 1657 + return NC_NOERR; +#line 1657 +} +#line 1657 + +static int +#line 1658 +ncx_get_float_uint(const void *xp, uint *ip) +#line 1658 +{ +#line 1658 + ix_float xx = 0; +#line 1658 + get_ix_float(xp, &xx); +#line 1658 + if (xx > (double)UINT_MAX || xx < 0) { +#line 1658 +#ifdef ERANGE_FILL +#line 1658 + *ip = NC_FILL_UINT; +#line 1658 +#endif +#line 1658 + return NC_ERANGE; +#line 1658 + } +#line 1658 + *ip = (uint)xx; +#line 1658 + return NC_NOERR; +#line 1658 +} +#line 1658 + +static int +#line 1659 +ncx_get_float_ulonglong(const void *xp, ulonglong *ip) +#line 1659 +{ +#line 1659 + ix_float xx = 0; +#line 1659 + get_ix_float(xp, &xx); +#line 1659 + if (xx == ULONGLONG_MAX) *ip = ULONGLONG_MAX; +#line 1659 + else if (xx > (double)ULONGLONG_MAX || xx < 0) { +#line 1659 +#ifdef ERANGE_FILL +#line 1659 + *ip = NC_FILL_UINT64; +#line 1659 +#endif +#line 1659 + return NC_ERANGE; +#line 1659 + } +#line 1659 + else *ip = (ulonglong)xx; +#line 1659 + return NC_NOERR; +#line 1659 +} +#line 1659 + + +#if X_SIZEOF_FLOAT != SIZEOF_FLOAT || defined(NO_IEEE_FLOAT) +static int +ncx_put_float_float(void *xp, const float *ip, void *fillp) +{ + int err=NC_NOERR; + float *_ip=ip; +#ifdef NO_IEEE_FLOAT +#ifdef ERANGE_FILL + float tmp; +#endif + if (*ip > X_FLOAT_MAX || *ip < X_FLOAT_MIN) { + +#line 1672 +#ifdef ERANGE_FILL +#line 1672 + if (fillp != NULL) memcpy(&tmp, fillp, 4); +#line 1672 +#endif +#ifdef ERANGE_FILL + _ip = &tmp; +#endif + err = NC_ERANGE; + } +#endif + put_ix_float(xp, _ip); + return err; +} +#endif + +static int +#line 1684 +ncx_put_float_schar(void *xp, const schar *ip, void *fillp) +#line 1684 +{ +#line 1684 + int err=NC_NOERR; +#line 1684 + ix_float xx = NC_FILL_FLOAT; +#line 1684 + +#line 1684 + +#line 1684 + xx = (ix_float)*ip; +#line 1684 + +#line 1684 + put_ix_float(xp, &xx); +#line 1684 + return err; +#line 1684 +} +#line 1684 + +static int +#line 1685 +ncx_put_float_short(void *xp, const short *ip, void *fillp) +#line 1685 +{ +#line 1685 + int err=NC_NOERR; +#line 1685 + ix_float xx = NC_FILL_FLOAT; +#line 1685 + +#line 1685 + +#line 1685 + xx = (ix_float)*ip; +#line 1685 + +#line 1685 + put_ix_float(xp, &xx); +#line 1685 + return err; +#line 1685 +} +#line 1685 + +static int +#line 1686 +ncx_put_float_int(void *xp, const int *ip, void *fillp) +#line 1686 +{ +#line 1686 + int err=NC_NOERR; +#line 1686 + ix_float xx = NC_FILL_FLOAT; +#line 1686 + +#line 1686 + +#line 1686 + xx = (ix_float)*ip; +#line 1686 + +#line 1686 + put_ix_float(xp, &xx); +#line 1686 + return err; +#line 1686 +} +#line 1686 + +static int +#line 1687 +ncx_put_float_long(void *xp, const long *ip, void *fillp) +#line 1687 +{ +#line 1687 + int err=NC_NOERR; +#line 1687 + ix_float xx = NC_FILL_FLOAT; +#line 1687 + +#line 1687 + +#line 1687 + xx = (ix_float)*ip; +#line 1687 + +#line 1687 + put_ix_float(xp, &xx); +#line 1687 + return err; +#line 1687 +} +#line 1687 + +static int +#line 1688 +ncx_put_float_double(void *xp, const double *ip, void *fillp) +#line 1688 +{ +#line 1688 + int err=NC_NOERR; +#line 1688 + ix_float xx = NC_FILL_FLOAT; +#line 1688 + +#line 1688 + if (*ip > X_FLOAT_MAX || *ip < X_FLOAT_MIN) { +#line 1688 + +#line 1688 +#ifdef ERANGE_FILL +#line 1688 + if (fillp != NULL) memcpy(&xx, fillp, 4); +#line 1688 +#endif +#line 1688 + err = NC_ERANGE; +#line 1688 + } +#line 1688 +#ifdef ERANGE_FILL +#line 1688 + else +#line 1688 +#endif +#line 1688 + xx = (ix_float)*ip; +#line 1688 + +#line 1688 + put_ix_float(xp, &xx); +#line 1688 + return err; +#line 1688 +} +#line 1688 + +static int +#line 1689 +ncx_put_float_longlong(void *xp, const longlong *ip, void *fillp) +#line 1689 +{ +#line 1689 + int err=NC_NOERR; +#line 1689 + ix_float xx = NC_FILL_FLOAT; +#line 1689 + +#line 1689 + +#line 1689 + xx = (ix_float)*ip; +#line 1689 + +#line 1689 + put_ix_float(xp, &xx); +#line 1689 + return err; +#line 1689 +} +#line 1689 + +static int +#line 1690 +ncx_put_float_uchar(void *xp, const uchar *ip, void *fillp) +#line 1690 +{ +#line 1690 + int err=NC_NOERR; +#line 1690 + ix_float xx = NC_FILL_FLOAT; +#line 1690 + +#line 1690 + +#line 1690 + xx = (ix_float)*ip; +#line 1690 + +#line 1690 + put_ix_float(xp, &xx); +#line 1690 + return err; +#line 1690 +} +#line 1690 + +static int +#line 1691 +ncx_put_float_ushort(void *xp, const ushort *ip, void *fillp) +#line 1691 +{ +#line 1691 + int err=NC_NOERR; +#line 1691 + ix_float xx = NC_FILL_FLOAT; +#line 1691 + +#line 1691 + +#line 1691 + xx = (ix_float)*ip; +#line 1691 + +#line 1691 + put_ix_float(xp, &xx); +#line 1691 + return err; +#line 1691 +} +#line 1691 + +static int +#line 1692 +ncx_put_float_uint(void *xp, const uint *ip, void *fillp) +#line 1692 +{ +#line 1692 + int err=NC_NOERR; +#line 1692 + ix_float xx = NC_FILL_FLOAT; +#line 1692 + +#line 1692 + +#line 1692 + xx = (ix_float)*ip; +#line 1692 + +#line 1692 + put_ix_float(xp, &xx); +#line 1692 + return err; +#line 1692 +} +#line 1692 + +static int +#line 1693 +ncx_put_float_ulonglong(void *xp, const ulonglong *ip, void *fillp) +#line 1693 +{ +#line 1693 + int err=NC_NOERR; +#line 1693 + ix_float xx = NC_FILL_FLOAT; +#line 1693 + +#line 1693 + +#line 1693 + xx = (ix_float)*ip; +#line 1693 + +#line 1693 + put_ix_float(xp, &xx); +#line 1693 + return err; +#line 1693 +} +#line 1693 + + + +/* external NC_DOUBLE -------------------------------------------------------*/ + +#if X_SIZEOF_DOUBLE == SIZEOF_DOUBLE && !defined(NO_IEEE_FLOAT) + +static void +get_ix_double(const void *xp, double *ip) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(ip, xp, SIZEOF_DOUBLE); +#else + swap8b(ip, xp); +#endif +} + +static void +put_ix_double(void *xp, const double *ip) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(xp, ip, X_SIZEOF_DOUBLE); +#else + swap8b(xp, ip); +#endif +} + +#elif defined(vax) && vax != 0 + +/* What IEEE double precision floating point looks like on a Vax */ +struct ieee_double { + unsigned int exp_hi : 7; + unsigned int sign : 1; + unsigned int mant_6 : 4; + unsigned int exp_lo : 4; + unsigned int mant_5 : 8; + unsigned int mant_4 : 8; + + unsigned int mant_lo : 32; +}; + +/* Vax double precision floating point */ +struct vax_double { + unsigned int mantissa1 : 7; + unsigned int exp : 8; + unsigned int sign : 1; + unsigned int mantissa2 : 16; + unsigned int mantissa3 : 16; + unsigned int mantissa4 : 16; +}; + +#define VAX_DBL_BIAS 0x81 +#define IEEE_DBL_BIAS 0x3ff +#define MASK(nbits) ((1 << nbits) - 1) + +static const struct dbl_limits { + struct vax_double d; + struct ieee_double ieee; +} dbl_limits[2] = { + {{ 0x7f, 0xff, 0x0, 0xffff, 0xffff, 0xffff }, /* Max Vax */ + { 0x7f, 0x0, 0x0, 0xf, 0x0, 0x0, 0x0}}, /* Max IEEE */ + {{ 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* Min Vax */ + { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}}, /* Min IEEE */ +}; + + +#line 1807 +static void +get_ix_double(const void *xp, double *ip) +{ + struct vax_double *const vdp = +#line 1810 + (struct vax_double *)ip; +#line 1810 + const struct ieee_double *const idp = +#line 1810 + (const struct ieee_double *) xp; +#line 1810 + { +#line 1810 + const struct dbl_limits *lim; +#line 1810 + int ii; +#line 1810 + for (ii = 0, lim = dbl_limits; +#line 1810 + ii < sizeof(dbl_limits)/sizeof(struct dbl_limits); +#line 1810 + ii++, lim++) +#line 1810 + { +#line 1810 + if ((idp->mant_lo == lim->ieee.mant_lo) +#line 1810 + && (idp->mant_4 == lim->ieee.mant_4) +#line 1810 + && (idp->mant_5 == lim->ieee.mant_5) +#line 1810 + && (idp->mant_6 == lim->ieee.mant_6) +#line 1810 + && (idp->exp_lo == lim->ieee.exp_lo) +#line 1810 + && (idp->exp_hi == lim->ieee.exp_hi) +#line 1810 + ) +#line 1810 + { +#line 1810 + *vdp = lim->d; +#line 1810 + goto doneit; +#line 1810 + } +#line 1810 + } +#line 1810 + } +#line 1810 + { +#line 1810 + unsigned exp = idp->exp_hi << 4 | idp->exp_lo; +#line 1810 + vdp->exp = exp - IEEE_DBL_BIAS + VAX_DBL_BIAS; +#line 1810 + } +#line 1810 + { +#line 1810 + unsigned mant_hi = ((idp->mant_6 << 16) +#line 1810 + | (idp->mant_5 << 8) +#line 1810 + | idp->mant_4); +#line 1810 + unsigned mant_lo = SWAP4(idp->mant_lo); +#line 1810 + vdp->mantissa1 = (mant_hi >> 13); +#line 1810 + vdp->mantissa2 = ((mant_hi & MASK(13)) << 3) +#line 1810 + | (mant_lo >> 29); +#line 1810 + vdp->mantissa3 = (mant_lo >> 13); +#line 1810 + vdp->mantissa4 = (mant_lo << 3); +#line 1810 + } +#line 1810 + doneit: +#line 1810 + vdp->sign = idp->sign; +#line 1810 + +} + + +#line 1880 +static void +put_ix_double(void *xp, const double *ip) +{ + const struct vax_double *const vdp = +#line 1883 + (const struct vax_double *)ip; +#line 1883 + struct ieee_double *const idp = +#line 1883 + (struct ieee_double *) xp; +#line 1883 + +#line 1883 + if ((vdp->mantissa4 > (dbl_limits[0].d.mantissa4 - 3)) && +#line 1883 + (vdp->mantissa3 == dbl_limits[0].d.mantissa3) && +#line 1883 + (vdp->mantissa2 == dbl_limits[0].d.mantissa2) && +#line 1883 + (vdp->mantissa1 == dbl_limits[0].d.mantissa1) && +#line 1883 + (vdp->exp == dbl_limits[0].d.exp)) +#line 1883 + { +#line 1883 + *idp = dbl_limits[0].ieee; +#line 1883 + goto shipit; +#line 1883 + } +#line 1883 + if ((vdp->mantissa4 == dbl_limits[1].d.mantissa4) && +#line 1883 + (vdp->mantissa3 == dbl_limits[1].d.mantissa3) && +#line 1883 + (vdp->mantissa2 == dbl_limits[1].d.mantissa2) && +#line 1883 + (vdp->mantissa1 == dbl_limits[1].d.mantissa1) && +#line 1883 + (vdp->exp == dbl_limits[1].d.exp)) +#line 1883 + { +#line 1883 + *idp = dbl_limits[1].ieee; +#line 1883 + goto shipit; +#line 1883 + } +#line 1883 + +#line 1883 + { +#line 1883 + unsigned exp = vdp->exp - VAX_DBL_BIAS + IEEE_DBL_BIAS; +#line 1883 + +#line 1883 + unsigned mant_lo = ((vdp->mantissa2 & MASK(3)) << 29) | +#line 1883 + (vdp->mantissa3 << 13) | +#line 1883 + ((vdp->mantissa4 >> 3) & MASK(13)); +#line 1883 + +#line 1883 + unsigned mant_hi = (vdp->mantissa1 << 13) +#line 1883 + | (vdp->mantissa2 >> 3); +#line 1883 + +#line 1883 + if ((vdp->mantissa4 & 7) > 4) +#line 1883 + { +#line 1883 + /* round up */ +#line 1883 + mant_lo++; +#line 1883 + if (mant_lo == 0) +#line 1883 + { +#line 1883 + mant_hi++; +#line 1883 + if (mant_hi > 0xffffff) +#line 1883 + { +#line 1883 + mant_hi = 0; +#line 1883 + exp++; +#line 1883 + } +#line 1883 + } +#line 1883 + } +#line 1883 + +#line 1883 + idp->mant_lo = SWAP4(mant_lo); +#line 1883 + idp->mant_6 = mant_hi >> 16; +#line 1883 + idp->mant_5 = (mant_hi & 0xff00) >> 8; +#line 1883 + idp->mant_4 = mant_hi; +#line 1883 + idp->exp_hi = exp >> 4; +#line 1883 + idp->exp_lo = exp; +#line 1883 + } +#line 1883 + +#line 1883 + shipit: +#line 1883 + idp->sign = vdp->sign; +#line 1883 + +} + + /* vax */ +#elif defined(_CRAY) && !defined(__crayx1) + +static void +get_ix_double(const void *xp, double *ip) +{ + const ieee_double *idp = (const ieee_double *) xp; + cray_single *csp = (cray_single *) ip; + + if (idp->exp == 0) + { + /* ieee subnormal */ + *ip = (double)idp->mant; + if (idp->mant != 0) + { + csp->exp -= (ieee_double_bias + 51); + } + } + else + { + csp->exp = idp->exp + cs_id_bias + 1; + csp->mant = idp->mant >> (52 - 48 + 1); + csp->mant |= (1 << (48 - 1)); + } + csp->sign = idp->sign; +} + +static void +put_ix_double(void *xp, const double *ip) +{ + ieee_double *idp = (ieee_double *) xp; + const cray_single *csp = (const cray_single *) ip; + + int ieee_exp = csp->exp - cs_id_bias -1; + + idp->sign = csp->sign; + + if (ieee_exp >= 0x7ff) + { + /* NC_ERANGE => ieee Inf */ + idp->exp = 0x7ff; + idp->mant = 0x0; + } + else if (ieee_exp > 0) + { + /* normal ieee representation */ + idp->exp = ieee_exp; + /* assumes cray rep is in normal form */ + assert(csp->mant & 0x800000000000); + idp->mant = (((csp->mant << 1) & + 0xffffffffffff) << (52 - 48)); + } + else if (ieee_exp >= (-(52 -48))) + { + /* ieee subnormal, left shift */ + const int lshift = (52 - 48) + ieee_exp; + idp->mant = csp->mant << lshift; + idp->exp = 0; + } + else if (ieee_exp >= -52) + { + /* ieee subnormal, right shift */ + const int rshift = (- (52 - 48) - ieee_exp); + + idp->mant = csp->mant >> rshift; + +#if 0 + if (csp->mant & (1 << (rshift -1))) + { + /* round up */ + idp->mant++; + } +#endif + + idp->exp = 0; + } + else + { + /* smaller than ieee can represent */ + idp->exp = 0; + idp->mant = 0; + } +} +#else +#error "ix_double implementation" +#endif + +#define ix_double double + +static int +#line 1975 +ncx_get_double_schar(const void *xp, schar *ip) +#line 1975 +{ +#line 1975 + ix_double xx = 0; +#line 1975 + get_ix_double(xp, &xx); +#line 1975 + if (xx > (double)SCHAR_MAX || xx < (double)SCHAR_MIN) { +#line 1975 +#ifdef ERANGE_FILL +#line 1975 + *ip = NC_FILL_BYTE; +#line 1975 +#endif +#line 1975 + return NC_ERANGE; +#line 1975 + } +#line 1975 + *ip = (schar)xx; +#line 1975 + return NC_NOERR; +#line 1975 +} +#line 1975 + +static int +#line 1976 +ncx_get_double_short(const void *xp, short *ip) +#line 1976 +{ +#line 1976 + ix_double xx = 0; +#line 1976 + get_ix_double(xp, &xx); +#line 1976 + if (xx > (double)SHORT_MAX || xx < (double)SHORT_MIN) { +#line 1976 +#ifdef ERANGE_FILL +#line 1976 + *ip = NC_FILL_SHORT; +#line 1976 +#endif +#line 1976 + return NC_ERANGE; +#line 1976 + } +#line 1976 + *ip = (short)xx; +#line 1976 + return NC_NOERR; +#line 1976 +} +#line 1976 + +static int +#line 1977 +ncx_get_double_int(const void *xp, int *ip) +#line 1977 +{ +#line 1977 + ix_double xx = 0; +#line 1977 + get_ix_double(xp, &xx); +#line 1977 + if (xx > (double)INT_MAX || xx < (double)INT_MIN) { +#line 1977 +#ifdef ERANGE_FILL +#line 1977 + *ip = NC_FILL_INT; +#line 1977 +#endif +#line 1977 + return NC_ERANGE; +#line 1977 + } +#line 1977 + *ip = (int)xx; +#line 1977 + return NC_NOERR; +#line 1977 +} +#line 1977 + +static int +#line 1978 +ncx_get_double_long(const void *xp, long *ip) +#line 1978 +{ +#line 1978 + ix_double xx = 0; +#line 1978 + get_ix_double(xp, &xx); +#line 1978 + if (xx > (double)LONG_MAX || xx < (double)LONG_MIN) { +#line 1978 +#ifdef ERANGE_FILL +#line 1978 + *ip = NC_FILL_INT; +#line 1978 +#endif +#line 1978 + return NC_ERANGE; +#line 1978 + } +#line 1978 + *ip = (long)xx; +#line 1978 + return NC_NOERR; +#line 1978 +} +#line 1978 + +static int +#line 1979 +ncx_get_double_longlong(const void *xp, longlong *ip) +#line 1979 +{ +#line 1979 + ix_double xx = 0; +#line 1979 + get_ix_double(xp, &xx); +#line 1979 + if (xx == LONGLONG_MAX) *ip = LONGLONG_MAX; +#line 1979 + else if (xx == LONGLONG_MIN) *ip = LONGLONG_MIN; +#line 1979 + else if (xx > (double)LONGLONG_MAX || xx < (double)LONGLONG_MIN) { +#line 1979 +#ifdef ERANGE_FILL +#line 1979 + *ip = NC_FILL_INT64; +#line 1979 +#endif +#line 1979 + return NC_ERANGE; +#line 1979 + } +#line 1979 + else *ip = (longlong)xx; +#line 1979 + return NC_NOERR; +#line 1979 +} +#line 1979 + +static int +#line 1980 +ncx_get_double_uchar(const void *xp, uchar *ip) +#line 1980 +{ +#line 1980 + ix_double xx = 0; +#line 1980 + get_ix_double(xp, &xx); +#line 1980 + if (xx > (double)UCHAR_MAX || xx < 0) { +#line 1980 +#ifdef ERANGE_FILL +#line 1980 + *ip = NC_FILL_UBYTE; +#line 1980 +#endif +#line 1980 + return NC_ERANGE; +#line 1980 + } +#line 1980 + *ip = (uchar)xx; +#line 1980 + return NC_NOERR; +#line 1980 +} +#line 1980 + +static int +#line 1981 +ncx_get_double_ushort(const void *xp, ushort *ip) +#line 1981 +{ +#line 1981 + ix_double xx = 0; +#line 1981 + get_ix_double(xp, &xx); +#line 1981 + if (xx > (double)USHORT_MAX || xx < 0) { +#line 1981 +#ifdef ERANGE_FILL +#line 1981 + *ip = NC_FILL_USHORT; +#line 1981 +#endif +#line 1981 + return NC_ERANGE; +#line 1981 + } +#line 1981 + *ip = (ushort)xx; +#line 1981 + return NC_NOERR; +#line 1981 +} +#line 1981 + +static int +#line 1982 +ncx_get_double_uint(const void *xp, uint *ip) +#line 1982 +{ +#line 1982 + ix_double xx = 0; +#line 1982 + get_ix_double(xp, &xx); +#line 1982 + if (xx > (double)UINT_MAX || xx < 0) { +#line 1982 +#ifdef ERANGE_FILL +#line 1982 + *ip = NC_FILL_UINT; +#line 1982 +#endif +#line 1982 + return NC_ERANGE; +#line 1982 + } +#line 1982 + *ip = (uint)xx; +#line 1982 + return NC_NOERR; +#line 1982 +} +#line 1982 + +static int +#line 1983 +ncx_get_double_ulonglong(const void *xp, ulonglong *ip) +#line 1983 +{ +#line 1983 + ix_double xx = 0; +#line 1983 + get_ix_double(xp, &xx); +#line 1983 + if (xx == ULONGLONG_MAX) *ip = ULONGLONG_MAX; +#line 1983 + else if (xx > (double)ULONGLONG_MAX || xx < 0) { +#line 1983 +#ifdef ERANGE_FILL +#line 1983 + *ip = NC_FILL_UINT64; +#line 1983 +#endif +#line 1983 + return NC_ERANGE; +#line 1983 + } +#line 1983 + else *ip = (ulonglong)xx; +#line 1983 + return NC_NOERR; +#line 1983 +} +#line 1983 + + +static int +ncx_get_double_float(const void *xp, float *ip) +{ + double xx = 0.0; + get_ix_double(xp, &xx); + if (xx > FLT_MAX) { +#ifdef ERANGE_FILL + *ip = NC_FILL_FLOAT; +#else + *ip = FLT_MAX; +#endif + return NC_ERANGE; + } + if (xx < (-FLT_MAX)) { +#ifdef ERANGE_FILL + *ip = NC_FILL_FLOAT; +#else + *ip = (-FLT_MAX); +#endif + return NC_ERANGE; + } + *ip = (float) xx; + return NC_NOERR; +} + +#if X_SIZEOF_DOUBLE != SIZEOF_DOUBLE || defined(NO_IEEE_FLOAT) +static int +ncx_get_double_double(const void *xp, double *ip, void *fillp) +{ + /* TODO */ + get_ix_double(xp, ip); + return NC_NOERR; +} +#endif + +static int +#line 2020 +ncx_put_double_schar(void *xp, const schar *ip, void *fillp) +#line 2020 +{ +#line 2020 + int err=NC_NOERR; +#line 2020 + ix_double xx = NC_FILL_DOUBLE; +#line 2020 + +#line 2020 + +#line 2020 + xx = (ix_double)*ip; +#line 2020 + +#line 2020 + put_ix_double(xp, &xx); +#line 2020 + return err; +#line 2020 +} +#line 2020 + +static int +#line 2021 +ncx_put_double_uchar(void *xp, const uchar *ip, void *fillp) +#line 2021 +{ +#line 2021 + int err=NC_NOERR; +#line 2021 + ix_double xx = NC_FILL_DOUBLE; +#line 2021 + +#line 2021 + +#line 2021 + xx = (ix_double)*ip; +#line 2021 + +#line 2021 + put_ix_double(xp, &xx); +#line 2021 + return err; +#line 2021 +} +#line 2021 + +static int +#line 2022 +ncx_put_double_short(void *xp, const short *ip, void *fillp) +#line 2022 +{ +#line 2022 + int err=NC_NOERR; +#line 2022 + ix_double xx = NC_FILL_DOUBLE; +#line 2022 + +#line 2022 + +#line 2022 + xx = (ix_double)*ip; +#line 2022 + +#line 2022 + put_ix_double(xp, &xx); +#line 2022 + return err; +#line 2022 +} +#line 2022 + +static int +#line 2023 +ncx_put_double_ushort(void *xp, const ushort *ip, void *fillp) +#line 2023 +{ +#line 2023 + int err=NC_NOERR; +#line 2023 + ix_double xx = NC_FILL_DOUBLE; +#line 2023 + +#line 2023 + +#line 2023 + xx = (ix_double)*ip; +#line 2023 + +#line 2023 + put_ix_double(xp, &xx); +#line 2023 + return err; +#line 2023 +} +#line 2023 + +static int +#line 2024 +ncx_put_double_int(void *xp, const int *ip, void *fillp) +#line 2024 +{ +#line 2024 + int err=NC_NOERR; +#line 2024 + ix_double xx = NC_FILL_DOUBLE; +#line 2024 + +#line 2024 + +#line 2024 + xx = (ix_double)*ip; +#line 2024 + +#line 2024 + put_ix_double(xp, &xx); +#line 2024 + return err; +#line 2024 +} +#line 2024 + +static int +#line 2025 +ncx_put_double_long(void *xp, const long *ip, void *fillp) +#line 2025 +{ +#line 2025 + int err=NC_NOERR; +#line 2025 + ix_double xx = NC_FILL_DOUBLE; +#line 2025 + +#line 2025 + +#line 2025 + xx = (ix_double)*ip; +#line 2025 + +#line 2025 + put_ix_double(xp, &xx); +#line 2025 + return err; +#line 2025 +} +#line 2025 + +static int +#line 2026 +ncx_put_double_uint(void *xp, const uint *ip, void *fillp) +#line 2026 +{ +#line 2026 + int err=NC_NOERR; +#line 2026 + ix_double xx = NC_FILL_DOUBLE; +#line 2026 + +#line 2026 + +#line 2026 + xx = (ix_double)*ip; +#line 2026 + +#line 2026 + put_ix_double(xp, &xx); +#line 2026 + return err; +#line 2026 +} +#line 2026 + +static int +#line 2027 +ncx_put_double_longlong(void *xp, const longlong *ip, void *fillp) +#line 2027 +{ +#line 2027 + int err=NC_NOERR; +#line 2027 + ix_double xx = NC_FILL_DOUBLE; +#line 2027 + +#line 2027 + +#line 2027 + xx = (ix_double)*ip; +#line 2027 + +#line 2027 + put_ix_double(xp, &xx); +#line 2027 + return err; +#line 2027 +} +#line 2027 + +static int +#line 2028 +ncx_put_double_ulonglong(void *xp, const ulonglong *ip, void *fillp) +#line 2028 +{ +#line 2028 + int err=NC_NOERR; +#line 2028 + ix_double xx = NC_FILL_DOUBLE; +#line 2028 + +#line 2028 + +#line 2028 + xx = (ix_double)*ip; +#line 2028 + +#line 2028 + put_ix_double(xp, &xx); +#line 2028 + return err; +#line 2028 +} +#line 2028 + + +static int +ncx_put_double_float(void *xp, const float *ip, void *fillp) +{ + int err=NC_NOERR; + double xx = NC_FILL_DOUBLE; +#if 1 /* TODO: figure this out (if condition below will never be true)*/ + if ((double)(*ip) > X_DOUBLE_MAX || (double)(*ip) < X_DOUBLE_MIN) { + +#line 2037 +#ifdef ERANGE_FILL +#line 2037 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2037 +#endif + err = NC_ERANGE; + } +#ifdef ERANGE_FILL + else +#endif +#endif + xx = (double) *ip; + + put_ix_double(xp, &xx); + return err; +} + +#if X_SIZEOF_DOUBLE != SIZEOF_DOUBLE || defined(NO_IEEE_FLOAT) +static int +ncx_put_double_double(void *xp, const double *ip, void *fillp) +{ + int err=NC_NOERR; + double *_ip = ip; +#ifdef NO_IEEE_FLOAT +#ifdef ERANGE_FILL + double tmp=NC_FILL_DOUBLE; +#endif + if (*ip > X_DOUBLE_MAX || *ip < X_DOUBLE_MIN) { + +#line 2061 +#ifdef ERANGE_FILL +#line 2061 + if (fillp != NULL) memcpy(&tmp, fillp, 8); +#line 2061 +#endif +#ifdef ERANGE_FILL + _ip = &tmp; +#endif + err = NC_ERANGE; + } +#endif + put_ix_double(xp, _ip); + return err; +} +#endif + + +/* external NC_INT64 --------------------------------------------------------*/ + +#if SHORT_MAX == X_INT64_MAX +typedef short ix_int64; +#define SIZEOF_IX_INT64 SIZEOF_SHORT +#define IX_INT64_MAX SHORT_MAX +#elif LONG_LONG_MAX >= X_INT64_MAX +typedef longlong ix_int64; +#define SIZEOF_IX_INT64 SIZEOF_LONGLONG +#define IX_INT64_MAX LONG_LONG_MAX +#elif LONG_MAX >= X_INT64_MAX +typedef long ix_int64; +#define SIZEOF_IX_INT64 SIZEOF_LONG +#define IX_INT64_MAX LONG_MAX +#else +#error "ix_int64 implementation" +#endif + + +static void +get_ix_int64(const void *xp, ix_int64 *ip) +{ + const uchar *cp = (const uchar *) xp; + + *ip = ((ix_int64)(*cp++) << 56); + *ip |= ((ix_int64)(*cp++) << 48); + *ip |= ((ix_int64)(*cp++) << 40); + *ip |= ((ix_int64)(*cp++) << 32); + *ip |= ((ix_int64)(*cp++) << 24); + *ip |= ((ix_int64)(*cp++) << 16); + *ip |= ((ix_int64)(*cp++) << 8); + *ip |= (ix_int64)*cp; +} + +static void +put_ix_int64(void *xp, const ix_int64 *ip) +{ + uchar *cp = (uchar *) xp; + + *cp++ = (uchar)((*ip) >> 56); + *cp++ = (uchar)(((*ip) & 0x00ff000000000000LL) >> 48); + *cp++ = (uchar)(((*ip) & 0x0000ff0000000000LL) >> 40); + *cp++ = (uchar)(((*ip) & 0x000000ff00000000LL) >> 32); + *cp++ = (uchar)(((*ip) & 0x00000000ff000000LL) >> 24); + *cp++ = (uchar)(((*ip) & 0x0000000000ff0000LL) >> 16); + *cp++ = (uchar)(((*ip) & 0x000000000000ff00LL) >> 8); + *cp = (uchar)( (*ip) & 0x00000000000000ffLL); +} + +#if X_SIZEOF_INT64 != SIZEOF_LONGLONG +static int +#line 2124 +ncx_get_longlong_longlong(const void *xp, longlong *ip) +#line 2124 +{ +#line 2124 + int err=NC_NOERR; +#line 2124 +#if SIZEOF_IX_INT64 == SIZEOF_LONGLONG && IX_INT64_MAX == LONGLONG_MAX +#line 2124 + get_ix_int64(xp, (ix_int64 *)ip); +#line 2124 +#else +#line 2124 + ix_int64 xx = 0; +#line 2124 + get_ix_int64(xp, &xx); +#line 2124 + +#line 2124 +#if IX_INT64_MAX > LONGLONG_MAX +#line 2124 + if (xx > LONGLONG_MAX || xx < LONGLONG_MIN) { +#line 2124 +#ifdef ERANGE_FILL +#line 2124 + *ip = NC_FILL_INT64; +#line 2124 + return NC_ERANGE; +#line 2124 +#else +#line 2124 + err = NC_ERANGE; +#line 2124 +#endif +#line 2124 + } +#line 2124 +#endif +#line 2124 + +#line 2124 + +#line 2124 + *ip = (longlong) xx; +#line 2124 +#endif +#line 2124 + return err; +#line 2124 +} +#line 2124 + +#endif +static int +#line 2126 +ncx_get_longlong_schar(const void *xp, schar *ip) +#line 2126 +{ +#line 2126 + int err=NC_NOERR; +#line 2126 + ix_int64 xx = 0; +#line 2126 + get_ix_int64(xp, &xx); +#line 2126 + +#line 2126 +#if IX_INT64_MAX > SCHAR_MAX +#line 2126 + if (xx > SCHAR_MAX || xx < SCHAR_MIN) { +#line 2126 +#ifdef ERANGE_FILL +#line 2126 + *ip = NC_FILL_BYTE; +#line 2126 + return NC_ERANGE; +#line 2126 +#else +#line 2126 + err = NC_ERANGE; +#line 2126 +#endif +#line 2126 + } +#line 2126 +#endif +#line 2126 + +#line 2126 + +#line 2126 + *ip = (schar) xx; +#line 2126 + return err; +#line 2126 +} +#line 2126 + +static int +#line 2127 +ncx_get_longlong_short(const void *xp, short *ip) +#line 2127 +{ +#line 2127 + int err=NC_NOERR; +#line 2127 +#if SIZEOF_IX_INT64 == SIZEOF_SHORT && IX_INT64_MAX == SHORT_MAX +#line 2127 + get_ix_int64(xp, (ix_int64 *)ip); +#line 2127 +#else +#line 2127 + ix_int64 xx = 0; +#line 2127 + get_ix_int64(xp, &xx); +#line 2127 + +#line 2127 +#if IX_INT64_MAX > SHORT_MAX +#line 2127 + if (xx > SHORT_MAX || xx < SHORT_MIN) { +#line 2127 +#ifdef ERANGE_FILL +#line 2127 + *ip = NC_FILL_SHORT; +#line 2127 + return NC_ERANGE; +#line 2127 +#else +#line 2127 + err = NC_ERANGE; +#line 2127 +#endif +#line 2127 + } +#line 2127 +#endif +#line 2127 + +#line 2127 + +#line 2127 + *ip = (short) xx; +#line 2127 +#endif +#line 2127 + return err; +#line 2127 +} +#line 2127 + +static int +#line 2128 +ncx_get_longlong_int(const void *xp, int *ip) +#line 2128 +{ +#line 2128 + int err=NC_NOERR; +#line 2128 +#if SIZEOF_IX_INT64 == SIZEOF_INT && IX_INT64_MAX == INT_MAX +#line 2128 + get_ix_int64(xp, (ix_int64 *)ip); +#line 2128 +#else +#line 2128 + ix_int64 xx = 0; +#line 2128 + get_ix_int64(xp, &xx); +#line 2128 + +#line 2128 +#if IX_INT64_MAX > INT_MAX +#line 2128 + if (xx > INT_MAX || xx < INT_MIN) { +#line 2128 +#ifdef ERANGE_FILL +#line 2128 + *ip = NC_FILL_INT; +#line 2128 + return NC_ERANGE; +#line 2128 +#else +#line 2128 + err = NC_ERANGE; +#line 2128 +#endif +#line 2128 + } +#line 2128 +#endif +#line 2128 + +#line 2128 + +#line 2128 + *ip = (int) xx; +#line 2128 +#endif +#line 2128 + return err; +#line 2128 +} +#line 2128 + +static int +#line 2129 +ncx_get_longlong_long(const void *xp, long *ip) +#line 2129 +{ +#line 2129 + int err=NC_NOERR; +#line 2129 +#if SIZEOF_IX_INT64 == SIZEOF_LONG && IX_INT64_MAX == LONG_MAX +#line 2129 + get_ix_int64(xp, (ix_int64 *)ip); +#line 2129 +#else +#line 2129 + ix_int64 xx = 0; +#line 2129 + get_ix_int64(xp, &xx); +#line 2129 + +#line 2129 +#if IX_INT64_MAX > LONG_MAX +#line 2129 + if (xx > LONG_MAX || xx < LONG_MIN) { +#line 2129 +#ifdef ERANGE_FILL +#line 2129 + *ip = NC_FILL_INT; +#line 2129 + return NC_ERANGE; +#line 2129 +#else +#line 2129 + err = NC_ERANGE; +#line 2129 +#endif +#line 2129 + } +#line 2129 +#endif +#line 2129 + +#line 2129 + +#line 2129 + *ip = (long) xx; +#line 2129 +#endif +#line 2129 + return err; +#line 2129 +} +#line 2129 + +static int +#line 2130 +ncx_get_longlong_ushort(const void *xp, ushort *ip) +#line 2130 +{ +#line 2130 + int err=NC_NOERR; +#line 2130 + ix_int64 xx = 0; +#line 2130 + get_ix_int64(xp, &xx); +#line 2130 + +#line 2130 +#if IX_INT64_MAX > USHORT_MAX +#line 2130 + if (xx > USHORT_MAX) { +#line 2130 +#ifdef ERANGE_FILL +#line 2130 + *ip = NC_FILL_USHORT; +#line 2130 + return NC_ERANGE; +#line 2130 +#else +#line 2130 + err = NC_ERANGE; +#line 2130 +#endif +#line 2130 + } +#line 2130 +#endif +#line 2130 + +#line 2130 + if (xx < 0) { +#line 2130 +#ifdef ERANGE_FILL +#line 2130 + *ip = NC_FILL_USHORT; +#line 2130 + return NC_ERANGE; +#line 2130 +#else +#line 2130 + err = NC_ERANGE; /* because ip is unsigned */ +#line 2130 +#endif +#line 2130 + } +#line 2130 + *ip = (ushort) xx; +#line 2130 + return err; +#line 2130 +} +#line 2130 + +static int +#line 2131 +ncx_get_longlong_uchar(const void *xp, uchar *ip) +#line 2131 +{ +#line 2131 + int err=NC_NOERR; +#line 2131 + ix_int64 xx = 0; +#line 2131 + get_ix_int64(xp, &xx); +#line 2131 + +#line 2131 +#if IX_INT64_MAX > UCHAR_MAX +#line 2131 + if (xx > UCHAR_MAX) { +#line 2131 +#ifdef ERANGE_FILL +#line 2131 + *ip = NC_FILL_UBYTE; +#line 2131 + return NC_ERANGE; +#line 2131 +#else +#line 2131 + err = NC_ERANGE; +#line 2131 +#endif +#line 2131 + } +#line 2131 +#endif +#line 2131 + +#line 2131 + if (xx < 0) { +#line 2131 +#ifdef ERANGE_FILL +#line 2131 + *ip = NC_FILL_UBYTE; +#line 2131 + return NC_ERANGE; +#line 2131 +#else +#line 2131 + err = NC_ERANGE; /* because ip is unsigned */ +#line 2131 +#endif +#line 2131 + } +#line 2131 + *ip = (uchar) xx; +#line 2131 + return err; +#line 2131 +} +#line 2131 + +static int +#line 2132 +ncx_get_longlong_uint(const void *xp, uint *ip) +#line 2132 +{ +#line 2132 + int err=NC_NOERR; +#line 2132 + ix_int64 xx = 0; +#line 2132 + get_ix_int64(xp, &xx); +#line 2132 + +#line 2132 +#if IX_INT64_MAX > UINT_MAX +#line 2132 + if (xx > UINT_MAX) { +#line 2132 +#ifdef ERANGE_FILL +#line 2132 + *ip = NC_FILL_UINT; +#line 2132 + return NC_ERANGE; +#line 2132 +#else +#line 2132 + err = NC_ERANGE; +#line 2132 +#endif +#line 2132 + } +#line 2132 +#endif +#line 2132 + +#line 2132 + if (xx < 0) { +#line 2132 +#ifdef ERANGE_FILL +#line 2132 + *ip = NC_FILL_UINT; +#line 2132 + return NC_ERANGE; +#line 2132 +#else +#line 2132 + err = NC_ERANGE; /* because ip is unsigned */ +#line 2132 +#endif +#line 2132 + } +#line 2132 + *ip = (uint) xx; +#line 2132 + return err; +#line 2132 +} +#line 2132 + +static int +#line 2133 +ncx_get_longlong_ulonglong(const void *xp, ulonglong *ip) +#line 2133 +{ +#line 2133 + int err=NC_NOERR; +#line 2133 + ix_int64 xx = 0; +#line 2133 + get_ix_int64(xp, &xx); +#line 2133 + +#line 2133 +#if IX_INT64_MAX > ULONGLONG_MAX +#line 2133 + if (xx > ULONGLONG_MAX) { +#line 2133 +#ifdef ERANGE_FILL +#line 2133 + *ip = NC_FILL_UINT64; +#line 2133 + return NC_ERANGE; +#line 2133 +#else +#line 2133 + err = NC_ERANGE; +#line 2133 +#endif +#line 2133 + } +#line 2133 +#endif +#line 2133 + +#line 2133 + if (xx < 0) { +#line 2133 +#ifdef ERANGE_FILL +#line 2133 + *ip = NC_FILL_UINT64; +#line 2133 + return NC_ERANGE; +#line 2133 +#else +#line 2133 + err = NC_ERANGE; /* because ip is unsigned */ +#line 2133 +#endif +#line 2133 + } +#line 2133 + *ip = (ulonglong) xx; +#line 2133 + return err; +#line 2133 +} +#line 2133 + +static int +#line 2134 +ncx_get_longlong_float(const void *xp, float *ip) +#line 2134 +{ +#line 2134 + ix_int64 xx = 0; +#line 2134 + get_ix_int64(xp, &xx); +#line 2134 + *ip = (float)xx; +#line 2134 + return NC_NOERR; +#line 2134 +} +#line 2134 + +static int +#line 2135 +ncx_get_longlong_double(const void *xp, double *ip) +#line 2135 +{ +#line 2135 + ix_int64 xx = 0; +#line 2135 + get_ix_int64(xp, &xx); +#line 2135 + *ip = (double)xx; +#line 2135 + return NC_NOERR; +#line 2135 +} +#line 2135 + + +#if X_SIZEOF_INT64 != SIZEOF_LONGLONG +static int +#line 2138 +ncx_put_longlong_longlong(void *xp, const longlong *ip, void *fillp) +#line 2138 +{ +#line 2138 + int err=NC_NOERR; +#line 2138 +#if SIZEOF_IX_INT64 == SIZEOF_LONGLONG && IX_INT64_MAX == LONGLONG_MAX +#line 2138 + put_ix_int64(xp, (const ix_int64 *)ip); +#line 2138 +#else +#line 2138 + ix_int64 xx = NC_FILL_INT64; +#line 2138 + +#line 2138 +#if IX_INT64_MAX < LONGLONG_MAX +#line 2138 + if (*ip > IX_INT64_MAX || *ip < X_INT64_MIN) { +#line 2138 + +#line 2138 +#ifdef ERANGE_FILL +#line 2138 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2138 +#endif +#line 2138 + err = NC_ERANGE; +#line 2138 + } +#line 2138 +#ifdef ERANGE_FILL +#line 2138 + else +#line 2138 +#endif +#line 2138 +#endif +#line 2138 + xx = (ix_int64)*ip; +#line 2138 + +#line 2138 + put_ix_int64(xp, &xx); +#line 2138 +#endif +#line 2138 + return err; +#line 2138 +} +#line 2138 + +#endif +static int +#line 2140 +ncx_put_longlong_schar(void *xp, const schar *ip, void *fillp) +#line 2140 +{ +#line 2140 + int err=NC_NOERR; +#line 2140 + ix_int64 xx = NC_FILL_INT64; +#line 2140 + +#line 2140 +#if IX_INT64_MAX < SCHAR_MAX +#line 2140 + if (*ip > IX_INT64_MAX || *ip < X_INT64_MIN) { +#line 2140 + +#line 2140 +#ifdef ERANGE_FILL +#line 2140 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2140 +#endif +#line 2140 + err = NC_ERANGE; +#line 2140 + } +#line 2140 +#ifdef ERANGE_FILL +#line 2140 + else +#line 2140 +#endif +#line 2140 +#endif +#line 2140 + xx = (ix_int64)*ip; +#line 2140 + +#line 2140 + put_ix_int64(xp, &xx); +#line 2140 + return err; +#line 2140 +} +#line 2140 + +static int +#line 2141 +ncx_put_longlong_short(void *xp, const short *ip, void *fillp) +#line 2141 +{ +#line 2141 + int err=NC_NOERR; +#line 2141 +#if SIZEOF_IX_INT64 == SIZEOF_SHORT && IX_INT64_MAX == SHORT_MAX +#line 2141 + put_ix_int64(xp, (const ix_int64 *)ip); +#line 2141 +#else +#line 2141 + ix_int64 xx = NC_FILL_INT64; +#line 2141 + +#line 2141 +#if IX_INT64_MAX < SHORT_MAX +#line 2141 + if (*ip > IX_INT64_MAX || *ip < X_INT64_MIN) { +#line 2141 + +#line 2141 +#ifdef ERANGE_FILL +#line 2141 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2141 +#endif +#line 2141 + err = NC_ERANGE; +#line 2141 + } +#line 2141 +#ifdef ERANGE_FILL +#line 2141 + else +#line 2141 +#endif +#line 2141 +#endif +#line 2141 + xx = (ix_int64)*ip; +#line 2141 + +#line 2141 + put_ix_int64(xp, &xx); +#line 2141 +#endif +#line 2141 + return err; +#line 2141 +} +#line 2141 + +static int +#line 2142 +ncx_put_longlong_int(void *xp, const int *ip, void *fillp) +#line 2142 +{ +#line 2142 + int err=NC_NOERR; +#line 2142 +#if SIZEOF_IX_INT64 == SIZEOF_INT && IX_INT64_MAX == INT_MAX +#line 2142 + put_ix_int64(xp, (const ix_int64 *)ip); +#line 2142 +#else +#line 2142 + ix_int64 xx = NC_FILL_INT64; +#line 2142 + +#line 2142 +#if IX_INT64_MAX < INT_MAX +#line 2142 + if (*ip > IX_INT64_MAX || *ip < X_INT64_MIN) { +#line 2142 + +#line 2142 +#ifdef ERANGE_FILL +#line 2142 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2142 +#endif +#line 2142 + err = NC_ERANGE; +#line 2142 + } +#line 2142 +#ifdef ERANGE_FILL +#line 2142 + else +#line 2142 +#endif +#line 2142 +#endif +#line 2142 + xx = (ix_int64)*ip; +#line 2142 + +#line 2142 + put_ix_int64(xp, &xx); +#line 2142 +#endif +#line 2142 + return err; +#line 2142 +} +#line 2142 + +static int +#line 2143 +ncx_put_longlong_long(void *xp, const long *ip, void *fillp) +#line 2143 +{ +#line 2143 + int err=NC_NOERR; +#line 2143 +#if SIZEOF_IX_INT64 == SIZEOF_LONG && IX_INT64_MAX == LONG_MAX +#line 2143 + put_ix_int64(xp, (const ix_int64 *)ip); +#line 2143 +#else +#line 2143 + ix_int64 xx = NC_FILL_INT64; +#line 2143 + +#line 2143 +#if IX_INT64_MAX < LONG_MAX +#line 2143 + if (*ip > IX_INT64_MAX || *ip < X_INT64_MIN) { +#line 2143 + +#line 2143 +#ifdef ERANGE_FILL +#line 2143 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2143 +#endif +#line 2143 + err = NC_ERANGE; +#line 2143 + } +#line 2143 +#ifdef ERANGE_FILL +#line 2143 + else +#line 2143 +#endif +#line 2143 +#endif +#line 2143 + xx = (ix_int64)*ip; +#line 2143 + +#line 2143 + put_ix_int64(xp, &xx); +#line 2143 +#endif +#line 2143 + return err; +#line 2143 +} +#line 2143 + +static int +#line 2144 +ncx_put_longlong_ushort(void *xp, const ushort *ip, void *fillp) +#line 2144 +{ +#line 2144 + int err=NC_NOERR; +#line 2144 + ix_int64 xx = NC_FILL_INT64; +#line 2144 + +#line 2144 +#if IX_INT64_MAX < USHORT_MAX +#line 2144 + if (*ip > IX_INT64_MAX) { +#line 2144 + +#line 2144 +#ifdef ERANGE_FILL +#line 2144 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2144 +#endif +#line 2144 + err = NC_ERANGE; +#line 2144 + } +#line 2144 +#ifdef ERANGE_FILL +#line 2144 + else +#line 2144 +#endif +#line 2144 +#endif +#line 2144 + xx = (ix_int64)*ip; +#line 2144 + +#line 2144 + put_ix_int64(xp, &xx); +#line 2144 + return err; +#line 2144 +} +#line 2144 + +static int +#line 2145 +ncx_put_longlong_uchar(void *xp, const uchar *ip, void *fillp) +#line 2145 +{ +#line 2145 + int err=NC_NOERR; +#line 2145 + ix_int64 xx = NC_FILL_INT64; +#line 2145 + +#line 2145 +#if IX_INT64_MAX < UCHAR_MAX +#line 2145 + if (*ip > IX_INT64_MAX) { +#line 2145 + +#line 2145 +#ifdef ERANGE_FILL +#line 2145 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2145 +#endif +#line 2145 + err = NC_ERANGE; +#line 2145 + } +#line 2145 +#ifdef ERANGE_FILL +#line 2145 + else +#line 2145 +#endif +#line 2145 +#endif +#line 2145 + xx = (ix_int64)*ip; +#line 2145 + +#line 2145 + put_ix_int64(xp, &xx); +#line 2145 + return err; +#line 2145 +} +#line 2145 + +static int +#line 2146 +ncx_put_longlong_uint(void *xp, const uint *ip, void *fillp) +#line 2146 +{ +#line 2146 + int err=NC_NOERR; +#line 2146 + ix_int64 xx = NC_FILL_INT64; +#line 2146 + +#line 2146 +#if IX_INT64_MAX < UINT_MAX +#line 2146 + if (*ip > IX_INT64_MAX) { +#line 2146 + +#line 2146 +#ifdef ERANGE_FILL +#line 2146 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2146 +#endif +#line 2146 + err = NC_ERANGE; +#line 2146 + } +#line 2146 +#ifdef ERANGE_FILL +#line 2146 + else +#line 2146 +#endif +#line 2146 +#endif +#line 2146 + xx = (ix_int64)*ip; +#line 2146 + +#line 2146 + put_ix_int64(xp, &xx); +#line 2146 + return err; +#line 2146 +} +#line 2146 + +static int +#line 2147 +ncx_put_longlong_ulonglong(void *xp, const ulonglong *ip, void *fillp) +#line 2147 +{ +#line 2147 + int err=NC_NOERR; +#line 2147 + ix_int64 xx = NC_FILL_INT64; +#line 2147 + +#line 2147 +#if IX_INT64_MAX < ULONGLONG_MAX +#line 2147 + if (*ip > IX_INT64_MAX) { +#line 2147 + +#line 2147 +#ifdef ERANGE_FILL +#line 2147 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2147 +#endif +#line 2147 + err = NC_ERANGE; +#line 2147 + } +#line 2147 +#ifdef ERANGE_FILL +#line 2147 + else +#line 2147 +#endif +#line 2147 +#endif +#line 2147 + xx = (ix_int64)*ip; +#line 2147 + +#line 2147 + put_ix_int64(xp, &xx); +#line 2147 + return err; +#line 2147 +} +#line 2147 + +static int +#line 2148 +ncx_put_longlong_float(void *xp, const float *ip, void *fillp) +#line 2148 +{ +#line 2148 + int err=NC_NOERR; +#line 2148 + ix_int64 xx = NC_FILL_INT64; +#line 2148 + +#line 2148 + if (*ip > (double)X_INT64_MAX || *ip < (double)X_INT64_MIN) { +#line 2148 + +#line 2148 +#ifdef ERANGE_FILL +#line 2148 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2148 +#endif +#line 2148 + err = NC_ERANGE; +#line 2148 + } +#line 2148 +#ifdef ERANGE_FILL +#line 2148 + else +#line 2148 +#endif +#line 2148 + xx = (ix_int64)*ip; +#line 2148 + +#line 2148 + put_ix_int64(xp, &xx); +#line 2148 + return err; +#line 2148 +} +#line 2148 + +static int +#line 2149 +ncx_put_longlong_double(void *xp, const double *ip, void *fillp) +#line 2149 +{ +#line 2149 + int err=NC_NOERR; +#line 2149 + ix_int64 xx = NC_FILL_INT64; +#line 2149 + +#line 2149 + if (*ip > X_INT64_MAX || *ip < X_INT64_MIN) { +#line 2149 + +#line 2149 +#ifdef ERANGE_FILL +#line 2149 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2149 +#endif +#line 2149 + err = NC_ERANGE; +#line 2149 + } +#line 2149 +#ifdef ERANGE_FILL +#line 2149 + else +#line 2149 +#endif +#line 2149 + xx = (ix_int64)*ip; +#line 2149 + +#line 2149 + put_ix_int64(xp, &xx); +#line 2149 + return err; +#line 2149 +} +#line 2149 + + + +/* external NC_UINT64 -------------------------------------------------------*/ + +#if USHORT_MAX == X_UINT64_MAX +typedef ushort ix_uint64; +#define SIZEOF_IX_UINT64 SIZEOF_USHORT +#define IX_UINT64_MAX USHORT_MAX +#elif ULONG_LONG_MAX >= X_UINT64_MAX +typedef ulonglong ix_uint64; +#define SIZEOF_IX_UINT64 SIZEOF_ULONGLONG +#define IX_UINT64_MAX ULONG_LONG_MAX +#elif ULONG_MAX >= X_UINT64_MAX +typedef ulong ix_uint64; +#define SIZEOF_IX_UINT64 SIZEOF_ULONG +#define IX_UINT64_MAX ULONG_MAX +#else +#error "ix_uint64 implementation" +#endif + + +static void +get_ix_uint64(const void *xp, ix_uint64 *ip) +{ + const uchar *cp = (const uchar *) xp; + + *ip = ((ix_uint64)(*cp++) << 56); + *ip |= ((ix_uint64)(*cp++) << 48); + *ip |= ((ix_uint64)(*cp++) << 40); + *ip |= ((ix_uint64)(*cp++) << 32); + *ip |= ((ix_uint64)(*cp++) << 24); + *ip |= ((ix_uint64)(*cp++) << 16); + *ip |= ((ix_uint64)(*cp++) << 8); + *ip |= (ix_uint64)*cp; +} + +static void +put_ix_uint64(void *xp, const ix_uint64 *ip) +{ + uchar *cp = (uchar *) xp; + + *cp++ = (uchar)((*ip) >> 56); + *cp++ = (uchar)(((*ip) & 0x00ff000000000000ULL) >> 48); + *cp++ = (uchar)(((*ip) & 0x0000ff0000000000ULL) >> 40); + *cp++ = (uchar)(((*ip) & 0x000000ff00000000ULL) >> 32); + *cp++ = (uchar)(((*ip) & 0x00000000ff000000ULL) >> 24); + *cp++ = (uchar)(((*ip) & 0x0000000000ff0000ULL) >> 16); + *cp++ = (uchar)(((*ip) & 0x000000000000ff00ULL) >> 8); + *cp = (uchar)( (*ip) & 0x00000000000000ffULL); +} + +#if X_SIZEOF_UINT64 != SIZEOF_ULONGLONG +static int +#line 2202 +ncx_get_ulonglong_ulonglong(const void *xp, ulonglong *ip) +#line 2202 +{ +#line 2202 + int err=NC_NOERR; +#line 2202 +#if SIZEOF_IX_UINT64 == SIZEOF_ULONGLONG && IX_UINT64_MAX == ULONGLONG_MAX +#line 2202 + get_ix_uint64(xp, (ix_uint64 *)ip); +#line 2202 +#else +#line 2202 + ix_uint64 xx = 0; +#line 2202 + get_ix_uint64(xp, &xx); +#line 2202 + +#line 2202 +#if IX_UINT64_MAX > ULONGLONG_MAX +#line 2202 + if (xx > ULONGLONG_MAX) { +#line 2202 +#ifdef ERANGE_FILL +#line 2202 + *ip = NC_FILL_UINT64; +#line 2202 + return NC_ERANGE; +#line 2202 +#else +#line 2202 + err = NC_ERANGE; +#line 2202 +#endif +#line 2202 + } +#line 2202 +#endif +#line 2202 + +#line 2202 + +#line 2202 + *ip = (ulonglong) xx; +#line 2202 +#endif +#line 2202 + return err; +#line 2202 +} +#line 2202 + +#endif +static int +#line 2204 +ncx_get_ulonglong_schar(const void *xp, schar *ip) +#line 2204 +{ +#line 2204 + int err=NC_NOERR; +#line 2204 + ix_uint64 xx = 0; +#line 2204 + get_ix_uint64(xp, &xx); +#line 2204 + +#line 2204 +#if IX_UINT64_MAX > SCHAR_MAX +#line 2204 + if (xx > SCHAR_MAX) { +#line 2204 +#ifdef ERANGE_FILL +#line 2204 + *ip = NC_FILL_BYTE; +#line 2204 + return NC_ERANGE; +#line 2204 +#else +#line 2204 + err = NC_ERANGE; +#line 2204 +#endif +#line 2204 + } +#line 2204 +#endif +#line 2204 + +#line 2204 + +#line 2204 + *ip = (schar) xx; +#line 2204 + return err; +#line 2204 +} +#line 2204 + +static int +#line 2205 +ncx_get_ulonglong_short(const void *xp, short *ip) +#line 2205 +{ +#line 2205 + int err=NC_NOERR; +#line 2205 + ix_uint64 xx = 0; +#line 2205 + get_ix_uint64(xp, &xx); +#line 2205 + +#line 2205 +#if IX_UINT64_MAX > SHORT_MAX +#line 2205 + if (xx > SHORT_MAX) { +#line 2205 +#ifdef ERANGE_FILL +#line 2205 + *ip = NC_FILL_SHORT; +#line 2205 + return NC_ERANGE; +#line 2205 +#else +#line 2205 + err = NC_ERANGE; +#line 2205 +#endif +#line 2205 + } +#line 2205 +#endif +#line 2205 + +#line 2205 + +#line 2205 + *ip = (short) xx; +#line 2205 + return err; +#line 2205 +} +#line 2205 + +static int +#line 2206 +ncx_get_ulonglong_int(const void *xp, int *ip) +#line 2206 +{ +#line 2206 + int err=NC_NOERR; +#line 2206 + ix_uint64 xx = 0; +#line 2206 + get_ix_uint64(xp, &xx); +#line 2206 + +#line 2206 +#if IX_UINT64_MAX > INT_MAX +#line 2206 + if (xx > INT_MAX) { +#line 2206 +#ifdef ERANGE_FILL +#line 2206 + *ip = NC_FILL_INT; +#line 2206 + return NC_ERANGE; +#line 2206 +#else +#line 2206 + err = NC_ERANGE; +#line 2206 +#endif +#line 2206 + } +#line 2206 +#endif +#line 2206 + +#line 2206 + +#line 2206 + *ip = (int) xx; +#line 2206 + return err; +#line 2206 +} +#line 2206 + +static int +#line 2207 +ncx_get_ulonglong_long(const void *xp, long *ip) +#line 2207 +{ +#line 2207 + int err=NC_NOERR; +#line 2207 + ix_uint64 xx = 0; +#line 2207 + get_ix_uint64(xp, &xx); +#line 2207 + +#line 2207 +#if IX_UINT64_MAX > LONG_MAX +#line 2207 + if (xx > LONG_MAX) { +#line 2207 +#ifdef ERANGE_FILL +#line 2207 + *ip = NC_FILL_INT; +#line 2207 + return NC_ERANGE; +#line 2207 +#else +#line 2207 + err = NC_ERANGE; +#line 2207 +#endif +#line 2207 + } +#line 2207 +#endif +#line 2207 + +#line 2207 + +#line 2207 + *ip = (long) xx; +#line 2207 + return err; +#line 2207 +} +#line 2207 + +static int +#line 2208 +ncx_get_ulonglong_longlong(const void *xp, longlong *ip) +#line 2208 +{ +#line 2208 + int err=NC_NOERR; +#line 2208 + ix_uint64 xx = 0; +#line 2208 + get_ix_uint64(xp, &xx); +#line 2208 + +#line 2208 +#if IX_UINT64_MAX > LONGLONG_MAX +#line 2208 + if (xx > LONGLONG_MAX) { +#line 2208 +#ifdef ERANGE_FILL +#line 2208 + *ip = NC_FILL_INT64; +#line 2208 + return NC_ERANGE; +#line 2208 +#else +#line 2208 + err = NC_ERANGE; +#line 2208 +#endif +#line 2208 + } +#line 2208 +#endif +#line 2208 + +#line 2208 + +#line 2208 + *ip = (longlong) xx; +#line 2208 + return err; +#line 2208 +} +#line 2208 + +static int +#line 2209 +ncx_get_ulonglong_ushort(const void *xp, ushort *ip) +#line 2209 +{ +#line 2209 + int err=NC_NOERR; +#line 2209 +#if SIZEOF_IX_UINT64 == SIZEOF_USHORT && IX_UINT64_MAX == USHORT_MAX +#line 2209 + get_ix_uint64(xp, (ix_uint64 *)ip); +#line 2209 +#else +#line 2209 + ix_uint64 xx = 0; +#line 2209 + get_ix_uint64(xp, &xx); +#line 2209 + +#line 2209 +#if IX_UINT64_MAX > USHORT_MAX +#line 2209 + if (xx > USHORT_MAX) { +#line 2209 +#ifdef ERANGE_FILL +#line 2209 + *ip = NC_FILL_USHORT; +#line 2209 + return NC_ERANGE; +#line 2209 +#else +#line 2209 + err = NC_ERANGE; +#line 2209 +#endif +#line 2209 + } +#line 2209 +#endif +#line 2209 + +#line 2209 + +#line 2209 + *ip = (ushort) xx; +#line 2209 +#endif +#line 2209 + return err; +#line 2209 +} +#line 2209 + +static int +#line 2210 +ncx_get_ulonglong_uchar(const void *xp, uchar *ip) +#line 2210 +{ +#line 2210 + int err=NC_NOERR; +#line 2210 +#if SIZEOF_IX_UINT64 == SIZEOF_UCHAR && IX_UINT64_MAX == UCHAR_MAX +#line 2210 + get_ix_uint64(xp, (ix_uint64 *)ip); +#line 2210 +#else +#line 2210 + ix_uint64 xx = 0; +#line 2210 + get_ix_uint64(xp, &xx); +#line 2210 + +#line 2210 +#if IX_UINT64_MAX > UCHAR_MAX +#line 2210 + if (xx > UCHAR_MAX) { +#line 2210 +#ifdef ERANGE_FILL +#line 2210 + *ip = NC_FILL_UBYTE; +#line 2210 + return NC_ERANGE; +#line 2210 +#else +#line 2210 + err = NC_ERANGE; +#line 2210 +#endif +#line 2210 + } +#line 2210 +#endif +#line 2210 + +#line 2210 + +#line 2210 + *ip = (uchar) xx; +#line 2210 +#endif +#line 2210 + return err; +#line 2210 +} +#line 2210 + +static int +#line 2211 +ncx_get_ulonglong_uint(const void *xp, uint *ip) +#line 2211 +{ +#line 2211 + int err=NC_NOERR; +#line 2211 +#if SIZEOF_IX_UINT64 == SIZEOF_UINT && IX_UINT64_MAX == UINT_MAX +#line 2211 + get_ix_uint64(xp, (ix_uint64 *)ip); +#line 2211 +#else +#line 2211 + ix_uint64 xx = 0; +#line 2211 + get_ix_uint64(xp, &xx); +#line 2211 + +#line 2211 +#if IX_UINT64_MAX > UINT_MAX +#line 2211 + if (xx > UINT_MAX) { +#line 2211 +#ifdef ERANGE_FILL +#line 2211 + *ip = NC_FILL_UINT; +#line 2211 + return NC_ERANGE; +#line 2211 +#else +#line 2211 + err = NC_ERANGE; +#line 2211 +#endif +#line 2211 + } +#line 2211 +#endif +#line 2211 + +#line 2211 + +#line 2211 + *ip = (uint) xx; +#line 2211 +#endif +#line 2211 + return err; +#line 2211 +} +#line 2211 + +static int +#line 2212 +ncx_get_ulonglong_float(const void *xp, float *ip) +#line 2212 +{ +#line 2212 + ix_uint64 xx = 0; +#line 2212 + get_ix_uint64(xp, &xx); +#line 2212 + *ip = (float)xx; +#line 2212 + return NC_NOERR; +#line 2212 +} +#line 2212 + +static int +#line 2213 +ncx_get_ulonglong_double(const void *xp, double *ip) +#line 2213 +{ +#line 2213 + ix_uint64 xx = 0; +#line 2213 + get_ix_uint64(xp, &xx); +#line 2213 + *ip = (double)xx; +#line 2213 + return NC_NOERR; +#line 2213 +} +#line 2213 + + +#if X_SIZEOF_UINT64 != SIZEOF_ULONGLONG +static int +#line 2216 +ncx_put_ulonglong_ulonglong(void *xp, const ulonglong *ip, void *fillp) +#line 2216 +{ +#line 2216 + int err=NC_NOERR; +#line 2216 +#if SIZEOF_IX_UINT64 == SIZEOF_ULONGLONG && IX_UINT64_MAX == ULONGLONG_MAX +#line 2216 + put_ix_uint64(xp, (const ix_uint64 *)ip); +#line 2216 +#else +#line 2216 + ix_uint64 xx = NC_FILL_UINT64; +#line 2216 + +#line 2216 +#if IX_UINT64_MAX < ULONGLONG_MAX +#line 2216 + if (*ip > IX_UINT64_MAX) { +#line 2216 + +#line 2216 +#ifdef ERANGE_FILL +#line 2216 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2216 +#endif +#line 2216 + err = NC_ERANGE; +#line 2216 + } +#line 2216 +#ifdef ERANGE_FILL +#line 2216 + else +#line 2216 +#endif +#line 2216 +#endif +#line 2216 + xx = (ix_uint64)*ip; +#line 2216 + +#line 2216 + put_ix_uint64(xp, &xx); +#line 2216 +#endif +#line 2216 + return err; +#line 2216 +} +#line 2216 + +#endif +static int +#line 2218 +ncx_put_ulonglong_schar(void *xp, const schar *ip, void *fillp) +#line 2218 +{ +#line 2218 + int err=NC_NOERR; +#line 2218 + ix_uint64 xx = NC_FILL_UINT64; +#line 2218 + +#line 2218 +#if IX_UINT64_MAX < SCHAR_MAX +#line 2218 + if (*ip > IX_UINT64_MAX) { +#line 2218 + +#line 2218 +#ifdef ERANGE_FILL +#line 2218 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2218 +#endif +#line 2218 + err = NC_ERANGE; +#line 2218 + } +#line 2218 +#ifdef ERANGE_FILL +#line 2218 + else +#line 2218 +#endif +#line 2218 +#endif +#line 2218 + if (*ip < 0) { +#line 2218 + +#line 2218 +#ifdef ERANGE_FILL +#line 2218 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2218 +#endif +#line 2218 + err = NC_ERANGE; /* because xp is unsigned */ +#line 2218 + } +#line 2218 +#ifdef ERANGE_FILL +#line 2218 + else +#line 2218 +#endif +#line 2218 + xx = (ix_uint64)*ip; +#line 2218 + +#line 2218 + put_ix_uint64(xp, &xx); +#line 2218 + return err; +#line 2218 +} +#line 2218 + +static int +#line 2219 +ncx_put_ulonglong_short(void *xp, const short *ip, void *fillp) +#line 2219 +{ +#line 2219 + int err=NC_NOERR; +#line 2219 + ix_uint64 xx = NC_FILL_UINT64; +#line 2219 + +#line 2219 +#if IX_UINT64_MAX < SHORT_MAX +#line 2219 + if (*ip > IX_UINT64_MAX) { +#line 2219 + +#line 2219 +#ifdef ERANGE_FILL +#line 2219 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2219 +#endif +#line 2219 + err = NC_ERANGE; +#line 2219 + } +#line 2219 +#ifdef ERANGE_FILL +#line 2219 + else +#line 2219 +#endif +#line 2219 +#endif +#line 2219 + if (*ip < 0) { +#line 2219 + +#line 2219 +#ifdef ERANGE_FILL +#line 2219 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2219 +#endif +#line 2219 + err = NC_ERANGE; /* because xp is unsigned */ +#line 2219 + } +#line 2219 +#ifdef ERANGE_FILL +#line 2219 + else +#line 2219 +#endif +#line 2219 + xx = (ix_uint64)*ip; +#line 2219 + +#line 2219 + put_ix_uint64(xp, &xx); +#line 2219 + return err; +#line 2219 +} +#line 2219 + +static int +#line 2220 +ncx_put_ulonglong_int(void *xp, const int *ip, void *fillp) +#line 2220 +{ +#line 2220 + int err=NC_NOERR; +#line 2220 + ix_uint64 xx = NC_FILL_UINT64; +#line 2220 + +#line 2220 +#if IX_UINT64_MAX < INT_MAX +#line 2220 + if (*ip > IX_UINT64_MAX) { +#line 2220 + +#line 2220 +#ifdef ERANGE_FILL +#line 2220 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2220 +#endif +#line 2220 + err = NC_ERANGE; +#line 2220 + } +#line 2220 +#ifdef ERANGE_FILL +#line 2220 + else +#line 2220 +#endif +#line 2220 +#endif +#line 2220 + if (*ip < 0) { +#line 2220 + +#line 2220 +#ifdef ERANGE_FILL +#line 2220 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2220 +#endif +#line 2220 + err = NC_ERANGE; /* because xp is unsigned */ +#line 2220 + } +#line 2220 +#ifdef ERANGE_FILL +#line 2220 + else +#line 2220 +#endif +#line 2220 + xx = (ix_uint64)*ip; +#line 2220 + +#line 2220 + put_ix_uint64(xp, &xx); +#line 2220 + return err; +#line 2220 +} +#line 2220 + +static int +#line 2221 +ncx_put_ulonglong_long(void *xp, const long *ip, void *fillp) +#line 2221 +{ +#line 2221 + int err=NC_NOERR; +#line 2221 + ix_uint64 xx = NC_FILL_UINT64; +#line 2221 + +#line 2221 +#if IX_UINT64_MAX < LONG_MAX +#line 2221 + if (*ip > IX_UINT64_MAX) { +#line 2221 + +#line 2221 +#ifdef ERANGE_FILL +#line 2221 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2221 +#endif +#line 2221 + err = NC_ERANGE; +#line 2221 + } +#line 2221 +#ifdef ERANGE_FILL +#line 2221 + else +#line 2221 +#endif +#line 2221 +#endif +#line 2221 + if (*ip < 0) { +#line 2221 + +#line 2221 +#ifdef ERANGE_FILL +#line 2221 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2221 +#endif +#line 2221 + err = NC_ERANGE; /* because xp is unsigned */ +#line 2221 + } +#line 2221 +#ifdef ERANGE_FILL +#line 2221 + else +#line 2221 +#endif +#line 2221 + xx = (ix_uint64)*ip; +#line 2221 + +#line 2221 + put_ix_uint64(xp, &xx); +#line 2221 + return err; +#line 2221 +} +#line 2221 + +static int +#line 2222 +ncx_put_ulonglong_longlong(void *xp, const longlong *ip, void *fillp) +#line 2222 +{ +#line 2222 + int err=NC_NOERR; +#line 2222 + ix_uint64 xx = NC_FILL_UINT64; +#line 2222 + +#line 2222 +#if IX_UINT64_MAX < LONGLONG_MAX +#line 2222 + if (*ip > IX_UINT64_MAX) { +#line 2222 + +#line 2222 +#ifdef ERANGE_FILL +#line 2222 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2222 +#endif +#line 2222 + err = NC_ERANGE; +#line 2222 + } +#line 2222 +#ifdef ERANGE_FILL +#line 2222 + else +#line 2222 +#endif +#line 2222 +#endif +#line 2222 + if (*ip < 0) { +#line 2222 + +#line 2222 +#ifdef ERANGE_FILL +#line 2222 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2222 +#endif +#line 2222 + err = NC_ERANGE; /* because xp is unsigned */ +#line 2222 + } +#line 2222 +#ifdef ERANGE_FILL +#line 2222 + else +#line 2222 +#endif +#line 2222 + xx = (ix_uint64)*ip; +#line 2222 + +#line 2222 + put_ix_uint64(xp, &xx); +#line 2222 + return err; +#line 2222 +} +#line 2222 + +static int +#line 2223 +ncx_put_ulonglong_uchar(void *xp, const uchar *ip, void *fillp) +#line 2223 +{ +#line 2223 + int err=NC_NOERR; +#line 2223 +#if SIZEOF_IX_UINT64 == SIZEOF_UCHAR && IX_UINT64_MAX == UCHAR_MAX +#line 2223 + put_ix_uint64(xp, (const ix_uint64 *)ip); +#line 2223 +#else +#line 2223 + ix_uint64 xx = NC_FILL_UINT64; +#line 2223 + +#line 2223 +#if IX_UINT64_MAX < UCHAR_MAX +#line 2223 + if (*ip > IX_UINT64_MAX) { +#line 2223 + +#line 2223 +#ifdef ERANGE_FILL +#line 2223 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2223 +#endif +#line 2223 + err = NC_ERANGE; +#line 2223 + } +#line 2223 +#ifdef ERANGE_FILL +#line 2223 + else +#line 2223 +#endif +#line 2223 +#endif +#line 2223 + xx = (ix_uint64)*ip; +#line 2223 + +#line 2223 + put_ix_uint64(xp, &xx); +#line 2223 +#endif +#line 2223 + return err; +#line 2223 +} +#line 2223 + +static int +#line 2224 +ncx_put_ulonglong_ushort(void *xp, const ushort *ip, void *fillp) +#line 2224 +{ +#line 2224 + int err=NC_NOERR; +#line 2224 +#if SIZEOF_IX_UINT64 == SIZEOF_USHORT && IX_UINT64_MAX == USHORT_MAX +#line 2224 + put_ix_uint64(xp, (const ix_uint64 *)ip); +#line 2224 +#else +#line 2224 + ix_uint64 xx = NC_FILL_UINT64; +#line 2224 + +#line 2224 +#if IX_UINT64_MAX < USHORT_MAX +#line 2224 + if (*ip > IX_UINT64_MAX) { +#line 2224 + +#line 2224 +#ifdef ERANGE_FILL +#line 2224 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2224 +#endif +#line 2224 + err = NC_ERANGE; +#line 2224 + } +#line 2224 +#ifdef ERANGE_FILL +#line 2224 + else +#line 2224 +#endif +#line 2224 +#endif +#line 2224 + xx = (ix_uint64)*ip; +#line 2224 + +#line 2224 + put_ix_uint64(xp, &xx); +#line 2224 +#endif +#line 2224 + return err; +#line 2224 +} +#line 2224 + +static int +#line 2225 +ncx_put_ulonglong_uint(void *xp, const uint *ip, void *fillp) +#line 2225 +{ +#line 2225 + int err=NC_NOERR; +#line 2225 +#if SIZEOF_IX_UINT64 == SIZEOF_UINT && IX_UINT64_MAX == UINT_MAX +#line 2225 + put_ix_uint64(xp, (const ix_uint64 *)ip); +#line 2225 +#else +#line 2225 + ix_uint64 xx = NC_FILL_UINT64; +#line 2225 + +#line 2225 +#if IX_UINT64_MAX < UINT_MAX +#line 2225 + if (*ip > IX_UINT64_MAX) { +#line 2225 + +#line 2225 +#ifdef ERANGE_FILL +#line 2225 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2225 +#endif +#line 2225 + err = NC_ERANGE; +#line 2225 + } +#line 2225 +#ifdef ERANGE_FILL +#line 2225 + else +#line 2225 +#endif +#line 2225 +#endif +#line 2225 + xx = (ix_uint64)*ip; +#line 2225 + +#line 2225 + put_ix_uint64(xp, &xx); +#line 2225 +#endif +#line 2225 + return err; +#line 2225 +} +#line 2225 + +static int +#line 2226 +ncx_put_ulonglong_float(void *xp, const float *ip, void *fillp) +#line 2226 +{ +#line 2226 + int err=NC_NOERR; +#line 2226 + ix_uint64 xx = NC_FILL_UINT64; +#line 2226 + +#line 2226 + if (*ip > (double)X_UINT64_MAX || *ip < 0) { +#line 2226 + +#line 2226 +#ifdef ERANGE_FILL +#line 2226 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2226 +#endif +#line 2226 + err = NC_ERANGE; +#line 2226 + } +#line 2226 +#ifdef ERANGE_FILL +#line 2226 + else +#line 2226 +#endif +#line 2226 + xx = (ix_uint64)*ip; +#line 2226 + +#line 2226 + put_ix_uint64(xp, &xx); +#line 2226 + return err; +#line 2226 +} +#line 2226 + +static int +#line 2227 +ncx_put_ulonglong_double(void *xp, const double *ip, void *fillp) +#line 2227 +{ +#line 2227 + int err=NC_NOERR; +#line 2227 + ix_uint64 xx = NC_FILL_UINT64; +#line 2227 + +#line 2227 + if (*ip > X_UINT64_MAX || *ip < 0) { +#line 2227 + +#line 2227 +#ifdef ERANGE_FILL +#line 2227 + if (fillp != NULL) memcpy(&xx, fillp, 8); +#line 2227 +#endif +#line 2227 + err = NC_ERANGE; +#line 2227 + } +#line 2227 +#ifdef ERANGE_FILL +#line 2227 + else +#line 2227 +#endif +#line 2227 + xx = (ix_uint64)*ip; +#line 2227 + +#line 2227 + put_ix_uint64(xp, &xx); +#line 2227 + return err; +#line 2227 +} +#line 2227 + + + +/* x_size_t */ + +#if SIZEOF_SIZE_T < X_SIZEOF_SIZE_T +#error "x_size_t implementation" +/* netcdf requires size_t which can hold a values from 0 to 2^32 -1 */ +#endif + +int +ncx_put_size_t(void **xpp, const size_t *ulp) +{ + /* similar to put_ix_int() */ + uchar *cp = (uchar *) *xpp; + assert(*ulp <= X_SIZE_MAX); + + *cp++ = (uchar)((*ulp) >> 24); + *cp++ = (uchar)(((*ulp) & 0x00ff0000) >> 16); + *cp++ = (uchar)(((*ulp) & 0x0000ff00) >> 8); + *cp = (uchar)((*ulp) & 0x000000ff); + + *xpp = (void *)((char *)(*xpp) + X_SIZEOF_SIZE_T); + return NC_NOERR; +} + +int +ncx_get_size_t(const void **xpp, size_t *ulp) +{ + /* similar to get_ix_int */ + const uchar *cp = (const uchar *) *xpp; + + *ulp = (unsigned)(*cp++) << 24; + *ulp |= (*cp++ << 16); + *ulp |= (*cp++ << 8); + *ulp |= *cp; + + *xpp = (const void *)((const char *)(*xpp) + X_SIZEOF_SIZE_T); + return NC_NOERR; +} + +/* x_off_t */ + +int +ncx_put_off_t(void **xpp, const off_t *lp, size_t sizeof_off_t) +{ + /* similar to put_ix_int() */ + uchar *cp = (uchar *) *xpp; + + /* No negative offsets stored in netcdf */ + if (*lp < 0) { + /* Assume this is an overflow of a 32-bit int... */ + return NC_ERANGE; + } + + assert(sizeof_off_t == 4 || sizeof_off_t == 8); + + if (sizeof_off_t == 4) { + *cp++ = (uchar) ((*lp) >> 24); + *cp++ = (uchar)(((*lp) & 0x00ff0000) >> 16); + *cp++ = (uchar)(((*lp) & 0x0000ff00) >> 8); + *cp = (uchar)( (*lp) & 0x000000ff); + } else { +#if SIZEOF_OFF_T == 4 +/* Write a 64-bit offset on a system with only a 32-bit offset */ + *cp++ = (uchar)0; + *cp++ = (uchar)0; + *cp++ = (uchar)0; + *cp++ = (uchar)0; + + *cp++ = (uchar)(((*lp) & 0xff000000) >> 24); + *cp++ = (uchar)(((*lp) & 0x00ff0000) >> 16); + *cp++ = (uchar)(((*lp) & 0x0000ff00) >> 8); + *cp = (uchar)( (*lp) & 0x000000ff); +#else + *cp++ = (uchar) ((*lp) >> 56); + *cp++ = (uchar)(((*lp) & 0x00ff000000000000LL) >> 48); + *cp++ = (uchar)(((*lp) & 0x0000ff0000000000LL) >> 40); + *cp++ = (uchar)(((*lp) & 0x000000ff00000000LL) >> 32); + *cp++ = (uchar)(((*lp) & 0x00000000ff000000LL) >> 24); + *cp++ = (uchar)(((*lp) & 0x0000000000ff0000LL) >> 16); + *cp++ = (uchar)(((*lp) & 0x000000000000ff00LL) >> 8); + *cp = (uchar)( (*lp) & 0x00000000000000ffLL); +#endif + } + *xpp = (void *)((char *)(*xpp) + sizeof_off_t); + return NC_NOERR; +} + +int +ncx_get_off_t(const void **xpp, off_t *lp, size_t sizeof_off_t) +{ + /* similar to get_ix_int() */ + const uchar *cp = (const uchar *) *xpp; + assert(sizeof_off_t == 4 || sizeof_off_t == 8); + + if (sizeof_off_t == 4) { + *lp = (off_t)(*cp++ << 24); + *lp |= (off_t)(*cp++ << 16); + *lp |= (off_t)(*cp++ << 8); + *lp |= (off_t)*cp; + } else { +#if SIZEOF_OFF_T == 4 +/* Read a 64-bit offset on a system with only a 32-bit offset */ +/* If the offset overflows, set an error code and return */ + *lp = ((off_t)(*cp++) << 24); + *lp |= ((off_t)(*cp++) << 16); + *lp |= ((off_t)(*cp++) << 8); + *lp |= ((off_t)(*cp++)); +/* + * lp now contains the upper 32-bits of the 64-bit offset. if lp is + * not zero, then the dataset is larger than can be represented + * on this system. Set an error code and return. + */ + if (*lp != 0) { + return NC_ERANGE; + } + + *lp = ((off_t)(*cp++) << 24); + *lp |= ((off_t)(*cp++) << 16); + *lp |= ((off_t)(*cp++) << 8); + *lp |= (off_t)*cp; + + if (*lp < 0) { + /* + * If this fails, then the offset is >2^31, but less + * than 2^32 which is not allowed, but is not caught + * by the previous check + */ + return NC_ERANGE; + } +#else + *lp = ((off_t)(*cp++) << 56); + *lp |= ((off_t)(*cp++) << 48); + *lp |= ((off_t)(*cp++) << 40); + *lp |= ((off_t)(*cp++) << 32); + *lp |= ((off_t)(*cp++) << 24); + *lp |= ((off_t)(*cp++) << 16); + *lp |= ((off_t)(*cp++) << 8); + *lp |= (off_t)*cp; +#endif + } + *xpp = (const void *)((const char *)(*xpp) + sizeof_off_t); + return NC_NOERR; +} + +/*----< ncx_get_uint32() >------------------------------------------*/ +int +ncx_get_uint32(const void **xpp, uint *ip) +{ +#ifdef WORDS_BIGENDIAN + /* use memcpy instead of assignment to avoid BUS_ADRALN alignment error on + * some system, such as HPUX */ + (void) memcpy(ip, *xpp, SIZEOF_UINT); +#else + const uchar *cp = (const uchar *) *xpp; + + *ip = (uint)(*cp++ << 24); + *ip = (uint)(*ip | (uint)(*cp++ << 16)); + *ip = (uint)(*ip | (uint)(*cp++ << 8)); + *ip = (uint)(*ip | *cp); +#endif + /* advance *xpp 4 bytes */ + *xpp = (void *)((const char *)(*xpp) + 4); + + return NC_NOERR; +} + +/*----< ncx_get_uint64() >------------------------------------------*/ +int +ncx_get_uint64(const void **xpp, unsigned long long *ullp) +{ +#ifdef WORDS_BIGENDIAN + /* use memcpy instead of assignment to avoid BUS_ADRALN alignment error on + * some system, such as HPUX */ + (void) memcpy(ullp, *xpp, SIZEOF_UINT64); +#else + const uchar *cp = (const uchar *) *xpp; + + /* below is the same as calling swap8b(ullp, *xpp) */ + *ullp = (unsigned long long)(*cp++) << 56; + *ullp = (unsigned long long)(*ullp | (unsigned long long)(*cp++) << 48); + *ullp = (unsigned long long)(*ullp | (unsigned long long)(*cp++) << 40); + *ullp = (unsigned long long)(*ullp | (unsigned long long)(*cp++) << 32); + *ullp = (unsigned long long)(*ullp | (unsigned long long)(*cp++) << 24); + *ullp = (unsigned long long)(*ullp | (unsigned long long)(*cp++) << 16); + *ullp = (unsigned long long)(*ullp | (unsigned long long)(*cp++) << 8); + *ullp = (unsigned long long)(*ullp | (unsigned long long)(*cp)); +#endif + /* advance *xpp 8 bytes */ + *xpp = (void *)((const char *)(*xpp) + 8); + + return NC_NOERR; +} + +/*---< ncx_put_uint32() >-------------------------------------------*/ +/* copy the contents of ip (an unsigned 32-bit integer) to xpp in Big Endian + * form and advance *xpp 4 bytes + */ +int +ncx_put_uint32(void **xpp, const unsigned int ip) +{ +#ifdef WORDS_BIGENDIAN + /* use memcpy instead of assignment to avoid BUS_ADRALN alignment error on + * some system, such as HPUX */ + (void) memcpy(*xpp, &ip, X_SIZEOF_UINT); +#else + /* bitwise shifts below are to produce an integer in Big Endian */ + uchar *cp = (uchar *) *xpp; + *cp++ = (uchar)((ip & 0xff000000) >> 24); + *cp++ = (uchar)((ip & 0x00ff0000) >> 16); + *cp++ = (uchar)((ip & 0x0000ff00) >> 8); + *cp = (uchar)( ip & 0x000000ff); +#endif + /* advance *xpp 4 bytes */ + *xpp = (void *)((char *)(*xpp) + 4); + + return NC_NOERR; +} + +/*---< ncx_put_uint64() >-------------------------------------------*/ +/* copy the contents of ip (an unsigned 64-bit integer) to xpp in Big Endian + * form and advance *xpp 8 bytes + */ +int +ncx_put_uint64(void **xpp, const unsigned long long ip) +{ +#ifdef WORDS_BIGENDIAN + /* use memcpy instead of assignment to avoid BUS_ADRALN alignment error on + * some system, such as HPUX */ + (void) memcpy(*xpp, &ip, X_SIZEOF_UINT64); +#else + uchar *cp = (uchar *) *xpp; + /* below is the same as calling swap8b(*xpp, &ip) */ + *cp++ = (uchar) (ip >> 56); + *cp++ = (uchar)((ip & 0x00ff000000000000LL) >> 48); + *cp++ = (uchar)((ip & 0x0000ff0000000000LL) >> 40); + *cp++ = (uchar)((ip & 0x000000ff00000000LL) >> 32); + *cp++ = (uchar)((ip & 0x00000000ff000000LL) >> 24); + *cp++ = (uchar)((ip & 0x0000000000ff0000LL) >> 16); + *cp++ = (uchar)((ip & 0x000000000000ff00LL) >> 8); + *cp = (uchar) (ip & 0x00000000000000ffLL); +#endif + /* advance *xpp 8 bytes */ + *xpp = (void *)((char *)(*xpp) + 8); + + return NC_NOERR; +} + + +/* + * Aggregate numeric conversion functions. + */ +#line 2483 + +#line 2886 + +#line 2892 + +/* schar ---------------------------------------------------------------------*/ + +#line 2896 +int +ncx_getn_schar_schar(const void **xpp, size_t nelems, schar *tp) +{ + (void) memcpy(tp, *xpp, (size_t)nelems); +#line 2899 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 2899 + return NC_NOERR; +#line 2899 + +} +int +#line 2901 +ncx_getn_schar_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 2901 +{ +#line 2901 + int status = NC_NOERR; +#line 2901 + schar *xp = (schar *)(*xpp); +#line 2901 + +#line 2901 + while (nelems-- != 0) { +#line 2901 + +#line 2901 + if (*xp < 0) { +#line 2901 +#ifdef ERANGE_FILL +#line 2901 + *tp = NC_FILL_UBYTE; +#line 2901 +#endif +#line 2901 + status = NC_ERANGE; /* because tp is unsigned */ +#line 2901 + +#line 2901 +#ifdef ERANGE_FILL +#line 2901 + xp++; tp++; continue; +#line 2901 +#endif +#line 2901 + } +#line 2901 + *tp++ = (uchar) (signed) (*xp++); /* type cast from schar to uchar */ +#line 2901 + } +#line 2901 + +#line 2901 + *xpp = (const void *)xp; +#line 2901 + return status; +#line 2901 +} +#line 2901 + +int +#line 2902 +ncx_getn_schar_short(const void **xpp, size_t nelems, short *tp) +#line 2902 +{ +#line 2902 + int status = NC_NOERR; +#line 2902 + schar *xp = (schar *)(*xpp); +#line 2902 + +#line 2902 + while (nelems-- != 0) { +#line 2902 + +#line 2902 + *tp++ = (short) (*xp++); /* type cast from schar to short */ +#line 2902 + } +#line 2902 + +#line 2902 + *xpp = (const void *)xp; +#line 2902 + return status; +#line 2902 +} +#line 2902 + +int +#line 2903 +ncx_getn_schar_int(const void **xpp, size_t nelems, int *tp) +#line 2903 +{ +#line 2903 + int status = NC_NOERR; +#line 2903 + schar *xp = (schar *)(*xpp); +#line 2903 + +#line 2903 + while (nelems-- != 0) { +#line 2903 + +#line 2903 + *tp++ = (int) (*xp++); /* type cast from schar to int */ +#line 2903 + } +#line 2903 + +#line 2903 + *xpp = (const void *)xp; +#line 2903 + return status; +#line 2903 +} +#line 2903 + +int +#line 2904 +ncx_getn_schar_long(const void **xpp, size_t nelems, long *tp) +#line 2904 +{ +#line 2904 + int status = NC_NOERR; +#line 2904 + schar *xp = (schar *)(*xpp); +#line 2904 + +#line 2904 + while (nelems-- != 0) { +#line 2904 + +#line 2904 + *tp++ = (long) (*xp++); /* type cast from schar to long */ +#line 2904 + } +#line 2904 + +#line 2904 + *xpp = (const void *)xp; +#line 2904 + return status; +#line 2904 +} +#line 2904 + +int +#line 2905 +ncx_getn_schar_float(const void **xpp, size_t nelems, float *tp) +#line 2905 +{ +#line 2905 + int status = NC_NOERR; +#line 2905 + schar *xp = (schar *)(*xpp); +#line 2905 + +#line 2905 + while (nelems-- != 0) { +#line 2905 + +#line 2905 + *tp++ = (float) (*xp++); /* type cast from schar to float */ +#line 2905 + } +#line 2905 + +#line 2905 + *xpp = (const void *)xp; +#line 2905 + return status; +#line 2905 +} +#line 2905 + +int +#line 2906 +ncx_getn_schar_double(const void **xpp, size_t nelems, double *tp) +#line 2906 +{ +#line 2906 + int status = NC_NOERR; +#line 2906 + schar *xp = (schar *)(*xpp); +#line 2906 + +#line 2906 + while (nelems-- != 0) { +#line 2906 + +#line 2906 + *tp++ = (double) (*xp++); /* type cast from schar to double */ +#line 2906 + } +#line 2906 + +#line 2906 + *xpp = (const void *)xp; +#line 2906 + return status; +#line 2906 +} +#line 2906 + +int +#line 2907 +ncx_getn_schar_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 2907 +{ +#line 2907 + int status = NC_NOERR; +#line 2907 + schar *xp = (schar *)(*xpp); +#line 2907 + +#line 2907 + while (nelems-- != 0) { +#line 2907 + +#line 2907 + *tp++ = (longlong) (*xp++); /* type cast from schar to longlong */ +#line 2907 + } +#line 2907 + +#line 2907 + *xpp = (const void *)xp; +#line 2907 + return status; +#line 2907 +} +#line 2907 + +int +#line 2908 +ncx_getn_schar_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 2908 +{ +#line 2908 + int status = NC_NOERR; +#line 2908 + schar *xp = (schar *)(*xpp); +#line 2908 + +#line 2908 + while (nelems-- != 0) { +#line 2908 + +#line 2908 + if (*xp < 0) { +#line 2908 +#ifdef ERANGE_FILL +#line 2908 + *tp = NC_FILL_USHORT; +#line 2908 +#endif +#line 2908 + status = NC_ERANGE; /* because tp is unsigned */ +#line 2908 + +#line 2908 +#ifdef ERANGE_FILL +#line 2908 + xp++; tp++; continue; +#line 2908 +#endif +#line 2908 + } +#line 2908 + *tp++ = (ushort) (signed) (*xp++); /* type cast from schar to ushort */ +#line 2908 + } +#line 2908 + +#line 2908 + *xpp = (const void *)xp; +#line 2908 + return status; +#line 2908 +} +#line 2908 + +int +#line 2909 +ncx_getn_schar_uint(const void **xpp, size_t nelems, uint *tp) +#line 2909 +{ +#line 2909 + int status = NC_NOERR; +#line 2909 + schar *xp = (schar *)(*xpp); +#line 2909 + +#line 2909 + while (nelems-- != 0) { +#line 2909 + +#line 2909 + if (*xp < 0) { +#line 2909 +#ifdef ERANGE_FILL +#line 2909 + *tp = NC_FILL_UINT; +#line 2909 +#endif +#line 2909 + status = NC_ERANGE; /* because tp is unsigned */ +#line 2909 + +#line 2909 +#ifdef ERANGE_FILL +#line 2909 + xp++; tp++; continue; +#line 2909 +#endif +#line 2909 + } +#line 2909 + *tp++ = (uint) (signed) (*xp++); /* type cast from schar to uint */ +#line 2909 + } +#line 2909 + +#line 2909 + *xpp = (const void *)xp; +#line 2909 + return status; +#line 2909 +} +#line 2909 + +int +#line 2910 +ncx_getn_schar_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 2910 +{ +#line 2910 + int status = NC_NOERR; +#line 2910 + schar *xp = (schar *)(*xpp); +#line 2910 + +#line 2910 + while (nelems-- != 0) { +#line 2910 + +#line 2910 + if (*xp < 0) { +#line 2910 +#ifdef ERANGE_FILL +#line 2910 + *tp = NC_FILL_UINT64; +#line 2910 +#endif +#line 2910 + status = NC_ERANGE; /* because tp is unsigned */ +#line 2910 + +#line 2910 +#ifdef ERANGE_FILL +#line 2910 + xp++; tp++; continue; +#line 2910 +#endif +#line 2910 + } +#line 2910 + *tp++ = (ulonglong) (signed) (*xp++); /* type cast from schar to ulonglong */ +#line 2910 + } +#line 2910 + +#line 2910 + *xpp = (const void *)xp; +#line 2910 + return status; +#line 2910 +} +#line 2910 + + +#line 2913 +int +ncx_pad_getn_schar_schar(const void **xpp, size_t nelems, schar *tp) +{ + size_t rndup = nelems % X_ALIGN; +#line 2916 + +#line 2916 + if (rndup) +#line 2916 + rndup = X_ALIGN - rndup; +#line 2916 + +#line 2916 + (void) memcpy(tp, *xpp, (size_t)nelems); +#line 2916 + *xpp = (void *)((char *)(*xpp) + nelems + rndup); +#line 2916 + +#line 2916 + return NC_NOERR; +#line 2916 + +} +int +#line 2918 +ncx_pad_getn_schar_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 2918 +{ +#line 2918 + int status = NC_NOERR; +#line 2918 + size_t rndup = nelems % X_ALIGN; +#line 2918 + schar *xp = (schar *) *xpp; +#line 2918 + +#line 2918 + if (rndup) +#line 2918 + rndup = X_ALIGN - rndup; +#line 2918 + +#line 2918 + while (nelems-- != 0) { +#line 2918 + +#line 2918 + if (*xp < 0) { +#line 2918 +#ifdef ERANGE_FILL +#line 2918 + *tp = NC_FILL_UBYTE; +#line 2918 +#endif +#line 2918 + status = NC_ERANGE; /* because tp is unsigned */ +#line 2918 + +#line 2918 +#ifdef ERANGE_FILL +#line 2918 + xp++; tp++; continue; +#line 2918 +#endif +#line 2918 + } +#line 2918 + *tp++ = (uchar) (signed) (*xp++); /* type cast from schar to uchar */ +#line 2918 + } +#line 2918 + +#line 2918 + *xpp = (void *)(xp + rndup); +#line 2918 + return status; +#line 2918 +} +#line 2918 + +int +#line 2919 +ncx_pad_getn_schar_short(const void **xpp, size_t nelems, short *tp) +#line 2919 +{ +#line 2919 + int status = NC_NOERR; +#line 2919 + size_t rndup = nelems % X_ALIGN; +#line 2919 + schar *xp = (schar *) *xpp; +#line 2919 + +#line 2919 + if (rndup) +#line 2919 + rndup = X_ALIGN - rndup; +#line 2919 + +#line 2919 + while (nelems-- != 0) { +#line 2919 + +#line 2919 + *tp++ = (short) (*xp++); /* type cast from schar to short */ +#line 2919 + } +#line 2919 + +#line 2919 + *xpp = (void *)(xp + rndup); +#line 2919 + return status; +#line 2919 +} +#line 2919 + +int +#line 2920 +ncx_pad_getn_schar_int(const void **xpp, size_t nelems, int *tp) +#line 2920 +{ +#line 2920 + int status = NC_NOERR; +#line 2920 + size_t rndup = nelems % X_ALIGN; +#line 2920 + schar *xp = (schar *) *xpp; +#line 2920 + +#line 2920 + if (rndup) +#line 2920 + rndup = X_ALIGN - rndup; +#line 2920 + +#line 2920 + while (nelems-- != 0) { +#line 2920 + +#line 2920 + *tp++ = (int) (*xp++); /* type cast from schar to int */ +#line 2920 + } +#line 2920 + +#line 2920 + *xpp = (void *)(xp + rndup); +#line 2920 + return status; +#line 2920 +} +#line 2920 + +int +#line 2921 +ncx_pad_getn_schar_long(const void **xpp, size_t nelems, long *tp) +#line 2921 +{ +#line 2921 + int status = NC_NOERR; +#line 2921 + size_t rndup = nelems % X_ALIGN; +#line 2921 + schar *xp = (schar *) *xpp; +#line 2921 + +#line 2921 + if (rndup) +#line 2921 + rndup = X_ALIGN - rndup; +#line 2921 + +#line 2921 + while (nelems-- != 0) { +#line 2921 + +#line 2921 + *tp++ = (long) (*xp++); /* type cast from schar to long */ +#line 2921 + } +#line 2921 + +#line 2921 + *xpp = (void *)(xp + rndup); +#line 2921 + return status; +#line 2921 +} +#line 2921 + +int +#line 2922 +ncx_pad_getn_schar_float(const void **xpp, size_t nelems, float *tp) +#line 2922 +{ +#line 2922 + int status = NC_NOERR; +#line 2922 + size_t rndup = nelems % X_ALIGN; +#line 2922 + schar *xp = (schar *) *xpp; +#line 2922 + +#line 2922 + if (rndup) +#line 2922 + rndup = X_ALIGN - rndup; +#line 2922 + +#line 2922 + while (nelems-- != 0) { +#line 2922 + +#line 2922 + *tp++ = (float) (*xp++); /* type cast from schar to float */ +#line 2922 + } +#line 2922 + +#line 2922 + *xpp = (void *)(xp + rndup); +#line 2922 + return status; +#line 2922 +} +#line 2922 + +int +#line 2923 +ncx_pad_getn_schar_double(const void **xpp, size_t nelems, double *tp) +#line 2923 +{ +#line 2923 + int status = NC_NOERR; +#line 2923 + size_t rndup = nelems % X_ALIGN; +#line 2923 + schar *xp = (schar *) *xpp; +#line 2923 + +#line 2923 + if (rndup) +#line 2923 + rndup = X_ALIGN - rndup; +#line 2923 + +#line 2923 + while (nelems-- != 0) { +#line 2923 + +#line 2923 + *tp++ = (double) (*xp++); /* type cast from schar to double */ +#line 2923 + } +#line 2923 + +#line 2923 + *xpp = (void *)(xp + rndup); +#line 2923 + return status; +#line 2923 +} +#line 2923 + +int +#line 2924 +ncx_pad_getn_schar_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 2924 +{ +#line 2924 + int status = NC_NOERR; +#line 2924 + size_t rndup = nelems % X_ALIGN; +#line 2924 + schar *xp = (schar *) *xpp; +#line 2924 + +#line 2924 + if (rndup) +#line 2924 + rndup = X_ALIGN - rndup; +#line 2924 + +#line 2924 + while (nelems-- != 0) { +#line 2924 + +#line 2924 + *tp++ = (longlong) (*xp++); /* type cast from schar to longlong */ +#line 2924 + } +#line 2924 + +#line 2924 + *xpp = (void *)(xp + rndup); +#line 2924 + return status; +#line 2924 +} +#line 2924 + +int +#line 2925 +ncx_pad_getn_schar_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 2925 +{ +#line 2925 + int status = NC_NOERR; +#line 2925 + size_t rndup = nelems % X_ALIGN; +#line 2925 + schar *xp = (schar *) *xpp; +#line 2925 + +#line 2925 + if (rndup) +#line 2925 + rndup = X_ALIGN - rndup; +#line 2925 + +#line 2925 + while (nelems-- != 0) { +#line 2925 + +#line 2925 + if (*xp < 0) { +#line 2925 +#ifdef ERANGE_FILL +#line 2925 + *tp = NC_FILL_USHORT; +#line 2925 +#endif +#line 2925 + status = NC_ERANGE; /* because tp is unsigned */ +#line 2925 + +#line 2925 +#ifdef ERANGE_FILL +#line 2925 + xp++; tp++; continue; +#line 2925 +#endif +#line 2925 + } +#line 2925 + *tp++ = (ushort) (signed) (*xp++); /* type cast from schar to ushort */ +#line 2925 + } +#line 2925 + +#line 2925 + *xpp = (void *)(xp + rndup); +#line 2925 + return status; +#line 2925 +} +#line 2925 + +int +#line 2926 +ncx_pad_getn_schar_uint(const void **xpp, size_t nelems, uint *tp) +#line 2926 +{ +#line 2926 + int status = NC_NOERR; +#line 2926 + size_t rndup = nelems % X_ALIGN; +#line 2926 + schar *xp = (schar *) *xpp; +#line 2926 + +#line 2926 + if (rndup) +#line 2926 + rndup = X_ALIGN - rndup; +#line 2926 + +#line 2926 + while (nelems-- != 0) { +#line 2926 + +#line 2926 + if (*xp < 0) { +#line 2926 +#ifdef ERANGE_FILL +#line 2926 + *tp = NC_FILL_UINT; +#line 2926 +#endif +#line 2926 + status = NC_ERANGE; /* because tp is unsigned */ +#line 2926 + +#line 2926 +#ifdef ERANGE_FILL +#line 2926 + xp++; tp++; continue; +#line 2926 +#endif +#line 2926 + } +#line 2926 + *tp++ = (uint) (signed) (*xp++); /* type cast from schar to uint */ +#line 2926 + } +#line 2926 + +#line 2926 + *xpp = (void *)(xp + rndup); +#line 2926 + return status; +#line 2926 +} +#line 2926 + +int +#line 2927 +ncx_pad_getn_schar_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 2927 +{ +#line 2927 + int status = NC_NOERR; +#line 2927 + size_t rndup = nelems % X_ALIGN; +#line 2927 + schar *xp = (schar *) *xpp; +#line 2927 + +#line 2927 + if (rndup) +#line 2927 + rndup = X_ALIGN - rndup; +#line 2927 + +#line 2927 + while (nelems-- != 0) { +#line 2927 + +#line 2927 + if (*xp < 0) { +#line 2927 +#ifdef ERANGE_FILL +#line 2927 + *tp = NC_FILL_UINT64; +#line 2927 +#endif +#line 2927 + status = NC_ERANGE; /* because tp is unsigned */ +#line 2927 + +#line 2927 +#ifdef ERANGE_FILL +#line 2927 + xp++; tp++; continue; +#line 2927 +#endif +#line 2927 + } +#line 2927 + *tp++ = (ulonglong) (signed) (*xp++); /* type cast from schar to ulonglong */ +#line 2927 + } +#line 2927 + +#line 2927 + *xpp = (void *)(xp + rndup); +#line 2927 + return status; +#line 2927 +} +#line 2927 + + +#line 2930 +int +ncx_putn_schar_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +{ + (void) memcpy(*xpp, tp, (size_t)nelems); +#line 2933 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 2933 + +#line 2933 + return NC_NOERR; +#line 2933 + +} +int +#line 2935 +ncx_putn_schar_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 2935 +{ +#line 2935 + int status = NC_NOERR; +#line 2935 + schar *xp = (schar *) *xpp; +#line 2935 + +#line 2935 + while (nelems-- != 0) { +#line 2935 + if (*tp > (uchar)X_SCHAR_MAX ) { +#line 2935 + +#line 2935 +#ifdef ERANGE_FILL +#line 2935 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2935 +#endif +#line 2935 + status = NC_ERANGE; +#line 2935 + +#line 2935 +#ifdef ERANGE_FILL +#line 2935 + xp++; tp++; continue; +#line 2935 +#endif +#line 2935 + } +#line 2935 + *xp++ = (schar) *tp++; /* type cast from uchar to schar */ +#line 2935 + } +#line 2935 + +#line 2935 + *xpp = (void *)xp; +#line 2935 + return status; +#line 2935 +} +#line 2935 + +int +#line 2936 +ncx_putn_schar_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 2936 +{ +#line 2936 + int status = NC_NOERR; +#line 2936 + schar *xp = (schar *) *xpp; +#line 2936 + +#line 2936 + while (nelems-- != 0) { +#line 2936 + if (*tp > (short)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2936 + +#line 2936 +#ifdef ERANGE_FILL +#line 2936 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2936 +#endif +#line 2936 + status = NC_ERANGE; +#line 2936 + +#line 2936 +#ifdef ERANGE_FILL +#line 2936 + xp++; tp++; continue; +#line 2936 +#endif +#line 2936 + } +#line 2936 + *xp++ = (schar) *tp++; /* type cast from short to schar */ +#line 2936 + } +#line 2936 + +#line 2936 + *xpp = (void *)xp; +#line 2936 + return status; +#line 2936 +} +#line 2936 + +int +#line 2937 +ncx_putn_schar_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 2937 +{ +#line 2937 + int status = NC_NOERR; +#line 2937 + schar *xp = (schar *) *xpp; +#line 2937 + +#line 2937 + while (nelems-- != 0) { +#line 2937 + if (*tp > (int)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2937 + +#line 2937 +#ifdef ERANGE_FILL +#line 2937 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2937 +#endif +#line 2937 + status = NC_ERANGE; +#line 2937 + +#line 2937 +#ifdef ERANGE_FILL +#line 2937 + xp++; tp++; continue; +#line 2937 +#endif +#line 2937 + } +#line 2937 + *xp++ = (schar) *tp++; /* type cast from int to schar */ +#line 2937 + } +#line 2937 + +#line 2937 + *xpp = (void *)xp; +#line 2937 + return status; +#line 2937 +} +#line 2937 + +int +#line 2938 +ncx_putn_schar_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 2938 +{ +#line 2938 + int status = NC_NOERR; +#line 2938 + schar *xp = (schar *) *xpp; +#line 2938 + +#line 2938 + while (nelems-- != 0) { +#line 2938 + if (*tp > (long)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2938 + +#line 2938 +#ifdef ERANGE_FILL +#line 2938 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2938 +#endif +#line 2938 + status = NC_ERANGE; +#line 2938 + +#line 2938 +#ifdef ERANGE_FILL +#line 2938 + xp++; tp++; continue; +#line 2938 +#endif +#line 2938 + } +#line 2938 + *xp++ = (schar) *tp++; /* type cast from long to schar */ +#line 2938 + } +#line 2938 + +#line 2938 + *xpp = (void *)xp; +#line 2938 + return status; +#line 2938 +} +#line 2938 + +int +#line 2939 +ncx_putn_schar_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 2939 +{ +#line 2939 + int status = NC_NOERR; +#line 2939 + schar *xp = (schar *) *xpp; +#line 2939 + +#line 2939 + while (nelems-- != 0) { +#line 2939 + if (*tp > (float)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2939 + +#line 2939 +#ifdef ERANGE_FILL +#line 2939 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2939 +#endif +#line 2939 + status = NC_ERANGE; +#line 2939 + +#line 2939 +#ifdef ERANGE_FILL +#line 2939 + xp++; tp++; continue; +#line 2939 +#endif +#line 2939 + } +#line 2939 + *xp++ = (schar) *tp++; /* type cast from float to schar */ +#line 2939 + } +#line 2939 + +#line 2939 + *xpp = (void *)xp; +#line 2939 + return status; +#line 2939 +} +#line 2939 + +int +#line 2940 +ncx_putn_schar_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 2940 +{ +#line 2940 + int status = NC_NOERR; +#line 2940 + schar *xp = (schar *) *xpp; +#line 2940 + +#line 2940 + while (nelems-- != 0) { +#line 2940 + if (*tp > (double)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2940 + +#line 2940 +#ifdef ERANGE_FILL +#line 2940 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2940 +#endif +#line 2940 + status = NC_ERANGE; +#line 2940 + +#line 2940 +#ifdef ERANGE_FILL +#line 2940 + xp++; tp++; continue; +#line 2940 +#endif +#line 2940 + } +#line 2940 + *xp++ = (schar) *tp++; /* type cast from double to schar */ +#line 2940 + } +#line 2940 + +#line 2940 + *xpp = (void *)xp; +#line 2940 + return status; +#line 2940 +} +#line 2940 + +int +#line 2941 +ncx_putn_schar_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 2941 +{ +#line 2941 + int status = NC_NOERR; +#line 2941 + schar *xp = (schar *) *xpp; +#line 2941 + +#line 2941 + while (nelems-- != 0) { +#line 2941 + if (*tp > (longlong)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2941 + +#line 2941 +#ifdef ERANGE_FILL +#line 2941 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2941 +#endif +#line 2941 + status = NC_ERANGE; +#line 2941 + +#line 2941 +#ifdef ERANGE_FILL +#line 2941 + xp++; tp++; continue; +#line 2941 +#endif +#line 2941 + } +#line 2941 + *xp++ = (schar) *tp++; /* type cast from longlong to schar */ +#line 2941 + } +#line 2941 + +#line 2941 + *xpp = (void *)xp; +#line 2941 + return status; +#line 2941 +} +#line 2941 + +int +#line 2942 +ncx_putn_schar_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 2942 +{ +#line 2942 + int status = NC_NOERR; +#line 2942 + schar *xp = (schar *) *xpp; +#line 2942 + +#line 2942 + while (nelems-- != 0) { +#line 2942 + if (*tp > (ushort)X_SCHAR_MAX ) { +#line 2942 + +#line 2942 +#ifdef ERANGE_FILL +#line 2942 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2942 +#endif +#line 2942 + status = NC_ERANGE; +#line 2942 + +#line 2942 +#ifdef ERANGE_FILL +#line 2942 + xp++; tp++; continue; +#line 2942 +#endif +#line 2942 + } +#line 2942 + *xp++ = (schar) *tp++; /* type cast from ushort to schar */ +#line 2942 + } +#line 2942 + +#line 2942 + *xpp = (void *)xp; +#line 2942 + return status; +#line 2942 +} +#line 2942 + +int +#line 2943 +ncx_putn_schar_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 2943 +{ +#line 2943 + int status = NC_NOERR; +#line 2943 + schar *xp = (schar *) *xpp; +#line 2943 + +#line 2943 + while (nelems-- != 0) { +#line 2943 + if (*tp > (uint)X_SCHAR_MAX ) { +#line 2943 + +#line 2943 +#ifdef ERANGE_FILL +#line 2943 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2943 +#endif +#line 2943 + status = NC_ERANGE; +#line 2943 + +#line 2943 +#ifdef ERANGE_FILL +#line 2943 + xp++; tp++; continue; +#line 2943 +#endif +#line 2943 + } +#line 2943 + *xp++ = (schar) *tp++; /* type cast from uint to schar */ +#line 2943 + } +#line 2943 + +#line 2943 + *xpp = (void *)xp; +#line 2943 + return status; +#line 2943 +} +#line 2943 + +int +#line 2944 +ncx_putn_schar_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 2944 +{ +#line 2944 + int status = NC_NOERR; +#line 2944 + schar *xp = (schar *) *xpp; +#line 2944 + +#line 2944 + while (nelems-- != 0) { +#line 2944 + if (*tp > (ulonglong)X_SCHAR_MAX ) { +#line 2944 + +#line 2944 +#ifdef ERANGE_FILL +#line 2944 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2944 +#endif +#line 2944 + status = NC_ERANGE; +#line 2944 + +#line 2944 +#ifdef ERANGE_FILL +#line 2944 + xp++; tp++; continue; +#line 2944 +#endif +#line 2944 + } +#line 2944 + *xp++ = (schar) *tp++; /* type cast from ulonglong to schar */ +#line 2944 + } +#line 2944 + +#line 2944 + *xpp = (void *)xp; +#line 2944 + return status; +#line 2944 +} +#line 2944 + + +#line 2947 +int +ncx_pad_putn_schar_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +{ + size_t rndup = nelems % X_ALIGN; +#line 2950 + +#line 2950 + if (rndup) +#line 2950 + rndup = X_ALIGN - rndup; +#line 2950 + +#line 2950 + (void) memcpy(*xpp, tp, (size_t)nelems); +#line 2950 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 2950 + +#line 2950 + if (rndup) +#line 2950 + { +#line 2950 + (void) memcpy(*xpp, nada, (size_t)rndup); +#line 2950 + *xpp = (void *)((char *)(*xpp) + rndup); +#line 2950 + } +#line 2950 + +#line 2950 + return NC_NOERR; +#line 2950 + +} +int +#line 2952 +ncx_pad_putn_schar_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 2952 +{ +#line 2952 + int status = NC_NOERR; +#line 2952 + size_t rndup = nelems % X_ALIGN; +#line 2952 + schar *xp = (schar *) *xpp; +#line 2952 + +#line 2952 + if (rndup) rndup = X_ALIGN - rndup; +#line 2952 + +#line 2952 + while (nelems-- != 0) { +#line 2952 + if (*tp > (uchar)X_SCHAR_MAX ) { +#line 2952 + +#line 2952 +#ifdef ERANGE_FILL +#line 2952 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2952 +#endif +#line 2952 + status = NC_ERANGE; +#line 2952 + +#line 2952 +#ifdef ERANGE_FILL +#line 2952 + xp++; tp++; continue; +#line 2952 +#endif +#line 2952 + } +#line 2952 + *xp++ = (schar) *tp++; /* type cast from uchar to schar */ +#line 2952 + } +#line 2952 + +#line 2952 + +#line 2952 + if (rndup) { +#line 2952 + (void) memcpy(xp, nada, (size_t)rndup); +#line 2952 + xp += rndup; +#line 2952 + } +#line 2952 + +#line 2952 + *xpp = (void *)xp; +#line 2952 + return status; +#line 2952 +} +#line 2952 + +int +#line 2953 +ncx_pad_putn_schar_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 2953 +{ +#line 2953 + int status = NC_NOERR; +#line 2953 + size_t rndup = nelems % X_ALIGN; +#line 2953 + schar *xp = (schar *) *xpp; +#line 2953 + +#line 2953 + if (rndup) rndup = X_ALIGN - rndup; +#line 2953 + +#line 2953 + while (nelems-- != 0) { +#line 2953 + if (*tp > (short)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2953 + +#line 2953 +#ifdef ERANGE_FILL +#line 2953 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2953 +#endif +#line 2953 + status = NC_ERANGE; +#line 2953 + +#line 2953 +#ifdef ERANGE_FILL +#line 2953 + xp++; tp++; continue; +#line 2953 +#endif +#line 2953 + } +#line 2953 + *xp++ = (schar) *tp++; /* type cast from short to schar */ +#line 2953 + } +#line 2953 + +#line 2953 + +#line 2953 + if (rndup) { +#line 2953 + (void) memcpy(xp, nada, (size_t)rndup); +#line 2953 + xp += rndup; +#line 2953 + } +#line 2953 + +#line 2953 + *xpp = (void *)xp; +#line 2953 + return status; +#line 2953 +} +#line 2953 + +int +#line 2954 +ncx_pad_putn_schar_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 2954 +{ +#line 2954 + int status = NC_NOERR; +#line 2954 + size_t rndup = nelems % X_ALIGN; +#line 2954 + schar *xp = (schar *) *xpp; +#line 2954 + +#line 2954 + if (rndup) rndup = X_ALIGN - rndup; +#line 2954 + +#line 2954 + while (nelems-- != 0) { +#line 2954 + if (*tp > (int)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2954 + +#line 2954 +#ifdef ERANGE_FILL +#line 2954 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2954 +#endif +#line 2954 + status = NC_ERANGE; +#line 2954 + +#line 2954 +#ifdef ERANGE_FILL +#line 2954 + xp++; tp++; continue; +#line 2954 +#endif +#line 2954 + } +#line 2954 + *xp++ = (schar) *tp++; /* type cast from int to schar */ +#line 2954 + } +#line 2954 + +#line 2954 + +#line 2954 + if (rndup) { +#line 2954 + (void) memcpy(xp, nada, (size_t)rndup); +#line 2954 + xp += rndup; +#line 2954 + } +#line 2954 + +#line 2954 + *xpp = (void *)xp; +#line 2954 + return status; +#line 2954 +} +#line 2954 + +int +#line 2955 +ncx_pad_putn_schar_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 2955 +{ +#line 2955 + int status = NC_NOERR; +#line 2955 + size_t rndup = nelems % X_ALIGN; +#line 2955 + schar *xp = (schar *) *xpp; +#line 2955 + +#line 2955 + if (rndup) rndup = X_ALIGN - rndup; +#line 2955 + +#line 2955 + while (nelems-- != 0) { +#line 2955 + if (*tp > (long)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2955 + +#line 2955 +#ifdef ERANGE_FILL +#line 2955 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2955 +#endif +#line 2955 + status = NC_ERANGE; +#line 2955 + +#line 2955 +#ifdef ERANGE_FILL +#line 2955 + xp++; tp++; continue; +#line 2955 +#endif +#line 2955 + } +#line 2955 + *xp++ = (schar) *tp++; /* type cast from long to schar */ +#line 2955 + } +#line 2955 + +#line 2955 + +#line 2955 + if (rndup) { +#line 2955 + (void) memcpy(xp, nada, (size_t)rndup); +#line 2955 + xp += rndup; +#line 2955 + } +#line 2955 + +#line 2955 + *xpp = (void *)xp; +#line 2955 + return status; +#line 2955 +} +#line 2955 + +int +#line 2956 +ncx_pad_putn_schar_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 2956 +{ +#line 2956 + int status = NC_NOERR; +#line 2956 + size_t rndup = nelems % X_ALIGN; +#line 2956 + schar *xp = (schar *) *xpp; +#line 2956 + +#line 2956 + if (rndup) rndup = X_ALIGN - rndup; +#line 2956 + +#line 2956 + while (nelems-- != 0) { +#line 2956 + if (*tp > (float)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2956 + +#line 2956 +#ifdef ERANGE_FILL +#line 2956 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2956 +#endif +#line 2956 + status = NC_ERANGE; +#line 2956 + +#line 2956 +#ifdef ERANGE_FILL +#line 2956 + xp++; tp++; continue; +#line 2956 +#endif +#line 2956 + } +#line 2956 + *xp++ = (schar) *tp++; /* type cast from float to schar */ +#line 2956 + } +#line 2956 + +#line 2956 + +#line 2956 + if (rndup) { +#line 2956 + (void) memcpy(xp, nada, (size_t)rndup); +#line 2956 + xp += rndup; +#line 2956 + } +#line 2956 + +#line 2956 + *xpp = (void *)xp; +#line 2956 + return status; +#line 2956 +} +#line 2956 + +int +#line 2957 +ncx_pad_putn_schar_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 2957 +{ +#line 2957 + int status = NC_NOERR; +#line 2957 + size_t rndup = nelems % X_ALIGN; +#line 2957 + schar *xp = (schar *) *xpp; +#line 2957 + +#line 2957 + if (rndup) rndup = X_ALIGN - rndup; +#line 2957 + +#line 2957 + while (nelems-- != 0) { +#line 2957 + if (*tp > (double)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2957 + +#line 2957 +#ifdef ERANGE_FILL +#line 2957 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2957 +#endif +#line 2957 + status = NC_ERANGE; +#line 2957 + +#line 2957 +#ifdef ERANGE_FILL +#line 2957 + xp++; tp++; continue; +#line 2957 +#endif +#line 2957 + } +#line 2957 + *xp++ = (schar) *tp++; /* type cast from double to schar */ +#line 2957 + } +#line 2957 + +#line 2957 + +#line 2957 + if (rndup) { +#line 2957 + (void) memcpy(xp, nada, (size_t)rndup); +#line 2957 + xp += rndup; +#line 2957 + } +#line 2957 + +#line 2957 + *xpp = (void *)xp; +#line 2957 + return status; +#line 2957 +} +#line 2957 + +int +#line 2958 +ncx_pad_putn_schar_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 2958 +{ +#line 2958 + int status = NC_NOERR; +#line 2958 + size_t rndup = nelems % X_ALIGN; +#line 2958 + schar *xp = (schar *) *xpp; +#line 2958 + +#line 2958 + if (rndup) rndup = X_ALIGN - rndup; +#line 2958 + +#line 2958 + while (nelems-- != 0) { +#line 2958 + if (*tp > (longlong)X_SCHAR_MAX || *tp < X_SCHAR_MIN) { +#line 2958 + +#line 2958 +#ifdef ERANGE_FILL +#line 2958 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2958 +#endif +#line 2958 + status = NC_ERANGE; +#line 2958 + +#line 2958 +#ifdef ERANGE_FILL +#line 2958 + xp++; tp++; continue; +#line 2958 +#endif +#line 2958 + } +#line 2958 + *xp++ = (schar) *tp++; /* type cast from longlong to schar */ +#line 2958 + } +#line 2958 + +#line 2958 + +#line 2958 + if (rndup) { +#line 2958 + (void) memcpy(xp, nada, (size_t)rndup); +#line 2958 + xp += rndup; +#line 2958 + } +#line 2958 + +#line 2958 + *xpp = (void *)xp; +#line 2958 + return status; +#line 2958 +} +#line 2958 + +int +#line 2959 +ncx_pad_putn_schar_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 2959 +{ +#line 2959 + int status = NC_NOERR; +#line 2959 + size_t rndup = nelems % X_ALIGN; +#line 2959 + schar *xp = (schar *) *xpp; +#line 2959 + +#line 2959 + if (rndup) rndup = X_ALIGN - rndup; +#line 2959 + +#line 2959 + while (nelems-- != 0) { +#line 2959 + if (*tp > (ushort)X_SCHAR_MAX ) { +#line 2959 + +#line 2959 +#ifdef ERANGE_FILL +#line 2959 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2959 +#endif +#line 2959 + status = NC_ERANGE; +#line 2959 + +#line 2959 +#ifdef ERANGE_FILL +#line 2959 + xp++; tp++; continue; +#line 2959 +#endif +#line 2959 + } +#line 2959 + *xp++ = (schar) *tp++; /* type cast from ushort to schar */ +#line 2959 + } +#line 2959 + +#line 2959 + +#line 2959 + if (rndup) { +#line 2959 + (void) memcpy(xp, nada, (size_t)rndup); +#line 2959 + xp += rndup; +#line 2959 + } +#line 2959 + +#line 2959 + *xpp = (void *)xp; +#line 2959 + return status; +#line 2959 +} +#line 2959 + +int +#line 2960 +ncx_pad_putn_schar_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 2960 +{ +#line 2960 + int status = NC_NOERR; +#line 2960 + size_t rndup = nelems % X_ALIGN; +#line 2960 + schar *xp = (schar *) *xpp; +#line 2960 + +#line 2960 + if (rndup) rndup = X_ALIGN - rndup; +#line 2960 + +#line 2960 + while (nelems-- != 0) { +#line 2960 + if (*tp > (uint)X_SCHAR_MAX ) { +#line 2960 + +#line 2960 +#ifdef ERANGE_FILL +#line 2960 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2960 +#endif +#line 2960 + status = NC_ERANGE; +#line 2960 + +#line 2960 +#ifdef ERANGE_FILL +#line 2960 + xp++; tp++; continue; +#line 2960 +#endif +#line 2960 + } +#line 2960 + *xp++ = (schar) *tp++; /* type cast from uint to schar */ +#line 2960 + } +#line 2960 + +#line 2960 + +#line 2960 + if (rndup) { +#line 2960 + (void) memcpy(xp, nada, (size_t)rndup); +#line 2960 + xp += rndup; +#line 2960 + } +#line 2960 + +#line 2960 + *xpp = (void *)xp; +#line 2960 + return status; +#line 2960 +} +#line 2960 + +int +#line 2961 +ncx_pad_putn_schar_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 2961 +{ +#line 2961 + int status = NC_NOERR; +#line 2961 + size_t rndup = nelems % X_ALIGN; +#line 2961 + schar *xp = (schar *) *xpp; +#line 2961 + +#line 2961 + if (rndup) rndup = X_ALIGN - rndup; +#line 2961 + +#line 2961 + while (nelems-- != 0) { +#line 2961 + if (*tp > (ulonglong)X_SCHAR_MAX ) { +#line 2961 + +#line 2961 +#ifdef ERANGE_FILL +#line 2961 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 2961 +#endif +#line 2961 + status = NC_ERANGE; +#line 2961 + +#line 2961 +#ifdef ERANGE_FILL +#line 2961 + xp++; tp++; continue; +#line 2961 +#endif +#line 2961 + } +#line 2961 + *xp++ = (schar) *tp++; /* type cast from ulonglong to schar */ +#line 2961 + } +#line 2961 + +#line 2961 + +#line 2961 + if (rndup) { +#line 2961 + (void) memcpy(xp, nada, (size_t)rndup); +#line 2961 + xp += rndup; +#line 2961 + } +#line 2961 + +#line 2961 + *xpp = (void *)xp; +#line 2961 + return status; +#line 2961 +} +#line 2961 + + + +/* uchar ---------------------------------------------------------------------*/ +#line 2967 +int +ncx_getn_uchar_schar(const void **xpp, size_t nelems, schar *tp) +{ + int status = NC_NOERR; + uchar *xp = (uchar *)(*xpp); + + while (nelems-- != 0) { + if (*xp > SCHAR_MAX) { + *tp = NC_FILL_BYTE; + status = NC_ERANGE; + +#line 2977 +#ifdef ERANGE_FILL +#line 2977 + xp++; tp++; continue; +#line 2977 +#endif + } + *tp++ = (schar) *xp++; /* type cast from uchar to schar */ + } + + *xpp = (const void *)xp; + return status; +} +#line 2986 +int +ncx_getn_uchar_uchar(const void **xpp, size_t nelems, uchar *tp) +{ + (void) memcpy(tp, *xpp, (size_t)nelems); +#line 2989 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 2989 + return NC_NOERR; +#line 2989 + +} +int +#line 2991 +ncx_getn_uchar_short(const void **xpp, size_t nelems, short *tp) +#line 2991 +{ +#line 2991 + int status = NC_NOERR; +#line 2991 + uchar *xp = (uchar *)(*xpp); +#line 2991 + +#line 2991 + while (nelems-- != 0) { +#line 2991 + +#line 2991 + *tp++ = (short) (*xp++); /* type cast from uchar to short */ +#line 2991 + } +#line 2991 + +#line 2991 + *xpp = (const void *)xp; +#line 2991 + return status; +#line 2991 +} +#line 2991 + +int +#line 2992 +ncx_getn_uchar_int(const void **xpp, size_t nelems, int *tp) +#line 2992 +{ +#line 2992 + int status = NC_NOERR; +#line 2992 + uchar *xp = (uchar *)(*xpp); +#line 2992 + +#line 2992 + while (nelems-- != 0) { +#line 2992 + +#line 2992 + *tp++ = (int) (*xp++); /* type cast from uchar to int */ +#line 2992 + } +#line 2992 + +#line 2992 + *xpp = (const void *)xp; +#line 2992 + return status; +#line 2992 +} +#line 2992 + +int +#line 2993 +ncx_getn_uchar_long(const void **xpp, size_t nelems, long *tp) +#line 2993 +{ +#line 2993 + int status = NC_NOERR; +#line 2993 + uchar *xp = (uchar *)(*xpp); +#line 2993 + +#line 2993 + while (nelems-- != 0) { +#line 2993 + +#line 2993 + *tp++ = (long) (*xp++); /* type cast from uchar to long */ +#line 2993 + } +#line 2993 + +#line 2993 + *xpp = (const void *)xp; +#line 2993 + return status; +#line 2993 +} +#line 2993 + +int +#line 2994 +ncx_getn_uchar_float(const void **xpp, size_t nelems, float *tp) +#line 2994 +{ +#line 2994 + int status = NC_NOERR; +#line 2994 + uchar *xp = (uchar *)(*xpp); +#line 2994 + +#line 2994 + while (nelems-- != 0) { +#line 2994 + +#line 2994 + *tp++ = (float) (*xp++); /* type cast from uchar to float */ +#line 2994 + } +#line 2994 + +#line 2994 + *xpp = (const void *)xp; +#line 2994 + return status; +#line 2994 +} +#line 2994 + +int +#line 2995 +ncx_getn_uchar_double(const void **xpp, size_t nelems, double *tp) +#line 2995 +{ +#line 2995 + int status = NC_NOERR; +#line 2995 + uchar *xp = (uchar *)(*xpp); +#line 2995 + +#line 2995 + while (nelems-- != 0) { +#line 2995 + +#line 2995 + *tp++ = (double) (*xp++); /* type cast from uchar to double */ +#line 2995 + } +#line 2995 + +#line 2995 + *xpp = (const void *)xp; +#line 2995 + return status; +#line 2995 +} +#line 2995 + +int +#line 2996 +ncx_getn_uchar_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 2996 +{ +#line 2996 + int status = NC_NOERR; +#line 2996 + uchar *xp = (uchar *)(*xpp); +#line 2996 + +#line 2996 + while (nelems-- != 0) { +#line 2996 + +#line 2996 + *tp++ = (longlong) (*xp++); /* type cast from uchar to longlong */ +#line 2996 + } +#line 2996 + +#line 2996 + *xpp = (const void *)xp; +#line 2996 + return status; +#line 2996 +} +#line 2996 + +int +#line 2997 +ncx_getn_uchar_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 2997 +{ +#line 2997 + int status = NC_NOERR; +#line 2997 + uchar *xp = (uchar *)(*xpp); +#line 2997 + +#line 2997 + while (nelems-- != 0) { +#line 2997 + +#line 2997 + *tp++ = (ushort) (*xp++); /* type cast from uchar to ushort */ +#line 2997 + } +#line 2997 + +#line 2997 + *xpp = (const void *)xp; +#line 2997 + return status; +#line 2997 +} +#line 2997 + +int +#line 2998 +ncx_getn_uchar_uint(const void **xpp, size_t nelems, uint *tp) +#line 2998 +{ +#line 2998 + int status = NC_NOERR; +#line 2998 + uchar *xp = (uchar *)(*xpp); +#line 2998 + +#line 2998 + while (nelems-- != 0) { +#line 2998 + +#line 2998 + *tp++ = (uint) (*xp++); /* type cast from uchar to uint */ +#line 2998 + } +#line 2998 + +#line 2998 + *xpp = (const void *)xp; +#line 2998 + return status; +#line 2998 +} +#line 2998 + +int +#line 2999 +ncx_getn_uchar_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 2999 +{ +#line 2999 + int status = NC_NOERR; +#line 2999 + uchar *xp = (uchar *)(*xpp); +#line 2999 + +#line 2999 + while (nelems-- != 0) { +#line 2999 + +#line 2999 + *tp++ = (ulonglong) (*xp++); /* type cast from uchar to ulonglong */ +#line 2999 + } +#line 2999 + +#line 2999 + *xpp = (const void *)xp; +#line 2999 + return status; +#line 2999 +} +#line 2999 + + +#line 3002 +int +ncx_pad_getn_uchar_schar(const void **xpp, size_t nelems, schar *tp) +{ + int status = NC_NOERR; + size_t rndup = nelems % X_ALIGN; + uchar *xp = (uchar *) *xpp; + + if (rndup) rndup = X_ALIGN - rndup; + + while (nelems-- != 0) { + if (*xp > SCHAR_MAX) { + *tp = NC_FILL_BYTE; + status = NC_ERANGE; + +#line 3015 +#ifdef ERANGE_FILL +#line 3015 + xp++; tp++; continue; +#line 3015 +#endif + } + *tp++ = (schar) *xp++; /* type cast from uchar to schar */ + } + + *xpp = (void *)(xp + rndup); + return status; +} +#line 3024 +int +ncx_pad_getn_uchar_uchar(const void **xpp, size_t nelems, uchar *tp) +{ + size_t rndup = nelems % X_ALIGN; +#line 3027 + +#line 3027 + if (rndup) +#line 3027 + rndup = X_ALIGN - rndup; +#line 3027 + +#line 3027 + (void) memcpy(tp, *xpp, (size_t)nelems); +#line 3027 + *xpp = (void *)((char *)(*xpp) + nelems + rndup); +#line 3027 + +#line 3027 + return NC_NOERR; +#line 3027 + +} +int +#line 3029 +ncx_pad_getn_uchar_short(const void **xpp, size_t nelems, short *tp) +#line 3029 +{ +#line 3029 + int status = NC_NOERR; +#line 3029 + size_t rndup = nelems % X_ALIGN; +#line 3029 + uchar *xp = (uchar *) *xpp; +#line 3029 + +#line 3029 + if (rndup) +#line 3029 + rndup = X_ALIGN - rndup; +#line 3029 + +#line 3029 + while (nelems-- != 0) { +#line 3029 + +#line 3029 + *tp++ = (short) (*xp++); /* type cast from uchar to short */ +#line 3029 + } +#line 3029 + +#line 3029 + *xpp = (void *)(xp + rndup); +#line 3029 + return status; +#line 3029 +} +#line 3029 + +int +#line 3030 +ncx_pad_getn_uchar_int(const void **xpp, size_t nelems, int *tp) +#line 3030 +{ +#line 3030 + int status = NC_NOERR; +#line 3030 + size_t rndup = nelems % X_ALIGN; +#line 3030 + uchar *xp = (uchar *) *xpp; +#line 3030 + +#line 3030 + if (rndup) +#line 3030 + rndup = X_ALIGN - rndup; +#line 3030 + +#line 3030 + while (nelems-- != 0) { +#line 3030 + +#line 3030 + *tp++ = (int) (*xp++); /* type cast from uchar to int */ +#line 3030 + } +#line 3030 + +#line 3030 + *xpp = (void *)(xp + rndup); +#line 3030 + return status; +#line 3030 +} +#line 3030 + +int +#line 3031 +ncx_pad_getn_uchar_long(const void **xpp, size_t nelems, long *tp) +#line 3031 +{ +#line 3031 + int status = NC_NOERR; +#line 3031 + size_t rndup = nelems % X_ALIGN; +#line 3031 + uchar *xp = (uchar *) *xpp; +#line 3031 + +#line 3031 + if (rndup) +#line 3031 + rndup = X_ALIGN - rndup; +#line 3031 + +#line 3031 + while (nelems-- != 0) { +#line 3031 + +#line 3031 + *tp++ = (long) (*xp++); /* type cast from uchar to long */ +#line 3031 + } +#line 3031 + +#line 3031 + *xpp = (void *)(xp + rndup); +#line 3031 + return status; +#line 3031 +} +#line 3031 + +int +#line 3032 +ncx_pad_getn_uchar_float(const void **xpp, size_t nelems, float *tp) +#line 3032 +{ +#line 3032 + int status = NC_NOERR; +#line 3032 + size_t rndup = nelems % X_ALIGN; +#line 3032 + uchar *xp = (uchar *) *xpp; +#line 3032 + +#line 3032 + if (rndup) +#line 3032 + rndup = X_ALIGN - rndup; +#line 3032 + +#line 3032 + while (nelems-- != 0) { +#line 3032 + +#line 3032 + *tp++ = (float) (*xp++); /* type cast from uchar to float */ +#line 3032 + } +#line 3032 + +#line 3032 + *xpp = (void *)(xp + rndup); +#line 3032 + return status; +#line 3032 +} +#line 3032 + +int +#line 3033 +ncx_pad_getn_uchar_double(const void **xpp, size_t nelems, double *tp) +#line 3033 +{ +#line 3033 + int status = NC_NOERR; +#line 3033 + size_t rndup = nelems % X_ALIGN; +#line 3033 + uchar *xp = (uchar *) *xpp; +#line 3033 + +#line 3033 + if (rndup) +#line 3033 + rndup = X_ALIGN - rndup; +#line 3033 + +#line 3033 + while (nelems-- != 0) { +#line 3033 + +#line 3033 + *tp++ = (double) (*xp++); /* type cast from uchar to double */ +#line 3033 + } +#line 3033 + +#line 3033 + *xpp = (void *)(xp + rndup); +#line 3033 + return status; +#line 3033 +} +#line 3033 + +int +#line 3034 +ncx_pad_getn_uchar_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 3034 +{ +#line 3034 + int status = NC_NOERR; +#line 3034 + size_t rndup = nelems % X_ALIGN; +#line 3034 + uchar *xp = (uchar *) *xpp; +#line 3034 + +#line 3034 + if (rndup) +#line 3034 + rndup = X_ALIGN - rndup; +#line 3034 + +#line 3034 + while (nelems-- != 0) { +#line 3034 + +#line 3034 + *tp++ = (longlong) (*xp++); /* type cast from uchar to longlong */ +#line 3034 + } +#line 3034 + +#line 3034 + *xpp = (void *)(xp + rndup); +#line 3034 + return status; +#line 3034 +} +#line 3034 + +int +#line 3035 +ncx_pad_getn_uchar_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 3035 +{ +#line 3035 + int status = NC_NOERR; +#line 3035 + size_t rndup = nelems % X_ALIGN; +#line 3035 + uchar *xp = (uchar *) *xpp; +#line 3035 + +#line 3035 + if (rndup) +#line 3035 + rndup = X_ALIGN - rndup; +#line 3035 + +#line 3035 + while (nelems-- != 0) { +#line 3035 + +#line 3035 + *tp++ = (ushort) (*xp++); /* type cast from uchar to ushort */ +#line 3035 + } +#line 3035 + +#line 3035 + *xpp = (void *)(xp + rndup); +#line 3035 + return status; +#line 3035 +} +#line 3035 + +int +#line 3036 +ncx_pad_getn_uchar_uint(const void **xpp, size_t nelems, uint *tp) +#line 3036 +{ +#line 3036 + int status = NC_NOERR; +#line 3036 + size_t rndup = nelems % X_ALIGN; +#line 3036 + uchar *xp = (uchar *) *xpp; +#line 3036 + +#line 3036 + if (rndup) +#line 3036 + rndup = X_ALIGN - rndup; +#line 3036 + +#line 3036 + while (nelems-- != 0) { +#line 3036 + +#line 3036 + *tp++ = (uint) (*xp++); /* type cast from uchar to uint */ +#line 3036 + } +#line 3036 + +#line 3036 + *xpp = (void *)(xp + rndup); +#line 3036 + return status; +#line 3036 +} +#line 3036 + +int +#line 3037 +ncx_pad_getn_uchar_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 3037 +{ +#line 3037 + int status = NC_NOERR; +#line 3037 + size_t rndup = nelems % X_ALIGN; +#line 3037 + uchar *xp = (uchar *) *xpp; +#line 3037 + +#line 3037 + if (rndup) +#line 3037 + rndup = X_ALIGN - rndup; +#line 3037 + +#line 3037 + while (nelems-- != 0) { +#line 3037 + +#line 3037 + *tp++ = (ulonglong) (*xp++); /* type cast from uchar to ulonglong */ +#line 3037 + } +#line 3037 + +#line 3037 + *xpp = (void *)(xp + rndup); +#line 3037 + return status; +#line 3037 +} +#line 3037 + + +#line 3040 +int +ncx_putn_uchar_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +{ + int status = NC_NOERR; + uchar *xp = (uchar *) *xpp; + + while (nelems-- != 0) { + if (*tp < 0) { + +#line 3048 +#ifdef ERANGE_FILL +#line 3048 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3048 +#endif + status = NC_ERANGE; + +#line 3050 +#ifdef ERANGE_FILL +#line 3050 + xp++; tp++; continue; +#line 3050 +#endif + } + *xp++ = (uchar) (signed) *tp++; /* type cast from schar to uchar */ + } + + *xpp = (void *)xp; + return status; +} +#line 3059 +int +ncx_putn_uchar_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +{ + (void) memcpy(*xpp, tp, (size_t)nelems); +#line 3062 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 3062 + +#line 3062 + return NC_NOERR; +#line 3062 + +} +int +#line 3064 +ncx_putn_uchar_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3064 +{ +#line 3064 + int status = NC_NOERR; +#line 3064 + uchar *xp = (uchar *) *xpp; +#line 3064 + +#line 3064 + while (nelems-- != 0) { +#line 3064 + if (*tp > (short)X_UCHAR_MAX || *tp < 0) { +#line 3064 + +#line 3064 +#ifdef ERANGE_FILL +#line 3064 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3064 +#endif +#line 3064 + status = NC_ERANGE; +#line 3064 + +#line 3064 +#ifdef ERANGE_FILL +#line 3064 + xp++; tp++; continue; +#line 3064 +#endif +#line 3064 + } +#line 3064 + *xp++ = (uchar) (signed) *tp++; /* type cast from short to uchar */ +#line 3064 + } +#line 3064 + +#line 3064 + *xpp = (void *)xp; +#line 3064 + return status; +#line 3064 +} +#line 3064 + +int +#line 3065 +ncx_putn_uchar_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3065 +{ +#line 3065 + int status = NC_NOERR; +#line 3065 + uchar *xp = (uchar *) *xpp; +#line 3065 + +#line 3065 + while (nelems-- != 0) { +#line 3065 + if (*tp > (int)X_UCHAR_MAX || *tp < 0) { +#line 3065 + +#line 3065 +#ifdef ERANGE_FILL +#line 3065 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3065 +#endif +#line 3065 + status = NC_ERANGE; +#line 3065 + +#line 3065 +#ifdef ERANGE_FILL +#line 3065 + xp++; tp++; continue; +#line 3065 +#endif +#line 3065 + } +#line 3065 + *xp++ = (uchar) (signed) *tp++; /* type cast from int to uchar */ +#line 3065 + } +#line 3065 + +#line 3065 + *xpp = (void *)xp; +#line 3065 + return status; +#line 3065 +} +#line 3065 + +int +#line 3066 +ncx_putn_uchar_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3066 +{ +#line 3066 + int status = NC_NOERR; +#line 3066 + uchar *xp = (uchar *) *xpp; +#line 3066 + +#line 3066 + while (nelems-- != 0) { +#line 3066 + if (*tp > (long)X_UCHAR_MAX || *tp < 0) { +#line 3066 + +#line 3066 +#ifdef ERANGE_FILL +#line 3066 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3066 +#endif +#line 3066 + status = NC_ERANGE; +#line 3066 + +#line 3066 +#ifdef ERANGE_FILL +#line 3066 + xp++; tp++; continue; +#line 3066 +#endif +#line 3066 + } +#line 3066 + *xp++ = (uchar) (signed) *tp++; /* type cast from long to uchar */ +#line 3066 + } +#line 3066 + +#line 3066 + *xpp = (void *)xp; +#line 3066 + return status; +#line 3066 +} +#line 3066 + +int +#line 3067 +ncx_putn_uchar_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 3067 +{ +#line 3067 + int status = NC_NOERR; +#line 3067 + uchar *xp = (uchar *) *xpp; +#line 3067 + +#line 3067 + while (nelems-- != 0) { +#line 3067 + if (*tp > (float)X_UCHAR_MAX || *tp < 0) { +#line 3067 + +#line 3067 +#ifdef ERANGE_FILL +#line 3067 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3067 +#endif +#line 3067 + status = NC_ERANGE; +#line 3067 + +#line 3067 +#ifdef ERANGE_FILL +#line 3067 + xp++; tp++; continue; +#line 3067 +#endif +#line 3067 + } +#line 3067 + *xp++ = (uchar) (signed) *tp++; /* type cast from float to uchar */ +#line 3067 + } +#line 3067 + +#line 3067 + *xpp = (void *)xp; +#line 3067 + return status; +#line 3067 +} +#line 3067 + +int +#line 3068 +ncx_putn_uchar_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 3068 +{ +#line 3068 + int status = NC_NOERR; +#line 3068 + uchar *xp = (uchar *) *xpp; +#line 3068 + +#line 3068 + while (nelems-- != 0) { +#line 3068 + if (*tp > (double)X_UCHAR_MAX || *tp < 0) { +#line 3068 + +#line 3068 +#ifdef ERANGE_FILL +#line 3068 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3068 +#endif +#line 3068 + status = NC_ERANGE; +#line 3068 + +#line 3068 +#ifdef ERANGE_FILL +#line 3068 + xp++; tp++; continue; +#line 3068 +#endif +#line 3068 + } +#line 3068 + *xp++ = (uchar) (signed) *tp++; /* type cast from double to uchar */ +#line 3068 + } +#line 3068 + +#line 3068 + *xpp = (void *)xp; +#line 3068 + return status; +#line 3068 +} +#line 3068 + +int +#line 3069 +ncx_putn_uchar_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3069 +{ +#line 3069 + int status = NC_NOERR; +#line 3069 + uchar *xp = (uchar *) *xpp; +#line 3069 + +#line 3069 + while (nelems-- != 0) { +#line 3069 + if (*tp > (longlong)X_UCHAR_MAX || *tp < 0) { +#line 3069 + +#line 3069 +#ifdef ERANGE_FILL +#line 3069 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3069 +#endif +#line 3069 + status = NC_ERANGE; +#line 3069 + +#line 3069 +#ifdef ERANGE_FILL +#line 3069 + xp++; tp++; continue; +#line 3069 +#endif +#line 3069 + } +#line 3069 + *xp++ = (uchar) (signed) *tp++; /* type cast from longlong to uchar */ +#line 3069 + } +#line 3069 + +#line 3069 + *xpp = (void *)xp; +#line 3069 + return status; +#line 3069 +} +#line 3069 + +int +#line 3070 +ncx_putn_uchar_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3070 +{ +#line 3070 + int status = NC_NOERR; +#line 3070 + uchar *xp = (uchar *) *xpp; +#line 3070 + +#line 3070 + while (nelems-- != 0) { +#line 3070 + if (*tp > (ushort)X_UCHAR_MAX ) { +#line 3070 + +#line 3070 +#ifdef ERANGE_FILL +#line 3070 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3070 +#endif +#line 3070 + status = NC_ERANGE; +#line 3070 + +#line 3070 +#ifdef ERANGE_FILL +#line 3070 + xp++; tp++; continue; +#line 3070 +#endif +#line 3070 + } +#line 3070 + *xp++ = (uchar) *tp++; /* type cast from ushort to uchar */ +#line 3070 + } +#line 3070 + +#line 3070 + *xpp = (void *)xp; +#line 3070 + return status; +#line 3070 +} +#line 3070 + +int +#line 3071 +ncx_putn_uchar_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3071 +{ +#line 3071 + int status = NC_NOERR; +#line 3071 + uchar *xp = (uchar *) *xpp; +#line 3071 + +#line 3071 + while (nelems-- != 0) { +#line 3071 + if (*tp > (uint)X_UCHAR_MAX ) { +#line 3071 + +#line 3071 +#ifdef ERANGE_FILL +#line 3071 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3071 +#endif +#line 3071 + status = NC_ERANGE; +#line 3071 + +#line 3071 +#ifdef ERANGE_FILL +#line 3071 + xp++; tp++; continue; +#line 3071 +#endif +#line 3071 + } +#line 3071 + *xp++ = (uchar) *tp++; /* type cast from uint to uchar */ +#line 3071 + } +#line 3071 + +#line 3071 + *xpp = (void *)xp; +#line 3071 + return status; +#line 3071 +} +#line 3071 + +int +#line 3072 +ncx_putn_uchar_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3072 +{ +#line 3072 + int status = NC_NOERR; +#line 3072 + uchar *xp = (uchar *) *xpp; +#line 3072 + +#line 3072 + while (nelems-- != 0) { +#line 3072 + if (*tp > (ulonglong)X_UCHAR_MAX ) { +#line 3072 + +#line 3072 +#ifdef ERANGE_FILL +#line 3072 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3072 +#endif +#line 3072 + status = NC_ERANGE; +#line 3072 + +#line 3072 +#ifdef ERANGE_FILL +#line 3072 + xp++; tp++; continue; +#line 3072 +#endif +#line 3072 + } +#line 3072 + *xp++ = (uchar) *tp++; /* type cast from ulonglong to uchar */ +#line 3072 + } +#line 3072 + +#line 3072 + *xpp = (void *)xp; +#line 3072 + return status; +#line 3072 +} +#line 3072 + + +#line 3075 +int +ncx_pad_putn_uchar_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +{ + int status = NC_NOERR; + size_t rndup = nelems % X_ALIGN; + uchar *xp = (uchar *) *xpp; + + if (rndup) rndup = X_ALIGN - rndup; + + while (nelems-- != 0) { + if (*tp < 0) { + +#line 3086 +#ifdef ERANGE_FILL +#line 3086 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3086 +#endif + status = NC_ERANGE; + +#line 3088 +#ifdef ERANGE_FILL +#line 3088 + xp++; tp++; continue; +#line 3088 +#endif + } + *xp++ = (uchar) (signed) *tp++; /* type cast from schar to uchar */ + } + + if (rndup) { + (void) memcpy(xp, nada, (size_t)rndup); + xp += rndup; + } + + *xpp = (void *)xp; + return status; +} +#line 3102 +int +ncx_pad_putn_uchar_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +{ + size_t rndup = nelems % X_ALIGN; +#line 3105 + +#line 3105 + if (rndup) +#line 3105 + rndup = X_ALIGN - rndup; +#line 3105 + +#line 3105 + (void) memcpy(*xpp, tp, (size_t)nelems); +#line 3105 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 3105 + +#line 3105 + if (rndup) +#line 3105 + { +#line 3105 + (void) memcpy(*xpp, nada, (size_t)rndup); +#line 3105 + *xpp = (void *)((char *)(*xpp) + rndup); +#line 3105 + } +#line 3105 + +#line 3105 + return NC_NOERR; +#line 3105 + +} +int +#line 3107 +ncx_pad_putn_uchar_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3107 +{ +#line 3107 + int status = NC_NOERR; +#line 3107 + size_t rndup = nelems % X_ALIGN; +#line 3107 + uchar *xp = (uchar *) *xpp; +#line 3107 + +#line 3107 + if (rndup) rndup = X_ALIGN - rndup; +#line 3107 + +#line 3107 + while (nelems-- != 0) { +#line 3107 + if (*tp > (short)X_UCHAR_MAX || *tp < 0) { +#line 3107 + +#line 3107 +#ifdef ERANGE_FILL +#line 3107 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3107 +#endif +#line 3107 + status = NC_ERANGE; +#line 3107 + +#line 3107 +#ifdef ERANGE_FILL +#line 3107 + xp++; tp++; continue; +#line 3107 +#endif +#line 3107 + } +#line 3107 + *xp++ = (uchar) (signed) *tp++; /* type cast from short to uchar */ +#line 3107 + } +#line 3107 + +#line 3107 + +#line 3107 + if (rndup) { +#line 3107 + (void) memcpy(xp, nada, (size_t)rndup); +#line 3107 + xp += rndup; +#line 3107 + } +#line 3107 + +#line 3107 + *xpp = (void *)xp; +#line 3107 + return status; +#line 3107 +} +#line 3107 + +int +#line 3108 +ncx_pad_putn_uchar_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3108 +{ +#line 3108 + int status = NC_NOERR; +#line 3108 + size_t rndup = nelems % X_ALIGN; +#line 3108 + uchar *xp = (uchar *) *xpp; +#line 3108 + +#line 3108 + if (rndup) rndup = X_ALIGN - rndup; +#line 3108 + +#line 3108 + while (nelems-- != 0) { +#line 3108 + if (*tp > (int)X_UCHAR_MAX || *tp < 0) { +#line 3108 + +#line 3108 +#ifdef ERANGE_FILL +#line 3108 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3108 +#endif +#line 3108 + status = NC_ERANGE; +#line 3108 + +#line 3108 +#ifdef ERANGE_FILL +#line 3108 + xp++; tp++; continue; +#line 3108 +#endif +#line 3108 + } +#line 3108 + *xp++ = (uchar) (signed) *tp++; /* type cast from int to uchar */ +#line 3108 + } +#line 3108 + +#line 3108 + +#line 3108 + if (rndup) { +#line 3108 + (void) memcpy(xp, nada, (size_t)rndup); +#line 3108 + xp += rndup; +#line 3108 + } +#line 3108 + +#line 3108 + *xpp = (void *)xp; +#line 3108 + return status; +#line 3108 +} +#line 3108 + +int +#line 3109 +ncx_pad_putn_uchar_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3109 +{ +#line 3109 + int status = NC_NOERR; +#line 3109 + size_t rndup = nelems % X_ALIGN; +#line 3109 + uchar *xp = (uchar *) *xpp; +#line 3109 + +#line 3109 + if (rndup) rndup = X_ALIGN - rndup; +#line 3109 + +#line 3109 + while (nelems-- != 0) { +#line 3109 + if (*tp > (long)X_UCHAR_MAX || *tp < 0) { +#line 3109 + +#line 3109 +#ifdef ERANGE_FILL +#line 3109 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3109 +#endif +#line 3109 + status = NC_ERANGE; +#line 3109 + +#line 3109 +#ifdef ERANGE_FILL +#line 3109 + xp++; tp++; continue; +#line 3109 +#endif +#line 3109 + } +#line 3109 + *xp++ = (uchar) (signed) *tp++; /* type cast from long to uchar */ +#line 3109 + } +#line 3109 + +#line 3109 + +#line 3109 + if (rndup) { +#line 3109 + (void) memcpy(xp, nada, (size_t)rndup); +#line 3109 + xp += rndup; +#line 3109 + } +#line 3109 + +#line 3109 + *xpp = (void *)xp; +#line 3109 + return status; +#line 3109 +} +#line 3109 + +int +#line 3110 +ncx_pad_putn_uchar_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 3110 +{ +#line 3110 + int status = NC_NOERR; +#line 3110 + size_t rndup = nelems % X_ALIGN; +#line 3110 + uchar *xp = (uchar *) *xpp; +#line 3110 + +#line 3110 + if (rndup) rndup = X_ALIGN - rndup; +#line 3110 + +#line 3110 + while (nelems-- != 0) { +#line 3110 + if (*tp > (float)X_UCHAR_MAX || *tp < 0) { +#line 3110 + +#line 3110 +#ifdef ERANGE_FILL +#line 3110 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3110 +#endif +#line 3110 + status = NC_ERANGE; +#line 3110 + +#line 3110 +#ifdef ERANGE_FILL +#line 3110 + xp++; tp++; continue; +#line 3110 +#endif +#line 3110 + } +#line 3110 + *xp++ = (uchar) (signed) *tp++; /* type cast from float to uchar */ +#line 3110 + } +#line 3110 + +#line 3110 + +#line 3110 + if (rndup) { +#line 3110 + (void) memcpy(xp, nada, (size_t)rndup); +#line 3110 + xp += rndup; +#line 3110 + } +#line 3110 + +#line 3110 + *xpp = (void *)xp; +#line 3110 + return status; +#line 3110 +} +#line 3110 + +int +#line 3111 +ncx_pad_putn_uchar_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 3111 +{ +#line 3111 + int status = NC_NOERR; +#line 3111 + size_t rndup = nelems % X_ALIGN; +#line 3111 + uchar *xp = (uchar *) *xpp; +#line 3111 + +#line 3111 + if (rndup) rndup = X_ALIGN - rndup; +#line 3111 + +#line 3111 + while (nelems-- != 0) { +#line 3111 + if (*tp > (double)X_UCHAR_MAX || *tp < 0) { +#line 3111 + +#line 3111 +#ifdef ERANGE_FILL +#line 3111 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3111 +#endif +#line 3111 + status = NC_ERANGE; +#line 3111 + +#line 3111 +#ifdef ERANGE_FILL +#line 3111 + xp++; tp++; continue; +#line 3111 +#endif +#line 3111 + } +#line 3111 + *xp++ = (uchar) (signed) *tp++; /* type cast from double to uchar */ +#line 3111 + } +#line 3111 + +#line 3111 + +#line 3111 + if (rndup) { +#line 3111 + (void) memcpy(xp, nada, (size_t)rndup); +#line 3111 + xp += rndup; +#line 3111 + } +#line 3111 + +#line 3111 + *xpp = (void *)xp; +#line 3111 + return status; +#line 3111 +} +#line 3111 + +int +#line 3112 +ncx_pad_putn_uchar_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3112 +{ +#line 3112 + int status = NC_NOERR; +#line 3112 + size_t rndup = nelems % X_ALIGN; +#line 3112 + uchar *xp = (uchar *) *xpp; +#line 3112 + +#line 3112 + if (rndup) rndup = X_ALIGN - rndup; +#line 3112 + +#line 3112 + while (nelems-- != 0) { +#line 3112 + if (*tp > (longlong)X_UCHAR_MAX || *tp < 0) { +#line 3112 + +#line 3112 +#ifdef ERANGE_FILL +#line 3112 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3112 +#endif +#line 3112 + status = NC_ERANGE; +#line 3112 + +#line 3112 +#ifdef ERANGE_FILL +#line 3112 + xp++; tp++; continue; +#line 3112 +#endif +#line 3112 + } +#line 3112 + *xp++ = (uchar) (signed) *tp++; /* type cast from longlong to uchar */ +#line 3112 + } +#line 3112 + +#line 3112 + +#line 3112 + if (rndup) { +#line 3112 + (void) memcpy(xp, nada, (size_t)rndup); +#line 3112 + xp += rndup; +#line 3112 + } +#line 3112 + +#line 3112 + *xpp = (void *)xp; +#line 3112 + return status; +#line 3112 +} +#line 3112 + +int +#line 3113 +ncx_pad_putn_uchar_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3113 +{ +#line 3113 + int status = NC_NOERR; +#line 3113 + size_t rndup = nelems % X_ALIGN; +#line 3113 + uchar *xp = (uchar *) *xpp; +#line 3113 + +#line 3113 + if (rndup) rndup = X_ALIGN - rndup; +#line 3113 + +#line 3113 + while (nelems-- != 0) { +#line 3113 + if (*tp > (ushort)X_UCHAR_MAX ) { +#line 3113 + +#line 3113 +#ifdef ERANGE_FILL +#line 3113 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3113 +#endif +#line 3113 + status = NC_ERANGE; +#line 3113 + +#line 3113 +#ifdef ERANGE_FILL +#line 3113 + xp++; tp++; continue; +#line 3113 +#endif +#line 3113 + } +#line 3113 + *xp++ = (uchar) *tp++; /* type cast from ushort to uchar */ +#line 3113 + } +#line 3113 + +#line 3113 + +#line 3113 + if (rndup) { +#line 3113 + (void) memcpy(xp, nada, (size_t)rndup); +#line 3113 + xp += rndup; +#line 3113 + } +#line 3113 + +#line 3113 + *xpp = (void *)xp; +#line 3113 + return status; +#line 3113 +} +#line 3113 + +int +#line 3114 +ncx_pad_putn_uchar_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3114 +{ +#line 3114 + int status = NC_NOERR; +#line 3114 + size_t rndup = nelems % X_ALIGN; +#line 3114 + uchar *xp = (uchar *) *xpp; +#line 3114 + +#line 3114 + if (rndup) rndup = X_ALIGN - rndup; +#line 3114 + +#line 3114 + while (nelems-- != 0) { +#line 3114 + if (*tp > (uint)X_UCHAR_MAX ) { +#line 3114 + +#line 3114 +#ifdef ERANGE_FILL +#line 3114 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3114 +#endif +#line 3114 + status = NC_ERANGE; +#line 3114 + +#line 3114 +#ifdef ERANGE_FILL +#line 3114 + xp++; tp++; continue; +#line 3114 +#endif +#line 3114 + } +#line 3114 + *xp++ = (uchar) *tp++; /* type cast from uint to uchar */ +#line 3114 + } +#line 3114 + +#line 3114 + +#line 3114 + if (rndup) { +#line 3114 + (void) memcpy(xp, nada, (size_t)rndup); +#line 3114 + xp += rndup; +#line 3114 + } +#line 3114 + +#line 3114 + *xpp = (void *)xp; +#line 3114 + return status; +#line 3114 +} +#line 3114 + +int +#line 3115 +ncx_pad_putn_uchar_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3115 +{ +#line 3115 + int status = NC_NOERR; +#line 3115 + size_t rndup = nelems % X_ALIGN; +#line 3115 + uchar *xp = (uchar *) *xpp; +#line 3115 + +#line 3115 + if (rndup) rndup = X_ALIGN - rndup; +#line 3115 + +#line 3115 + while (nelems-- != 0) { +#line 3115 + if (*tp > (ulonglong)X_UCHAR_MAX ) { +#line 3115 + +#line 3115 +#ifdef ERANGE_FILL +#line 3115 + if (fillp != NULL) memcpy(xp, fillp, 1); +#line 3115 +#endif +#line 3115 + status = NC_ERANGE; +#line 3115 + +#line 3115 +#ifdef ERANGE_FILL +#line 3115 + xp++; tp++; continue; +#line 3115 +#endif +#line 3115 + } +#line 3115 + *xp++ = (uchar) *tp++; /* type cast from ulonglong to uchar */ +#line 3115 + } +#line 3115 + +#line 3115 + +#line 3115 + if (rndup) { +#line 3115 + (void) memcpy(xp, nada, (size_t)rndup); +#line 3115 + xp += rndup; +#line 3115 + } +#line 3115 + +#line 3115 + *xpp = (void *)xp; +#line 3115 + return status; +#line 3115 +} +#line 3115 + + +/* short ---------------------------------------------------------------------*/ + +#if X_SIZEOF_SHORT == SIZEOF_SHORT +/* optimized version */ +int +ncx_getn_short_short(const void **xpp, size_t nelems, short *tp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(tp, *xpp, (size_t)nelems * SIZEOF_SHORT); +# else + swapn2b(tp, *xpp, nelems); +# endif + *xpp = (const void *)((const char *)(*xpp) + nelems * X_SIZEOF_SHORT); + return NC_NOERR; +} +#else +int +#line 3133 +ncx_getn_short_short(const void **xpp, size_t nelems, short *tp) +#line 3133 +{ +#line 3133 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3133 + +#line 3133 + /* basic algorithm is: +#line 3133 + * - ensure sane alignment of input data +#line 3133 + * - copy (conversion happens automatically) input data +#line 3133 + * to output +#line 3133 + * - update xpp to point at next unconverted input, and tp to point +#line 3133 + * at next location for converted output +#line 3133 + */ +#line 3133 + long i, j, ni; +#line 3133 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3133 + short *xp; +#line 3133 + int nrange = 0; /* number of range errors */ +#line 3133 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3133 + long cxp = (long) *((char**)xpp); +#line 3133 + +#line 3133 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3133 + /* sjl: manually stripmine so we can limit amount of +#line 3133 + * vector work space reserved to LOOPCNT elements. Also +#line 3133 + * makes vectorisation easy */ +#line 3133 + for (j=0; j= 0 */ +#line 3133 + nrange += xp[i] > SHORT_MAX || xp[i] < SHORT_MIN; +#line 3133 + } +#line 3133 + /* update xpp and tp */ +#line 3133 + if (realign) xp = (short *) *xpp; +#line 3133 + xp += ni; +#line 3133 + tp += ni; +#line 3133 + *xpp = (void*)xp; +#line 3133 + } +#line 3133 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3133 + +#line 3133 +#else /* not SX */ +#line 3133 + const char *xp = (const char *) *xpp; +#line 3133 + int status = NC_NOERR; +#line 3133 + +#line 3133 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3133 + { +#line 3133 + const int lstatus = ncx_get_short_short(xp, tp); +#line 3133 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3133 + status = lstatus; +#line 3133 + } +#line 3133 + +#line 3133 + *xpp = (const void *)xp; +#line 3133 + return status; +#line 3133 +#endif +#line 3133 +} +#line 3133 + +#endif +int +#line 3135 +ncx_getn_short_schar(const void **xpp, size_t nelems, schar *tp) +#line 3135 +{ +#line 3135 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3135 + +#line 3135 + /* basic algorithm is: +#line 3135 + * - ensure sane alignment of input data +#line 3135 + * - copy (conversion happens automatically) input data +#line 3135 + * to output +#line 3135 + * - update xpp to point at next unconverted input, and tp to point +#line 3135 + * at next location for converted output +#line 3135 + */ +#line 3135 + long i, j, ni; +#line 3135 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3135 + short *xp; +#line 3135 + int nrange = 0; /* number of range errors */ +#line 3135 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3135 + long cxp = (long) *((char**)xpp); +#line 3135 + +#line 3135 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3135 + /* sjl: manually stripmine so we can limit amount of +#line 3135 + * vector work space reserved to LOOPCNT elements. Also +#line 3135 + * makes vectorisation easy */ +#line 3135 + for (j=0; j= 0 */ +#line 3135 + nrange += xp[i] > SCHAR_MAX || xp[i] < SCHAR_MIN; +#line 3135 + } +#line 3135 + /* update xpp and tp */ +#line 3135 + if (realign) xp = (short *) *xpp; +#line 3135 + xp += ni; +#line 3135 + tp += ni; +#line 3135 + *xpp = (void*)xp; +#line 3135 + } +#line 3135 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3135 + +#line 3135 +#else /* not SX */ +#line 3135 + const char *xp = (const char *) *xpp; +#line 3135 + int status = NC_NOERR; +#line 3135 + +#line 3135 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3135 + { +#line 3135 + const int lstatus = ncx_get_short_schar(xp, tp); +#line 3135 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3135 + status = lstatus; +#line 3135 + } +#line 3135 + +#line 3135 + *xpp = (const void *)xp; +#line 3135 + return status; +#line 3135 +#endif +#line 3135 +} +#line 3135 + +int +#line 3136 +ncx_getn_short_int(const void **xpp, size_t nelems, int *tp) +#line 3136 +{ +#line 3136 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3136 + +#line 3136 + /* basic algorithm is: +#line 3136 + * - ensure sane alignment of input data +#line 3136 + * - copy (conversion happens automatically) input data +#line 3136 + * to output +#line 3136 + * - update xpp to point at next unconverted input, and tp to point +#line 3136 + * at next location for converted output +#line 3136 + */ +#line 3136 + long i, j, ni; +#line 3136 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3136 + short *xp; +#line 3136 + int nrange = 0; /* number of range errors */ +#line 3136 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3136 + long cxp = (long) *((char**)xpp); +#line 3136 + +#line 3136 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3136 + /* sjl: manually stripmine so we can limit amount of +#line 3136 + * vector work space reserved to LOOPCNT elements. Also +#line 3136 + * makes vectorisation easy */ +#line 3136 + for (j=0; j= 0 */ +#line 3136 + nrange += xp[i] > INT_MAX || xp[i] < INT_MIN; +#line 3136 + } +#line 3136 + /* update xpp and tp */ +#line 3136 + if (realign) xp = (short *) *xpp; +#line 3136 + xp += ni; +#line 3136 + tp += ni; +#line 3136 + *xpp = (void*)xp; +#line 3136 + } +#line 3136 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3136 + +#line 3136 +#else /* not SX */ +#line 3136 + const char *xp = (const char *) *xpp; +#line 3136 + int status = NC_NOERR; +#line 3136 + +#line 3136 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3136 + { +#line 3136 + const int lstatus = ncx_get_short_int(xp, tp); +#line 3136 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3136 + status = lstatus; +#line 3136 + } +#line 3136 + +#line 3136 + *xpp = (const void *)xp; +#line 3136 + return status; +#line 3136 +#endif +#line 3136 +} +#line 3136 + +int +#line 3137 +ncx_getn_short_long(const void **xpp, size_t nelems, long *tp) +#line 3137 +{ +#line 3137 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3137 + +#line 3137 + /* basic algorithm is: +#line 3137 + * - ensure sane alignment of input data +#line 3137 + * - copy (conversion happens automatically) input data +#line 3137 + * to output +#line 3137 + * - update xpp to point at next unconverted input, and tp to point +#line 3137 + * at next location for converted output +#line 3137 + */ +#line 3137 + long i, j, ni; +#line 3137 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3137 + short *xp; +#line 3137 + int nrange = 0; /* number of range errors */ +#line 3137 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3137 + long cxp = (long) *((char**)xpp); +#line 3137 + +#line 3137 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3137 + /* sjl: manually stripmine so we can limit amount of +#line 3137 + * vector work space reserved to LOOPCNT elements. Also +#line 3137 + * makes vectorisation easy */ +#line 3137 + for (j=0; j= 0 */ +#line 3137 + nrange += xp[i] > LONG_MAX || xp[i] < LONG_MIN; +#line 3137 + } +#line 3137 + /* update xpp and tp */ +#line 3137 + if (realign) xp = (short *) *xpp; +#line 3137 + xp += ni; +#line 3137 + tp += ni; +#line 3137 + *xpp = (void*)xp; +#line 3137 + } +#line 3137 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3137 + +#line 3137 +#else /* not SX */ +#line 3137 + const char *xp = (const char *) *xpp; +#line 3137 + int status = NC_NOERR; +#line 3137 + +#line 3137 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3137 + { +#line 3137 + const int lstatus = ncx_get_short_long(xp, tp); +#line 3137 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3137 + status = lstatus; +#line 3137 + } +#line 3137 + +#line 3137 + *xpp = (const void *)xp; +#line 3137 + return status; +#line 3137 +#endif +#line 3137 +} +#line 3137 + +int +#line 3138 +ncx_getn_short_float(const void **xpp, size_t nelems, float *tp) +#line 3138 +{ +#line 3138 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3138 + +#line 3138 + /* basic algorithm is: +#line 3138 + * - ensure sane alignment of input data +#line 3138 + * - copy (conversion happens automatically) input data +#line 3138 + * to output +#line 3138 + * - update xpp to point at next unconverted input, and tp to point +#line 3138 + * at next location for converted output +#line 3138 + */ +#line 3138 + long i, j, ni; +#line 3138 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3138 + short *xp; +#line 3138 + int nrange = 0; /* number of range errors */ +#line 3138 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3138 + long cxp = (long) *((char**)xpp); +#line 3138 + +#line 3138 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3138 + /* sjl: manually stripmine so we can limit amount of +#line 3138 + * vector work space reserved to LOOPCNT elements. Also +#line 3138 + * makes vectorisation easy */ +#line 3138 + for (j=0; j= 0 */ +#line 3138 + nrange += xp[i] > FLOAT_MAX || xp[i] < FLOAT_MIN; +#line 3138 + } +#line 3138 + /* update xpp and tp */ +#line 3138 + if (realign) xp = (short *) *xpp; +#line 3138 + xp += ni; +#line 3138 + tp += ni; +#line 3138 + *xpp = (void*)xp; +#line 3138 + } +#line 3138 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3138 + +#line 3138 +#else /* not SX */ +#line 3138 + const char *xp = (const char *) *xpp; +#line 3138 + int status = NC_NOERR; +#line 3138 + +#line 3138 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3138 + { +#line 3138 + const int lstatus = ncx_get_short_float(xp, tp); +#line 3138 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3138 + status = lstatus; +#line 3138 + } +#line 3138 + +#line 3138 + *xpp = (const void *)xp; +#line 3138 + return status; +#line 3138 +#endif +#line 3138 +} +#line 3138 + +int +#line 3139 +ncx_getn_short_double(const void **xpp, size_t nelems, double *tp) +#line 3139 +{ +#line 3139 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3139 + +#line 3139 + /* basic algorithm is: +#line 3139 + * - ensure sane alignment of input data +#line 3139 + * - copy (conversion happens automatically) input data +#line 3139 + * to output +#line 3139 + * - update xpp to point at next unconverted input, and tp to point +#line 3139 + * at next location for converted output +#line 3139 + */ +#line 3139 + long i, j, ni; +#line 3139 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3139 + short *xp; +#line 3139 + int nrange = 0; /* number of range errors */ +#line 3139 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3139 + long cxp = (long) *((char**)xpp); +#line 3139 + +#line 3139 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3139 + /* sjl: manually stripmine so we can limit amount of +#line 3139 + * vector work space reserved to LOOPCNT elements. Also +#line 3139 + * makes vectorisation easy */ +#line 3139 + for (j=0; j= 0 */ +#line 3139 + nrange += xp[i] > DOUBLE_MAX || xp[i] < DOUBLE_MIN; +#line 3139 + } +#line 3139 + /* update xpp and tp */ +#line 3139 + if (realign) xp = (short *) *xpp; +#line 3139 + xp += ni; +#line 3139 + tp += ni; +#line 3139 + *xpp = (void*)xp; +#line 3139 + } +#line 3139 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3139 + +#line 3139 +#else /* not SX */ +#line 3139 + const char *xp = (const char *) *xpp; +#line 3139 + int status = NC_NOERR; +#line 3139 + +#line 3139 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3139 + { +#line 3139 + const int lstatus = ncx_get_short_double(xp, tp); +#line 3139 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3139 + status = lstatus; +#line 3139 + } +#line 3139 + +#line 3139 + *xpp = (const void *)xp; +#line 3139 + return status; +#line 3139 +#endif +#line 3139 +} +#line 3139 + +int +#line 3140 +ncx_getn_short_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 3140 +{ +#line 3140 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3140 + +#line 3140 + /* basic algorithm is: +#line 3140 + * - ensure sane alignment of input data +#line 3140 + * - copy (conversion happens automatically) input data +#line 3140 + * to output +#line 3140 + * - update xpp to point at next unconverted input, and tp to point +#line 3140 + * at next location for converted output +#line 3140 + */ +#line 3140 + long i, j, ni; +#line 3140 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3140 + short *xp; +#line 3140 + int nrange = 0; /* number of range errors */ +#line 3140 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3140 + long cxp = (long) *((char**)xpp); +#line 3140 + +#line 3140 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3140 + /* sjl: manually stripmine so we can limit amount of +#line 3140 + * vector work space reserved to LOOPCNT elements. Also +#line 3140 + * makes vectorisation easy */ +#line 3140 + for (j=0; j= 0 */ +#line 3140 + nrange += xp[i] > LONGLONG_MAX || xp[i] < LONGLONG_MIN; +#line 3140 + } +#line 3140 + /* update xpp and tp */ +#line 3140 + if (realign) xp = (short *) *xpp; +#line 3140 + xp += ni; +#line 3140 + tp += ni; +#line 3140 + *xpp = (void*)xp; +#line 3140 + } +#line 3140 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3140 + +#line 3140 +#else /* not SX */ +#line 3140 + const char *xp = (const char *) *xpp; +#line 3140 + int status = NC_NOERR; +#line 3140 + +#line 3140 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3140 + { +#line 3140 + const int lstatus = ncx_get_short_longlong(xp, tp); +#line 3140 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3140 + status = lstatus; +#line 3140 + } +#line 3140 + +#line 3140 + *xpp = (const void *)xp; +#line 3140 + return status; +#line 3140 +#endif +#line 3140 +} +#line 3140 + +int +#line 3141 +ncx_getn_short_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 3141 +{ +#line 3141 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3141 + +#line 3141 + /* basic algorithm is: +#line 3141 + * - ensure sane alignment of input data +#line 3141 + * - copy (conversion happens automatically) input data +#line 3141 + * to output +#line 3141 + * - update xpp to point at next unconverted input, and tp to point +#line 3141 + * at next location for converted output +#line 3141 + */ +#line 3141 + long i, j, ni; +#line 3141 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3141 + short *xp; +#line 3141 + int nrange = 0; /* number of range errors */ +#line 3141 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3141 + long cxp = (long) *((char**)xpp); +#line 3141 + +#line 3141 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3141 + /* sjl: manually stripmine so we can limit amount of +#line 3141 + * vector work space reserved to LOOPCNT elements. Also +#line 3141 + * makes vectorisation easy */ +#line 3141 + for (j=0; j= 0 */ +#line 3141 + nrange += xp[i] > UCHAR_MAX || xp[i] < 0; +#line 3141 + } +#line 3141 + /* update xpp and tp */ +#line 3141 + if (realign) xp = (short *) *xpp; +#line 3141 + xp += ni; +#line 3141 + tp += ni; +#line 3141 + *xpp = (void*)xp; +#line 3141 + } +#line 3141 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3141 + +#line 3141 +#else /* not SX */ +#line 3141 + const char *xp = (const char *) *xpp; +#line 3141 + int status = NC_NOERR; +#line 3141 + +#line 3141 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3141 + { +#line 3141 + const int lstatus = ncx_get_short_uchar(xp, tp); +#line 3141 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3141 + status = lstatus; +#line 3141 + } +#line 3141 + +#line 3141 + *xpp = (const void *)xp; +#line 3141 + return status; +#line 3141 +#endif +#line 3141 +} +#line 3141 + +int +#line 3142 +ncx_getn_short_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 3142 +{ +#line 3142 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3142 + +#line 3142 + /* basic algorithm is: +#line 3142 + * - ensure sane alignment of input data +#line 3142 + * - copy (conversion happens automatically) input data +#line 3142 + * to output +#line 3142 + * - update xpp to point at next unconverted input, and tp to point +#line 3142 + * at next location for converted output +#line 3142 + */ +#line 3142 + long i, j, ni; +#line 3142 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3142 + short *xp; +#line 3142 + int nrange = 0; /* number of range errors */ +#line 3142 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3142 + long cxp = (long) *((char**)xpp); +#line 3142 + +#line 3142 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3142 + /* sjl: manually stripmine so we can limit amount of +#line 3142 + * vector work space reserved to LOOPCNT elements. Also +#line 3142 + * makes vectorisation easy */ +#line 3142 + for (j=0; j= 0 */ +#line 3142 + nrange += xp[i] > USHORT_MAX || xp[i] < 0; +#line 3142 + } +#line 3142 + /* update xpp and tp */ +#line 3142 + if (realign) xp = (short *) *xpp; +#line 3142 + xp += ni; +#line 3142 + tp += ni; +#line 3142 + *xpp = (void*)xp; +#line 3142 + } +#line 3142 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3142 + +#line 3142 +#else /* not SX */ +#line 3142 + const char *xp = (const char *) *xpp; +#line 3142 + int status = NC_NOERR; +#line 3142 + +#line 3142 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3142 + { +#line 3142 + const int lstatus = ncx_get_short_ushort(xp, tp); +#line 3142 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3142 + status = lstatus; +#line 3142 + } +#line 3142 + +#line 3142 + *xpp = (const void *)xp; +#line 3142 + return status; +#line 3142 +#endif +#line 3142 +} +#line 3142 + +int +#line 3143 +ncx_getn_short_uint(const void **xpp, size_t nelems, uint *tp) +#line 3143 +{ +#line 3143 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3143 + +#line 3143 + /* basic algorithm is: +#line 3143 + * - ensure sane alignment of input data +#line 3143 + * - copy (conversion happens automatically) input data +#line 3143 + * to output +#line 3143 + * - update xpp to point at next unconverted input, and tp to point +#line 3143 + * at next location for converted output +#line 3143 + */ +#line 3143 + long i, j, ni; +#line 3143 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3143 + short *xp; +#line 3143 + int nrange = 0; /* number of range errors */ +#line 3143 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3143 + long cxp = (long) *((char**)xpp); +#line 3143 + +#line 3143 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3143 + /* sjl: manually stripmine so we can limit amount of +#line 3143 + * vector work space reserved to LOOPCNT elements. Also +#line 3143 + * makes vectorisation easy */ +#line 3143 + for (j=0; j= 0 */ +#line 3143 + nrange += xp[i] > UINT_MAX || xp[i] < 0; +#line 3143 + } +#line 3143 + /* update xpp and tp */ +#line 3143 + if (realign) xp = (short *) *xpp; +#line 3143 + xp += ni; +#line 3143 + tp += ni; +#line 3143 + *xpp = (void*)xp; +#line 3143 + } +#line 3143 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3143 + +#line 3143 +#else /* not SX */ +#line 3143 + const char *xp = (const char *) *xpp; +#line 3143 + int status = NC_NOERR; +#line 3143 + +#line 3143 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3143 + { +#line 3143 + const int lstatus = ncx_get_short_uint(xp, tp); +#line 3143 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3143 + status = lstatus; +#line 3143 + } +#line 3143 + +#line 3143 + *xpp = (const void *)xp; +#line 3143 + return status; +#line 3143 +#endif +#line 3143 +} +#line 3143 + +int +#line 3144 +ncx_getn_short_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 3144 +{ +#line 3144 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3144 + +#line 3144 + /* basic algorithm is: +#line 3144 + * - ensure sane alignment of input data +#line 3144 + * - copy (conversion happens automatically) input data +#line 3144 + * to output +#line 3144 + * - update xpp to point at next unconverted input, and tp to point +#line 3144 + * at next location for converted output +#line 3144 + */ +#line 3144 + long i, j, ni; +#line 3144 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3144 + short *xp; +#line 3144 + int nrange = 0; /* number of range errors */ +#line 3144 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3144 + long cxp = (long) *((char**)xpp); +#line 3144 + +#line 3144 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3144 + /* sjl: manually stripmine so we can limit amount of +#line 3144 + * vector work space reserved to LOOPCNT elements. Also +#line 3144 + * makes vectorisation easy */ +#line 3144 + for (j=0; j= 0 */ +#line 3144 + nrange += xp[i] > ULONGLONG_MAX || xp[i] < 0; +#line 3144 + } +#line 3144 + /* update xpp and tp */ +#line 3144 + if (realign) xp = (short *) *xpp; +#line 3144 + xp += ni; +#line 3144 + tp += ni; +#line 3144 + *xpp = (void*)xp; +#line 3144 + } +#line 3144 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3144 + +#line 3144 +#else /* not SX */ +#line 3144 + const char *xp = (const char *) *xpp; +#line 3144 + int status = NC_NOERR; +#line 3144 + +#line 3144 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3144 + { +#line 3144 + const int lstatus = ncx_get_short_ulonglong(xp, tp); +#line 3144 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3144 + status = lstatus; +#line 3144 + } +#line 3144 + +#line 3144 + *xpp = (const void *)xp; +#line 3144 + return status; +#line 3144 +#endif +#line 3144 +} +#line 3144 + + +int +#line 3146 +ncx_pad_getn_short_schar(const void **xpp, size_t nelems, schar *tp) +#line 3146 +{ +#line 3146 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3146 + +#line 3146 + const char *xp = (const char *) *xpp; +#line 3146 + int status = NC_NOERR; +#line 3146 + +#line 3146 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3146 + { +#line 3146 + const int lstatus = ncx_get_short_schar(xp, tp); +#line 3146 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3146 + status = lstatus; +#line 3146 + } +#line 3146 + +#line 3146 + if (rndup != 0) +#line 3146 + xp += X_SIZEOF_SHORT; +#line 3146 + +#line 3146 + *xpp = (void *)xp; +#line 3146 + return status; +#line 3146 +} +#line 3146 + +int +#line 3147 +ncx_pad_getn_short_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 3147 +{ +#line 3147 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3147 + +#line 3147 + const char *xp = (const char *) *xpp; +#line 3147 + int status = NC_NOERR; +#line 3147 + +#line 3147 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3147 + { +#line 3147 + const int lstatus = ncx_get_short_uchar(xp, tp); +#line 3147 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3147 + status = lstatus; +#line 3147 + } +#line 3147 + +#line 3147 + if (rndup != 0) +#line 3147 + xp += X_SIZEOF_SHORT; +#line 3147 + +#line 3147 + *xpp = (void *)xp; +#line 3147 + return status; +#line 3147 +} +#line 3147 + +int +#line 3148 +ncx_pad_getn_short_short(const void **xpp, size_t nelems, short *tp) +#line 3148 +{ +#line 3148 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3148 + +#line 3148 + const char *xp = (const char *) *xpp; +#line 3148 + int status = NC_NOERR; +#line 3148 + +#line 3148 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3148 + { +#line 3148 + const int lstatus = ncx_get_short_short(xp, tp); +#line 3148 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3148 + status = lstatus; +#line 3148 + } +#line 3148 + +#line 3148 + if (rndup != 0) +#line 3148 + xp += X_SIZEOF_SHORT; +#line 3148 + +#line 3148 + *xpp = (void *)xp; +#line 3148 + return status; +#line 3148 +} +#line 3148 + +int +#line 3149 +ncx_pad_getn_short_int(const void **xpp, size_t nelems, int *tp) +#line 3149 +{ +#line 3149 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3149 + +#line 3149 + const char *xp = (const char *) *xpp; +#line 3149 + int status = NC_NOERR; +#line 3149 + +#line 3149 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3149 + { +#line 3149 + const int lstatus = ncx_get_short_int(xp, tp); +#line 3149 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3149 + status = lstatus; +#line 3149 + } +#line 3149 + +#line 3149 + if (rndup != 0) +#line 3149 + xp += X_SIZEOF_SHORT; +#line 3149 + +#line 3149 + *xpp = (void *)xp; +#line 3149 + return status; +#line 3149 +} +#line 3149 + +int +#line 3150 +ncx_pad_getn_short_long(const void **xpp, size_t nelems, long *tp) +#line 3150 +{ +#line 3150 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3150 + +#line 3150 + const char *xp = (const char *) *xpp; +#line 3150 + int status = NC_NOERR; +#line 3150 + +#line 3150 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3150 + { +#line 3150 + const int lstatus = ncx_get_short_long(xp, tp); +#line 3150 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3150 + status = lstatus; +#line 3150 + } +#line 3150 + +#line 3150 + if (rndup != 0) +#line 3150 + xp += X_SIZEOF_SHORT; +#line 3150 + +#line 3150 + *xpp = (void *)xp; +#line 3150 + return status; +#line 3150 +} +#line 3150 + +int +#line 3151 +ncx_pad_getn_short_float(const void **xpp, size_t nelems, float *tp) +#line 3151 +{ +#line 3151 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3151 + +#line 3151 + const char *xp = (const char *) *xpp; +#line 3151 + int status = NC_NOERR; +#line 3151 + +#line 3151 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3151 + { +#line 3151 + const int lstatus = ncx_get_short_float(xp, tp); +#line 3151 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3151 + status = lstatus; +#line 3151 + } +#line 3151 + +#line 3151 + if (rndup != 0) +#line 3151 + xp += X_SIZEOF_SHORT; +#line 3151 + +#line 3151 + *xpp = (void *)xp; +#line 3151 + return status; +#line 3151 +} +#line 3151 + +int +#line 3152 +ncx_pad_getn_short_double(const void **xpp, size_t nelems, double *tp) +#line 3152 +{ +#line 3152 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3152 + +#line 3152 + const char *xp = (const char *) *xpp; +#line 3152 + int status = NC_NOERR; +#line 3152 + +#line 3152 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3152 + { +#line 3152 + const int lstatus = ncx_get_short_double(xp, tp); +#line 3152 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3152 + status = lstatus; +#line 3152 + } +#line 3152 + +#line 3152 + if (rndup != 0) +#line 3152 + xp += X_SIZEOF_SHORT; +#line 3152 + +#line 3152 + *xpp = (void *)xp; +#line 3152 + return status; +#line 3152 +} +#line 3152 + +int +#line 3153 +ncx_pad_getn_short_uint(const void **xpp, size_t nelems, uint *tp) +#line 3153 +{ +#line 3153 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3153 + +#line 3153 + const char *xp = (const char *) *xpp; +#line 3153 + int status = NC_NOERR; +#line 3153 + +#line 3153 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3153 + { +#line 3153 + const int lstatus = ncx_get_short_uint(xp, tp); +#line 3153 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3153 + status = lstatus; +#line 3153 + } +#line 3153 + +#line 3153 + if (rndup != 0) +#line 3153 + xp += X_SIZEOF_SHORT; +#line 3153 + +#line 3153 + *xpp = (void *)xp; +#line 3153 + return status; +#line 3153 +} +#line 3153 + +int +#line 3154 +ncx_pad_getn_short_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 3154 +{ +#line 3154 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3154 + +#line 3154 + const char *xp = (const char *) *xpp; +#line 3154 + int status = NC_NOERR; +#line 3154 + +#line 3154 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3154 + { +#line 3154 + const int lstatus = ncx_get_short_longlong(xp, tp); +#line 3154 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3154 + status = lstatus; +#line 3154 + } +#line 3154 + +#line 3154 + if (rndup != 0) +#line 3154 + xp += X_SIZEOF_SHORT; +#line 3154 + +#line 3154 + *xpp = (void *)xp; +#line 3154 + return status; +#line 3154 +} +#line 3154 + +int +#line 3155 +ncx_pad_getn_short_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 3155 +{ +#line 3155 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3155 + +#line 3155 + const char *xp = (const char *) *xpp; +#line 3155 + int status = NC_NOERR; +#line 3155 + +#line 3155 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3155 + { +#line 3155 + const int lstatus = ncx_get_short_ulonglong(xp, tp); +#line 3155 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3155 + status = lstatus; +#line 3155 + } +#line 3155 + +#line 3155 + if (rndup != 0) +#line 3155 + xp += X_SIZEOF_SHORT; +#line 3155 + +#line 3155 + *xpp = (void *)xp; +#line 3155 + return status; +#line 3155 +} +#line 3155 + +int +#line 3156 +ncx_pad_getn_short_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 3156 +{ +#line 3156 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3156 + +#line 3156 + const char *xp = (const char *) *xpp; +#line 3156 + int status = NC_NOERR; +#line 3156 + +#line 3156 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3156 + { +#line 3156 + const int lstatus = ncx_get_short_ushort(xp, tp); +#line 3156 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3156 + status = lstatus; +#line 3156 + } +#line 3156 + +#line 3156 + if (rndup != 0) +#line 3156 + xp += X_SIZEOF_SHORT; +#line 3156 + +#line 3156 + *xpp = (void *)xp; +#line 3156 + return status; +#line 3156 +} +#line 3156 + + +#if X_SIZEOF_SHORT == SIZEOF_SHORT +/* optimized version */ +int +ncx_putn_short_short(void **xpp, size_t nelems, const short *tp, void *fillp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(*xpp, tp, (size_t)nelems * X_SIZEOF_SHORT); +# else + swapn2b(*xpp, tp, nelems); +# endif + *xpp = (void *)((char *)(*xpp) + nelems * X_SIZEOF_SHORT); + return NC_NOERR; +} +#else +int +#line 3172 +ncx_putn_short_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3172 +{ +#line 3172 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3172 + +#line 3172 + /* basic algorithm is: +#line 3172 + * - ensure sane alignment of output data +#line 3172 + * - copy (conversion happens automatically) input data +#line 3172 + * to output +#line 3172 + * - update tp to point at next unconverted input, and xpp to point +#line 3172 + * at next location for converted output +#line 3172 + */ +#line 3172 + long i, j, ni; +#line 3172 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3172 + short *xp; +#line 3172 + int nrange = 0; /* number of range errors */ +#line 3172 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3172 + long cxp = (long) *((char**)xpp); +#line 3172 + +#line 3172 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3172 + /* sjl: manually stripmine so we can limit amount of +#line 3172 + * vector work space reserved to LOOPCNT elements. Also +#line 3172 + * makes vectorisation easy */ +#line 3172 + for (j=0; j= 0 */ +#line 3172 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3172 + nrange += tp[i] > X_SHORT_MAX || tp[i] < X_SHORT_MIN; +#line 3172 + } +#line 3172 + /* copy workspace back if necessary */ +#line 3172 + if (realign) { +#line 3172 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_SHORT); +#line 3172 + xp = (short *) *xpp; +#line 3172 + } +#line 3172 + /* update xpp and tp */ +#line 3172 + xp += ni; +#line 3172 + tp += ni; +#line 3172 + *xpp = (void*)xp; +#line 3172 + } +#line 3172 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3172 + +#line 3172 +#else /* not SX */ +#line 3172 + +#line 3172 + char *xp = (char *) *xpp; +#line 3172 + int status = NC_NOERR; +#line 3172 + +#line 3172 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3172 + { +#line 3172 + int lstatus = ncx_put_short_short(xp, tp, fillp); +#line 3172 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3172 + status = lstatus; +#line 3172 + } +#line 3172 + +#line 3172 + *xpp = (void *)xp; +#line 3172 + return status; +#line 3172 +#endif +#line 3172 +} +#line 3172 + +#endif +int +#line 3174 +ncx_putn_short_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +#line 3174 +{ +#line 3174 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3174 + +#line 3174 + /* basic algorithm is: +#line 3174 + * - ensure sane alignment of output data +#line 3174 + * - copy (conversion happens automatically) input data +#line 3174 + * to output +#line 3174 + * - update tp to point at next unconverted input, and xpp to point +#line 3174 + * at next location for converted output +#line 3174 + */ +#line 3174 + long i, j, ni; +#line 3174 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3174 + short *xp; +#line 3174 + int nrange = 0; /* number of range errors */ +#line 3174 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3174 + long cxp = (long) *((char**)xpp); +#line 3174 + +#line 3174 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3174 + /* sjl: manually stripmine so we can limit amount of +#line 3174 + * vector work space reserved to LOOPCNT elements. Also +#line 3174 + * makes vectorisation easy */ +#line 3174 + for (j=0; j= 0 */ +#line 3174 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3174 + nrange += tp[i] > X_SHORT_MAX || tp[i] < X_SHORT_MIN; +#line 3174 + } +#line 3174 + /* copy workspace back if necessary */ +#line 3174 + if (realign) { +#line 3174 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_SHORT); +#line 3174 + xp = (short *) *xpp; +#line 3174 + } +#line 3174 + /* update xpp and tp */ +#line 3174 + xp += ni; +#line 3174 + tp += ni; +#line 3174 + *xpp = (void*)xp; +#line 3174 + } +#line 3174 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3174 + +#line 3174 +#else /* not SX */ +#line 3174 + +#line 3174 + char *xp = (char *) *xpp; +#line 3174 + int status = NC_NOERR; +#line 3174 + +#line 3174 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3174 + { +#line 3174 + int lstatus = ncx_put_short_schar(xp, tp, fillp); +#line 3174 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3174 + status = lstatus; +#line 3174 + } +#line 3174 + +#line 3174 + *xpp = (void *)xp; +#line 3174 + return status; +#line 3174 +#endif +#line 3174 +} +#line 3174 + +int +#line 3175 +ncx_putn_short_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3175 +{ +#line 3175 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3175 + +#line 3175 + /* basic algorithm is: +#line 3175 + * - ensure sane alignment of output data +#line 3175 + * - copy (conversion happens automatically) input data +#line 3175 + * to output +#line 3175 + * - update tp to point at next unconverted input, and xpp to point +#line 3175 + * at next location for converted output +#line 3175 + */ +#line 3175 + long i, j, ni; +#line 3175 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3175 + short *xp; +#line 3175 + int nrange = 0; /* number of range errors */ +#line 3175 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3175 + long cxp = (long) *((char**)xpp); +#line 3175 + +#line 3175 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3175 + /* sjl: manually stripmine so we can limit amount of +#line 3175 + * vector work space reserved to LOOPCNT elements. Also +#line 3175 + * makes vectorisation easy */ +#line 3175 + for (j=0; j= 0 */ +#line 3175 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3175 + nrange += tp[i] > X_SHORT_MAX || tp[i] < X_SHORT_MIN; +#line 3175 + } +#line 3175 + /* copy workspace back if necessary */ +#line 3175 + if (realign) { +#line 3175 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_SHORT); +#line 3175 + xp = (short *) *xpp; +#line 3175 + } +#line 3175 + /* update xpp and tp */ +#line 3175 + xp += ni; +#line 3175 + tp += ni; +#line 3175 + *xpp = (void*)xp; +#line 3175 + } +#line 3175 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3175 + +#line 3175 +#else /* not SX */ +#line 3175 + +#line 3175 + char *xp = (char *) *xpp; +#line 3175 + int status = NC_NOERR; +#line 3175 + +#line 3175 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3175 + { +#line 3175 + int lstatus = ncx_put_short_int(xp, tp, fillp); +#line 3175 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3175 + status = lstatus; +#line 3175 + } +#line 3175 + +#line 3175 + *xpp = (void *)xp; +#line 3175 + return status; +#line 3175 +#endif +#line 3175 +} +#line 3175 + +int +#line 3176 +ncx_putn_short_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3176 +{ +#line 3176 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3176 + +#line 3176 + /* basic algorithm is: +#line 3176 + * - ensure sane alignment of output data +#line 3176 + * - copy (conversion happens automatically) input data +#line 3176 + * to output +#line 3176 + * - update tp to point at next unconverted input, and xpp to point +#line 3176 + * at next location for converted output +#line 3176 + */ +#line 3176 + long i, j, ni; +#line 3176 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3176 + short *xp; +#line 3176 + int nrange = 0; /* number of range errors */ +#line 3176 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3176 + long cxp = (long) *((char**)xpp); +#line 3176 + +#line 3176 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3176 + /* sjl: manually stripmine so we can limit amount of +#line 3176 + * vector work space reserved to LOOPCNT elements. Also +#line 3176 + * makes vectorisation easy */ +#line 3176 + for (j=0; j= 0 */ +#line 3176 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3176 + nrange += tp[i] > X_SHORT_MAX || tp[i] < X_SHORT_MIN; +#line 3176 + } +#line 3176 + /* copy workspace back if necessary */ +#line 3176 + if (realign) { +#line 3176 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_SHORT); +#line 3176 + xp = (short *) *xpp; +#line 3176 + } +#line 3176 + /* update xpp and tp */ +#line 3176 + xp += ni; +#line 3176 + tp += ni; +#line 3176 + *xpp = (void*)xp; +#line 3176 + } +#line 3176 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3176 + +#line 3176 +#else /* not SX */ +#line 3176 + +#line 3176 + char *xp = (char *) *xpp; +#line 3176 + int status = NC_NOERR; +#line 3176 + +#line 3176 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3176 + { +#line 3176 + int lstatus = ncx_put_short_long(xp, tp, fillp); +#line 3176 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3176 + status = lstatus; +#line 3176 + } +#line 3176 + +#line 3176 + *xpp = (void *)xp; +#line 3176 + return status; +#line 3176 +#endif +#line 3176 +} +#line 3176 + +int +#line 3177 +ncx_putn_short_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 3177 +{ +#line 3177 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3177 + +#line 3177 + /* basic algorithm is: +#line 3177 + * - ensure sane alignment of output data +#line 3177 + * - copy (conversion happens automatically) input data +#line 3177 + * to output +#line 3177 + * - update tp to point at next unconverted input, and xpp to point +#line 3177 + * at next location for converted output +#line 3177 + */ +#line 3177 + long i, j, ni; +#line 3177 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3177 + short *xp; +#line 3177 + int nrange = 0; /* number of range errors */ +#line 3177 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3177 + long cxp = (long) *((char**)xpp); +#line 3177 + +#line 3177 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3177 + /* sjl: manually stripmine so we can limit amount of +#line 3177 + * vector work space reserved to LOOPCNT elements. Also +#line 3177 + * makes vectorisation easy */ +#line 3177 + for (j=0; j= 0 */ +#line 3177 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3177 + nrange += tp[i] > X_SHORT_MAX || tp[i] < X_SHORT_MIN; +#line 3177 + } +#line 3177 + /* copy workspace back if necessary */ +#line 3177 + if (realign) { +#line 3177 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_SHORT); +#line 3177 + xp = (short *) *xpp; +#line 3177 + } +#line 3177 + /* update xpp and tp */ +#line 3177 + xp += ni; +#line 3177 + tp += ni; +#line 3177 + *xpp = (void*)xp; +#line 3177 + } +#line 3177 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3177 + +#line 3177 +#else /* not SX */ +#line 3177 + +#line 3177 + char *xp = (char *) *xpp; +#line 3177 + int status = NC_NOERR; +#line 3177 + +#line 3177 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3177 + { +#line 3177 + int lstatus = ncx_put_short_float(xp, tp, fillp); +#line 3177 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3177 + status = lstatus; +#line 3177 + } +#line 3177 + +#line 3177 + *xpp = (void *)xp; +#line 3177 + return status; +#line 3177 +#endif +#line 3177 +} +#line 3177 + +int +#line 3178 +ncx_putn_short_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 3178 +{ +#line 3178 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3178 + +#line 3178 + /* basic algorithm is: +#line 3178 + * - ensure sane alignment of output data +#line 3178 + * - copy (conversion happens automatically) input data +#line 3178 + * to output +#line 3178 + * - update tp to point at next unconverted input, and xpp to point +#line 3178 + * at next location for converted output +#line 3178 + */ +#line 3178 + long i, j, ni; +#line 3178 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3178 + short *xp; +#line 3178 + int nrange = 0; /* number of range errors */ +#line 3178 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3178 + long cxp = (long) *((char**)xpp); +#line 3178 + +#line 3178 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3178 + /* sjl: manually stripmine so we can limit amount of +#line 3178 + * vector work space reserved to LOOPCNT elements. Also +#line 3178 + * makes vectorisation easy */ +#line 3178 + for (j=0; j= 0 */ +#line 3178 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3178 + nrange += tp[i] > X_SHORT_MAX || tp[i] < X_SHORT_MIN; +#line 3178 + } +#line 3178 + /* copy workspace back if necessary */ +#line 3178 + if (realign) { +#line 3178 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_SHORT); +#line 3178 + xp = (short *) *xpp; +#line 3178 + } +#line 3178 + /* update xpp and tp */ +#line 3178 + xp += ni; +#line 3178 + tp += ni; +#line 3178 + *xpp = (void*)xp; +#line 3178 + } +#line 3178 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3178 + +#line 3178 +#else /* not SX */ +#line 3178 + +#line 3178 + char *xp = (char *) *xpp; +#line 3178 + int status = NC_NOERR; +#line 3178 + +#line 3178 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3178 + { +#line 3178 + int lstatus = ncx_put_short_double(xp, tp, fillp); +#line 3178 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3178 + status = lstatus; +#line 3178 + } +#line 3178 + +#line 3178 + *xpp = (void *)xp; +#line 3178 + return status; +#line 3178 +#endif +#line 3178 +} +#line 3178 + +int +#line 3179 +ncx_putn_short_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3179 +{ +#line 3179 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3179 + +#line 3179 + /* basic algorithm is: +#line 3179 + * - ensure sane alignment of output data +#line 3179 + * - copy (conversion happens automatically) input data +#line 3179 + * to output +#line 3179 + * - update tp to point at next unconverted input, and xpp to point +#line 3179 + * at next location for converted output +#line 3179 + */ +#line 3179 + long i, j, ni; +#line 3179 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3179 + short *xp; +#line 3179 + int nrange = 0; /* number of range errors */ +#line 3179 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3179 + long cxp = (long) *((char**)xpp); +#line 3179 + +#line 3179 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3179 + /* sjl: manually stripmine so we can limit amount of +#line 3179 + * vector work space reserved to LOOPCNT elements. Also +#line 3179 + * makes vectorisation easy */ +#line 3179 + for (j=0; j= 0 */ +#line 3179 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3179 + nrange += tp[i] > X_SHORT_MAX || tp[i] < X_SHORT_MIN; +#line 3179 + } +#line 3179 + /* copy workspace back if necessary */ +#line 3179 + if (realign) { +#line 3179 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_SHORT); +#line 3179 + xp = (short *) *xpp; +#line 3179 + } +#line 3179 + /* update xpp and tp */ +#line 3179 + xp += ni; +#line 3179 + tp += ni; +#line 3179 + *xpp = (void*)xp; +#line 3179 + } +#line 3179 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3179 + +#line 3179 +#else /* not SX */ +#line 3179 + +#line 3179 + char *xp = (char *) *xpp; +#line 3179 + int status = NC_NOERR; +#line 3179 + +#line 3179 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3179 + { +#line 3179 + int lstatus = ncx_put_short_longlong(xp, tp, fillp); +#line 3179 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3179 + status = lstatus; +#line 3179 + } +#line 3179 + +#line 3179 + *xpp = (void *)xp; +#line 3179 + return status; +#line 3179 +#endif +#line 3179 +} +#line 3179 + +int +#line 3180 +ncx_putn_short_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 3180 +{ +#line 3180 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3180 + +#line 3180 + /* basic algorithm is: +#line 3180 + * - ensure sane alignment of output data +#line 3180 + * - copy (conversion happens automatically) input data +#line 3180 + * to output +#line 3180 + * - update tp to point at next unconverted input, and xpp to point +#line 3180 + * at next location for converted output +#line 3180 + */ +#line 3180 + long i, j, ni; +#line 3180 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3180 + short *xp; +#line 3180 + int nrange = 0; /* number of range errors */ +#line 3180 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3180 + long cxp = (long) *((char**)xpp); +#line 3180 + +#line 3180 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3180 + /* sjl: manually stripmine so we can limit amount of +#line 3180 + * vector work space reserved to LOOPCNT elements. Also +#line 3180 + * makes vectorisation easy */ +#line 3180 + for (j=0; j= 0 */ +#line 3180 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3180 + nrange += tp[i] > X_SHORT_MAX ; +#line 3180 + } +#line 3180 + /* copy workspace back if necessary */ +#line 3180 + if (realign) { +#line 3180 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_SHORT); +#line 3180 + xp = (short *) *xpp; +#line 3180 + } +#line 3180 + /* update xpp and tp */ +#line 3180 + xp += ni; +#line 3180 + tp += ni; +#line 3180 + *xpp = (void*)xp; +#line 3180 + } +#line 3180 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3180 + +#line 3180 +#else /* not SX */ +#line 3180 + +#line 3180 + char *xp = (char *) *xpp; +#line 3180 + int status = NC_NOERR; +#line 3180 + +#line 3180 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3180 + { +#line 3180 + int lstatus = ncx_put_short_uchar(xp, tp, fillp); +#line 3180 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3180 + status = lstatus; +#line 3180 + } +#line 3180 + +#line 3180 + *xpp = (void *)xp; +#line 3180 + return status; +#line 3180 +#endif +#line 3180 +} +#line 3180 + +int +#line 3181 +ncx_putn_short_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3181 +{ +#line 3181 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3181 + +#line 3181 + /* basic algorithm is: +#line 3181 + * - ensure sane alignment of output data +#line 3181 + * - copy (conversion happens automatically) input data +#line 3181 + * to output +#line 3181 + * - update tp to point at next unconverted input, and xpp to point +#line 3181 + * at next location for converted output +#line 3181 + */ +#line 3181 + long i, j, ni; +#line 3181 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3181 + short *xp; +#line 3181 + int nrange = 0; /* number of range errors */ +#line 3181 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3181 + long cxp = (long) *((char**)xpp); +#line 3181 + +#line 3181 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3181 + /* sjl: manually stripmine so we can limit amount of +#line 3181 + * vector work space reserved to LOOPCNT elements. Also +#line 3181 + * makes vectorisation easy */ +#line 3181 + for (j=0; j= 0 */ +#line 3181 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3181 + nrange += tp[i] > X_SHORT_MAX ; +#line 3181 + } +#line 3181 + /* copy workspace back if necessary */ +#line 3181 + if (realign) { +#line 3181 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_SHORT); +#line 3181 + xp = (short *) *xpp; +#line 3181 + } +#line 3181 + /* update xpp and tp */ +#line 3181 + xp += ni; +#line 3181 + tp += ni; +#line 3181 + *xpp = (void*)xp; +#line 3181 + } +#line 3181 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3181 + +#line 3181 +#else /* not SX */ +#line 3181 + +#line 3181 + char *xp = (char *) *xpp; +#line 3181 + int status = NC_NOERR; +#line 3181 + +#line 3181 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3181 + { +#line 3181 + int lstatus = ncx_put_short_uint(xp, tp, fillp); +#line 3181 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3181 + status = lstatus; +#line 3181 + } +#line 3181 + +#line 3181 + *xpp = (void *)xp; +#line 3181 + return status; +#line 3181 +#endif +#line 3181 +} +#line 3181 + +int +#line 3182 +ncx_putn_short_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3182 +{ +#line 3182 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3182 + +#line 3182 + /* basic algorithm is: +#line 3182 + * - ensure sane alignment of output data +#line 3182 + * - copy (conversion happens automatically) input data +#line 3182 + * to output +#line 3182 + * - update tp to point at next unconverted input, and xpp to point +#line 3182 + * at next location for converted output +#line 3182 + */ +#line 3182 + long i, j, ni; +#line 3182 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3182 + short *xp; +#line 3182 + int nrange = 0; /* number of range errors */ +#line 3182 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3182 + long cxp = (long) *((char**)xpp); +#line 3182 + +#line 3182 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3182 + /* sjl: manually stripmine so we can limit amount of +#line 3182 + * vector work space reserved to LOOPCNT elements. Also +#line 3182 + * makes vectorisation easy */ +#line 3182 + for (j=0; j= 0 */ +#line 3182 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3182 + nrange += tp[i] > X_SHORT_MAX ; +#line 3182 + } +#line 3182 + /* copy workspace back if necessary */ +#line 3182 + if (realign) { +#line 3182 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_SHORT); +#line 3182 + xp = (short *) *xpp; +#line 3182 + } +#line 3182 + /* update xpp and tp */ +#line 3182 + xp += ni; +#line 3182 + tp += ni; +#line 3182 + *xpp = (void*)xp; +#line 3182 + } +#line 3182 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3182 + +#line 3182 +#else /* not SX */ +#line 3182 + +#line 3182 + char *xp = (char *) *xpp; +#line 3182 + int status = NC_NOERR; +#line 3182 + +#line 3182 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3182 + { +#line 3182 + int lstatus = ncx_put_short_ulonglong(xp, tp, fillp); +#line 3182 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3182 + status = lstatus; +#line 3182 + } +#line 3182 + +#line 3182 + *xpp = (void *)xp; +#line 3182 + return status; +#line 3182 +#endif +#line 3182 +} +#line 3182 + +int +#line 3183 +ncx_putn_short_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3183 +{ +#line 3183 +#if defined(_SX) && _SX != 0 && X_SIZEOF_SHORT == SIZEOF_SHORT +#line 3183 + +#line 3183 + /* basic algorithm is: +#line 3183 + * - ensure sane alignment of output data +#line 3183 + * - copy (conversion happens automatically) input data +#line 3183 + * to output +#line 3183 + * - update tp to point at next unconverted input, and xpp to point +#line 3183 + * at next location for converted output +#line 3183 + */ +#line 3183 + long i, j, ni; +#line 3183 + short tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3183 + short *xp; +#line 3183 + int nrange = 0; /* number of range errors */ +#line 3183 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3183 + long cxp = (long) *((char**)xpp); +#line 3183 + +#line 3183 + realign = (cxp & 7) % SIZEOF_SHORT; +#line 3183 + /* sjl: manually stripmine so we can limit amount of +#line 3183 + * vector work space reserved to LOOPCNT elements. Also +#line 3183 + * makes vectorisation easy */ +#line 3183 + for (j=0; j= 0 */ +#line 3183 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3183 + nrange += tp[i] > X_SHORT_MAX ; +#line 3183 + } +#line 3183 + /* copy workspace back if necessary */ +#line 3183 + if (realign) { +#line 3183 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_SHORT); +#line 3183 + xp = (short *) *xpp; +#line 3183 + } +#line 3183 + /* update xpp and tp */ +#line 3183 + xp += ni; +#line 3183 + tp += ni; +#line 3183 + *xpp = (void*)xp; +#line 3183 + } +#line 3183 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3183 + +#line 3183 +#else /* not SX */ +#line 3183 + +#line 3183 + char *xp = (char *) *xpp; +#line 3183 + int status = NC_NOERR; +#line 3183 + +#line 3183 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3183 + { +#line 3183 + int lstatus = ncx_put_short_ushort(xp, tp, fillp); +#line 3183 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3183 + status = lstatus; +#line 3183 + } +#line 3183 + +#line 3183 + *xpp = (void *)xp; +#line 3183 + return status; +#line 3183 +#endif +#line 3183 +} +#line 3183 + + +int +#line 3185 +ncx_pad_putn_short_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +#line 3185 +{ +#line 3185 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3185 + +#line 3185 + char *xp = (char *) *xpp; +#line 3185 + int status = NC_NOERR; +#line 3185 + +#line 3185 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3185 + { +#line 3185 + int lstatus = ncx_put_short_schar(xp, tp, fillp); +#line 3185 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3185 + status = lstatus; +#line 3185 + } +#line 3185 + +#line 3185 + if (rndup != 0) +#line 3185 + { +#line 3185 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_SHORT)); +#line 3185 + xp += X_SIZEOF_SHORT; +#line 3185 + } +#line 3185 + +#line 3185 + *xpp = (void *)xp; +#line 3185 + return status; +#line 3185 +} +#line 3185 + +int +#line 3186 +ncx_pad_putn_short_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 3186 +{ +#line 3186 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3186 + +#line 3186 + char *xp = (char *) *xpp; +#line 3186 + int status = NC_NOERR; +#line 3186 + +#line 3186 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3186 + { +#line 3186 + int lstatus = ncx_put_short_uchar(xp, tp, fillp); +#line 3186 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3186 + status = lstatus; +#line 3186 + } +#line 3186 + +#line 3186 + if (rndup != 0) +#line 3186 + { +#line 3186 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_SHORT)); +#line 3186 + xp += X_SIZEOF_SHORT; +#line 3186 + } +#line 3186 + +#line 3186 + *xpp = (void *)xp; +#line 3186 + return status; +#line 3186 +} +#line 3186 + +int +#line 3187 +ncx_pad_putn_short_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3187 +{ +#line 3187 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3187 + +#line 3187 + char *xp = (char *) *xpp; +#line 3187 + int status = NC_NOERR; +#line 3187 + +#line 3187 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3187 + { +#line 3187 + int lstatus = ncx_put_short_short(xp, tp, fillp); +#line 3187 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3187 + status = lstatus; +#line 3187 + } +#line 3187 + +#line 3187 + if (rndup != 0) +#line 3187 + { +#line 3187 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_SHORT)); +#line 3187 + xp += X_SIZEOF_SHORT; +#line 3187 + } +#line 3187 + +#line 3187 + *xpp = (void *)xp; +#line 3187 + return status; +#line 3187 +} +#line 3187 + +int +#line 3188 +ncx_pad_putn_short_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3188 +{ +#line 3188 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3188 + +#line 3188 + char *xp = (char *) *xpp; +#line 3188 + int status = NC_NOERR; +#line 3188 + +#line 3188 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3188 + { +#line 3188 + int lstatus = ncx_put_short_int(xp, tp, fillp); +#line 3188 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3188 + status = lstatus; +#line 3188 + } +#line 3188 + +#line 3188 + if (rndup != 0) +#line 3188 + { +#line 3188 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_SHORT)); +#line 3188 + xp += X_SIZEOF_SHORT; +#line 3188 + } +#line 3188 + +#line 3188 + *xpp = (void *)xp; +#line 3188 + return status; +#line 3188 +} +#line 3188 + +int +#line 3189 +ncx_pad_putn_short_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3189 +{ +#line 3189 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3189 + +#line 3189 + char *xp = (char *) *xpp; +#line 3189 + int status = NC_NOERR; +#line 3189 + +#line 3189 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3189 + { +#line 3189 + int lstatus = ncx_put_short_long(xp, tp, fillp); +#line 3189 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3189 + status = lstatus; +#line 3189 + } +#line 3189 + +#line 3189 + if (rndup != 0) +#line 3189 + { +#line 3189 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_SHORT)); +#line 3189 + xp += X_SIZEOF_SHORT; +#line 3189 + } +#line 3189 + +#line 3189 + *xpp = (void *)xp; +#line 3189 + return status; +#line 3189 +} +#line 3189 + +int +#line 3190 +ncx_pad_putn_short_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 3190 +{ +#line 3190 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3190 + +#line 3190 + char *xp = (char *) *xpp; +#line 3190 + int status = NC_NOERR; +#line 3190 + +#line 3190 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3190 + { +#line 3190 + int lstatus = ncx_put_short_float(xp, tp, fillp); +#line 3190 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3190 + status = lstatus; +#line 3190 + } +#line 3190 + +#line 3190 + if (rndup != 0) +#line 3190 + { +#line 3190 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_SHORT)); +#line 3190 + xp += X_SIZEOF_SHORT; +#line 3190 + } +#line 3190 + +#line 3190 + *xpp = (void *)xp; +#line 3190 + return status; +#line 3190 +} +#line 3190 + +int +#line 3191 +ncx_pad_putn_short_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 3191 +{ +#line 3191 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3191 + +#line 3191 + char *xp = (char *) *xpp; +#line 3191 + int status = NC_NOERR; +#line 3191 + +#line 3191 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3191 + { +#line 3191 + int lstatus = ncx_put_short_double(xp, tp, fillp); +#line 3191 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3191 + status = lstatus; +#line 3191 + } +#line 3191 + +#line 3191 + if (rndup != 0) +#line 3191 + { +#line 3191 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_SHORT)); +#line 3191 + xp += X_SIZEOF_SHORT; +#line 3191 + } +#line 3191 + +#line 3191 + *xpp = (void *)xp; +#line 3191 + return status; +#line 3191 +} +#line 3191 + +int +#line 3192 +ncx_pad_putn_short_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3192 +{ +#line 3192 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3192 + +#line 3192 + char *xp = (char *) *xpp; +#line 3192 + int status = NC_NOERR; +#line 3192 + +#line 3192 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3192 + { +#line 3192 + int lstatus = ncx_put_short_uint(xp, tp, fillp); +#line 3192 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3192 + status = lstatus; +#line 3192 + } +#line 3192 + +#line 3192 + if (rndup != 0) +#line 3192 + { +#line 3192 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_SHORT)); +#line 3192 + xp += X_SIZEOF_SHORT; +#line 3192 + } +#line 3192 + +#line 3192 + *xpp = (void *)xp; +#line 3192 + return status; +#line 3192 +} +#line 3192 + +int +#line 3193 +ncx_pad_putn_short_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3193 +{ +#line 3193 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3193 + +#line 3193 + char *xp = (char *) *xpp; +#line 3193 + int status = NC_NOERR; +#line 3193 + +#line 3193 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3193 + { +#line 3193 + int lstatus = ncx_put_short_longlong(xp, tp, fillp); +#line 3193 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3193 + status = lstatus; +#line 3193 + } +#line 3193 + +#line 3193 + if (rndup != 0) +#line 3193 + { +#line 3193 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_SHORT)); +#line 3193 + xp += X_SIZEOF_SHORT; +#line 3193 + } +#line 3193 + +#line 3193 + *xpp = (void *)xp; +#line 3193 + return status; +#line 3193 +} +#line 3193 + +int +#line 3194 +ncx_pad_putn_short_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3194 +{ +#line 3194 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3194 + +#line 3194 + char *xp = (char *) *xpp; +#line 3194 + int status = NC_NOERR; +#line 3194 + +#line 3194 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3194 + { +#line 3194 + int lstatus = ncx_put_short_ulonglong(xp, tp, fillp); +#line 3194 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3194 + status = lstatus; +#line 3194 + } +#line 3194 + +#line 3194 + if (rndup != 0) +#line 3194 + { +#line 3194 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_SHORT)); +#line 3194 + xp += X_SIZEOF_SHORT; +#line 3194 + } +#line 3194 + +#line 3194 + *xpp = (void *)xp; +#line 3194 + return status; +#line 3194 +} +#line 3194 + +int +#line 3195 +ncx_pad_putn_short_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3195 +{ +#line 3195 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3195 + +#line 3195 + char *xp = (char *) *xpp; +#line 3195 + int status = NC_NOERR; +#line 3195 + +#line 3195 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_SHORT, tp++) +#line 3195 + { +#line 3195 + int lstatus = ncx_put_short_ushort(xp, tp, fillp); +#line 3195 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3195 + status = lstatus; +#line 3195 + } +#line 3195 + +#line 3195 + if (rndup != 0) +#line 3195 + { +#line 3195 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_SHORT)); +#line 3195 + xp += X_SIZEOF_SHORT; +#line 3195 + } +#line 3195 + +#line 3195 + *xpp = (void *)xp; +#line 3195 + return status; +#line 3195 +} +#line 3195 + + + +/* ushort --------------------------------------------------------------------*/ + +#if X_SIZEOF_USHORT == SIZEOF_USHORT +/* optimized version */ +int +ncx_getn_ushort_ushort(const void **xpp, size_t nelems, unsigned short *tp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(tp, *xpp, (size_t)nelems * SIZEOF_USHORT); +# else + swapn2b(tp, *xpp, nelems); +# endif + *xpp = (const void *)((const char *)(*xpp) + nelems * X_SIZEOF_USHORT); + return NC_NOERR; +} +#else +int +#line 3214 +ncx_getn_ushort_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 3214 +{ +#line 3214 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3214 + +#line 3214 + /* basic algorithm is: +#line 3214 + * - ensure sane alignment of input data +#line 3214 + * - copy (conversion happens automatically) input data +#line 3214 + * to output +#line 3214 + * - update xpp to point at next unconverted input, and tp to point +#line 3214 + * at next location for converted output +#line 3214 + */ +#line 3214 + long i, j, ni; +#line 3214 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3214 + ushort *xp; +#line 3214 + int nrange = 0; /* number of range errors */ +#line 3214 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3214 + long cxp = (long) *((char**)xpp); +#line 3214 + +#line 3214 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3214 + /* sjl: manually stripmine so we can limit amount of +#line 3214 + * vector work space reserved to LOOPCNT elements. Also +#line 3214 + * makes vectorisation easy */ +#line 3214 + for (j=0; j= 0 */ +#line 3214 + nrange += xp[i] > USHORT_MAX ; +#line 3214 + } +#line 3214 + /* update xpp and tp */ +#line 3214 + if (realign) xp = (ushort *) *xpp; +#line 3214 + xp += ni; +#line 3214 + tp += ni; +#line 3214 + *xpp = (void*)xp; +#line 3214 + } +#line 3214 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3214 + +#line 3214 +#else /* not SX */ +#line 3214 + const char *xp = (const char *) *xpp; +#line 3214 + int status = NC_NOERR; +#line 3214 + +#line 3214 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3214 + { +#line 3214 + const int lstatus = ncx_get_ushort_ushort(xp, tp); +#line 3214 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3214 + status = lstatus; +#line 3214 + } +#line 3214 + +#line 3214 + *xpp = (const void *)xp; +#line 3214 + return status; +#line 3214 +#endif +#line 3214 +} +#line 3214 + +#endif +int +#line 3216 +ncx_getn_ushort_schar(const void **xpp, size_t nelems, schar *tp) +#line 3216 +{ +#line 3216 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3216 + +#line 3216 + /* basic algorithm is: +#line 3216 + * - ensure sane alignment of input data +#line 3216 + * - copy (conversion happens automatically) input data +#line 3216 + * to output +#line 3216 + * - update xpp to point at next unconverted input, and tp to point +#line 3216 + * at next location for converted output +#line 3216 + */ +#line 3216 + long i, j, ni; +#line 3216 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3216 + ushort *xp; +#line 3216 + int nrange = 0; /* number of range errors */ +#line 3216 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3216 + long cxp = (long) *((char**)xpp); +#line 3216 + +#line 3216 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3216 + /* sjl: manually stripmine so we can limit amount of +#line 3216 + * vector work space reserved to LOOPCNT elements. Also +#line 3216 + * makes vectorisation easy */ +#line 3216 + for (j=0; j= 0 */ +#line 3216 + nrange += xp[i] > SCHAR_MAX ; +#line 3216 + } +#line 3216 + /* update xpp and tp */ +#line 3216 + if (realign) xp = (ushort *) *xpp; +#line 3216 + xp += ni; +#line 3216 + tp += ni; +#line 3216 + *xpp = (void*)xp; +#line 3216 + } +#line 3216 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3216 + +#line 3216 +#else /* not SX */ +#line 3216 + const char *xp = (const char *) *xpp; +#line 3216 + int status = NC_NOERR; +#line 3216 + +#line 3216 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3216 + { +#line 3216 + const int lstatus = ncx_get_ushort_schar(xp, tp); +#line 3216 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3216 + status = lstatus; +#line 3216 + } +#line 3216 + +#line 3216 + *xpp = (const void *)xp; +#line 3216 + return status; +#line 3216 +#endif +#line 3216 +} +#line 3216 + +int +#line 3217 +ncx_getn_ushort_short(const void **xpp, size_t nelems, short *tp) +#line 3217 +{ +#line 3217 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3217 + +#line 3217 + /* basic algorithm is: +#line 3217 + * - ensure sane alignment of input data +#line 3217 + * - copy (conversion happens automatically) input data +#line 3217 + * to output +#line 3217 + * - update xpp to point at next unconverted input, and tp to point +#line 3217 + * at next location for converted output +#line 3217 + */ +#line 3217 + long i, j, ni; +#line 3217 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3217 + ushort *xp; +#line 3217 + int nrange = 0; /* number of range errors */ +#line 3217 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3217 + long cxp = (long) *((char**)xpp); +#line 3217 + +#line 3217 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3217 + /* sjl: manually stripmine so we can limit amount of +#line 3217 + * vector work space reserved to LOOPCNT elements. Also +#line 3217 + * makes vectorisation easy */ +#line 3217 + for (j=0; j= 0 */ +#line 3217 + nrange += xp[i] > SHORT_MAX ; +#line 3217 + } +#line 3217 + /* update xpp and tp */ +#line 3217 + if (realign) xp = (ushort *) *xpp; +#line 3217 + xp += ni; +#line 3217 + tp += ni; +#line 3217 + *xpp = (void*)xp; +#line 3217 + } +#line 3217 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3217 + +#line 3217 +#else /* not SX */ +#line 3217 + const char *xp = (const char *) *xpp; +#line 3217 + int status = NC_NOERR; +#line 3217 + +#line 3217 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3217 + { +#line 3217 + const int lstatus = ncx_get_ushort_short(xp, tp); +#line 3217 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3217 + status = lstatus; +#line 3217 + } +#line 3217 + +#line 3217 + *xpp = (const void *)xp; +#line 3217 + return status; +#line 3217 +#endif +#line 3217 +} +#line 3217 + +int +#line 3218 +ncx_getn_ushort_int(const void **xpp, size_t nelems, int *tp) +#line 3218 +{ +#line 3218 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3218 + +#line 3218 + /* basic algorithm is: +#line 3218 + * - ensure sane alignment of input data +#line 3218 + * - copy (conversion happens automatically) input data +#line 3218 + * to output +#line 3218 + * - update xpp to point at next unconverted input, and tp to point +#line 3218 + * at next location for converted output +#line 3218 + */ +#line 3218 + long i, j, ni; +#line 3218 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3218 + ushort *xp; +#line 3218 + int nrange = 0; /* number of range errors */ +#line 3218 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3218 + long cxp = (long) *((char**)xpp); +#line 3218 + +#line 3218 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3218 + /* sjl: manually stripmine so we can limit amount of +#line 3218 + * vector work space reserved to LOOPCNT elements. Also +#line 3218 + * makes vectorisation easy */ +#line 3218 + for (j=0; j= 0 */ +#line 3218 + nrange += xp[i] > INT_MAX ; +#line 3218 + } +#line 3218 + /* update xpp and tp */ +#line 3218 + if (realign) xp = (ushort *) *xpp; +#line 3218 + xp += ni; +#line 3218 + tp += ni; +#line 3218 + *xpp = (void*)xp; +#line 3218 + } +#line 3218 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3218 + +#line 3218 +#else /* not SX */ +#line 3218 + const char *xp = (const char *) *xpp; +#line 3218 + int status = NC_NOERR; +#line 3218 + +#line 3218 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3218 + { +#line 3218 + const int lstatus = ncx_get_ushort_int(xp, tp); +#line 3218 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3218 + status = lstatus; +#line 3218 + } +#line 3218 + +#line 3218 + *xpp = (const void *)xp; +#line 3218 + return status; +#line 3218 +#endif +#line 3218 +} +#line 3218 + +int +#line 3219 +ncx_getn_ushort_long(const void **xpp, size_t nelems, long *tp) +#line 3219 +{ +#line 3219 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3219 + +#line 3219 + /* basic algorithm is: +#line 3219 + * - ensure sane alignment of input data +#line 3219 + * - copy (conversion happens automatically) input data +#line 3219 + * to output +#line 3219 + * - update xpp to point at next unconverted input, and tp to point +#line 3219 + * at next location for converted output +#line 3219 + */ +#line 3219 + long i, j, ni; +#line 3219 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3219 + ushort *xp; +#line 3219 + int nrange = 0; /* number of range errors */ +#line 3219 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3219 + long cxp = (long) *((char**)xpp); +#line 3219 + +#line 3219 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3219 + /* sjl: manually stripmine so we can limit amount of +#line 3219 + * vector work space reserved to LOOPCNT elements. Also +#line 3219 + * makes vectorisation easy */ +#line 3219 + for (j=0; j= 0 */ +#line 3219 + nrange += xp[i] > LONG_MAX ; +#line 3219 + } +#line 3219 + /* update xpp and tp */ +#line 3219 + if (realign) xp = (ushort *) *xpp; +#line 3219 + xp += ni; +#line 3219 + tp += ni; +#line 3219 + *xpp = (void*)xp; +#line 3219 + } +#line 3219 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3219 + +#line 3219 +#else /* not SX */ +#line 3219 + const char *xp = (const char *) *xpp; +#line 3219 + int status = NC_NOERR; +#line 3219 + +#line 3219 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3219 + { +#line 3219 + const int lstatus = ncx_get_ushort_long(xp, tp); +#line 3219 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3219 + status = lstatus; +#line 3219 + } +#line 3219 + +#line 3219 + *xpp = (const void *)xp; +#line 3219 + return status; +#line 3219 +#endif +#line 3219 +} +#line 3219 + +int +#line 3220 +ncx_getn_ushort_float(const void **xpp, size_t nelems, float *tp) +#line 3220 +{ +#line 3220 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3220 + +#line 3220 + /* basic algorithm is: +#line 3220 + * - ensure sane alignment of input data +#line 3220 + * - copy (conversion happens automatically) input data +#line 3220 + * to output +#line 3220 + * - update xpp to point at next unconverted input, and tp to point +#line 3220 + * at next location for converted output +#line 3220 + */ +#line 3220 + long i, j, ni; +#line 3220 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3220 + ushort *xp; +#line 3220 + int nrange = 0; /* number of range errors */ +#line 3220 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3220 + long cxp = (long) *((char**)xpp); +#line 3220 + +#line 3220 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3220 + /* sjl: manually stripmine so we can limit amount of +#line 3220 + * vector work space reserved to LOOPCNT elements. Also +#line 3220 + * makes vectorisation easy */ +#line 3220 + for (j=0; j= 0 */ +#line 3220 + nrange += xp[i] > FLOAT_MAX ; +#line 3220 + } +#line 3220 + /* update xpp and tp */ +#line 3220 + if (realign) xp = (ushort *) *xpp; +#line 3220 + xp += ni; +#line 3220 + tp += ni; +#line 3220 + *xpp = (void*)xp; +#line 3220 + } +#line 3220 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3220 + +#line 3220 +#else /* not SX */ +#line 3220 + const char *xp = (const char *) *xpp; +#line 3220 + int status = NC_NOERR; +#line 3220 + +#line 3220 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3220 + { +#line 3220 + const int lstatus = ncx_get_ushort_float(xp, tp); +#line 3220 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3220 + status = lstatus; +#line 3220 + } +#line 3220 + +#line 3220 + *xpp = (const void *)xp; +#line 3220 + return status; +#line 3220 +#endif +#line 3220 +} +#line 3220 + +int +#line 3221 +ncx_getn_ushort_double(const void **xpp, size_t nelems, double *tp) +#line 3221 +{ +#line 3221 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3221 + +#line 3221 + /* basic algorithm is: +#line 3221 + * - ensure sane alignment of input data +#line 3221 + * - copy (conversion happens automatically) input data +#line 3221 + * to output +#line 3221 + * - update xpp to point at next unconverted input, and tp to point +#line 3221 + * at next location for converted output +#line 3221 + */ +#line 3221 + long i, j, ni; +#line 3221 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3221 + ushort *xp; +#line 3221 + int nrange = 0; /* number of range errors */ +#line 3221 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3221 + long cxp = (long) *((char**)xpp); +#line 3221 + +#line 3221 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3221 + /* sjl: manually stripmine so we can limit amount of +#line 3221 + * vector work space reserved to LOOPCNT elements. Also +#line 3221 + * makes vectorisation easy */ +#line 3221 + for (j=0; j= 0 */ +#line 3221 + nrange += xp[i] > DOUBLE_MAX ; +#line 3221 + } +#line 3221 + /* update xpp and tp */ +#line 3221 + if (realign) xp = (ushort *) *xpp; +#line 3221 + xp += ni; +#line 3221 + tp += ni; +#line 3221 + *xpp = (void*)xp; +#line 3221 + } +#line 3221 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3221 + +#line 3221 +#else /* not SX */ +#line 3221 + const char *xp = (const char *) *xpp; +#line 3221 + int status = NC_NOERR; +#line 3221 + +#line 3221 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3221 + { +#line 3221 + const int lstatus = ncx_get_ushort_double(xp, tp); +#line 3221 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3221 + status = lstatus; +#line 3221 + } +#line 3221 + +#line 3221 + *xpp = (const void *)xp; +#line 3221 + return status; +#line 3221 +#endif +#line 3221 +} +#line 3221 + +int +#line 3222 +ncx_getn_ushort_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 3222 +{ +#line 3222 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3222 + +#line 3222 + /* basic algorithm is: +#line 3222 + * - ensure sane alignment of input data +#line 3222 + * - copy (conversion happens automatically) input data +#line 3222 + * to output +#line 3222 + * - update xpp to point at next unconverted input, and tp to point +#line 3222 + * at next location for converted output +#line 3222 + */ +#line 3222 + long i, j, ni; +#line 3222 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3222 + ushort *xp; +#line 3222 + int nrange = 0; /* number of range errors */ +#line 3222 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3222 + long cxp = (long) *((char**)xpp); +#line 3222 + +#line 3222 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3222 + /* sjl: manually stripmine so we can limit amount of +#line 3222 + * vector work space reserved to LOOPCNT elements. Also +#line 3222 + * makes vectorisation easy */ +#line 3222 + for (j=0; j= 0 */ +#line 3222 + nrange += xp[i] > LONGLONG_MAX ; +#line 3222 + } +#line 3222 + /* update xpp and tp */ +#line 3222 + if (realign) xp = (ushort *) *xpp; +#line 3222 + xp += ni; +#line 3222 + tp += ni; +#line 3222 + *xpp = (void*)xp; +#line 3222 + } +#line 3222 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3222 + +#line 3222 +#else /* not SX */ +#line 3222 + const char *xp = (const char *) *xpp; +#line 3222 + int status = NC_NOERR; +#line 3222 + +#line 3222 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3222 + { +#line 3222 + const int lstatus = ncx_get_ushort_longlong(xp, tp); +#line 3222 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3222 + status = lstatus; +#line 3222 + } +#line 3222 + +#line 3222 + *xpp = (const void *)xp; +#line 3222 + return status; +#line 3222 +#endif +#line 3222 +} +#line 3222 + +int +#line 3223 +ncx_getn_ushort_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 3223 +{ +#line 3223 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3223 + +#line 3223 + /* basic algorithm is: +#line 3223 + * - ensure sane alignment of input data +#line 3223 + * - copy (conversion happens automatically) input data +#line 3223 + * to output +#line 3223 + * - update xpp to point at next unconverted input, and tp to point +#line 3223 + * at next location for converted output +#line 3223 + */ +#line 3223 + long i, j, ni; +#line 3223 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3223 + ushort *xp; +#line 3223 + int nrange = 0; /* number of range errors */ +#line 3223 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3223 + long cxp = (long) *((char**)xpp); +#line 3223 + +#line 3223 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3223 + /* sjl: manually stripmine so we can limit amount of +#line 3223 + * vector work space reserved to LOOPCNT elements. Also +#line 3223 + * makes vectorisation easy */ +#line 3223 + for (j=0; j= 0 */ +#line 3223 + nrange += xp[i] > UCHAR_MAX ; +#line 3223 + } +#line 3223 + /* update xpp and tp */ +#line 3223 + if (realign) xp = (ushort *) *xpp; +#line 3223 + xp += ni; +#line 3223 + tp += ni; +#line 3223 + *xpp = (void*)xp; +#line 3223 + } +#line 3223 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3223 + +#line 3223 +#else /* not SX */ +#line 3223 + const char *xp = (const char *) *xpp; +#line 3223 + int status = NC_NOERR; +#line 3223 + +#line 3223 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3223 + { +#line 3223 + const int lstatus = ncx_get_ushort_uchar(xp, tp); +#line 3223 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3223 + status = lstatus; +#line 3223 + } +#line 3223 + +#line 3223 + *xpp = (const void *)xp; +#line 3223 + return status; +#line 3223 +#endif +#line 3223 +} +#line 3223 + +int +#line 3224 +ncx_getn_ushort_uint(const void **xpp, size_t nelems, uint *tp) +#line 3224 +{ +#line 3224 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3224 + +#line 3224 + /* basic algorithm is: +#line 3224 + * - ensure sane alignment of input data +#line 3224 + * - copy (conversion happens automatically) input data +#line 3224 + * to output +#line 3224 + * - update xpp to point at next unconverted input, and tp to point +#line 3224 + * at next location for converted output +#line 3224 + */ +#line 3224 + long i, j, ni; +#line 3224 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3224 + ushort *xp; +#line 3224 + int nrange = 0; /* number of range errors */ +#line 3224 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3224 + long cxp = (long) *((char**)xpp); +#line 3224 + +#line 3224 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3224 + /* sjl: manually stripmine so we can limit amount of +#line 3224 + * vector work space reserved to LOOPCNT elements. Also +#line 3224 + * makes vectorisation easy */ +#line 3224 + for (j=0; j= 0 */ +#line 3224 + nrange += xp[i] > UINT_MAX ; +#line 3224 + } +#line 3224 + /* update xpp and tp */ +#line 3224 + if (realign) xp = (ushort *) *xpp; +#line 3224 + xp += ni; +#line 3224 + tp += ni; +#line 3224 + *xpp = (void*)xp; +#line 3224 + } +#line 3224 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3224 + +#line 3224 +#else /* not SX */ +#line 3224 + const char *xp = (const char *) *xpp; +#line 3224 + int status = NC_NOERR; +#line 3224 + +#line 3224 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3224 + { +#line 3224 + const int lstatus = ncx_get_ushort_uint(xp, tp); +#line 3224 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3224 + status = lstatus; +#line 3224 + } +#line 3224 + +#line 3224 + *xpp = (const void *)xp; +#line 3224 + return status; +#line 3224 +#endif +#line 3224 +} +#line 3224 + +int +#line 3225 +ncx_getn_ushort_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 3225 +{ +#line 3225 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3225 + +#line 3225 + /* basic algorithm is: +#line 3225 + * - ensure sane alignment of input data +#line 3225 + * - copy (conversion happens automatically) input data +#line 3225 + * to output +#line 3225 + * - update xpp to point at next unconverted input, and tp to point +#line 3225 + * at next location for converted output +#line 3225 + */ +#line 3225 + long i, j, ni; +#line 3225 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3225 + ushort *xp; +#line 3225 + int nrange = 0; /* number of range errors */ +#line 3225 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3225 + long cxp = (long) *((char**)xpp); +#line 3225 + +#line 3225 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3225 + /* sjl: manually stripmine so we can limit amount of +#line 3225 + * vector work space reserved to LOOPCNT elements. Also +#line 3225 + * makes vectorisation easy */ +#line 3225 + for (j=0; j= 0 */ +#line 3225 + nrange += xp[i] > ULONGLONG_MAX ; +#line 3225 + } +#line 3225 + /* update xpp and tp */ +#line 3225 + if (realign) xp = (ushort *) *xpp; +#line 3225 + xp += ni; +#line 3225 + tp += ni; +#line 3225 + *xpp = (void*)xp; +#line 3225 + } +#line 3225 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3225 + +#line 3225 +#else /* not SX */ +#line 3225 + const char *xp = (const char *) *xpp; +#line 3225 + int status = NC_NOERR; +#line 3225 + +#line 3225 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3225 + { +#line 3225 + const int lstatus = ncx_get_ushort_ulonglong(xp, tp); +#line 3225 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3225 + status = lstatus; +#line 3225 + } +#line 3225 + +#line 3225 + *xpp = (const void *)xp; +#line 3225 + return status; +#line 3225 +#endif +#line 3225 +} +#line 3225 + + +int +#line 3227 +ncx_pad_getn_ushort_schar(const void **xpp, size_t nelems, schar *tp) +#line 3227 +{ +#line 3227 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3227 + +#line 3227 + const char *xp = (const char *) *xpp; +#line 3227 + int status = NC_NOERR; +#line 3227 + +#line 3227 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3227 + { +#line 3227 + const int lstatus = ncx_get_ushort_schar(xp, tp); +#line 3227 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3227 + status = lstatus; +#line 3227 + } +#line 3227 + +#line 3227 + if (rndup != 0) +#line 3227 + xp += X_SIZEOF_USHORT; +#line 3227 + +#line 3227 + *xpp = (void *)xp; +#line 3227 + return status; +#line 3227 +} +#line 3227 + +int +#line 3228 +ncx_pad_getn_ushort_short(const void **xpp, size_t nelems, short *tp) +#line 3228 +{ +#line 3228 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3228 + +#line 3228 + const char *xp = (const char *) *xpp; +#line 3228 + int status = NC_NOERR; +#line 3228 + +#line 3228 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3228 + { +#line 3228 + const int lstatus = ncx_get_ushort_short(xp, tp); +#line 3228 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3228 + status = lstatus; +#line 3228 + } +#line 3228 + +#line 3228 + if (rndup != 0) +#line 3228 + xp += X_SIZEOF_USHORT; +#line 3228 + +#line 3228 + *xpp = (void *)xp; +#line 3228 + return status; +#line 3228 +} +#line 3228 + +int +#line 3229 +ncx_pad_getn_ushort_int(const void **xpp, size_t nelems, int *tp) +#line 3229 +{ +#line 3229 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3229 + +#line 3229 + const char *xp = (const char *) *xpp; +#line 3229 + int status = NC_NOERR; +#line 3229 + +#line 3229 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3229 + { +#line 3229 + const int lstatus = ncx_get_ushort_int(xp, tp); +#line 3229 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3229 + status = lstatus; +#line 3229 + } +#line 3229 + +#line 3229 + if (rndup != 0) +#line 3229 + xp += X_SIZEOF_USHORT; +#line 3229 + +#line 3229 + *xpp = (void *)xp; +#line 3229 + return status; +#line 3229 +} +#line 3229 + +int +#line 3230 +ncx_pad_getn_ushort_long(const void **xpp, size_t nelems, long *tp) +#line 3230 +{ +#line 3230 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3230 + +#line 3230 + const char *xp = (const char *) *xpp; +#line 3230 + int status = NC_NOERR; +#line 3230 + +#line 3230 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3230 + { +#line 3230 + const int lstatus = ncx_get_ushort_long(xp, tp); +#line 3230 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3230 + status = lstatus; +#line 3230 + } +#line 3230 + +#line 3230 + if (rndup != 0) +#line 3230 + xp += X_SIZEOF_USHORT; +#line 3230 + +#line 3230 + *xpp = (void *)xp; +#line 3230 + return status; +#line 3230 +} +#line 3230 + +int +#line 3231 +ncx_pad_getn_ushort_float(const void **xpp, size_t nelems, float *tp) +#line 3231 +{ +#line 3231 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3231 + +#line 3231 + const char *xp = (const char *) *xpp; +#line 3231 + int status = NC_NOERR; +#line 3231 + +#line 3231 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3231 + { +#line 3231 + const int lstatus = ncx_get_ushort_float(xp, tp); +#line 3231 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3231 + status = lstatus; +#line 3231 + } +#line 3231 + +#line 3231 + if (rndup != 0) +#line 3231 + xp += X_SIZEOF_USHORT; +#line 3231 + +#line 3231 + *xpp = (void *)xp; +#line 3231 + return status; +#line 3231 +} +#line 3231 + +int +#line 3232 +ncx_pad_getn_ushort_double(const void **xpp, size_t nelems, double *tp) +#line 3232 +{ +#line 3232 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3232 + +#line 3232 + const char *xp = (const char *) *xpp; +#line 3232 + int status = NC_NOERR; +#line 3232 + +#line 3232 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3232 + { +#line 3232 + const int lstatus = ncx_get_ushort_double(xp, tp); +#line 3232 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3232 + status = lstatus; +#line 3232 + } +#line 3232 + +#line 3232 + if (rndup != 0) +#line 3232 + xp += X_SIZEOF_USHORT; +#line 3232 + +#line 3232 + *xpp = (void *)xp; +#line 3232 + return status; +#line 3232 +} +#line 3232 + +int +#line 3233 +ncx_pad_getn_ushort_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 3233 +{ +#line 3233 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3233 + +#line 3233 + const char *xp = (const char *) *xpp; +#line 3233 + int status = NC_NOERR; +#line 3233 + +#line 3233 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3233 + { +#line 3233 + const int lstatus = ncx_get_ushort_uchar(xp, tp); +#line 3233 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3233 + status = lstatus; +#line 3233 + } +#line 3233 + +#line 3233 + if (rndup != 0) +#line 3233 + xp += X_SIZEOF_USHORT; +#line 3233 + +#line 3233 + *xpp = (void *)xp; +#line 3233 + return status; +#line 3233 +} +#line 3233 + +int +#line 3234 +ncx_pad_getn_ushort_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 3234 +{ +#line 3234 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3234 + +#line 3234 + const char *xp = (const char *) *xpp; +#line 3234 + int status = NC_NOERR; +#line 3234 + +#line 3234 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3234 + { +#line 3234 + const int lstatus = ncx_get_ushort_ushort(xp, tp); +#line 3234 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3234 + status = lstatus; +#line 3234 + } +#line 3234 + +#line 3234 + if (rndup != 0) +#line 3234 + xp += X_SIZEOF_USHORT; +#line 3234 + +#line 3234 + *xpp = (void *)xp; +#line 3234 + return status; +#line 3234 +} +#line 3234 + +int +#line 3235 +ncx_pad_getn_ushort_uint(const void **xpp, size_t nelems, uint *tp) +#line 3235 +{ +#line 3235 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3235 + +#line 3235 + const char *xp = (const char *) *xpp; +#line 3235 + int status = NC_NOERR; +#line 3235 + +#line 3235 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3235 + { +#line 3235 + const int lstatus = ncx_get_ushort_uint(xp, tp); +#line 3235 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3235 + status = lstatus; +#line 3235 + } +#line 3235 + +#line 3235 + if (rndup != 0) +#line 3235 + xp += X_SIZEOF_USHORT; +#line 3235 + +#line 3235 + *xpp = (void *)xp; +#line 3235 + return status; +#line 3235 +} +#line 3235 + +int +#line 3236 +ncx_pad_getn_ushort_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 3236 +{ +#line 3236 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3236 + +#line 3236 + const char *xp = (const char *) *xpp; +#line 3236 + int status = NC_NOERR; +#line 3236 + +#line 3236 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3236 + { +#line 3236 + const int lstatus = ncx_get_ushort_longlong(xp, tp); +#line 3236 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3236 + status = lstatus; +#line 3236 + } +#line 3236 + +#line 3236 + if (rndup != 0) +#line 3236 + xp += X_SIZEOF_USHORT; +#line 3236 + +#line 3236 + *xpp = (void *)xp; +#line 3236 + return status; +#line 3236 +} +#line 3236 + +int +#line 3237 +ncx_pad_getn_ushort_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 3237 +{ +#line 3237 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3237 + +#line 3237 + const char *xp = (const char *) *xpp; +#line 3237 + int status = NC_NOERR; +#line 3237 + +#line 3237 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3237 + { +#line 3237 + const int lstatus = ncx_get_ushort_ulonglong(xp, tp); +#line 3237 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3237 + status = lstatus; +#line 3237 + } +#line 3237 + +#line 3237 + if (rndup != 0) +#line 3237 + xp += X_SIZEOF_USHORT; +#line 3237 + +#line 3237 + *xpp = (void *)xp; +#line 3237 + return status; +#line 3237 +} +#line 3237 + + +#if X_SIZEOF_USHORT == SIZEOF_USHORT +/* optimized version */ +int +ncx_putn_ushort_ushort(void **xpp, size_t nelems, const unsigned short *tp, void *fillp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(*xpp, tp, (size_t)nelems * X_SIZEOF_USHORT); +# else + swapn2b(*xpp, tp, nelems); +# endif + *xpp = (void *)((char *)(*xpp) + nelems * X_SIZEOF_USHORT); + return NC_NOERR; +} +#else +int +#line 3253 +ncx_putn_ushort_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3253 +{ +#line 3253 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3253 + +#line 3253 + /* basic algorithm is: +#line 3253 + * - ensure sane alignment of output data +#line 3253 + * - copy (conversion happens automatically) input data +#line 3253 + * to output +#line 3253 + * - update tp to point at next unconverted input, and xpp to point +#line 3253 + * at next location for converted output +#line 3253 + */ +#line 3253 + long i, j, ni; +#line 3253 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3253 + ushort *xp; +#line 3253 + int nrange = 0; /* number of range errors */ +#line 3253 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3253 + long cxp = (long) *((char**)xpp); +#line 3253 + +#line 3253 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3253 + /* sjl: manually stripmine so we can limit amount of +#line 3253 + * vector work space reserved to LOOPCNT elements. Also +#line 3253 + * makes vectorisation easy */ +#line 3253 + for (j=0; j= 0 */ +#line 3253 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3253 + nrange += tp[i] > X_USHORT_MAX ; +#line 3253 + } +#line 3253 + /* copy workspace back if necessary */ +#line 3253 + if (realign) { +#line 3253 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_USHORT); +#line 3253 + xp = (ushort *) *xpp; +#line 3253 + } +#line 3253 + /* update xpp and tp */ +#line 3253 + xp += ni; +#line 3253 + tp += ni; +#line 3253 + *xpp = (void*)xp; +#line 3253 + } +#line 3253 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3253 + +#line 3253 +#else /* not SX */ +#line 3253 + +#line 3253 + char *xp = (char *) *xpp; +#line 3253 + int status = NC_NOERR; +#line 3253 + +#line 3253 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3253 + { +#line 3253 + int lstatus = ncx_put_ushort_ushort(xp, tp, fillp); +#line 3253 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3253 + status = lstatus; +#line 3253 + } +#line 3253 + +#line 3253 + *xpp = (void *)xp; +#line 3253 + return status; +#line 3253 +#endif +#line 3253 +} +#line 3253 + +#endif +int +#line 3255 +ncx_putn_ushort_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +#line 3255 +{ +#line 3255 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3255 + +#line 3255 + /* basic algorithm is: +#line 3255 + * - ensure sane alignment of output data +#line 3255 + * - copy (conversion happens automatically) input data +#line 3255 + * to output +#line 3255 + * - update tp to point at next unconverted input, and xpp to point +#line 3255 + * at next location for converted output +#line 3255 + */ +#line 3255 + long i, j, ni; +#line 3255 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3255 + ushort *xp; +#line 3255 + int nrange = 0; /* number of range errors */ +#line 3255 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3255 + long cxp = (long) *((char**)xpp); +#line 3255 + +#line 3255 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3255 + /* sjl: manually stripmine so we can limit amount of +#line 3255 + * vector work space reserved to LOOPCNT elements. Also +#line 3255 + * makes vectorisation easy */ +#line 3255 + for (j=0; j= 0 */ +#line 3255 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3255 + nrange += tp[i] > X_USHORT_MAX || tp[i] < 0; +#line 3255 + } +#line 3255 + /* copy workspace back if necessary */ +#line 3255 + if (realign) { +#line 3255 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_USHORT); +#line 3255 + xp = (ushort *) *xpp; +#line 3255 + } +#line 3255 + /* update xpp and tp */ +#line 3255 + xp += ni; +#line 3255 + tp += ni; +#line 3255 + *xpp = (void*)xp; +#line 3255 + } +#line 3255 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3255 + +#line 3255 +#else /* not SX */ +#line 3255 + +#line 3255 + char *xp = (char *) *xpp; +#line 3255 + int status = NC_NOERR; +#line 3255 + +#line 3255 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3255 + { +#line 3255 + int lstatus = ncx_put_ushort_schar(xp, tp, fillp); +#line 3255 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3255 + status = lstatus; +#line 3255 + } +#line 3255 + +#line 3255 + *xpp = (void *)xp; +#line 3255 + return status; +#line 3255 +#endif +#line 3255 +} +#line 3255 + +int +#line 3256 +ncx_putn_ushort_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3256 +{ +#line 3256 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3256 + +#line 3256 + /* basic algorithm is: +#line 3256 + * - ensure sane alignment of output data +#line 3256 + * - copy (conversion happens automatically) input data +#line 3256 + * to output +#line 3256 + * - update tp to point at next unconverted input, and xpp to point +#line 3256 + * at next location for converted output +#line 3256 + */ +#line 3256 + long i, j, ni; +#line 3256 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3256 + ushort *xp; +#line 3256 + int nrange = 0; /* number of range errors */ +#line 3256 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3256 + long cxp = (long) *((char**)xpp); +#line 3256 + +#line 3256 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3256 + /* sjl: manually stripmine so we can limit amount of +#line 3256 + * vector work space reserved to LOOPCNT elements. Also +#line 3256 + * makes vectorisation easy */ +#line 3256 + for (j=0; j= 0 */ +#line 3256 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3256 + nrange += tp[i] > X_USHORT_MAX || tp[i] < 0; +#line 3256 + } +#line 3256 + /* copy workspace back if necessary */ +#line 3256 + if (realign) { +#line 3256 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_USHORT); +#line 3256 + xp = (ushort *) *xpp; +#line 3256 + } +#line 3256 + /* update xpp and tp */ +#line 3256 + xp += ni; +#line 3256 + tp += ni; +#line 3256 + *xpp = (void*)xp; +#line 3256 + } +#line 3256 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3256 + +#line 3256 +#else /* not SX */ +#line 3256 + +#line 3256 + char *xp = (char *) *xpp; +#line 3256 + int status = NC_NOERR; +#line 3256 + +#line 3256 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3256 + { +#line 3256 + int lstatus = ncx_put_ushort_short(xp, tp, fillp); +#line 3256 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3256 + status = lstatus; +#line 3256 + } +#line 3256 + +#line 3256 + *xpp = (void *)xp; +#line 3256 + return status; +#line 3256 +#endif +#line 3256 +} +#line 3256 + +int +#line 3257 +ncx_putn_ushort_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3257 +{ +#line 3257 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3257 + +#line 3257 + /* basic algorithm is: +#line 3257 + * - ensure sane alignment of output data +#line 3257 + * - copy (conversion happens automatically) input data +#line 3257 + * to output +#line 3257 + * - update tp to point at next unconverted input, and xpp to point +#line 3257 + * at next location for converted output +#line 3257 + */ +#line 3257 + long i, j, ni; +#line 3257 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3257 + ushort *xp; +#line 3257 + int nrange = 0; /* number of range errors */ +#line 3257 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3257 + long cxp = (long) *((char**)xpp); +#line 3257 + +#line 3257 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3257 + /* sjl: manually stripmine so we can limit amount of +#line 3257 + * vector work space reserved to LOOPCNT elements. Also +#line 3257 + * makes vectorisation easy */ +#line 3257 + for (j=0; j= 0 */ +#line 3257 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3257 + nrange += tp[i] > X_USHORT_MAX || tp[i] < 0; +#line 3257 + } +#line 3257 + /* copy workspace back if necessary */ +#line 3257 + if (realign) { +#line 3257 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_USHORT); +#line 3257 + xp = (ushort *) *xpp; +#line 3257 + } +#line 3257 + /* update xpp and tp */ +#line 3257 + xp += ni; +#line 3257 + tp += ni; +#line 3257 + *xpp = (void*)xp; +#line 3257 + } +#line 3257 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3257 + +#line 3257 +#else /* not SX */ +#line 3257 + +#line 3257 + char *xp = (char *) *xpp; +#line 3257 + int status = NC_NOERR; +#line 3257 + +#line 3257 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3257 + { +#line 3257 + int lstatus = ncx_put_ushort_int(xp, tp, fillp); +#line 3257 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3257 + status = lstatus; +#line 3257 + } +#line 3257 + +#line 3257 + *xpp = (void *)xp; +#line 3257 + return status; +#line 3257 +#endif +#line 3257 +} +#line 3257 + +int +#line 3258 +ncx_putn_ushort_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3258 +{ +#line 3258 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3258 + +#line 3258 + /* basic algorithm is: +#line 3258 + * - ensure sane alignment of output data +#line 3258 + * - copy (conversion happens automatically) input data +#line 3258 + * to output +#line 3258 + * - update tp to point at next unconverted input, and xpp to point +#line 3258 + * at next location for converted output +#line 3258 + */ +#line 3258 + long i, j, ni; +#line 3258 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3258 + ushort *xp; +#line 3258 + int nrange = 0; /* number of range errors */ +#line 3258 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3258 + long cxp = (long) *((char**)xpp); +#line 3258 + +#line 3258 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3258 + /* sjl: manually stripmine so we can limit amount of +#line 3258 + * vector work space reserved to LOOPCNT elements. Also +#line 3258 + * makes vectorisation easy */ +#line 3258 + for (j=0; j= 0 */ +#line 3258 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3258 + nrange += tp[i] > X_USHORT_MAX || tp[i] < 0; +#line 3258 + } +#line 3258 + /* copy workspace back if necessary */ +#line 3258 + if (realign) { +#line 3258 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_USHORT); +#line 3258 + xp = (ushort *) *xpp; +#line 3258 + } +#line 3258 + /* update xpp and tp */ +#line 3258 + xp += ni; +#line 3258 + tp += ni; +#line 3258 + *xpp = (void*)xp; +#line 3258 + } +#line 3258 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3258 + +#line 3258 +#else /* not SX */ +#line 3258 + +#line 3258 + char *xp = (char *) *xpp; +#line 3258 + int status = NC_NOERR; +#line 3258 + +#line 3258 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3258 + { +#line 3258 + int lstatus = ncx_put_ushort_long(xp, tp, fillp); +#line 3258 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3258 + status = lstatus; +#line 3258 + } +#line 3258 + +#line 3258 + *xpp = (void *)xp; +#line 3258 + return status; +#line 3258 +#endif +#line 3258 +} +#line 3258 + +int +#line 3259 +ncx_putn_ushort_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 3259 +{ +#line 3259 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3259 + +#line 3259 + /* basic algorithm is: +#line 3259 + * - ensure sane alignment of output data +#line 3259 + * - copy (conversion happens automatically) input data +#line 3259 + * to output +#line 3259 + * - update tp to point at next unconverted input, and xpp to point +#line 3259 + * at next location for converted output +#line 3259 + */ +#line 3259 + long i, j, ni; +#line 3259 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3259 + ushort *xp; +#line 3259 + int nrange = 0; /* number of range errors */ +#line 3259 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3259 + long cxp = (long) *((char**)xpp); +#line 3259 + +#line 3259 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3259 + /* sjl: manually stripmine so we can limit amount of +#line 3259 + * vector work space reserved to LOOPCNT elements. Also +#line 3259 + * makes vectorisation easy */ +#line 3259 + for (j=0; j= 0 */ +#line 3259 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3259 + nrange += tp[i] > X_USHORT_MAX || tp[i] < 0; +#line 3259 + } +#line 3259 + /* copy workspace back if necessary */ +#line 3259 + if (realign) { +#line 3259 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_USHORT); +#line 3259 + xp = (ushort *) *xpp; +#line 3259 + } +#line 3259 + /* update xpp and tp */ +#line 3259 + xp += ni; +#line 3259 + tp += ni; +#line 3259 + *xpp = (void*)xp; +#line 3259 + } +#line 3259 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3259 + +#line 3259 +#else /* not SX */ +#line 3259 + +#line 3259 + char *xp = (char *) *xpp; +#line 3259 + int status = NC_NOERR; +#line 3259 + +#line 3259 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3259 + { +#line 3259 + int lstatus = ncx_put_ushort_float(xp, tp, fillp); +#line 3259 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3259 + status = lstatus; +#line 3259 + } +#line 3259 + +#line 3259 + *xpp = (void *)xp; +#line 3259 + return status; +#line 3259 +#endif +#line 3259 +} +#line 3259 + +int +#line 3260 +ncx_putn_ushort_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 3260 +{ +#line 3260 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3260 + +#line 3260 + /* basic algorithm is: +#line 3260 + * - ensure sane alignment of output data +#line 3260 + * - copy (conversion happens automatically) input data +#line 3260 + * to output +#line 3260 + * - update tp to point at next unconverted input, and xpp to point +#line 3260 + * at next location for converted output +#line 3260 + */ +#line 3260 + long i, j, ni; +#line 3260 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3260 + ushort *xp; +#line 3260 + int nrange = 0; /* number of range errors */ +#line 3260 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3260 + long cxp = (long) *((char**)xpp); +#line 3260 + +#line 3260 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3260 + /* sjl: manually stripmine so we can limit amount of +#line 3260 + * vector work space reserved to LOOPCNT elements. Also +#line 3260 + * makes vectorisation easy */ +#line 3260 + for (j=0; j= 0 */ +#line 3260 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3260 + nrange += tp[i] > X_USHORT_MAX || tp[i] < 0; +#line 3260 + } +#line 3260 + /* copy workspace back if necessary */ +#line 3260 + if (realign) { +#line 3260 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_USHORT); +#line 3260 + xp = (ushort *) *xpp; +#line 3260 + } +#line 3260 + /* update xpp and tp */ +#line 3260 + xp += ni; +#line 3260 + tp += ni; +#line 3260 + *xpp = (void*)xp; +#line 3260 + } +#line 3260 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3260 + +#line 3260 +#else /* not SX */ +#line 3260 + +#line 3260 + char *xp = (char *) *xpp; +#line 3260 + int status = NC_NOERR; +#line 3260 + +#line 3260 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3260 + { +#line 3260 + int lstatus = ncx_put_ushort_double(xp, tp, fillp); +#line 3260 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3260 + status = lstatus; +#line 3260 + } +#line 3260 + +#line 3260 + *xpp = (void *)xp; +#line 3260 + return status; +#line 3260 +#endif +#line 3260 +} +#line 3260 + +int +#line 3261 +ncx_putn_ushort_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3261 +{ +#line 3261 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3261 + +#line 3261 + /* basic algorithm is: +#line 3261 + * - ensure sane alignment of output data +#line 3261 + * - copy (conversion happens automatically) input data +#line 3261 + * to output +#line 3261 + * - update tp to point at next unconverted input, and xpp to point +#line 3261 + * at next location for converted output +#line 3261 + */ +#line 3261 + long i, j, ni; +#line 3261 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3261 + ushort *xp; +#line 3261 + int nrange = 0; /* number of range errors */ +#line 3261 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3261 + long cxp = (long) *((char**)xpp); +#line 3261 + +#line 3261 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3261 + /* sjl: manually stripmine so we can limit amount of +#line 3261 + * vector work space reserved to LOOPCNT elements. Also +#line 3261 + * makes vectorisation easy */ +#line 3261 + for (j=0; j= 0 */ +#line 3261 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3261 + nrange += tp[i] > X_USHORT_MAX || tp[i] < 0; +#line 3261 + } +#line 3261 + /* copy workspace back if necessary */ +#line 3261 + if (realign) { +#line 3261 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_USHORT); +#line 3261 + xp = (ushort *) *xpp; +#line 3261 + } +#line 3261 + /* update xpp and tp */ +#line 3261 + xp += ni; +#line 3261 + tp += ni; +#line 3261 + *xpp = (void*)xp; +#line 3261 + } +#line 3261 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3261 + +#line 3261 +#else /* not SX */ +#line 3261 + +#line 3261 + char *xp = (char *) *xpp; +#line 3261 + int status = NC_NOERR; +#line 3261 + +#line 3261 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3261 + { +#line 3261 + int lstatus = ncx_put_ushort_longlong(xp, tp, fillp); +#line 3261 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3261 + status = lstatus; +#line 3261 + } +#line 3261 + +#line 3261 + *xpp = (void *)xp; +#line 3261 + return status; +#line 3261 +#endif +#line 3261 +} +#line 3261 + +int +#line 3262 +ncx_putn_ushort_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 3262 +{ +#line 3262 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3262 + +#line 3262 + /* basic algorithm is: +#line 3262 + * - ensure sane alignment of output data +#line 3262 + * - copy (conversion happens automatically) input data +#line 3262 + * to output +#line 3262 + * - update tp to point at next unconverted input, and xpp to point +#line 3262 + * at next location for converted output +#line 3262 + */ +#line 3262 + long i, j, ni; +#line 3262 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3262 + ushort *xp; +#line 3262 + int nrange = 0; /* number of range errors */ +#line 3262 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3262 + long cxp = (long) *((char**)xpp); +#line 3262 + +#line 3262 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3262 + /* sjl: manually stripmine so we can limit amount of +#line 3262 + * vector work space reserved to LOOPCNT elements. Also +#line 3262 + * makes vectorisation easy */ +#line 3262 + for (j=0; j= 0 */ +#line 3262 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3262 + nrange += tp[i] > X_USHORT_MAX ; +#line 3262 + } +#line 3262 + /* copy workspace back if necessary */ +#line 3262 + if (realign) { +#line 3262 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_USHORT); +#line 3262 + xp = (ushort *) *xpp; +#line 3262 + } +#line 3262 + /* update xpp and tp */ +#line 3262 + xp += ni; +#line 3262 + tp += ni; +#line 3262 + *xpp = (void*)xp; +#line 3262 + } +#line 3262 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3262 + +#line 3262 +#else /* not SX */ +#line 3262 + +#line 3262 + char *xp = (char *) *xpp; +#line 3262 + int status = NC_NOERR; +#line 3262 + +#line 3262 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3262 + { +#line 3262 + int lstatus = ncx_put_ushort_uchar(xp, tp, fillp); +#line 3262 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3262 + status = lstatus; +#line 3262 + } +#line 3262 + +#line 3262 + *xpp = (void *)xp; +#line 3262 + return status; +#line 3262 +#endif +#line 3262 +} +#line 3262 + +int +#line 3263 +ncx_putn_ushort_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3263 +{ +#line 3263 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3263 + +#line 3263 + /* basic algorithm is: +#line 3263 + * - ensure sane alignment of output data +#line 3263 + * - copy (conversion happens automatically) input data +#line 3263 + * to output +#line 3263 + * - update tp to point at next unconverted input, and xpp to point +#line 3263 + * at next location for converted output +#line 3263 + */ +#line 3263 + long i, j, ni; +#line 3263 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3263 + ushort *xp; +#line 3263 + int nrange = 0; /* number of range errors */ +#line 3263 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3263 + long cxp = (long) *((char**)xpp); +#line 3263 + +#line 3263 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3263 + /* sjl: manually stripmine so we can limit amount of +#line 3263 + * vector work space reserved to LOOPCNT elements. Also +#line 3263 + * makes vectorisation easy */ +#line 3263 + for (j=0; j= 0 */ +#line 3263 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3263 + nrange += tp[i] > X_USHORT_MAX ; +#line 3263 + } +#line 3263 + /* copy workspace back if necessary */ +#line 3263 + if (realign) { +#line 3263 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_USHORT); +#line 3263 + xp = (ushort *) *xpp; +#line 3263 + } +#line 3263 + /* update xpp and tp */ +#line 3263 + xp += ni; +#line 3263 + tp += ni; +#line 3263 + *xpp = (void*)xp; +#line 3263 + } +#line 3263 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3263 + +#line 3263 +#else /* not SX */ +#line 3263 + +#line 3263 + char *xp = (char *) *xpp; +#line 3263 + int status = NC_NOERR; +#line 3263 + +#line 3263 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3263 + { +#line 3263 + int lstatus = ncx_put_ushort_uint(xp, tp, fillp); +#line 3263 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3263 + status = lstatus; +#line 3263 + } +#line 3263 + +#line 3263 + *xpp = (void *)xp; +#line 3263 + return status; +#line 3263 +#endif +#line 3263 +} +#line 3263 + +int +#line 3264 +ncx_putn_ushort_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3264 +{ +#line 3264 +#if defined(_SX) && _SX != 0 && X_SIZEOF_USHORT == SIZEOF_USHORT +#line 3264 + +#line 3264 + /* basic algorithm is: +#line 3264 + * - ensure sane alignment of output data +#line 3264 + * - copy (conversion happens automatically) input data +#line 3264 + * to output +#line 3264 + * - update tp to point at next unconverted input, and xpp to point +#line 3264 + * at next location for converted output +#line 3264 + */ +#line 3264 + long i, j, ni; +#line 3264 + ushort tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3264 + ushort *xp; +#line 3264 + int nrange = 0; /* number of range errors */ +#line 3264 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3264 + long cxp = (long) *((char**)xpp); +#line 3264 + +#line 3264 + realign = (cxp & 7) % SIZEOF_USHORT; +#line 3264 + /* sjl: manually stripmine so we can limit amount of +#line 3264 + * vector work space reserved to LOOPCNT elements. Also +#line 3264 + * makes vectorisation easy */ +#line 3264 + for (j=0; j= 0 */ +#line 3264 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3264 + nrange += tp[i] > X_USHORT_MAX ; +#line 3264 + } +#line 3264 + /* copy workspace back if necessary */ +#line 3264 + if (realign) { +#line 3264 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_USHORT); +#line 3264 + xp = (ushort *) *xpp; +#line 3264 + } +#line 3264 + /* update xpp and tp */ +#line 3264 + xp += ni; +#line 3264 + tp += ni; +#line 3264 + *xpp = (void*)xp; +#line 3264 + } +#line 3264 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3264 + +#line 3264 +#else /* not SX */ +#line 3264 + +#line 3264 + char *xp = (char *) *xpp; +#line 3264 + int status = NC_NOERR; +#line 3264 + +#line 3264 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3264 + { +#line 3264 + int lstatus = ncx_put_ushort_ulonglong(xp, tp, fillp); +#line 3264 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3264 + status = lstatus; +#line 3264 + } +#line 3264 + +#line 3264 + *xpp = (void *)xp; +#line 3264 + return status; +#line 3264 +#endif +#line 3264 +} +#line 3264 + + +int +#line 3266 +ncx_pad_putn_ushort_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +#line 3266 +{ +#line 3266 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3266 + +#line 3266 + char *xp = (char *) *xpp; +#line 3266 + int status = NC_NOERR; +#line 3266 + +#line 3266 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3266 + { +#line 3266 + int lstatus = ncx_put_ushort_schar(xp, tp, fillp); +#line 3266 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3266 + status = lstatus; +#line 3266 + } +#line 3266 + +#line 3266 + if (rndup != 0) +#line 3266 + { +#line 3266 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_USHORT)); +#line 3266 + xp += X_SIZEOF_USHORT; +#line 3266 + } +#line 3266 + +#line 3266 + *xpp = (void *)xp; +#line 3266 + return status; +#line 3266 +} +#line 3266 + +int +#line 3267 +ncx_pad_putn_ushort_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 3267 +{ +#line 3267 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3267 + +#line 3267 + char *xp = (char *) *xpp; +#line 3267 + int status = NC_NOERR; +#line 3267 + +#line 3267 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3267 + { +#line 3267 + int lstatus = ncx_put_ushort_uchar(xp, tp, fillp); +#line 3267 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3267 + status = lstatus; +#line 3267 + } +#line 3267 + +#line 3267 + if (rndup != 0) +#line 3267 + { +#line 3267 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_USHORT)); +#line 3267 + xp += X_SIZEOF_USHORT; +#line 3267 + } +#line 3267 + +#line 3267 + *xpp = (void *)xp; +#line 3267 + return status; +#line 3267 +} +#line 3267 + +int +#line 3268 +ncx_pad_putn_ushort_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3268 +{ +#line 3268 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3268 + +#line 3268 + char *xp = (char *) *xpp; +#line 3268 + int status = NC_NOERR; +#line 3268 + +#line 3268 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3268 + { +#line 3268 + int lstatus = ncx_put_ushort_short(xp, tp, fillp); +#line 3268 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3268 + status = lstatus; +#line 3268 + } +#line 3268 + +#line 3268 + if (rndup != 0) +#line 3268 + { +#line 3268 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_USHORT)); +#line 3268 + xp += X_SIZEOF_USHORT; +#line 3268 + } +#line 3268 + +#line 3268 + *xpp = (void *)xp; +#line 3268 + return status; +#line 3268 +} +#line 3268 + +int +#line 3269 +ncx_pad_putn_ushort_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3269 +{ +#line 3269 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3269 + +#line 3269 + char *xp = (char *) *xpp; +#line 3269 + int status = NC_NOERR; +#line 3269 + +#line 3269 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3269 + { +#line 3269 + int lstatus = ncx_put_ushort_int(xp, tp, fillp); +#line 3269 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3269 + status = lstatus; +#line 3269 + } +#line 3269 + +#line 3269 + if (rndup != 0) +#line 3269 + { +#line 3269 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_USHORT)); +#line 3269 + xp += X_SIZEOF_USHORT; +#line 3269 + } +#line 3269 + +#line 3269 + *xpp = (void *)xp; +#line 3269 + return status; +#line 3269 +} +#line 3269 + +int +#line 3270 +ncx_pad_putn_ushort_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3270 +{ +#line 3270 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3270 + +#line 3270 + char *xp = (char *) *xpp; +#line 3270 + int status = NC_NOERR; +#line 3270 + +#line 3270 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3270 + { +#line 3270 + int lstatus = ncx_put_ushort_long(xp, tp, fillp); +#line 3270 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3270 + status = lstatus; +#line 3270 + } +#line 3270 + +#line 3270 + if (rndup != 0) +#line 3270 + { +#line 3270 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_USHORT)); +#line 3270 + xp += X_SIZEOF_USHORT; +#line 3270 + } +#line 3270 + +#line 3270 + *xpp = (void *)xp; +#line 3270 + return status; +#line 3270 +} +#line 3270 + +int +#line 3271 +ncx_pad_putn_ushort_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 3271 +{ +#line 3271 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3271 + +#line 3271 + char *xp = (char *) *xpp; +#line 3271 + int status = NC_NOERR; +#line 3271 + +#line 3271 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3271 + { +#line 3271 + int lstatus = ncx_put_ushort_float(xp, tp, fillp); +#line 3271 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3271 + status = lstatus; +#line 3271 + } +#line 3271 + +#line 3271 + if (rndup != 0) +#line 3271 + { +#line 3271 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_USHORT)); +#line 3271 + xp += X_SIZEOF_USHORT; +#line 3271 + } +#line 3271 + +#line 3271 + *xpp = (void *)xp; +#line 3271 + return status; +#line 3271 +} +#line 3271 + +int +#line 3272 +ncx_pad_putn_ushort_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 3272 +{ +#line 3272 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3272 + +#line 3272 + char *xp = (char *) *xpp; +#line 3272 + int status = NC_NOERR; +#line 3272 + +#line 3272 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3272 + { +#line 3272 + int lstatus = ncx_put_ushort_double(xp, tp, fillp); +#line 3272 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3272 + status = lstatus; +#line 3272 + } +#line 3272 + +#line 3272 + if (rndup != 0) +#line 3272 + { +#line 3272 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_USHORT)); +#line 3272 + xp += X_SIZEOF_USHORT; +#line 3272 + } +#line 3272 + +#line 3272 + *xpp = (void *)xp; +#line 3272 + return status; +#line 3272 +} +#line 3272 + +int +#line 3273 +ncx_pad_putn_ushort_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3273 +{ +#line 3273 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3273 + +#line 3273 + char *xp = (char *) *xpp; +#line 3273 + int status = NC_NOERR; +#line 3273 + +#line 3273 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3273 + { +#line 3273 + int lstatus = ncx_put_ushort_uint(xp, tp, fillp); +#line 3273 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3273 + status = lstatus; +#line 3273 + } +#line 3273 + +#line 3273 + if (rndup != 0) +#line 3273 + { +#line 3273 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_USHORT)); +#line 3273 + xp += X_SIZEOF_USHORT; +#line 3273 + } +#line 3273 + +#line 3273 + *xpp = (void *)xp; +#line 3273 + return status; +#line 3273 +} +#line 3273 + +int +#line 3274 +ncx_pad_putn_ushort_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3274 +{ +#line 3274 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3274 + +#line 3274 + char *xp = (char *) *xpp; +#line 3274 + int status = NC_NOERR; +#line 3274 + +#line 3274 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3274 + { +#line 3274 + int lstatus = ncx_put_ushort_longlong(xp, tp, fillp); +#line 3274 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3274 + status = lstatus; +#line 3274 + } +#line 3274 + +#line 3274 + if (rndup != 0) +#line 3274 + { +#line 3274 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_USHORT)); +#line 3274 + xp += X_SIZEOF_USHORT; +#line 3274 + } +#line 3274 + +#line 3274 + *xpp = (void *)xp; +#line 3274 + return status; +#line 3274 +} +#line 3274 + +int +#line 3275 +ncx_pad_putn_ushort_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3275 +{ +#line 3275 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3275 + +#line 3275 + char *xp = (char *) *xpp; +#line 3275 + int status = NC_NOERR; +#line 3275 + +#line 3275 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3275 + { +#line 3275 + int lstatus = ncx_put_ushort_ulonglong(xp, tp, fillp); +#line 3275 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3275 + status = lstatus; +#line 3275 + } +#line 3275 + +#line 3275 + if (rndup != 0) +#line 3275 + { +#line 3275 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_USHORT)); +#line 3275 + xp += X_SIZEOF_USHORT; +#line 3275 + } +#line 3275 + +#line 3275 + *xpp = (void *)xp; +#line 3275 + return status; +#line 3275 +} +#line 3275 + +int +#line 3276 +ncx_pad_putn_ushort_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3276 +{ +#line 3276 + const size_t rndup = nelems % X_SIZEOF_SHORT; +#line 3276 + +#line 3276 + char *xp = (char *) *xpp; +#line 3276 + int status = NC_NOERR; +#line 3276 + +#line 3276 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_USHORT, tp++) +#line 3276 + { +#line 3276 + int lstatus = ncx_put_ushort_ushort(xp, tp, fillp); +#line 3276 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3276 + status = lstatus; +#line 3276 + } +#line 3276 + +#line 3276 + if (rndup != 0) +#line 3276 + { +#line 3276 + (void) memcpy(xp, nada, (size_t)(X_SIZEOF_USHORT)); +#line 3276 + xp += X_SIZEOF_USHORT; +#line 3276 + } +#line 3276 + +#line 3276 + *xpp = (void *)xp; +#line 3276 + return status; +#line 3276 +} +#line 3276 + + + +/* int -----------------------------------------------------------------------*/ + +#if X_SIZEOF_INT == SIZEOF_INT +/* optimized version */ +int +ncx_getn_int_int(const void **xpp, size_t nelems, int *tp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(tp, *xpp, (size_t)nelems * SIZEOF_INT); +# else + swapn4b(tp, *xpp, nelems); +# endif + *xpp = (const void *)((const char *)(*xpp) + nelems * X_SIZEOF_INT); + return NC_NOERR; +} +#else +int +#line 3295 +ncx_getn_int_int(const void **xpp, size_t nelems, int *tp) +#line 3295 +{ +#line 3295 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3295 + +#line 3295 + /* basic algorithm is: +#line 3295 + * - ensure sane alignment of input data +#line 3295 + * - copy (conversion happens automatically) input data +#line 3295 + * to output +#line 3295 + * - update xpp to point at next unconverted input, and tp to point +#line 3295 + * at next location for converted output +#line 3295 + */ +#line 3295 + long i, j, ni; +#line 3295 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3295 + int *xp; +#line 3295 + int nrange = 0; /* number of range errors */ +#line 3295 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3295 + long cxp = (long) *((char**)xpp); +#line 3295 + +#line 3295 + realign = (cxp & 7) % SIZEOF_INT; +#line 3295 + /* sjl: manually stripmine so we can limit amount of +#line 3295 + * vector work space reserved to LOOPCNT elements. Also +#line 3295 + * makes vectorisation easy */ +#line 3295 + for (j=0; j= 0 */ +#line 3295 + nrange += xp[i] > INT_MAX || xp[i] < INT_MIN; +#line 3295 + } +#line 3295 + /* update xpp and tp */ +#line 3295 + if (realign) xp = (int *) *xpp; +#line 3295 + xp += ni; +#line 3295 + tp += ni; +#line 3295 + *xpp = (void*)xp; +#line 3295 + } +#line 3295 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3295 + +#line 3295 +#else /* not SX */ +#line 3295 + const char *xp = (const char *) *xpp; +#line 3295 + int status = NC_NOERR; +#line 3295 + +#line 3295 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3295 + { +#line 3295 + const int lstatus = ncx_get_int_int(xp, tp); +#line 3295 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3295 + status = lstatus; +#line 3295 + } +#line 3295 + +#line 3295 + *xpp = (const void *)xp; +#line 3295 + return status; +#line 3295 +#endif +#line 3295 +} +#line 3295 + +#endif +int +#line 3297 +ncx_getn_int_schar(const void **xpp, size_t nelems, schar *tp) +#line 3297 +{ +#line 3297 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3297 + +#line 3297 + /* basic algorithm is: +#line 3297 + * - ensure sane alignment of input data +#line 3297 + * - copy (conversion happens automatically) input data +#line 3297 + * to output +#line 3297 + * - update xpp to point at next unconverted input, and tp to point +#line 3297 + * at next location for converted output +#line 3297 + */ +#line 3297 + long i, j, ni; +#line 3297 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3297 + int *xp; +#line 3297 + int nrange = 0; /* number of range errors */ +#line 3297 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3297 + long cxp = (long) *((char**)xpp); +#line 3297 + +#line 3297 + realign = (cxp & 7) % SIZEOF_INT; +#line 3297 + /* sjl: manually stripmine so we can limit amount of +#line 3297 + * vector work space reserved to LOOPCNT elements. Also +#line 3297 + * makes vectorisation easy */ +#line 3297 + for (j=0; j= 0 */ +#line 3297 + nrange += xp[i] > SCHAR_MAX || xp[i] < SCHAR_MIN; +#line 3297 + } +#line 3297 + /* update xpp and tp */ +#line 3297 + if (realign) xp = (int *) *xpp; +#line 3297 + xp += ni; +#line 3297 + tp += ni; +#line 3297 + *xpp = (void*)xp; +#line 3297 + } +#line 3297 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3297 + +#line 3297 +#else /* not SX */ +#line 3297 + const char *xp = (const char *) *xpp; +#line 3297 + int status = NC_NOERR; +#line 3297 + +#line 3297 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3297 + { +#line 3297 + const int lstatus = ncx_get_int_schar(xp, tp); +#line 3297 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3297 + status = lstatus; +#line 3297 + } +#line 3297 + +#line 3297 + *xpp = (const void *)xp; +#line 3297 + return status; +#line 3297 +#endif +#line 3297 +} +#line 3297 + +int +#line 3298 +ncx_getn_int_short(const void **xpp, size_t nelems, short *tp) +#line 3298 +{ +#line 3298 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3298 + +#line 3298 + /* basic algorithm is: +#line 3298 + * - ensure sane alignment of input data +#line 3298 + * - copy (conversion happens automatically) input data +#line 3298 + * to output +#line 3298 + * - update xpp to point at next unconverted input, and tp to point +#line 3298 + * at next location for converted output +#line 3298 + */ +#line 3298 + long i, j, ni; +#line 3298 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3298 + int *xp; +#line 3298 + int nrange = 0; /* number of range errors */ +#line 3298 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3298 + long cxp = (long) *((char**)xpp); +#line 3298 + +#line 3298 + realign = (cxp & 7) % SIZEOF_INT; +#line 3298 + /* sjl: manually stripmine so we can limit amount of +#line 3298 + * vector work space reserved to LOOPCNT elements. Also +#line 3298 + * makes vectorisation easy */ +#line 3298 + for (j=0; j= 0 */ +#line 3298 + nrange += xp[i] > SHORT_MAX || xp[i] < SHORT_MIN; +#line 3298 + } +#line 3298 + /* update xpp and tp */ +#line 3298 + if (realign) xp = (int *) *xpp; +#line 3298 + xp += ni; +#line 3298 + tp += ni; +#line 3298 + *xpp = (void*)xp; +#line 3298 + } +#line 3298 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3298 + +#line 3298 +#else /* not SX */ +#line 3298 + const char *xp = (const char *) *xpp; +#line 3298 + int status = NC_NOERR; +#line 3298 + +#line 3298 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3298 + { +#line 3298 + const int lstatus = ncx_get_int_short(xp, tp); +#line 3298 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3298 + status = lstatus; +#line 3298 + } +#line 3298 + +#line 3298 + *xpp = (const void *)xp; +#line 3298 + return status; +#line 3298 +#endif +#line 3298 +} +#line 3298 + +int +#line 3299 +ncx_getn_int_long(const void **xpp, size_t nelems, long *tp) +#line 3299 +{ +#line 3299 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3299 + +#line 3299 + /* basic algorithm is: +#line 3299 + * - ensure sane alignment of input data +#line 3299 + * - copy (conversion happens automatically) input data +#line 3299 + * to output +#line 3299 + * - update xpp to point at next unconverted input, and tp to point +#line 3299 + * at next location for converted output +#line 3299 + */ +#line 3299 + long i, j, ni; +#line 3299 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3299 + int *xp; +#line 3299 + int nrange = 0; /* number of range errors */ +#line 3299 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3299 + long cxp = (long) *((char**)xpp); +#line 3299 + +#line 3299 + realign = (cxp & 7) % SIZEOF_INT; +#line 3299 + /* sjl: manually stripmine so we can limit amount of +#line 3299 + * vector work space reserved to LOOPCNT elements. Also +#line 3299 + * makes vectorisation easy */ +#line 3299 + for (j=0; j= 0 */ +#line 3299 + nrange += xp[i] > LONG_MAX || xp[i] < LONG_MIN; +#line 3299 + } +#line 3299 + /* update xpp and tp */ +#line 3299 + if (realign) xp = (int *) *xpp; +#line 3299 + xp += ni; +#line 3299 + tp += ni; +#line 3299 + *xpp = (void*)xp; +#line 3299 + } +#line 3299 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3299 + +#line 3299 +#else /* not SX */ +#line 3299 + const char *xp = (const char *) *xpp; +#line 3299 + int status = NC_NOERR; +#line 3299 + +#line 3299 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3299 + { +#line 3299 + const int lstatus = ncx_get_int_long(xp, tp); +#line 3299 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3299 + status = lstatus; +#line 3299 + } +#line 3299 + +#line 3299 + *xpp = (const void *)xp; +#line 3299 + return status; +#line 3299 +#endif +#line 3299 +} +#line 3299 + +int +#line 3300 +ncx_getn_int_float(const void **xpp, size_t nelems, float *tp) +#line 3300 +{ +#line 3300 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3300 + +#line 3300 + /* basic algorithm is: +#line 3300 + * - ensure sane alignment of input data +#line 3300 + * - copy (conversion happens automatically) input data +#line 3300 + * to output +#line 3300 + * - update xpp to point at next unconverted input, and tp to point +#line 3300 + * at next location for converted output +#line 3300 + */ +#line 3300 + long i, j, ni; +#line 3300 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3300 + int *xp; +#line 3300 + int nrange = 0; /* number of range errors */ +#line 3300 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3300 + long cxp = (long) *((char**)xpp); +#line 3300 + +#line 3300 + realign = (cxp & 7) % SIZEOF_INT; +#line 3300 + /* sjl: manually stripmine so we can limit amount of +#line 3300 + * vector work space reserved to LOOPCNT elements. Also +#line 3300 + * makes vectorisation easy */ +#line 3300 + for (j=0; j= 0 */ +#line 3300 + nrange += xp[i] > FLOAT_MAX || xp[i] < FLOAT_MIN; +#line 3300 + } +#line 3300 + /* update xpp and tp */ +#line 3300 + if (realign) xp = (int *) *xpp; +#line 3300 + xp += ni; +#line 3300 + tp += ni; +#line 3300 + *xpp = (void*)xp; +#line 3300 + } +#line 3300 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3300 + +#line 3300 +#else /* not SX */ +#line 3300 + const char *xp = (const char *) *xpp; +#line 3300 + int status = NC_NOERR; +#line 3300 + +#line 3300 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3300 + { +#line 3300 + const int lstatus = ncx_get_int_float(xp, tp); +#line 3300 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3300 + status = lstatus; +#line 3300 + } +#line 3300 + +#line 3300 + *xpp = (const void *)xp; +#line 3300 + return status; +#line 3300 +#endif +#line 3300 +} +#line 3300 + +int +#line 3301 +ncx_getn_int_double(const void **xpp, size_t nelems, double *tp) +#line 3301 +{ +#line 3301 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3301 + +#line 3301 + /* basic algorithm is: +#line 3301 + * - ensure sane alignment of input data +#line 3301 + * - copy (conversion happens automatically) input data +#line 3301 + * to output +#line 3301 + * - update xpp to point at next unconverted input, and tp to point +#line 3301 + * at next location for converted output +#line 3301 + */ +#line 3301 + long i, j, ni; +#line 3301 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3301 + int *xp; +#line 3301 + int nrange = 0; /* number of range errors */ +#line 3301 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3301 + long cxp = (long) *((char**)xpp); +#line 3301 + +#line 3301 + realign = (cxp & 7) % SIZEOF_INT; +#line 3301 + /* sjl: manually stripmine so we can limit amount of +#line 3301 + * vector work space reserved to LOOPCNT elements. Also +#line 3301 + * makes vectorisation easy */ +#line 3301 + for (j=0; j= 0 */ +#line 3301 + nrange += xp[i] > DOUBLE_MAX || xp[i] < DOUBLE_MIN; +#line 3301 + } +#line 3301 + /* update xpp and tp */ +#line 3301 + if (realign) xp = (int *) *xpp; +#line 3301 + xp += ni; +#line 3301 + tp += ni; +#line 3301 + *xpp = (void*)xp; +#line 3301 + } +#line 3301 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3301 + +#line 3301 +#else /* not SX */ +#line 3301 + const char *xp = (const char *) *xpp; +#line 3301 + int status = NC_NOERR; +#line 3301 + +#line 3301 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3301 + { +#line 3301 + const int lstatus = ncx_get_int_double(xp, tp); +#line 3301 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3301 + status = lstatus; +#line 3301 + } +#line 3301 + +#line 3301 + *xpp = (const void *)xp; +#line 3301 + return status; +#line 3301 +#endif +#line 3301 +} +#line 3301 + +int +#line 3302 +ncx_getn_int_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 3302 +{ +#line 3302 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3302 + +#line 3302 + /* basic algorithm is: +#line 3302 + * - ensure sane alignment of input data +#line 3302 + * - copy (conversion happens automatically) input data +#line 3302 + * to output +#line 3302 + * - update xpp to point at next unconverted input, and tp to point +#line 3302 + * at next location for converted output +#line 3302 + */ +#line 3302 + long i, j, ni; +#line 3302 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3302 + int *xp; +#line 3302 + int nrange = 0; /* number of range errors */ +#line 3302 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3302 + long cxp = (long) *((char**)xpp); +#line 3302 + +#line 3302 + realign = (cxp & 7) % SIZEOF_INT; +#line 3302 + /* sjl: manually stripmine so we can limit amount of +#line 3302 + * vector work space reserved to LOOPCNT elements. Also +#line 3302 + * makes vectorisation easy */ +#line 3302 + for (j=0; j= 0 */ +#line 3302 + nrange += xp[i] > LONGLONG_MAX || xp[i] < LONGLONG_MIN; +#line 3302 + } +#line 3302 + /* update xpp and tp */ +#line 3302 + if (realign) xp = (int *) *xpp; +#line 3302 + xp += ni; +#line 3302 + tp += ni; +#line 3302 + *xpp = (void*)xp; +#line 3302 + } +#line 3302 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3302 + +#line 3302 +#else /* not SX */ +#line 3302 + const char *xp = (const char *) *xpp; +#line 3302 + int status = NC_NOERR; +#line 3302 + +#line 3302 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3302 + { +#line 3302 + const int lstatus = ncx_get_int_longlong(xp, tp); +#line 3302 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3302 + status = lstatus; +#line 3302 + } +#line 3302 + +#line 3302 + *xpp = (const void *)xp; +#line 3302 + return status; +#line 3302 +#endif +#line 3302 +} +#line 3302 + +int +#line 3303 +ncx_getn_int_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 3303 +{ +#line 3303 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3303 + +#line 3303 + /* basic algorithm is: +#line 3303 + * - ensure sane alignment of input data +#line 3303 + * - copy (conversion happens automatically) input data +#line 3303 + * to output +#line 3303 + * - update xpp to point at next unconverted input, and tp to point +#line 3303 + * at next location for converted output +#line 3303 + */ +#line 3303 + long i, j, ni; +#line 3303 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3303 + int *xp; +#line 3303 + int nrange = 0; /* number of range errors */ +#line 3303 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3303 + long cxp = (long) *((char**)xpp); +#line 3303 + +#line 3303 + realign = (cxp & 7) % SIZEOF_INT; +#line 3303 + /* sjl: manually stripmine so we can limit amount of +#line 3303 + * vector work space reserved to LOOPCNT elements. Also +#line 3303 + * makes vectorisation easy */ +#line 3303 + for (j=0; j= 0 */ +#line 3303 + nrange += xp[i] > UCHAR_MAX || xp[i] < 0; +#line 3303 + } +#line 3303 + /* update xpp and tp */ +#line 3303 + if (realign) xp = (int *) *xpp; +#line 3303 + xp += ni; +#line 3303 + tp += ni; +#line 3303 + *xpp = (void*)xp; +#line 3303 + } +#line 3303 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3303 + +#line 3303 +#else /* not SX */ +#line 3303 + const char *xp = (const char *) *xpp; +#line 3303 + int status = NC_NOERR; +#line 3303 + +#line 3303 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3303 + { +#line 3303 + const int lstatus = ncx_get_int_uchar(xp, tp); +#line 3303 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3303 + status = lstatus; +#line 3303 + } +#line 3303 + +#line 3303 + *xpp = (const void *)xp; +#line 3303 + return status; +#line 3303 +#endif +#line 3303 +} +#line 3303 + +int +#line 3304 +ncx_getn_int_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 3304 +{ +#line 3304 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3304 + +#line 3304 + /* basic algorithm is: +#line 3304 + * - ensure sane alignment of input data +#line 3304 + * - copy (conversion happens automatically) input data +#line 3304 + * to output +#line 3304 + * - update xpp to point at next unconverted input, and tp to point +#line 3304 + * at next location for converted output +#line 3304 + */ +#line 3304 + long i, j, ni; +#line 3304 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3304 + int *xp; +#line 3304 + int nrange = 0; /* number of range errors */ +#line 3304 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3304 + long cxp = (long) *((char**)xpp); +#line 3304 + +#line 3304 + realign = (cxp & 7) % SIZEOF_INT; +#line 3304 + /* sjl: manually stripmine so we can limit amount of +#line 3304 + * vector work space reserved to LOOPCNT elements. Also +#line 3304 + * makes vectorisation easy */ +#line 3304 + for (j=0; j= 0 */ +#line 3304 + nrange += xp[i] > USHORT_MAX || xp[i] < 0; +#line 3304 + } +#line 3304 + /* update xpp and tp */ +#line 3304 + if (realign) xp = (int *) *xpp; +#line 3304 + xp += ni; +#line 3304 + tp += ni; +#line 3304 + *xpp = (void*)xp; +#line 3304 + } +#line 3304 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3304 + +#line 3304 +#else /* not SX */ +#line 3304 + const char *xp = (const char *) *xpp; +#line 3304 + int status = NC_NOERR; +#line 3304 + +#line 3304 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3304 + { +#line 3304 + const int lstatus = ncx_get_int_ushort(xp, tp); +#line 3304 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3304 + status = lstatus; +#line 3304 + } +#line 3304 + +#line 3304 + *xpp = (const void *)xp; +#line 3304 + return status; +#line 3304 +#endif +#line 3304 +} +#line 3304 + +int +#line 3305 +ncx_getn_int_uint(const void **xpp, size_t nelems, uint *tp) +#line 3305 +{ +#line 3305 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3305 + +#line 3305 + /* basic algorithm is: +#line 3305 + * - ensure sane alignment of input data +#line 3305 + * - copy (conversion happens automatically) input data +#line 3305 + * to output +#line 3305 + * - update xpp to point at next unconverted input, and tp to point +#line 3305 + * at next location for converted output +#line 3305 + */ +#line 3305 + long i, j, ni; +#line 3305 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3305 + int *xp; +#line 3305 + int nrange = 0; /* number of range errors */ +#line 3305 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3305 + long cxp = (long) *((char**)xpp); +#line 3305 + +#line 3305 + realign = (cxp & 7) % SIZEOF_INT; +#line 3305 + /* sjl: manually stripmine so we can limit amount of +#line 3305 + * vector work space reserved to LOOPCNT elements. Also +#line 3305 + * makes vectorisation easy */ +#line 3305 + for (j=0; j= 0 */ +#line 3305 + nrange += xp[i] > UINT_MAX || xp[i] < 0; +#line 3305 + } +#line 3305 + /* update xpp and tp */ +#line 3305 + if (realign) xp = (int *) *xpp; +#line 3305 + xp += ni; +#line 3305 + tp += ni; +#line 3305 + *xpp = (void*)xp; +#line 3305 + } +#line 3305 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3305 + +#line 3305 +#else /* not SX */ +#line 3305 + const char *xp = (const char *) *xpp; +#line 3305 + int status = NC_NOERR; +#line 3305 + +#line 3305 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3305 + { +#line 3305 + const int lstatus = ncx_get_int_uint(xp, tp); +#line 3305 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3305 + status = lstatus; +#line 3305 + } +#line 3305 + +#line 3305 + *xpp = (const void *)xp; +#line 3305 + return status; +#line 3305 +#endif +#line 3305 +} +#line 3305 + +int +#line 3306 +ncx_getn_int_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 3306 +{ +#line 3306 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3306 + +#line 3306 + /* basic algorithm is: +#line 3306 + * - ensure sane alignment of input data +#line 3306 + * - copy (conversion happens automatically) input data +#line 3306 + * to output +#line 3306 + * - update xpp to point at next unconverted input, and tp to point +#line 3306 + * at next location for converted output +#line 3306 + */ +#line 3306 + long i, j, ni; +#line 3306 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3306 + int *xp; +#line 3306 + int nrange = 0; /* number of range errors */ +#line 3306 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3306 + long cxp = (long) *((char**)xpp); +#line 3306 + +#line 3306 + realign = (cxp & 7) % SIZEOF_INT; +#line 3306 + /* sjl: manually stripmine so we can limit amount of +#line 3306 + * vector work space reserved to LOOPCNT elements. Also +#line 3306 + * makes vectorisation easy */ +#line 3306 + for (j=0; j= 0 */ +#line 3306 + nrange += xp[i] > ULONGLONG_MAX || xp[i] < 0; +#line 3306 + } +#line 3306 + /* update xpp and tp */ +#line 3306 + if (realign) xp = (int *) *xpp; +#line 3306 + xp += ni; +#line 3306 + tp += ni; +#line 3306 + *xpp = (void*)xp; +#line 3306 + } +#line 3306 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3306 + +#line 3306 +#else /* not SX */ +#line 3306 + const char *xp = (const char *) *xpp; +#line 3306 + int status = NC_NOERR; +#line 3306 + +#line 3306 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3306 + { +#line 3306 + const int lstatus = ncx_get_int_ulonglong(xp, tp); +#line 3306 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3306 + status = lstatus; +#line 3306 + } +#line 3306 + +#line 3306 + *xpp = (const void *)xp; +#line 3306 + return status; +#line 3306 +#endif +#line 3306 +} +#line 3306 + + +#if X_SIZEOF_INT == SIZEOF_INT +/* optimized version */ +int +ncx_putn_int_int(void **xpp, size_t nelems, const int *tp, void *fillp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(*xpp, tp, (size_t)nelems * X_SIZEOF_INT); +# else + swapn4b(*xpp, tp, nelems); +# endif + *xpp = (void *)((char *)(*xpp) + nelems * X_SIZEOF_INT); + return NC_NOERR; +} +#else +int +#line 3322 +ncx_putn_int_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3322 +{ +#line 3322 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3322 + +#line 3322 + /* basic algorithm is: +#line 3322 + * - ensure sane alignment of output data +#line 3322 + * - copy (conversion happens automatically) input data +#line 3322 + * to output +#line 3322 + * - update tp to point at next unconverted input, and xpp to point +#line 3322 + * at next location for converted output +#line 3322 + */ +#line 3322 + long i, j, ni; +#line 3322 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3322 + int *xp; +#line 3322 + int nrange = 0; /* number of range errors */ +#line 3322 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3322 + long cxp = (long) *((char**)xpp); +#line 3322 + +#line 3322 + realign = (cxp & 7) % SIZEOF_INT; +#line 3322 + /* sjl: manually stripmine so we can limit amount of +#line 3322 + * vector work space reserved to LOOPCNT elements. Also +#line 3322 + * makes vectorisation easy */ +#line 3322 + for (j=0; j= 0 */ +#line 3322 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3322 + nrange += tp[i] > X_INT_MAX || tp[i] < X_INT_MIN; +#line 3322 + } +#line 3322 + /* copy workspace back if necessary */ +#line 3322 + if (realign) { +#line 3322 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT); +#line 3322 + xp = (int *) *xpp; +#line 3322 + } +#line 3322 + /* update xpp and tp */ +#line 3322 + xp += ni; +#line 3322 + tp += ni; +#line 3322 + *xpp = (void*)xp; +#line 3322 + } +#line 3322 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3322 + +#line 3322 +#else /* not SX */ +#line 3322 + +#line 3322 + char *xp = (char *) *xpp; +#line 3322 + int status = NC_NOERR; +#line 3322 + +#line 3322 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3322 + { +#line 3322 + int lstatus = ncx_put_int_int(xp, tp, fillp); +#line 3322 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3322 + status = lstatus; +#line 3322 + } +#line 3322 + +#line 3322 + *xpp = (void *)xp; +#line 3322 + return status; +#line 3322 +#endif +#line 3322 +} +#line 3322 + +#endif +int +#line 3324 +ncx_putn_int_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +#line 3324 +{ +#line 3324 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3324 + +#line 3324 + /* basic algorithm is: +#line 3324 + * - ensure sane alignment of output data +#line 3324 + * - copy (conversion happens automatically) input data +#line 3324 + * to output +#line 3324 + * - update tp to point at next unconverted input, and xpp to point +#line 3324 + * at next location for converted output +#line 3324 + */ +#line 3324 + long i, j, ni; +#line 3324 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3324 + int *xp; +#line 3324 + int nrange = 0; /* number of range errors */ +#line 3324 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3324 + long cxp = (long) *((char**)xpp); +#line 3324 + +#line 3324 + realign = (cxp & 7) % SIZEOF_INT; +#line 3324 + /* sjl: manually stripmine so we can limit amount of +#line 3324 + * vector work space reserved to LOOPCNT elements. Also +#line 3324 + * makes vectorisation easy */ +#line 3324 + for (j=0; j= 0 */ +#line 3324 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3324 + nrange += tp[i] > X_INT_MAX || tp[i] < X_INT_MIN; +#line 3324 + } +#line 3324 + /* copy workspace back if necessary */ +#line 3324 + if (realign) { +#line 3324 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT); +#line 3324 + xp = (int *) *xpp; +#line 3324 + } +#line 3324 + /* update xpp and tp */ +#line 3324 + xp += ni; +#line 3324 + tp += ni; +#line 3324 + *xpp = (void*)xp; +#line 3324 + } +#line 3324 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3324 + +#line 3324 +#else /* not SX */ +#line 3324 + +#line 3324 + char *xp = (char *) *xpp; +#line 3324 + int status = NC_NOERR; +#line 3324 + +#line 3324 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3324 + { +#line 3324 + int lstatus = ncx_put_int_schar(xp, tp, fillp); +#line 3324 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3324 + status = lstatus; +#line 3324 + } +#line 3324 + +#line 3324 + *xpp = (void *)xp; +#line 3324 + return status; +#line 3324 +#endif +#line 3324 +} +#line 3324 + +int +#line 3325 +ncx_putn_int_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3325 +{ +#line 3325 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3325 + +#line 3325 + /* basic algorithm is: +#line 3325 + * - ensure sane alignment of output data +#line 3325 + * - copy (conversion happens automatically) input data +#line 3325 + * to output +#line 3325 + * - update tp to point at next unconverted input, and xpp to point +#line 3325 + * at next location for converted output +#line 3325 + */ +#line 3325 + long i, j, ni; +#line 3325 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3325 + int *xp; +#line 3325 + int nrange = 0; /* number of range errors */ +#line 3325 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3325 + long cxp = (long) *((char**)xpp); +#line 3325 + +#line 3325 + realign = (cxp & 7) % SIZEOF_INT; +#line 3325 + /* sjl: manually stripmine so we can limit amount of +#line 3325 + * vector work space reserved to LOOPCNT elements. Also +#line 3325 + * makes vectorisation easy */ +#line 3325 + for (j=0; j= 0 */ +#line 3325 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3325 + nrange += tp[i] > X_INT_MAX || tp[i] < X_INT_MIN; +#line 3325 + } +#line 3325 + /* copy workspace back if necessary */ +#line 3325 + if (realign) { +#line 3325 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT); +#line 3325 + xp = (int *) *xpp; +#line 3325 + } +#line 3325 + /* update xpp and tp */ +#line 3325 + xp += ni; +#line 3325 + tp += ni; +#line 3325 + *xpp = (void*)xp; +#line 3325 + } +#line 3325 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3325 + +#line 3325 +#else /* not SX */ +#line 3325 + +#line 3325 + char *xp = (char *) *xpp; +#line 3325 + int status = NC_NOERR; +#line 3325 + +#line 3325 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3325 + { +#line 3325 + int lstatus = ncx_put_int_short(xp, tp, fillp); +#line 3325 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3325 + status = lstatus; +#line 3325 + } +#line 3325 + +#line 3325 + *xpp = (void *)xp; +#line 3325 + return status; +#line 3325 +#endif +#line 3325 +} +#line 3325 + +int +#line 3326 +ncx_putn_int_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3326 +{ +#line 3326 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3326 + +#line 3326 + /* basic algorithm is: +#line 3326 + * - ensure sane alignment of output data +#line 3326 + * - copy (conversion happens automatically) input data +#line 3326 + * to output +#line 3326 + * - update tp to point at next unconverted input, and xpp to point +#line 3326 + * at next location for converted output +#line 3326 + */ +#line 3326 + long i, j, ni; +#line 3326 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3326 + int *xp; +#line 3326 + int nrange = 0; /* number of range errors */ +#line 3326 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3326 + long cxp = (long) *((char**)xpp); +#line 3326 + +#line 3326 + realign = (cxp & 7) % SIZEOF_INT; +#line 3326 + /* sjl: manually stripmine so we can limit amount of +#line 3326 + * vector work space reserved to LOOPCNT elements. Also +#line 3326 + * makes vectorisation easy */ +#line 3326 + for (j=0; j= 0 */ +#line 3326 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3326 + nrange += tp[i] > X_INT_MAX || tp[i] < X_INT_MIN; +#line 3326 + } +#line 3326 + /* copy workspace back if necessary */ +#line 3326 + if (realign) { +#line 3326 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT); +#line 3326 + xp = (int *) *xpp; +#line 3326 + } +#line 3326 + /* update xpp and tp */ +#line 3326 + xp += ni; +#line 3326 + tp += ni; +#line 3326 + *xpp = (void*)xp; +#line 3326 + } +#line 3326 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3326 + +#line 3326 +#else /* not SX */ +#line 3326 + +#line 3326 + char *xp = (char *) *xpp; +#line 3326 + int status = NC_NOERR; +#line 3326 + +#line 3326 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3326 + { +#line 3326 + int lstatus = ncx_put_int_long(xp, tp, fillp); +#line 3326 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3326 + status = lstatus; +#line 3326 + } +#line 3326 + +#line 3326 + *xpp = (void *)xp; +#line 3326 + return status; +#line 3326 +#endif +#line 3326 +} +#line 3326 + +int +#line 3327 +ncx_putn_int_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 3327 +{ +#line 3327 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3327 + +#line 3327 + /* basic algorithm is: +#line 3327 + * - ensure sane alignment of output data +#line 3327 + * - copy (conversion happens automatically) input data +#line 3327 + * to output +#line 3327 + * - update tp to point at next unconverted input, and xpp to point +#line 3327 + * at next location for converted output +#line 3327 + */ +#line 3327 + long i, j, ni; +#line 3327 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3327 + int *xp; +#line 3327 + double d; /* special case for ncx_putn_int_float */ +#line 3327 + int nrange = 0; /* number of range errors */ +#line 3327 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3327 + long cxp = (long) *((char**)xpp); +#line 3327 + +#line 3327 + realign = (cxp & 7) % SIZEOF_INT; +#line 3327 + /* sjl: manually stripmine so we can limit amount of +#line 3327 + * vector work space reserved to LOOPCNT elements. Also +#line 3327 + * makes vectorisation easy */ +#line 3327 + for (j=0; j X_INT_MAX || tp[i] < X_INT_MIN; +#line 3327 + } +#line 3327 + /* copy workspace back if necessary */ +#line 3327 + if (realign) { +#line 3327 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT); +#line 3327 + xp = (int *) *xpp; +#line 3327 + } +#line 3327 + /* update xpp and tp */ +#line 3327 + xp += ni; +#line 3327 + tp += ni; +#line 3327 + *xpp = (void*)xp; +#line 3327 + } +#line 3327 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3327 + +#line 3327 +#else /* not SX */ +#line 3327 + +#line 3327 + char *xp = (char *) *xpp; +#line 3327 + int status = NC_NOERR; +#line 3327 + +#line 3327 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3327 + { +#line 3327 + int lstatus = ncx_put_int_float(xp, tp, fillp); +#line 3327 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3327 + status = lstatus; +#line 3327 + } +#line 3327 + +#line 3327 + *xpp = (void *)xp; +#line 3327 + return status; +#line 3327 +#endif +#line 3327 +} +#line 3327 + +int +#line 3328 +ncx_putn_int_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 3328 +{ +#line 3328 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3328 + +#line 3328 + /* basic algorithm is: +#line 3328 + * - ensure sane alignment of output data +#line 3328 + * - copy (conversion happens automatically) input data +#line 3328 + * to output +#line 3328 + * - update tp to point at next unconverted input, and xpp to point +#line 3328 + * at next location for converted output +#line 3328 + */ +#line 3328 + long i, j, ni; +#line 3328 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3328 + int *xp; +#line 3328 + int nrange = 0; /* number of range errors */ +#line 3328 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3328 + long cxp = (long) *((char**)xpp); +#line 3328 + +#line 3328 + realign = (cxp & 7) % SIZEOF_INT; +#line 3328 + /* sjl: manually stripmine so we can limit amount of +#line 3328 + * vector work space reserved to LOOPCNT elements. Also +#line 3328 + * makes vectorisation easy */ +#line 3328 + for (j=0; j= 0 */ +#line 3328 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3328 + nrange += tp[i] > X_INT_MAX || tp[i] < X_INT_MIN; +#line 3328 + } +#line 3328 + /* copy workspace back if necessary */ +#line 3328 + if (realign) { +#line 3328 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT); +#line 3328 + xp = (int *) *xpp; +#line 3328 + } +#line 3328 + /* update xpp and tp */ +#line 3328 + xp += ni; +#line 3328 + tp += ni; +#line 3328 + *xpp = (void*)xp; +#line 3328 + } +#line 3328 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3328 + +#line 3328 +#else /* not SX */ +#line 3328 + +#line 3328 + char *xp = (char *) *xpp; +#line 3328 + int status = NC_NOERR; +#line 3328 + +#line 3328 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3328 + { +#line 3328 + int lstatus = ncx_put_int_double(xp, tp, fillp); +#line 3328 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3328 + status = lstatus; +#line 3328 + } +#line 3328 + +#line 3328 + *xpp = (void *)xp; +#line 3328 + return status; +#line 3328 +#endif +#line 3328 +} +#line 3328 + +int +#line 3329 +ncx_putn_int_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3329 +{ +#line 3329 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3329 + +#line 3329 + /* basic algorithm is: +#line 3329 + * - ensure sane alignment of output data +#line 3329 + * - copy (conversion happens automatically) input data +#line 3329 + * to output +#line 3329 + * - update tp to point at next unconverted input, and xpp to point +#line 3329 + * at next location for converted output +#line 3329 + */ +#line 3329 + long i, j, ni; +#line 3329 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3329 + int *xp; +#line 3329 + int nrange = 0; /* number of range errors */ +#line 3329 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3329 + long cxp = (long) *((char**)xpp); +#line 3329 + +#line 3329 + realign = (cxp & 7) % SIZEOF_INT; +#line 3329 + /* sjl: manually stripmine so we can limit amount of +#line 3329 + * vector work space reserved to LOOPCNT elements. Also +#line 3329 + * makes vectorisation easy */ +#line 3329 + for (j=0; j= 0 */ +#line 3329 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3329 + nrange += tp[i] > X_INT_MAX || tp[i] < X_INT_MIN; +#line 3329 + } +#line 3329 + /* copy workspace back if necessary */ +#line 3329 + if (realign) { +#line 3329 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT); +#line 3329 + xp = (int *) *xpp; +#line 3329 + } +#line 3329 + /* update xpp and tp */ +#line 3329 + xp += ni; +#line 3329 + tp += ni; +#line 3329 + *xpp = (void*)xp; +#line 3329 + } +#line 3329 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3329 + +#line 3329 +#else /* not SX */ +#line 3329 + +#line 3329 + char *xp = (char *) *xpp; +#line 3329 + int status = NC_NOERR; +#line 3329 + +#line 3329 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3329 + { +#line 3329 + int lstatus = ncx_put_int_longlong(xp, tp, fillp); +#line 3329 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3329 + status = lstatus; +#line 3329 + } +#line 3329 + +#line 3329 + *xpp = (void *)xp; +#line 3329 + return status; +#line 3329 +#endif +#line 3329 +} +#line 3329 + +int +#line 3330 +ncx_putn_int_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 3330 +{ +#line 3330 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3330 + +#line 3330 + /* basic algorithm is: +#line 3330 + * - ensure sane alignment of output data +#line 3330 + * - copy (conversion happens automatically) input data +#line 3330 + * to output +#line 3330 + * - update tp to point at next unconverted input, and xpp to point +#line 3330 + * at next location for converted output +#line 3330 + */ +#line 3330 + long i, j, ni; +#line 3330 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3330 + int *xp; +#line 3330 + int nrange = 0; /* number of range errors */ +#line 3330 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3330 + long cxp = (long) *((char**)xpp); +#line 3330 + +#line 3330 + realign = (cxp & 7) % SIZEOF_INT; +#line 3330 + /* sjl: manually stripmine so we can limit amount of +#line 3330 + * vector work space reserved to LOOPCNT elements. Also +#line 3330 + * makes vectorisation easy */ +#line 3330 + for (j=0; j= 0 */ +#line 3330 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3330 + nrange += tp[i] > X_INT_MAX ; +#line 3330 + } +#line 3330 + /* copy workspace back if necessary */ +#line 3330 + if (realign) { +#line 3330 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT); +#line 3330 + xp = (int *) *xpp; +#line 3330 + } +#line 3330 + /* update xpp and tp */ +#line 3330 + xp += ni; +#line 3330 + tp += ni; +#line 3330 + *xpp = (void*)xp; +#line 3330 + } +#line 3330 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3330 + +#line 3330 +#else /* not SX */ +#line 3330 + +#line 3330 + char *xp = (char *) *xpp; +#line 3330 + int status = NC_NOERR; +#line 3330 + +#line 3330 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3330 + { +#line 3330 + int lstatus = ncx_put_int_uchar(xp, tp, fillp); +#line 3330 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3330 + status = lstatus; +#line 3330 + } +#line 3330 + +#line 3330 + *xpp = (void *)xp; +#line 3330 + return status; +#line 3330 +#endif +#line 3330 +} +#line 3330 + +int +#line 3331 +ncx_putn_int_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3331 +{ +#line 3331 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3331 + +#line 3331 + /* basic algorithm is: +#line 3331 + * - ensure sane alignment of output data +#line 3331 + * - copy (conversion happens automatically) input data +#line 3331 + * to output +#line 3331 + * - update tp to point at next unconverted input, and xpp to point +#line 3331 + * at next location for converted output +#line 3331 + */ +#line 3331 + long i, j, ni; +#line 3331 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3331 + int *xp; +#line 3331 + int nrange = 0; /* number of range errors */ +#line 3331 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3331 + long cxp = (long) *((char**)xpp); +#line 3331 + +#line 3331 + realign = (cxp & 7) % SIZEOF_INT; +#line 3331 + /* sjl: manually stripmine so we can limit amount of +#line 3331 + * vector work space reserved to LOOPCNT elements. Also +#line 3331 + * makes vectorisation easy */ +#line 3331 + for (j=0; j= 0 */ +#line 3331 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3331 + nrange += tp[i] > X_INT_MAX ; +#line 3331 + } +#line 3331 + /* copy workspace back if necessary */ +#line 3331 + if (realign) { +#line 3331 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT); +#line 3331 + xp = (int *) *xpp; +#line 3331 + } +#line 3331 + /* update xpp and tp */ +#line 3331 + xp += ni; +#line 3331 + tp += ni; +#line 3331 + *xpp = (void*)xp; +#line 3331 + } +#line 3331 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3331 + +#line 3331 +#else /* not SX */ +#line 3331 + +#line 3331 + char *xp = (char *) *xpp; +#line 3331 + int status = NC_NOERR; +#line 3331 + +#line 3331 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3331 + { +#line 3331 + int lstatus = ncx_put_int_ushort(xp, tp, fillp); +#line 3331 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3331 + status = lstatus; +#line 3331 + } +#line 3331 + +#line 3331 + *xpp = (void *)xp; +#line 3331 + return status; +#line 3331 +#endif +#line 3331 +} +#line 3331 + +int +#line 3332 +ncx_putn_int_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3332 +{ +#line 3332 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3332 + +#line 3332 + /* basic algorithm is: +#line 3332 + * - ensure sane alignment of output data +#line 3332 + * - copy (conversion happens automatically) input data +#line 3332 + * to output +#line 3332 + * - update tp to point at next unconverted input, and xpp to point +#line 3332 + * at next location for converted output +#line 3332 + */ +#line 3332 + long i, j, ni; +#line 3332 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3332 + int *xp; +#line 3332 + int nrange = 0; /* number of range errors */ +#line 3332 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3332 + long cxp = (long) *((char**)xpp); +#line 3332 + +#line 3332 + realign = (cxp & 7) % SIZEOF_INT; +#line 3332 + /* sjl: manually stripmine so we can limit amount of +#line 3332 + * vector work space reserved to LOOPCNT elements. Also +#line 3332 + * makes vectorisation easy */ +#line 3332 + for (j=0; j= 0 */ +#line 3332 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3332 + nrange += tp[i] > X_INT_MAX ; +#line 3332 + } +#line 3332 + /* copy workspace back if necessary */ +#line 3332 + if (realign) { +#line 3332 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT); +#line 3332 + xp = (int *) *xpp; +#line 3332 + } +#line 3332 + /* update xpp and tp */ +#line 3332 + xp += ni; +#line 3332 + tp += ni; +#line 3332 + *xpp = (void*)xp; +#line 3332 + } +#line 3332 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3332 + +#line 3332 +#else /* not SX */ +#line 3332 + +#line 3332 + char *xp = (char *) *xpp; +#line 3332 + int status = NC_NOERR; +#line 3332 + +#line 3332 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3332 + { +#line 3332 + int lstatus = ncx_put_int_uint(xp, tp, fillp); +#line 3332 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3332 + status = lstatus; +#line 3332 + } +#line 3332 + +#line 3332 + *xpp = (void *)xp; +#line 3332 + return status; +#line 3332 +#endif +#line 3332 +} +#line 3332 + +int +#line 3333 +ncx_putn_int_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3333 +{ +#line 3333 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT == SIZEOF_INT +#line 3333 + +#line 3333 + /* basic algorithm is: +#line 3333 + * - ensure sane alignment of output data +#line 3333 + * - copy (conversion happens automatically) input data +#line 3333 + * to output +#line 3333 + * - update tp to point at next unconverted input, and xpp to point +#line 3333 + * at next location for converted output +#line 3333 + */ +#line 3333 + long i, j, ni; +#line 3333 + int tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3333 + int *xp; +#line 3333 + int nrange = 0; /* number of range errors */ +#line 3333 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3333 + long cxp = (long) *((char**)xpp); +#line 3333 + +#line 3333 + realign = (cxp & 7) % SIZEOF_INT; +#line 3333 + /* sjl: manually stripmine so we can limit amount of +#line 3333 + * vector work space reserved to LOOPCNT elements. Also +#line 3333 + * makes vectorisation easy */ +#line 3333 + for (j=0; j= 0 */ +#line 3333 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3333 + nrange += tp[i] > X_INT_MAX ; +#line 3333 + } +#line 3333 + /* copy workspace back if necessary */ +#line 3333 + if (realign) { +#line 3333 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT); +#line 3333 + xp = (int *) *xpp; +#line 3333 + } +#line 3333 + /* update xpp and tp */ +#line 3333 + xp += ni; +#line 3333 + tp += ni; +#line 3333 + *xpp = (void*)xp; +#line 3333 + } +#line 3333 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3333 + +#line 3333 +#else /* not SX */ +#line 3333 + +#line 3333 + char *xp = (char *) *xpp; +#line 3333 + int status = NC_NOERR; +#line 3333 + +#line 3333 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT, tp++) +#line 3333 + { +#line 3333 + int lstatus = ncx_put_int_ulonglong(xp, tp, fillp); +#line 3333 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3333 + status = lstatus; +#line 3333 + } +#line 3333 + +#line 3333 + *xpp = (void *)xp; +#line 3333 + return status; +#line 3333 +#endif +#line 3333 +} +#line 3333 + + +/* uint ----------------------------------------------------------------------*/ + +#if X_SIZEOF_UINT == SIZEOF_UINT +/* optimized version */ +int +ncx_getn_uint_uint(const void **xpp, size_t nelems, unsigned int *tp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(tp, *xpp, (size_t)nelems * SIZEOF_UINT); +# else + swapn4b(tp, *xpp, nelems); +# endif + *xpp = (const void *)((const char *)(*xpp) + nelems * X_SIZEOF_UINT); + return NC_NOERR; +} +#else +int +#line 3351 +ncx_getn_uint_uint(const void **xpp, size_t nelems, uint *tp) +#line 3351 +{ +#line 3351 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3351 + +#line 3351 + /* basic algorithm is: +#line 3351 + * - ensure sane alignment of input data +#line 3351 + * - copy (conversion happens automatically) input data +#line 3351 + * to output +#line 3351 + * - update xpp to point at next unconverted input, and tp to point +#line 3351 + * at next location for converted output +#line 3351 + */ +#line 3351 + long i, j, ni; +#line 3351 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3351 + uint *xp; +#line 3351 + int nrange = 0; /* number of range errors */ +#line 3351 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3351 + long cxp = (long) *((char**)xpp); +#line 3351 + +#line 3351 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3351 + /* sjl: manually stripmine so we can limit amount of +#line 3351 + * vector work space reserved to LOOPCNT elements. Also +#line 3351 + * makes vectorisation easy */ +#line 3351 + for (j=0; j= 0 */ +#line 3351 + nrange += xp[i] > UINT_MAX ; +#line 3351 + } +#line 3351 + /* update xpp and tp */ +#line 3351 + if (realign) xp = (uint *) *xpp; +#line 3351 + xp += ni; +#line 3351 + tp += ni; +#line 3351 + *xpp = (void*)xp; +#line 3351 + } +#line 3351 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3351 + +#line 3351 +#else /* not SX */ +#line 3351 + const char *xp = (const char *) *xpp; +#line 3351 + int status = NC_NOERR; +#line 3351 + +#line 3351 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3351 + { +#line 3351 + const int lstatus = ncx_get_uint_uint(xp, tp); +#line 3351 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3351 + status = lstatus; +#line 3351 + } +#line 3351 + +#line 3351 + *xpp = (const void *)xp; +#line 3351 + return status; +#line 3351 +#endif +#line 3351 +} +#line 3351 + +#endif +int +#line 3353 +ncx_getn_uint_schar(const void **xpp, size_t nelems, schar *tp) +#line 3353 +{ +#line 3353 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3353 + +#line 3353 + /* basic algorithm is: +#line 3353 + * - ensure sane alignment of input data +#line 3353 + * - copy (conversion happens automatically) input data +#line 3353 + * to output +#line 3353 + * - update xpp to point at next unconverted input, and tp to point +#line 3353 + * at next location for converted output +#line 3353 + */ +#line 3353 + long i, j, ni; +#line 3353 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3353 + uint *xp; +#line 3353 + int nrange = 0; /* number of range errors */ +#line 3353 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3353 + long cxp = (long) *((char**)xpp); +#line 3353 + +#line 3353 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3353 + /* sjl: manually stripmine so we can limit amount of +#line 3353 + * vector work space reserved to LOOPCNT elements. Also +#line 3353 + * makes vectorisation easy */ +#line 3353 + for (j=0; j= 0 */ +#line 3353 + nrange += xp[i] > SCHAR_MAX ; +#line 3353 + } +#line 3353 + /* update xpp and tp */ +#line 3353 + if (realign) xp = (uint *) *xpp; +#line 3353 + xp += ni; +#line 3353 + tp += ni; +#line 3353 + *xpp = (void*)xp; +#line 3353 + } +#line 3353 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3353 + +#line 3353 +#else /* not SX */ +#line 3353 + const char *xp = (const char *) *xpp; +#line 3353 + int status = NC_NOERR; +#line 3353 + +#line 3353 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3353 + { +#line 3353 + const int lstatus = ncx_get_uint_schar(xp, tp); +#line 3353 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3353 + status = lstatus; +#line 3353 + } +#line 3353 + +#line 3353 + *xpp = (const void *)xp; +#line 3353 + return status; +#line 3353 +#endif +#line 3353 +} +#line 3353 + +int +#line 3354 +ncx_getn_uint_short(const void **xpp, size_t nelems, short *tp) +#line 3354 +{ +#line 3354 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3354 + +#line 3354 + /* basic algorithm is: +#line 3354 + * - ensure sane alignment of input data +#line 3354 + * - copy (conversion happens automatically) input data +#line 3354 + * to output +#line 3354 + * - update xpp to point at next unconverted input, and tp to point +#line 3354 + * at next location for converted output +#line 3354 + */ +#line 3354 + long i, j, ni; +#line 3354 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3354 + uint *xp; +#line 3354 + int nrange = 0; /* number of range errors */ +#line 3354 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3354 + long cxp = (long) *((char**)xpp); +#line 3354 + +#line 3354 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3354 + /* sjl: manually stripmine so we can limit amount of +#line 3354 + * vector work space reserved to LOOPCNT elements. Also +#line 3354 + * makes vectorisation easy */ +#line 3354 + for (j=0; j= 0 */ +#line 3354 + nrange += xp[i] > SHORT_MAX ; +#line 3354 + } +#line 3354 + /* update xpp and tp */ +#line 3354 + if (realign) xp = (uint *) *xpp; +#line 3354 + xp += ni; +#line 3354 + tp += ni; +#line 3354 + *xpp = (void*)xp; +#line 3354 + } +#line 3354 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3354 + +#line 3354 +#else /* not SX */ +#line 3354 + const char *xp = (const char *) *xpp; +#line 3354 + int status = NC_NOERR; +#line 3354 + +#line 3354 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3354 + { +#line 3354 + const int lstatus = ncx_get_uint_short(xp, tp); +#line 3354 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3354 + status = lstatus; +#line 3354 + } +#line 3354 + +#line 3354 + *xpp = (const void *)xp; +#line 3354 + return status; +#line 3354 +#endif +#line 3354 +} +#line 3354 + +int +#line 3355 +ncx_getn_uint_int(const void **xpp, size_t nelems, int *tp) +#line 3355 +{ +#line 3355 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3355 + +#line 3355 + /* basic algorithm is: +#line 3355 + * - ensure sane alignment of input data +#line 3355 + * - copy (conversion happens automatically) input data +#line 3355 + * to output +#line 3355 + * - update xpp to point at next unconverted input, and tp to point +#line 3355 + * at next location for converted output +#line 3355 + */ +#line 3355 + long i, j, ni; +#line 3355 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3355 + uint *xp; +#line 3355 + int nrange = 0; /* number of range errors */ +#line 3355 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3355 + long cxp = (long) *((char**)xpp); +#line 3355 + +#line 3355 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3355 + /* sjl: manually stripmine so we can limit amount of +#line 3355 + * vector work space reserved to LOOPCNT elements. Also +#line 3355 + * makes vectorisation easy */ +#line 3355 + for (j=0; j= 0 */ +#line 3355 + nrange += xp[i] > INT_MAX ; +#line 3355 + } +#line 3355 + /* update xpp and tp */ +#line 3355 + if (realign) xp = (uint *) *xpp; +#line 3355 + xp += ni; +#line 3355 + tp += ni; +#line 3355 + *xpp = (void*)xp; +#line 3355 + } +#line 3355 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3355 + +#line 3355 +#else /* not SX */ +#line 3355 + const char *xp = (const char *) *xpp; +#line 3355 + int status = NC_NOERR; +#line 3355 + +#line 3355 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3355 + { +#line 3355 + const int lstatus = ncx_get_uint_int(xp, tp); +#line 3355 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3355 + status = lstatus; +#line 3355 + } +#line 3355 + +#line 3355 + *xpp = (const void *)xp; +#line 3355 + return status; +#line 3355 +#endif +#line 3355 +} +#line 3355 + +int +#line 3356 +ncx_getn_uint_long(const void **xpp, size_t nelems, long *tp) +#line 3356 +{ +#line 3356 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3356 + +#line 3356 + /* basic algorithm is: +#line 3356 + * - ensure sane alignment of input data +#line 3356 + * - copy (conversion happens automatically) input data +#line 3356 + * to output +#line 3356 + * - update xpp to point at next unconverted input, and tp to point +#line 3356 + * at next location for converted output +#line 3356 + */ +#line 3356 + long i, j, ni; +#line 3356 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3356 + uint *xp; +#line 3356 + int nrange = 0; /* number of range errors */ +#line 3356 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3356 + long cxp = (long) *((char**)xpp); +#line 3356 + +#line 3356 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3356 + /* sjl: manually stripmine so we can limit amount of +#line 3356 + * vector work space reserved to LOOPCNT elements. Also +#line 3356 + * makes vectorisation easy */ +#line 3356 + for (j=0; j= 0 */ +#line 3356 + nrange += xp[i] > LONG_MAX ; +#line 3356 + } +#line 3356 + /* update xpp and tp */ +#line 3356 + if (realign) xp = (uint *) *xpp; +#line 3356 + xp += ni; +#line 3356 + tp += ni; +#line 3356 + *xpp = (void*)xp; +#line 3356 + } +#line 3356 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3356 + +#line 3356 +#else /* not SX */ +#line 3356 + const char *xp = (const char *) *xpp; +#line 3356 + int status = NC_NOERR; +#line 3356 + +#line 3356 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3356 + { +#line 3356 + const int lstatus = ncx_get_uint_long(xp, tp); +#line 3356 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3356 + status = lstatus; +#line 3356 + } +#line 3356 + +#line 3356 + *xpp = (const void *)xp; +#line 3356 + return status; +#line 3356 +#endif +#line 3356 +} +#line 3356 + +int +#line 3357 +ncx_getn_uint_float(const void **xpp, size_t nelems, float *tp) +#line 3357 +{ +#line 3357 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3357 + +#line 3357 + /* basic algorithm is: +#line 3357 + * - ensure sane alignment of input data +#line 3357 + * - copy (conversion happens automatically) input data +#line 3357 + * to output +#line 3357 + * - update xpp to point at next unconverted input, and tp to point +#line 3357 + * at next location for converted output +#line 3357 + */ +#line 3357 + long i, j, ni; +#line 3357 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3357 + uint *xp; +#line 3357 + int nrange = 0; /* number of range errors */ +#line 3357 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3357 + long cxp = (long) *((char**)xpp); +#line 3357 + +#line 3357 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3357 + /* sjl: manually stripmine so we can limit amount of +#line 3357 + * vector work space reserved to LOOPCNT elements. Also +#line 3357 + * makes vectorisation easy */ +#line 3357 + for (j=0; j= 0 */ +#line 3357 + nrange += xp[i] > FLOAT_MAX ; +#line 3357 + } +#line 3357 + /* update xpp and tp */ +#line 3357 + if (realign) xp = (uint *) *xpp; +#line 3357 + xp += ni; +#line 3357 + tp += ni; +#line 3357 + *xpp = (void*)xp; +#line 3357 + } +#line 3357 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3357 + +#line 3357 +#else /* not SX */ +#line 3357 + const char *xp = (const char *) *xpp; +#line 3357 + int status = NC_NOERR; +#line 3357 + +#line 3357 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3357 + { +#line 3357 + const int lstatus = ncx_get_uint_float(xp, tp); +#line 3357 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3357 + status = lstatus; +#line 3357 + } +#line 3357 + +#line 3357 + *xpp = (const void *)xp; +#line 3357 + return status; +#line 3357 +#endif +#line 3357 +} +#line 3357 + +int +#line 3358 +ncx_getn_uint_double(const void **xpp, size_t nelems, double *tp) +#line 3358 +{ +#line 3358 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3358 + +#line 3358 + /* basic algorithm is: +#line 3358 + * - ensure sane alignment of input data +#line 3358 + * - copy (conversion happens automatically) input data +#line 3358 + * to output +#line 3358 + * - update xpp to point at next unconverted input, and tp to point +#line 3358 + * at next location for converted output +#line 3358 + */ +#line 3358 + long i, j, ni; +#line 3358 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3358 + uint *xp; +#line 3358 + int nrange = 0; /* number of range errors */ +#line 3358 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3358 + long cxp = (long) *((char**)xpp); +#line 3358 + +#line 3358 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3358 + /* sjl: manually stripmine so we can limit amount of +#line 3358 + * vector work space reserved to LOOPCNT elements. Also +#line 3358 + * makes vectorisation easy */ +#line 3358 + for (j=0; j= 0 */ +#line 3358 + nrange += xp[i] > DOUBLE_MAX ; +#line 3358 + } +#line 3358 + /* update xpp and tp */ +#line 3358 + if (realign) xp = (uint *) *xpp; +#line 3358 + xp += ni; +#line 3358 + tp += ni; +#line 3358 + *xpp = (void*)xp; +#line 3358 + } +#line 3358 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3358 + +#line 3358 +#else /* not SX */ +#line 3358 + const char *xp = (const char *) *xpp; +#line 3358 + int status = NC_NOERR; +#line 3358 + +#line 3358 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3358 + { +#line 3358 + const int lstatus = ncx_get_uint_double(xp, tp); +#line 3358 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3358 + status = lstatus; +#line 3358 + } +#line 3358 + +#line 3358 + *xpp = (const void *)xp; +#line 3358 + return status; +#line 3358 +#endif +#line 3358 +} +#line 3358 + +int +#line 3359 +ncx_getn_uint_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 3359 +{ +#line 3359 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3359 + +#line 3359 + /* basic algorithm is: +#line 3359 + * - ensure sane alignment of input data +#line 3359 + * - copy (conversion happens automatically) input data +#line 3359 + * to output +#line 3359 + * - update xpp to point at next unconverted input, and tp to point +#line 3359 + * at next location for converted output +#line 3359 + */ +#line 3359 + long i, j, ni; +#line 3359 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3359 + uint *xp; +#line 3359 + int nrange = 0; /* number of range errors */ +#line 3359 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3359 + long cxp = (long) *((char**)xpp); +#line 3359 + +#line 3359 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3359 + /* sjl: manually stripmine so we can limit amount of +#line 3359 + * vector work space reserved to LOOPCNT elements. Also +#line 3359 + * makes vectorisation easy */ +#line 3359 + for (j=0; j= 0 */ +#line 3359 + nrange += xp[i] > LONGLONG_MAX ; +#line 3359 + } +#line 3359 + /* update xpp and tp */ +#line 3359 + if (realign) xp = (uint *) *xpp; +#line 3359 + xp += ni; +#line 3359 + tp += ni; +#line 3359 + *xpp = (void*)xp; +#line 3359 + } +#line 3359 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3359 + +#line 3359 +#else /* not SX */ +#line 3359 + const char *xp = (const char *) *xpp; +#line 3359 + int status = NC_NOERR; +#line 3359 + +#line 3359 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3359 + { +#line 3359 + const int lstatus = ncx_get_uint_longlong(xp, tp); +#line 3359 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3359 + status = lstatus; +#line 3359 + } +#line 3359 + +#line 3359 + *xpp = (const void *)xp; +#line 3359 + return status; +#line 3359 +#endif +#line 3359 +} +#line 3359 + +int +#line 3360 +ncx_getn_uint_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 3360 +{ +#line 3360 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3360 + +#line 3360 + /* basic algorithm is: +#line 3360 + * - ensure sane alignment of input data +#line 3360 + * - copy (conversion happens automatically) input data +#line 3360 + * to output +#line 3360 + * - update xpp to point at next unconverted input, and tp to point +#line 3360 + * at next location for converted output +#line 3360 + */ +#line 3360 + long i, j, ni; +#line 3360 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3360 + uint *xp; +#line 3360 + int nrange = 0; /* number of range errors */ +#line 3360 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3360 + long cxp = (long) *((char**)xpp); +#line 3360 + +#line 3360 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3360 + /* sjl: manually stripmine so we can limit amount of +#line 3360 + * vector work space reserved to LOOPCNT elements. Also +#line 3360 + * makes vectorisation easy */ +#line 3360 + for (j=0; j= 0 */ +#line 3360 + nrange += xp[i] > UCHAR_MAX ; +#line 3360 + } +#line 3360 + /* update xpp and tp */ +#line 3360 + if (realign) xp = (uint *) *xpp; +#line 3360 + xp += ni; +#line 3360 + tp += ni; +#line 3360 + *xpp = (void*)xp; +#line 3360 + } +#line 3360 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3360 + +#line 3360 +#else /* not SX */ +#line 3360 + const char *xp = (const char *) *xpp; +#line 3360 + int status = NC_NOERR; +#line 3360 + +#line 3360 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3360 + { +#line 3360 + const int lstatus = ncx_get_uint_uchar(xp, tp); +#line 3360 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3360 + status = lstatus; +#line 3360 + } +#line 3360 + +#line 3360 + *xpp = (const void *)xp; +#line 3360 + return status; +#line 3360 +#endif +#line 3360 +} +#line 3360 + +int +#line 3361 +ncx_getn_uint_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 3361 +{ +#line 3361 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3361 + +#line 3361 + /* basic algorithm is: +#line 3361 + * - ensure sane alignment of input data +#line 3361 + * - copy (conversion happens automatically) input data +#line 3361 + * to output +#line 3361 + * - update xpp to point at next unconverted input, and tp to point +#line 3361 + * at next location for converted output +#line 3361 + */ +#line 3361 + long i, j, ni; +#line 3361 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3361 + uint *xp; +#line 3361 + int nrange = 0; /* number of range errors */ +#line 3361 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3361 + long cxp = (long) *((char**)xpp); +#line 3361 + +#line 3361 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3361 + /* sjl: manually stripmine so we can limit amount of +#line 3361 + * vector work space reserved to LOOPCNT elements. Also +#line 3361 + * makes vectorisation easy */ +#line 3361 + for (j=0; j= 0 */ +#line 3361 + nrange += xp[i] > USHORT_MAX ; +#line 3361 + } +#line 3361 + /* update xpp and tp */ +#line 3361 + if (realign) xp = (uint *) *xpp; +#line 3361 + xp += ni; +#line 3361 + tp += ni; +#line 3361 + *xpp = (void*)xp; +#line 3361 + } +#line 3361 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3361 + +#line 3361 +#else /* not SX */ +#line 3361 + const char *xp = (const char *) *xpp; +#line 3361 + int status = NC_NOERR; +#line 3361 + +#line 3361 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3361 + { +#line 3361 + const int lstatus = ncx_get_uint_ushort(xp, tp); +#line 3361 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3361 + status = lstatus; +#line 3361 + } +#line 3361 + +#line 3361 + *xpp = (const void *)xp; +#line 3361 + return status; +#line 3361 +#endif +#line 3361 +} +#line 3361 + +int +#line 3362 +ncx_getn_uint_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 3362 +{ +#line 3362 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3362 + +#line 3362 + /* basic algorithm is: +#line 3362 + * - ensure sane alignment of input data +#line 3362 + * - copy (conversion happens automatically) input data +#line 3362 + * to output +#line 3362 + * - update xpp to point at next unconverted input, and tp to point +#line 3362 + * at next location for converted output +#line 3362 + */ +#line 3362 + long i, j, ni; +#line 3362 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3362 + uint *xp; +#line 3362 + int nrange = 0; /* number of range errors */ +#line 3362 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3362 + long cxp = (long) *((char**)xpp); +#line 3362 + +#line 3362 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3362 + /* sjl: manually stripmine so we can limit amount of +#line 3362 + * vector work space reserved to LOOPCNT elements. Also +#line 3362 + * makes vectorisation easy */ +#line 3362 + for (j=0; j= 0 */ +#line 3362 + nrange += xp[i] > ULONGLONG_MAX ; +#line 3362 + } +#line 3362 + /* update xpp and tp */ +#line 3362 + if (realign) xp = (uint *) *xpp; +#line 3362 + xp += ni; +#line 3362 + tp += ni; +#line 3362 + *xpp = (void*)xp; +#line 3362 + } +#line 3362 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3362 + +#line 3362 +#else /* not SX */ +#line 3362 + const char *xp = (const char *) *xpp; +#line 3362 + int status = NC_NOERR; +#line 3362 + +#line 3362 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3362 + { +#line 3362 + const int lstatus = ncx_get_uint_ulonglong(xp, tp); +#line 3362 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3362 + status = lstatus; +#line 3362 + } +#line 3362 + +#line 3362 + *xpp = (const void *)xp; +#line 3362 + return status; +#line 3362 +#endif +#line 3362 +} +#line 3362 + + +#if X_SIZEOF_UINT == SIZEOF_UINT +/* optimized version */ +int +ncx_putn_uint_uint(void **xpp, size_t nelems, const unsigned int *tp, void *fillp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(*xpp, tp, (size_t)nelems * X_SIZEOF_UINT); +# else + swapn4b(*xpp, tp, nelems); +# endif + *xpp = (void *)((char *)(*xpp) + nelems * X_SIZEOF_UINT); + return NC_NOERR; +} +#else +int +#line 3378 +ncx_putn_uint_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3378 +{ +#line 3378 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3378 + +#line 3378 + /* basic algorithm is: +#line 3378 + * - ensure sane alignment of output data +#line 3378 + * - copy (conversion happens automatically) input data +#line 3378 + * to output +#line 3378 + * - update tp to point at next unconverted input, and xpp to point +#line 3378 + * at next location for converted output +#line 3378 + */ +#line 3378 + long i, j, ni; +#line 3378 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3378 + uint *xp; +#line 3378 + int nrange = 0; /* number of range errors */ +#line 3378 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3378 + long cxp = (long) *((char**)xpp); +#line 3378 + +#line 3378 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3378 + /* sjl: manually stripmine so we can limit amount of +#line 3378 + * vector work space reserved to LOOPCNT elements. Also +#line 3378 + * makes vectorisation easy */ +#line 3378 + for (j=0; j= 0 */ +#line 3378 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3378 + nrange += tp[i] > X_UINT_MAX ; +#line 3378 + } +#line 3378 + /* copy workspace back if necessary */ +#line 3378 + if (realign) { +#line 3378 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT); +#line 3378 + xp = (uint *) *xpp; +#line 3378 + } +#line 3378 + /* update xpp and tp */ +#line 3378 + xp += ni; +#line 3378 + tp += ni; +#line 3378 + *xpp = (void*)xp; +#line 3378 + } +#line 3378 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3378 + +#line 3378 +#else /* not SX */ +#line 3378 + +#line 3378 + char *xp = (char *) *xpp; +#line 3378 + int status = NC_NOERR; +#line 3378 + +#line 3378 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3378 + { +#line 3378 + int lstatus = ncx_put_uint_uint(xp, tp, fillp); +#line 3378 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3378 + status = lstatus; +#line 3378 + } +#line 3378 + +#line 3378 + *xpp = (void *)xp; +#line 3378 + return status; +#line 3378 +#endif +#line 3378 +} +#line 3378 + +#endif +int +#line 3380 +ncx_putn_uint_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +#line 3380 +{ +#line 3380 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3380 + +#line 3380 + /* basic algorithm is: +#line 3380 + * - ensure sane alignment of output data +#line 3380 + * - copy (conversion happens automatically) input data +#line 3380 + * to output +#line 3380 + * - update tp to point at next unconverted input, and xpp to point +#line 3380 + * at next location for converted output +#line 3380 + */ +#line 3380 + long i, j, ni; +#line 3380 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3380 + uint *xp; +#line 3380 + int nrange = 0; /* number of range errors */ +#line 3380 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3380 + long cxp = (long) *((char**)xpp); +#line 3380 + +#line 3380 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3380 + /* sjl: manually stripmine so we can limit amount of +#line 3380 + * vector work space reserved to LOOPCNT elements. Also +#line 3380 + * makes vectorisation easy */ +#line 3380 + for (j=0; j= 0 */ +#line 3380 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3380 + nrange += tp[i] > X_UINT_MAX || tp[i] < 0; +#line 3380 + } +#line 3380 + /* copy workspace back if necessary */ +#line 3380 + if (realign) { +#line 3380 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT); +#line 3380 + xp = (uint *) *xpp; +#line 3380 + } +#line 3380 + /* update xpp and tp */ +#line 3380 + xp += ni; +#line 3380 + tp += ni; +#line 3380 + *xpp = (void*)xp; +#line 3380 + } +#line 3380 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3380 + +#line 3380 +#else /* not SX */ +#line 3380 + +#line 3380 + char *xp = (char *) *xpp; +#line 3380 + int status = NC_NOERR; +#line 3380 + +#line 3380 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3380 + { +#line 3380 + int lstatus = ncx_put_uint_schar(xp, tp, fillp); +#line 3380 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3380 + status = lstatus; +#line 3380 + } +#line 3380 + +#line 3380 + *xpp = (void *)xp; +#line 3380 + return status; +#line 3380 +#endif +#line 3380 +} +#line 3380 + +int +#line 3381 +ncx_putn_uint_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3381 +{ +#line 3381 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3381 + +#line 3381 + /* basic algorithm is: +#line 3381 + * - ensure sane alignment of output data +#line 3381 + * - copy (conversion happens automatically) input data +#line 3381 + * to output +#line 3381 + * - update tp to point at next unconverted input, and xpp to point +#line 3381 + * at next location for converted output +#line 3381 + */ +#line 3381 + long i, j, ni; +#line 3381 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3381 + uint *xp; +#line 3381 + int nrange = 0; /* number of range errors */ +#line 3381 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3381 + long cxp = (long) *((char**)xpp); +#line 3381 + +#line 3381 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3381 + /* sjl: manually stripmine so we can limit amount of +#line 3381 + * vector work space reserved to LOOPCNT elements. Also +#line 3381 + * makes vectorisation easy */ +#line 3381 + for (j=0; j= 0 */ +#line 3381 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3381 + nrange += tp[i] > X_UINT_MAX || tp[i] < 0; +#line 3381 + } +#line 3381 + /* copy workspace back if necessary */ +#line 3381 + if (realign) { +#line 3381 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT); +#line 3381 + xp = (uint *) *xpp; +#line 3381 + } +#line 3381 + /* update xpp and tp */ +#line 3381 + xp += ni; +#line 3381 + tp += ni; +#line 3381 + *xpp = (void*)xp; +#line 3381 + } +#line 3381 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3381 + +#line 3381 +#else /* not SX */ +#line 3381 + +#line 3381 + char *xp = (char *) *xpp; +#line 3381 + int status = NC_NOERR; +#line 3381 + +#line 3381 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3381 + { +#line 3381 + int lstatus = ncx_put_uint_short(xp, tp, fillp); +#line 3381 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3381 + status = lstatus; +#line 3381 + } +#line 3381 + +#line 3381 + *xpp = (void *)xp; +#line 3381 + return status; +#line 3381 +#endif +#line 3381 +} +#line 3381 + +int +#line 3382 +ncx_putn_uint_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3382 +{ +#line 3382 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3382 + +#line 3382 + /* basic algorithm is: +#line 3382 + * - ensure sane alignment of output data +#line 3382 + * - copy (conversion happens automatically) input data +#line 3382 + * to output +#line 3382 + * - update tp to point at next unconverted input, and xpp to point +#line 3382 + * at next location for converted output +#line 3382 + */ +#line 3382 + long i, j, ni; +#line 3382 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3382 + uint *xp; +#line 3382 + int nrange = 0; /* number of range errors */ +#line 3382 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3382 + long cxp = (long) *((char**)xpp); +#line 3382 + +#line 3382 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3382 + /* sjl: manually stripmine so we can limit amount of +#line 3382 + * vector work space reserved to LOOPCNT elements. Also +#line 3382 + * makes vectorisation easy */ +#line 3382 + for (j=0; j= 0 */ +#line 3382 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3382 + nrange += tp[i] > X_UINT_MAX || tp[i] < 0; +#line 3382 + } +#line 3382 + /* copy workspace back if necessary */ +#line 3382 + if (realign) { +#line 3382 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT); +#line 3382 + xp = (uint *) *xpp; +#line 3382 + } +#line 3382 + /* update xpp and tp */ +#line 3382 + xp += ni; +#line 3382 + tp += ni; +#line 3382 + *xpp = (void*)xp; +#line 3382 + } +#line 3382 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3382 + +#line 3382 +#else /* not SX */ +#line 3382 + +#line 3382 + char *xp = (char *) *xpp; +#line 3382 + int status = NC_NOERR; +#line 3382 + +#line 3382 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3382 + { +#line 3382 + int lstatus = ncx_put_uint_int(xp, tp, fillp); +#line 3382 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3382 + status = lstatus; +#line 3382 + } +#line 3382 + +#line 3382 + *xpp = (void *)xp; +#line 3382 + return status; +#line 3382 +#endif +#line 3382 +} +#line 3382 + +int +#line 3383 +ncx_putn_uint_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3383 +{ +#line 3383 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3383 + +#line 3383 + /* basic algorithm is: +#line 3383 + * - ensure sane alignment of output data +#line 3383 + * - copy (conversion happens automatically) input data +#line 3383 + * to output +#line 3383 + * - update tp to point at next unconverted input, and xpp to point +#line 3383 + * at next location for converted output +#line 3383 + */ +#line 3383 + long i, j, ni; +#line 3383 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3383 + uint *xp; +#line 3383 + int nrange = 0; /* number of range errors */ +#line 3383 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3383 + long cxp = (long) *((char**)xpp); +#line 3383 + +#line 3383 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3383 + /* sjl: manually stripmine so we can limit amount of +#line 3383 + * vector work space reserved to LOOPCNT elements. Also +#line 3383 + * makes vectorisation easy */ +#line 3383 + for (j=0; j= 0 */ +#line 3383 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3383 + nrange += tp[i] > X_UINT_MAX || tp[i] < 0; +#line 3383 + } +#line 3383 + /* copy workspace back if necessary */ +#line 3383 + if (realign) { +#line 3383 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT); +#line 3383 + xp = (uint *) *xpp; +#line 3383 + } +#line 3383 + /* update xpp and tp */ +#line 3383 + xp += ni; +#line 3383 + tp += ni; +#line 3383 + *xpp = (void*)xp; +#line 3383 + } +#line 3383 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3383 + +#line 3383 +#else /* not SX */ +#line 3383 + +#line 3383 + char *xp = (char *) *xpp; +#line 3383 + int status = NC_NOERR; +#line 3383 + +#line 3383 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3383 + { +#line 3383 + int lstatus = ncx_put_uint_long(xp, tp, fillp); +#line 3383 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3383 + status = lstatus; +#line 3383 + } +#line 3383 + +#line 3383 + *xpp = (void *)xp; +#line 3383 + return status; +#line 3383 +#endif +#line 3383 +} +#line 3383 + +int +#line 3384 +ncx_putn_uint_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 3384 +{ +#line 3384 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3384 + +#line 3384 + /* basic algorithm is: +#line 3384 + * - ensure sane alignment of output data +#line 3384 + * - copy (conversion happens automatically) input data +#line 3384 + * to output +#line 3384 + * - update tp to point at next unconverted input, and xpp to point +#line 3384 + * at next location for converted output +#line 3384 + */ +#line 3384 + long i, j, ni; +#line 3384 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3384 + uint *xp; +#line 3384 + int nrange = 0; /* number of range errors */ +#line 3384 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3384 + long cxp = (long) *((char**)xpp); +#line 3384 + +#line 3384 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3384 + /* sjl: manually stripmine so we can limit amount of +#line 3384 + * vector work space reserved to LOOPCNT elements. Also +#line 3384 + * makes vectorisation easy */ +#line 3384 + for (j=0; j= 0 */ +#line 3384 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3384 + nrange += tp[i] > X_UINT_MAX || tp[i] < 0; +#line 3384 + } +#line 3384 + /* copy workspace back if necessary */ +#line 3384 + if (realign) { +#line 3384 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT); +#line 3384 + xp = (uint *) *xpp; +#line 3384 + } +#line 3384 + /* update xpp and tp */ +#line 3384 + xp += ni; +#line 3384 + tp += ni; +#line 3384 + *xpp = (void*)xp; +#line 3384 + } +#line 3384 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3384 + +#line 3384 +#else /* not SX */ +#line 3384 + +#line 3384 + char *xp = (char *) *xpp; +#line 3384 + int status = NC_NOERR; +#line 3384 + +#line 3384 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3384 + { +#line 3384 + int lstatus = ncx_put_uint_float(xp, tp, fillp); +#line 3384 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3384 + status = lstatus; +#line 3384 + } +#line 3384 + +#line 3384 + *xpp = (void *)xp; +#line 3384 + return status; +#line 3384 +#endif +#line 3384 +} +#line 3384 + +int +#line 3385 +ncx_putn_uint_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 3385 +{ +#line 3385 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3385 + +#line 3385 + /* basic algorithm is: +#line 3385 + * - ensure sane alignment of output data +#line 3385 + * - copy (conversion happens automatically) input data +#line 3385 + * to output +#line 3385 + * - update tp to point at next unconverted input, and xpp to point +#line 3385 + * at next location for converted output +#line 3385 + */ +#line 3385 + long i, j, ni; +#line 3385 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3385 + uint *xp; +#line 3385 + int nrange = 0; /* number of range errors */ +#line 3385 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3385 + long cxp = (long) *((char**)xpp); +#line 3385 + +#line 3385 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3385 + /* sjl: manually stripmine so we can limit amount of +#line 3385 + * vector work space reserved to LOOPCNT elements. Also +#line 3385 + * makes vectorisation easy */ +#line 3385 + for (j=0; j= 0 */ +#line 3385 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3385 + nrange += tp[i] > X_UINT_MAX || tp[i] < 0; +#line 3385 + } +#line 3385 + /* copy workspace back if necessary */ +#line 3385 + if (realign) { +#line 3385 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT); +#line 3385 + xp = (uint *) *xpp; +#line 3385 + } +#line 3385 + /* update xpp and tp */ +#line 3385 + xp += ni; +#line 3385 + tp += ni; +#line 3385 + *xpp = (void*)xp; +#line 3385 + } +#line 3385 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3385 + +#line 3385 +#else /* not SX */ +#line 3385 + +#line 3385 + char *xp = (char *) *xpp; +#line 3385 + int status = NC_NOERR; +#line 3385 + +#line 3385 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3385 + { +#line 3385 + int lstatus = ncx_put_uint_double(xp, tp, fillp); +#line 3385 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3385 + status = lstatus; +#line 3385 + } +#line 3385 + +#line 3385 + *xpp = (void *)xp; +#line 3385 + return status; +#line 3385 +#endif +#line 3385 +} +#line 3385 + +int +#line 3386 +ncx_putn_uint_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3386 +{ +#line 3386 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3386 + +#line 3386 + /* basic algorithm is: +#line 3386 + * - ensure sane alignment of output data +#line 3386 + * - copy (conversion happens automatically) input data +#line 3386 + * to output +#line 3386 + * - update tp to point at next unconverted input, and xpp to point +#line 3386 + * at next location for converted output +#line 3386 + */ +#line 3386 + long i, j, ni; +#line 3386 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3386 + uint *xp; +#line 3386 + int nrange = 0; /* number of range errors */ +#line 3386 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3386 + long cxp = (long) *((char**)xpp); +#line 3386 + +#line 3386 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3386 + /* sjl: manually stripmine so we can limit amount of +#line 3386 + * vector work space reserved to LOOPCNT elements. Also +#line 3386 + * makes vectorisation easy */ +#line 3386 + for (j=0; j= 0 */ +#line 3386 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3386 + nrange += tp[i] > X_UINT_MAX || tp[i] < 0; +#line 3386 + } +#line 3386 + /* copy workspace back if necessary */ +#line 3386 + if (realign) { +#line 3386 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT); +#line 3386 + xp = (uint *) *xpp; +#line 3386 + } +#line 3386 + /* update xpp and tp */ +#line 3386 + xp += ni; +#line 3386 + tp += ni; +#line 3386 + *xpp = (void*)xp; +#line 3386 + } +#line 3386 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3386 + +#line 3386 +#else /* not SX */ +#line 3386 + +#line 3386 + char *xp = (char *) *xpp; +#line 3386 + int status = NC_NOERR; +#line 3386 + +#line 3386 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3386 + { +#line 3386 + int lstatus = ncx_put_uint_longlong(xp, tp, fillp); +#line 3386 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3386 + status = lstatus; +#line 3386 + } +#line 3386 + +#line 3386 + *xpp = (void *)xp; +#line 3386 + return status; +#line 3386 +#endif +#line 3386 +} +#line 3386 + +int +#line 3387 +ncx_putn_uint_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 3387 +{ +#line 3387 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3387 + +#line 3387 + /* basic algorithm is: +#line 3387 + * - ensure sane alignment of output data +#line 3387 + * - copy (conversion happens automatically) input data +#line 3387 + * to output +#line 3387 + * - update tp to point at next unconverted input, and xpp to point +#line 3387 + * at next location for converted output +#line 3387 + */ +#line 3387 + long i, j, ni; +#line 3387 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3387 + uint *xp; +#line 3387 + int nrange = 0; /* number of range errors */ +#line 3387 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3387 + long cxp = (long) *((char**)xpp); +#line 3387 + +#line 3387 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3387 + /* sjl: manually stripmine so we can limit amount of +#line 3387 + * vector work space reserved to LOOPCNT elements. Also +#line 3387 + * makes vectorisation easy */ +#line 3387 + for (j=0; j= 0 */ +#line 3387 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3387 + nrange += tp[i] > X_UINT_MAX ; +#line 3387 + } +#line 3387 + /* copy workspace back if necessary */ +#line 3387 + if (realign) { +#line 3387 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT); +#line 3387 + xp = (uint *) *xpp; +#line 3387 + } +#line 3387 + /* update xpp and tp */ +#line 3387 + xp += ni; +#line 3387 + tp += ni; +#line 3387 + *xpp = (void*)xp; +#line 3387 + } +#line 3387 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3387 + +#line 3387 +#else /* not SX */ +#line 3387 + +#line 3387 + char *xp = (char *) *xpp; +#line 3387 + int status = NC_NOERR; +#line 3387 + +#line 3387 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3387 + { +#line 3387 + int lstatus = ncx_put_uint_uchar(xp, tp, fillp); +#line 3387 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3387 + status = lstatus; +#line 3387 + } +#line 3387 + +#line 3387 + *xpp = (void *)xp; +#line 3387 + return status; +#line 3387 +#endif +#line 3387 +} +#line 3387 + +int +#line 3388 +ncx_putn_uint_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3388 +{ +#line 3388 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3388 + +#line 3388 + /* basic algorithm is: +#line 3388 + * - ensure sane alignment of output data +#line 3388 + * - copy (conversion happens automatically) input data +#line 3388 + * to output +#line 3388 + * - update tp to point at next unconverted input, and xpp to point +#line 3388 + * at next location for converted output +#line 3388 + */ +#line 3388 + long i, j, ni; +#line 3388 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3388 + uint *xp; +#line 3388 + int nrange = 0; /* number of range errors */ +#line 3388 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3388 + long cxp = (long) *((char**)xpp); +#line 3388 + +#line 3388 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3388 + /* sjl: manually stripmine so we can limit amount of +#line 3388 + * vector work space reserved to LOOPCNT elements. Also +#line 3388 + * makes vectorisation easy */ +#line 3388 + for (j=0; j= 0 */ +#line 3388 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3388 + nrange += tp[i] > X_UINT_MAX ; +#line 3388 + } +#line 3388 + /* copy workspace back if necessary */ +#line 3388 + if (realign) { +#line 3388 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT); +#line 3388 + xp = (uint *) *xpp; +#line 3388 + } +#line 3388 + /* update xpp and tp */ +#line 3388 + xp += ni; +#line 3388 + tp += ni; +#line 3388 + *xpp = (void*)xp; +#line 3388 + } +#line 3388 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3388 + +#line 3388 +#else /* not SX */ +#line 3388 + +#line 3388 + char *xp = (char *) *xpp; +#line 3388 + int status = NC_NOERR; +#line 3388 + +#line 3388 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3388 + { +#line 3388 + int lstatus = ncx_put_uint_ushort(xp, tp, fillp); +#line 3388 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3388 + status = lstatus; +#line 3388 + } +#line 3388 + +#line 3388 + *xpp = (void *)xp; +#line 3388 + return status; +#line 3388 +#endif +#line 3388 +} +#line 3388 + +int +#line 3389 +ncx_putn_uint_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3389 +{ +#line 3389 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT == SIZEOF_UINT +#line 3389 + +#line 3389 + /* basic algorithm is: +#line 3389 + * - ensure sane alignment of output data +#line 3389 + * - copy (conversion happens automatically) input data +#line 3389 + * to output +#line 3389 + * - update tp to point at next unconverted input, and xpp to point +#line 3389 + * at next location for converted output +#line 3389 + */ +#line 3389 + long i, j, ni; +#line 3389 + uint tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3389 + uint *xp; +#line 3389 + int nrange = 0; /* number of range errors */ +#line 3389 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3389 + long cxp = (long) *((char**)xpp); +#line 3389 + +#line 3389 + realign = (cxp & 7) % SIZEOF_UINT; +#line 3389 + /* sjl: manually stripmine so we can limit amount of +#line 3389 + * vector work space reserved to LOOPCNT elements. Also +#line 3389 + * makes vectorisation easy */ +#line 3389 + for (j=0; j= 0 */ +#line 3389 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3389 + nrange += tp[i] > X_UINT_MAX ; +#line 3389 + } +#line 3389 + /* copy workspace back if necessary */ +#line 3389 + if (realign) { +#line 3389 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT); +#line 3389 + xp = (uint *) *xpp; +#line 3389 + } +#line 3389 + /* update xpp and tp */ +#line 3389 + xp += ni; +#line 3389 + tp += ni; +#line 3389 + *xpp = (void*)xp; +#line 3389 + } +#line 3389 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3389 + +#line 3389 +#else /* not SX */ +#line 3389 + +#line 3389 + char *xp = (char *) *xpp; +#line 3389 + int status = NC_NOERR; +#line 3389 + +#line 3389 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT, tp++) +#line 3389 + { +#line 3389 + int lstatus = ncx_put_uint_ulonglong(xp, tp, fillp); +#line 3389 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3389 + status = lstatus; +#line 3389 + } +#line 3389 + +#line 3389 + *xpp = (void *)xp; +#line 3389 + return status; +#line 3389 +#endif +#line 3389 +} +#line 3389 + + + +/* float ---------------------------------------------------------------------*/ + +#if X_SIZEOF_FLOAT == SIZEOF_FLOAT && !defined(NO_IEEE_FLOAT) +/* optimized version */ +int +ncx_getn_float_float(const void **xpp, size_t nelems, float *tp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(tp, *xpp, (size_t)nelems * SIZEOF_FLOAT); +# else + swapn4b(tp, *xpp, nelems); +# endif + *xpp = (const void *)((const char *)(*xpp) + nelems * X_SIZEOF_FLOAT); + return NC_NOERR; +} +#elif defined(vax) && vax != 0 +int +ncx_getn_float_float(const void **xpp, size_t nfloats, float *ip) +{ + float *const end = ip + nfloats; + + while (ip < end) + { + struct vax_single *const vsp = (struct vax_single *) ip; +#line 3415 + const struct ieee_single *const isp = +#line 3415 + (const struct ieee_single *) (*xpp); +#line 3415 + unsigned exp = isp->exp_hi << 1 | isp->exp_lo; +#line 3415 + +#line 3415 + switch(exp) { +#line 3415 + case 0 : +#line 3415 + /* ieee subnormal */ +#line 3415 + if (isp->mant_hi == min.ieee.mant_hi +#line 3415 + && isp->mant_lo_hi == min.ieee.mant_lo_hi +#line 3415 + && isp->mant_lo_lo == min.ieee.mant_lo_lo) +#line 3415 + { +#line 3415 + *vsp = min.s; +#line 3415 + } +#line 3415 + else +#line 3415 + { +#line 3415 + unsigned mantissa = (isp->mant_hi << 16) +#line 3415 + | isp->mant_lo_hi << 8 +#line 3415 + | isp->mant_lo_lo; +#line 3415 + unsigned tmp = mantissa >> 20; +#line 3415 + if (tmp >= 4) { +#line 3415 + vsp->exp = 2; +#line 3415 + } else if (tmp >= 2) { +#line 3415 + vsp->exp = 1; +#line 3415 + } else { +#line 3415 + *vsp = min.s; +#line 3415 + break; +#line 3415 + } /* else */ +#line 3415 + tmp = mantissa - (1 << (20 + vsp->exp )); +#line 3415 + tmp <<= 3 - vsp->exp; +#line 3415 + vsp->mantissa2 = tmp; +#line 3415 + vsp->mantissa1 = (tmp >> 16); +#line 3415 + } +#line 3415 + break; +#line 3415 + case 0xfe : +#line 3415 + case 0xff : +#line 3415 + *vsp = max.s; +#line 3415 + break; +#line 3415 + default : +#line 3415 + vsp->exp = exp - IEEE_SNG_BIAS + VAX_SNG_BIAS; +#line 3415 + vsp->mantissa2 = isp->mant_lo_hi << 8 | isp->mant_lo_lo; +#line 3415 + vsp->mantissa1 = isp->mant_hi; +#line 3415 + } +#line 3415 + +#line 3415 + vsp->sign = isp->sign; +#line 3415 + + + ip++; + *xpp = (char *)(*xpp) + X_SIZEOF_FLOAT; + } + return NC_NOERR; +} +#else +int +ncx_getn_float_float(const void **xpp, size_t nelems, float *tp) +{ + const char *xp = *xpp; + int status = NC_NOERR; + + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) + { + const int lstatus = ncx_get_float_float(xp, tp, fillp); + if (status == NC_NOERR) /* report the first encountered error */ + status = lstatus; + } + + *xpp = (const void *)xp; + return status; +} + +#endif +int +#line 3441 +ncx_getn_float_schar(const void **xpp, size_t nelems, schar *tp) +#line 3441 +{ +#line 3441 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3441 + +#line 3441 + /* basic algorithm is: +#line 3441 + * - ensure sane alignment of input data +#line 3441 + * - copy (conversion happens automatically) input data +#line 3441 + * to output +#line 3441 + * - update xpp to point at next unconverted input, and tp to point +#line 3441 + * at next location for converted output +#line 3441 + */ +#line 3441 + long i, j, ni; +#line 3441 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3441 + float *xp; +#line 3441 + int nrange = 0; /* number of range errors */ +#line 3441 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3441 + long cxp = (long) *((char**)xpp); +#line 3441 + +#line 3441 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3441 + /* sjl: manually stripmine so we can limit amount of +#line 3441 + * vector work space reserved to LOOPCNT elements. Also +#line 3441 + * makes vectorisation easy */ +#line 3441 + for (j=0; j= 0 */ +#line 3441 + nrange += xp[i] > SCHAR_MAX || xp[i] < SCHAR_MIN; +#line 3441 + } +#line 3441 + /* update xpp and tp */ +#line 3441 + if (realign) xp = (float *) *xpp; +#line 3441 + xp += ni; +#line 3441 + tp += ni; +#line 3441 + *xpp = (void*)xp; +#line 3441 + } +#line 3441 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3441 + +#line 3441 +#else /* not SX */ +#line 3441 + const char *xp = (const char *) *xpp; +#line 3441 + int status = NC_NOERR; +#line 3441 + +#line 3441 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3441 + { +#line 3441 + const int lstatus = ncx_get_float_schar(xp, tp); +#line 3441 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3441 + status = lstatus; +#line 3441 + } +#line 3441 + +#line 3441 + *xpp = (const void *)xp; +#line 3441 + return status; +#line 3441 +#endif +#line 3441 +} +#line 3441 + +int +#line 3442 +ncx_getn_float_short(const void **xpp, size_t nelems, short *tp) +#line 3442 +{ +#line 3442 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3442 + +#line 3442 + /* basic algorithm is: +#line 3442 + * - ensure sane alignment of input data +#line 3442 + * - copy (conversion happens automatically) input data +#line 3442 + * to output +#line 3442 + * - update xpp to point at next unconverted input, and tp to point +#line 3442 + * at next location for converted output +#line 3442 + */ +#line 3442 + long i, j, ni; +#line 3442 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3442 + float *xp; +#line 3442 + int nrange = 0; /* number of range errors */ +#line 3442 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3442 + long cxp = (long) *((char**)xpp); +#line 3442 + +#line 3442 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3442 + /* sjl: manually stripmine so we can limit amount of +#line 3442 + * vector work space reserved to LOOPCNT elements. Also +#line 3442 + * makes vectorisation easy */ +#line 3442 + for (j=0; j= 0 */ +#line 3442 + nrange += xp[i] > SHORT_MAX || xp[i] < SHORT_MIN; +#line 3442 + } +#line 3442 + /* update xpp and tp */ +#line 3442 + if (realign) xp = (float *) *xpp; +#line 3442 + xp += ni; +#line 3442 + tp += ni; +#line 3442 + *xpp = (void*)xp; +#line 3442 + } +#line 3442 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3442 + +#line 3442 +#else /* not SX */ +#line 3442 + const char *xp = (const char *) *xpp; +#line 3442 + int status = NC_NOERR; +#line 3442 + +#line 3442 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3442 + { +#line 3442 + const int lstatus = ncx_get_float_short(xp, tp); +#line 3442 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3442 + status = lstatus; +#line 3442 + } +#line 3442 + +#line 3442 + *xpp = (const void *)xp; +#line 3442 + return status; +#line 3442 +#endif +#line 3442 +} +#line 3442 + +int +#line 3443 +ncx_getn_float_int(const void **xpp, size_t nelems, int *tp) +#line 3443 +{ +#line 3443 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3443 + +#line 3443 + /* basic algorithm is: +#line 3443 + * - ensure sane alignment of input data +#line 3443 + * - copy (conversion happens automatically) input data +#line 3443 + * to output +#line 3443 + * - update xpp to point at next unconverted input, and tp to point +#line 3443 + * at next location for converted output +#line 3443 + */ +#line 3443 + long i, j, ni; +#line 3443 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3443 + float *xp; +#line 3443 + int nrange = 0; /* number of range errors */ +#line 3443 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3443 + long cxp = (long) *((char**)xpp); +#line 3443 + +#line 3443 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3443 + /* sjl: manually stripmine so we can limit amount of +#line 3443 + * vector work space reserved to LOOPCNT elements. Also +#line 3443 + * makes vectorisation easy */ +#line 3443 + for (j=0; j= 0 */ +#line 3443 + nrange += xp[i] > INT_MAX || xp[i] < INT_MIN; +#line 3443 + } +#line 3443 + /* update xpp and tp */ +#line 3443 + if (realign) xp = (float *) *xpp; +#line 3443 + xp += ni; +#line 3443 + tp += ni; +#line 3443 + *xpp = (void*)xp; +#line 3443 + } +#line 3443 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3443 + +#line 3443 +#else /* not SX */ +#line 3443 + const char *xp = (const char *) *xpp; +#line 3443 + int status = NC_NOERR; +#line 3443 + +#line 3443 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3443 + { +#line 3443 + const int lstatus = ncx_get_float_int(xp, tp); +#line 3443 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3443 + status = lstatus; +#line 3443 + } +#line 3443 + +#line 3443 + *xpp = (const void *)xp; +#line 3443 + return status; +#line 3443 +#endif +#line 3443 +} +#line 3443 + +int +#line 3444 +ncx_getn_float_long(const void **xpp, size_t nelems, long *tp) +#line 3444 +{ +#line 3444 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3444 + +#line 3444 + /* basic algorithm is: +#line 3444 + * - ensure sane alignment of input data +#line 3444 + * - copy (conversion happens automatically) input data +#line 3444 + * to output +#line 3444 + * - update xpp to point at next unconverted input, and tp to point +#line 3444 + * at next location for converted output +#line 3444 + */ +#line 3444 + long i, j, ni; +#line 3444 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3444 + float *xp; +#line 3444 + int nrange = 0; /* number of range errors */ +#line 3444 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3444 + long cxp = (long) *((char**)xpp); +#line 3444 + +#line 3444 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3444 + /* sjl: manually stripmine so we can limit amount of +#line 3444 + * vector work space reserved to LOOPCNT elements. Also +#line 3444 + * makes vectorisation easy */ +#line 3444 + for (j=0; j= 0 */ +#line 3444 + nrange += xp[i] > LONG_MAX || xp[i] < LONG_MIN; +#line 3444 + } +#line 3444 + /* update xpp and tp */ +#line 3444 + if (realign) xp = (float *) *xpp; +#line 3444 + xp += ni; +#line 3444 + tp += ni; +#line 3444 + *xpp = (void*)xp; +#line 3444 + } +#line 3444 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3444 + +#line 3444 +#else /* not SX */ +#line 3444 + const char *xp = (const char *) *xpp; +#line 3444 + int status = NC_NOERR; +#line 3444 + +#line 3444 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3444 + { +#line 3444 + const int lstatus = ncx_get_float_long(xp, tp); +#line 3444 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3444 + status = lstatus; +#line 3444 + } +#line 3444 + +#line 3444 + *xpp = (const void *)xp; +#line 3444 + return status; +#line 3444 +#endif +#line 3444 +} +#line 3444 + +int +#line 3445 +ncx_getn_float_double(const void **xpp, size_t nelems, double *tp) +#line 3445 +{ +#line 3445 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3445 + +#line 3445 + /* basic algorithm is: +#line 3445 + * - ensure sane alignment of input data +#line 3445 + * - copy (conversion happens automatically) input data +#line 3445 + * to output +#line 3445 + * - update xpp to point at next unconverted input, and tp to point +#line 3445 + * at next location for converted output +#line 3445 + */ +#line 3445 + long i, j, ni; +#line 3445 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3445 + float *xp; +#line 3445 + int nrange = 0; /* number of range errors */ +#line 3445 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3445 + long cxp = (long) *((char**)xpp); +#line 3445 + +#line 3445 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3445 + /* sjl: manually stripmine so we can limit amount of +#line 3445 + * vector work space reserved to LOOPCNT elements. Also +#line 3445 + * makes vectorisation easy */ +#line 3445 + for (j=0; j= 0 */ +#line 3445 + nrange += xp[i] > DOUBLE_MAX || xp[i] < DOUBLE_MIN; +#line 3445 + } +#line 3445 + /* update xpp and tp */ +#line 3445 + if (realign) xp = (float *) *xpp; +#line 3445 + xp += ni; +#line 3445 + tp += ni; +#line 3445 + *xpp = (void*)xp; +#line 3445 + } +#line 3445 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3445 + +#line 3445 +#else /* not SX */ +#line 3445 + const char *xp = (const char *) *xpp; +#line 3445 + int status = NC_NOERR; +#line 3445 + +#line 3445 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3445 + { +#line 3445 + const int lstatus = ncx_get_float_double(xp, tp); +#line 3445 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3445 + status = lstatus; +#line 3445 + } +#line 3445 + +#line 3445 + *xpp = (const void *)xp; +#line 3445 + return status; +#line 3445 +#endif +#line 3445 +} +#line 3445 + +int +#line 3446 +ncx_getn_float_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 3446 +{ +#line 3446 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3446 + +#line 3446 + /* basic algorithm is: +#line 3446 + * - ensure sane alignment of input data +#line 3446 + * - copy (conversion happens automatically) input data +#line 3446 + * to output +#line 3446 + * - update xpp to point at next unconverted input, and tp to point +#line 3446 + * at next location for converted output +#line 3446 + */ +#line 3446 + long i, j, ni; +#line 3446 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3446 + float *xp; +#line 3446 + int nrange = 0; /* number of range errors */ +#line 3446 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3446 + long cxp = (long) *((char**)xpp); +#line 3446 + +#line 3446 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3446 + /* sjl: manually stripmine so we can limit amount of +#line 3446 + * vector work space reserved to LOOPCNT elements. Also +#line 3446 + * makes vectorisation easy */ +#line 3446 + for (j=0; j= 0 */ +#line 3446 + nrange += xp[i] > LONGLONG_MAX || xp[i] < LONGLONG_MIN; +#line 3446 + } +#line 3446 + /* update xpp and tp */ +#line 3446 + if (realign) xp = (float *) *xpp; +#line 3446 + xp += ni; +#line 3446 + tp += ni; +#line 3446 + *xpp = (void*)xp; +#line 3446 + } +#line 3446 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3446 + +#line 3446 +#else /* not SX */ +#line 3446 + const char *xp = (const char *) *xpp; +#line 3446 + int status = NC_NOERR; +#line 3446 + +#line 3446 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3446 + { +#line 3446 + const int lstatus = ncx_get_float_longlong(xp, tp); +#line 3446 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3446 + status = lstatus; +#line 3446 + } +#line 3446 + +#line 3446 + *xpp = (const void *)xp; +#line 3446 + return status; +#line 3446 +#endif +#line 3446 +} +#line 3446 + +int +#line 3447 +ncx_getn_float_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 3447 +{ +#line 3447 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3447 + +#line 3447 + /* basic algorithm is: +#line 3447 + * - ensure sane alignment of input data +#line 3447 + * - copy (conversion happens automatically) input data +#line 3447 + * to output +#line 3447 + * - update xpp to point at next unconverted input, and tp to point +#line 3447 + * at next location for converted output +#line 3447 + */ +#line 3447 + long i, j, ni; +#line 3447 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3447 + float *xp; +#line 3447 + int nrange = 0; /* number of range errors */ +#line 3447 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3447 + long cxp = (long) *((char**)xpp); +#line 3447 + +#line 3447 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3447 + /* sjl: manually stripmine so we can limit amount of +#line 3447 + * vector work space reserved to LOOPCNT elements. Also +#line 3447 + * makes vectorisation easy */ +#line 3447 + for (j=0; j= 0 */ +#line 3447 + nrange += xp[i] > USHORT_MAX || xp[i] < 0; +#line 3447 + } +#line 3447 + /* update xpp and tp */ +#line 3447 + if (realign) xp = (float *) *xpp; +#line 3447 + xp += ni; +#line 3447 + tp += ni; +#line 3447 + *xpp = (void*)xp; +#line 3447 + } +#line 3447 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3447 + +#line 3447 +#else /* not SX */ +#line 3447 + const char *xp = (const char *) *xpp; +#line 3447 + int status = NC_NOERR; +#line 3447 + +#line 3447 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3447 + { +#line 3447 + const int lstatus = ncx_get_float_ushort(xp, tp); +#line 3447 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3447 + status = lstatus; +#line 3447 + } +#line 3447 + +#line 3447 + *xpp = (const void *)xp; +#line 3447 + return status; +#line 3447 +#endif +#line 3447 +} +#line 3447 + +int +#line 3448 +ncx_getn_float_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 3448 +{ +#line 3448 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3448 + +#line 3448 + /* basic algorithm is: +#line 3448 + * - ensure sane alignment of input data +#line 3448 + * - copy (conversion happens automatically) input data +#line 3448 + * to output +#line 3448 + * - update xpp to point at next unconverted input, and tp to point +#line 3448 + * at next location for converted output +#line 3448 + */ +#line 3448 + long i, j, ni; +#line 3448 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3448 + float *xp; +#line 3448 + int nrange = 0; /* number of range errors */ +#line 3448 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3448 + long cxp = (long) *((char**)xpp); +#line 3448 + +#line 3448 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3448 + /* sjl: manually stripmine so we can limit amount of +#line 3448 + * vector work space reserved to LOOPCNT elements. Also +#line 3448 + * makes vectorisation easy */ +#line 3448 + for (j=0; j= 0 */ +#line 3448 + nrange += xp[i] > UCHAR_MAX || xp[i] < 0; +#line 3448 + } +#line 3448 + /* update xpp and tp */ +#line 3448 + if (realign) xp = (float *) *xpp; +#line 3448 + xp += ni; +#line 3448 + tp += ni; +#line 3448 + *xpp = (void*)xp; +#line 3448 + } +#line 3448 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3448 + +#line 3448 +#else /* not SX */ +#line 3448 + const char *xp = (const char *) *xpp; +#line 3448 + int status = NC_NOERR; +#line 3448 + +#line 3448 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3448 + { +#line 3448 + const int lstatus = ncx_get_float_uchar(xp, tp); +#line 3448 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3448 + status = lstatus; +#line 3448 + } +#line 3448 + +#line 3448 + *xpp = (const void *)xp; +#line 3448 + return status; +#line 3448 +#endif +#line 3448 +} +#line 3448 + +int +#line 3449 +ncx_getn_float_uint(const void **xpp, size_t nelems, uint *tp) +#line 3449 +{ +#line 3449 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3449 + +#line 3449 + /* basic algorithm is: +#line 3449 + * - ensure sane alignment of input data +#line 3449 + * - copy (conversion happens automatically) input data +#line 3449 + * to output +#line 3449 + * - update xpp to point at next unconverted input, and tp to point +#line 3449 + * at next location for converted output +#line 3449 + */ +#line 3449 + long i, j, ni; +#line 3449 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3449 + float *xp; +#line 3449 + int nrange = 0; /* number of range errors */ +#line 3449 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3449 + long cxp = (long) *((char**)xpp); +#line 3449 + +#line 3449 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3449 + /* sjl: manually stripmine so we can limit amount of +#line 3449 + * vector work space reserved to LOOPCNT elements. Also +#line 3449 + * makes vectorisation easy */ +#line 3449 + for (j=0; j= 0 */ +#line 3449 + nrange += xp[i] > UINT_MAX || xp[i] < 0; +#line 3449 + } +#line 3449 + /* update xpp and tp */ +#line 3449 + if (realign) xp = (float *) *xpp; +#line 3449 + xp += ni; +#line 3449 + tp += ni; +#line 3449 + *xpp = (void*)xp; +#line 3449 + } +#line 3449 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3449 + +#line 3449 +#else /* not SX */ +#line 3449 + const char *xp = (const char *) *xpp; +#line 3449 + int status = NC_NOERR; +#line 3449 + +#line 3449 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3449 + { +#line 3449 + const int lstatus = ncx_get_float_uint(xp, tp); +#line 3449 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3449 + status = lstatus; +#line 3449 + } +#line 3449 + +#line 3449 + *xpp = (const void *)xp; +#line 3449 + return status; +#line 3449 +#endif +#line 3449 +} +#line 3449 + +int +#line 3450 +ncx_getn_float_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 3450 +{ +#line 3450 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3450 + +#line 3450 + /* basic algorithm is: +#line 3450 + * - ensure sane alignment of input data +#line 3450 + * - copy (conversion happens automatically) input data +#line 3450 + * to output +#line 3450 + * - update xpp to point at next unconverted input, and tp to point +#line 3450 + * at next location for converted output +#line 3450 + */ +#line 3450 + long i, j, ni; +#line 3450 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3450 + float *xp; +#line 3450 + int nrange = 0; /* number of range errors */ +#line 3450 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3450 + long cxp = (long) *((char**)xpp); +#line 3450 + +#line 3450 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3450 + /* sjl: manually stripmine so we can limit amount of +#line 3450 + * vector work space reserved to LOOPCNT elements. Also +#line 3450 + * makes vectorisation easy */ +#line 3450 + for (j=0; j= 0 */ +#line 3450 + nrange += xp[i] > ULONGLONG_MAX || xp[i] < 0; +#line 3450 + } +#line 3450 + /* update xpp and tp */ +#line 3450 + if (realign) xp = (float *) *xpp; +#line 3450 + xp += ni; +#line 3450 + tp += ni; +#line 3450 + *xpp = (void*)xp; +#line 3450 + } +#line 3450 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3450 + +#line 3450 +#else /* not SX */ +#line 3450 + const char *xp = (const char *) *xpp; +#line 3450 + int status = NC_NOERR; +#line 3450 + +#line 3450 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3450 + { +#line 3450 + const int lstatus = ncx_get_float_ulonglong(xp, tp); +#line 3450 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3450 + status = lstatus; +#line 3450 + } +#line 3450 + +#line 3450 + *xpp = (const void *)xp; +#line 3450 + return status; +#line 3450 +#endif +#line 3450 +} +#line 3450 + + +int +ncx_putn_float_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#if X_SIZEOF_FLOAT == SIZEOF_FLOAT && !defined(NO_IEEE_FLOAT) +/* optimized version */ +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(*xpp, tp, (size_t)nelems * X_SIZEOF_FLOAT); +# else + swapn4b(*xpp, tp, nelems); +# endif + *xpp = (void *)((char *)(*xpp) + nelems * X_SIZEOF_FLOAT); + return NC_NOERR; +} +#elif defined(vax) && vax != 0 +{ + const float *const end = tp + nelems; + + while (tp < end) { + const struct vax_single *const vsp = +#line 3470 + (const struct vax_single *)ip; +#line 3470 + struct ieee_single *const isp = (struct ieee_single *) (*xpp); +#line 3470 + +#line 3470 + switch(vsp->exp){ +#line 3470 + case 0 : +#line 3470 + /* all vax float with zero exponent map to zero */ +#line 3470 + *isp = min.ieee; +#line 3470 + break; +#line 3470 + case 2 : +#line 3470 + case 1 : +#line 3470 + { +#line 3470 + /* These will map to subnormals */ +#line 3470 + unsigned mantissa = (vsp->mantissa1 << 16) +#line 3470 + | vsp->mantissa2; +#line 3470 + mantissa >>= 3 - vsp->exp; +#line 3470 + mantissa += (1 << (20 + vsp->exp)); +#line 3470 + isp->mant_lo_lo = mantissa; +#line 3470 + isp->mant_lo_hi = mantissa >> 8; +#line 3470 + isp->mant_hi = mantissa >> 16; +#line 3470 + isp->exp_lo = 0; +#line 3470 + isp->exp_hi = 0; +#line 3470 + } +#line 3470 + break; +#line 3470 + case 0xff : /* max.s.exp */ +#line 3470 + if (vsp->mantissa2 == max.s.mantissa2 && +#line 3470 + vsp->mantissa1 == max.s.mantissa1) +#line 3470 + { +#line 3470 + /* map largest vax float to ieee infinity */ +#line 3470 + *isp = max.ieee; +#line 3470 + break; +#line 3470 + } /* else, fall thru */ +#line 3470 + default : +#line 3470 + { +#line 3470 + unsigned exp = vsp->exp - VAX_SNG_BIAS + IEEE_SNG_BIAS; +#line 3470 + isp->exp_hi = exp >> 1; +#line 3470 + isp->exp_lo = exp; +#line 3470 + isp->mant_lo_lo = vsp->mantissa2; +#line 3470 + isp->mant_lo_hi = vsp->mantissa2 >> 8; +#line 3470 + isp->mant_hi = vsp->mantissa1; +#line 3470 + } +#line 3470 + } +#line 3470 + +#line 3470 + isp->sign = vsp->sign; +#line 3470 + + tp++; + *xpp = (char *)(*xpp) + X_SIZEOF_FLOAT; + } + return NC_NOERR; +} +#else +{ + char *xp = *xpp; + int status = NC_NOERR; + + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) { + int lstatus = ncx_put_float_float(xp, tp, fillp); + if (status == NC_NOERR) /* report the first encountered error */ + status = lstatus; + } + + *xpp = (void *)xp; + return status; +} +#endif +int +#line 3491 +ncx_putn_float_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +#line 3491 +{ +#line 3491 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3491 + +#line 3491 + /* basic algorithm is: +#line 3491 + * - ensure sane alignment of output data +#line 3491 + * - copy (conversion happens automatically) input data +#line 3491 + * to output +#line 3491 + * - update tp to point at next unconverted input, and xpp to point +#line 3491 + * at next location for converted output +#line 3491 + */ +#line 3491 + long i, j, ni; +#line 3491 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3491 + float *xp; +#line 3491 + int nrange = 0; /* number of range errors */ +#line 3491 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3491 + long cxp = (long) *((char**)xpp); +#line 3491 + +#line 3491 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3491 + /* sjl: manually stripmine so we can limit amount of +#line 3491 + * vector work space reserved to LOOPCNT elements. Also +#line 3491 + * makes vectorisation easy */ +#line 3491 + for (j=0; j= 0 */ +#line 3491 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3491 + nrange += tp[i] > X_FLOAT_MAX || tp[i] < X_FLOAT_MIN; +#line 3491 + } +#line 3491 + /* copy workspace back if necessary */ +#line 3491 + if (realign) { +#line 3491 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_FLOAT); +#line 3491 + xp = (float *) *xpp; +#line 3491 + } +#line 3491 + /* update xpp and tp */ +#line 3491 + xp += ni; +#line 3491 + tp += ni; +#line 3491 + *xpp = (void*)xp; +#line 3491 + } +#line 3491 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3491 + +#line 3491 +#else /* not SX */ +#line 3491 + +#line 3491 + char *xp = (char *) *xpp; +#line 3491 + int status = NC_NOERR; +#line 3491 + +#line 3491 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3491 + { +#line 3491 + int lstatus = ncx_put_float_schar(xp, tp, fillp); +#line 3491 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3491 + status = lstatus; +#line 3491 + } +#line 3491 + +#line 3491 + *xpp = (void *)xp; +#line 3491 + return status; +#line 3491 +#endif +#line 3491 +} +#line 3491 + +int +#line 3492 +ncx_putn_float_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3492 +{ +#line 3492 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3492 + +#line 3492 + /* basic algorithm is: +#line 3492 + * - ensure sane alignment of output data +#line 3492 + * - copy (conversion happens automatically) input data +#line 3492 + * to output +#line 3492 + * - update tp to point at next unconverted input, and xpp to point +#line 3492 + * at next location for converted output +#line 3492 + */ +#line 3492 + long i, j, ni; +#line 3492 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3492 + float *xp; +#line 3492 + int nrange = 0; /* number of range errors */ +#line 3492 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3492 + long cxp = (long) *((char**)xpp); +#line 3492 + +#line 3492 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3492 + /* sjl: manually stripmine so we can limit amount of +#line 3492 + * vector work space reserved to LOOPCNT elements. Also +#line 3492 + * makes vectorisation easy */ +#line 3492 + for (j=0; j= 0 */ +#line 3492 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3492 + nrange += tp[i] > X_FLOAT_MAX || tp[i] < X_FLOAT_MIN; +#line 3492 + } +#line 3492 + /* copy workspace back if necessary */ +#line 3492 + if (realign) { +#line 3492 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_FLOAT); +#line 3492 + xp = (float *) *xpp; +#line 3492 + } +#line 3492 + /* update xpp and tp */ +#line 3492 + xp += ni; +#line 3492 + tp += ni; +#line 3492 + *xpp = (void*)xp; +#line 3492 + } +#line 3492 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3492 + +#line 3492 +#else /* not SX */ +#line 3492 + +#line 3492 + char *xp = (char *) *xpp; +#line 3492 + int status = NC_NOERR; +#line 3492 + +#line 3492 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3492 + { +#line 3492 + int lstatus = ncx_put_float_short(xp, tp, fillp); +#line 3492 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3492 + status = lstatus; +#line 3492 + } +#line 3492 + +#line 3492 + *xpp = (void *)xp; +#line 3492 + return status; +#line 3492 +#endif +#line 3492 +} +#line 3492 + +int +#line 3493 +ncx_putn_float_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3493 +{ +#line 3493 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3493 + +#line 3493 + /* basic algorithm is: +#line 3493 + * - ensure sane alignment of output data +#line 3493 + * - copy (conversion happens automatically) input data +#line 3493 + * to output +#line 3493 + * - update tp to point at next unconverted input, and xpp to point +#line 3493 + * at next location for converted output +#line 3493 + */ +#line 3493 + long i, j, ni; +#line 3493 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3493 + float *xp; +#line 3493 + int nrange = 0; /* number of range errors */ +#line 3493 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3493 + long cxp = (long) *((char**)xpp); +#line 3493 + +#line 3493 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3493 + /* sjl: manually stripmine so we can limit amount of +#line 3493 + * vector work space reserved to LOOPCNT elements. Also +#line 3493 + * makes vectorisation easy */ +#line 3493 + for (j=0; j= 0 */ +#line 3493 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3493 + nrange += tp[i] > X_FLOAT_MAX || tp[i] < X_FLOAT_MIN; +#line 3493 + } +#line 3493 + /* copy workspace back if necessary */ +#line 3493 + if (realign) { +#line 3493 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_FLOAT); +#line 3493 + xp = (float *) *xpp; +#line 3493 + } +#line 3493 + /* update xpp and tp */ +#line 3493 + xp += ni; +#line 3493 + tp += ni; +#line 3493 + *xpp = (void*)xp; +#line 3493 + } +#line 3493 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3493 + +#line 3493 +#else /* not SX */ +#line 3493 + +#line 3493 + char *xp = (char *) *xpp; +#line 3493 + int status = NC_NOERR; +#line 3493 + +#line 3493 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3493 + { +#line 3493 + int lstatus = ncx_put_float_int(xp, tp, fillp); +#line 3493 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3493 + status = lstatus; +#line 3493 + } +#line 3493 + +#line 3493 + *xpp = (void *)xp; +#line 3493 + return status; +#line 3493 +#endif +#line 3493 +} +#line 3493 + +int +#line 3494 +ncx_putn_float_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3494 +{ +#line 3494 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3494 + +#line 3494 + /* basic algorithm is: +#line 3494 + * - ensure sane alignment of output data +#line 3494 + * - copy (conversion happens automatically) input data +#line 3494 + * to output +#line 3494 + * - update tp to point at next unconverted input, and xpp to point +#line 3494 + * at next location for converted output +#line 3494 + */ +#line 3494 + long i, j, ni; +#line 3494 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3494 + float *xp; +#line 3494 + int nrange = 0; /* number of range errors */ +#line 3494 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3494 + long cxp = (long) *((char**)xpp); +#line 3494 + +#line 3494 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3494 + /* sjl: manually stripmine so we can limit amount of +#line 3494 + * vector work space reserved to LOOPCNT elements. Also +#line 3494 + * makes vectorisation easy */ +#line 3494 + for (j=0; j= 0 */ +#line 3494 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3494 + nrange += tp[i] > X_FLOAT_MAX || tp[i] < X_FLOAT_MIN; +#line 3494 + } +#line 3494 + /* copy workspace back if necessary */ +#line 3494 + if (realign) { +#line 3494 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_FLOAT); +#line 3494 + xp = (float *) *xpp; +#line 3494 + } +#line 3494 + /* update xpp and tp */ +#line 3494 + xp += ni; +#line 3494 + tp += ni; +#line 3494 + *xpp = (void*)xp; +#line 3494 + } +#line 3494 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3494 + +#line 3494 +#else /* not SX */ +#line 3494 + +#line 3494 + char *xp = (char *) *xpp; +#line 3494 + int status = NC_NOERR; +#line 3494 + +#line 3494 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3494 + { +#line 3494 + int lstatus = ncx_put_float_long(xp, tp, fillp); +#line 3494 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3494 + status = lstatus; +#line 3494 + } +#line 3494 + +#line 3494 + *xpp = (void *)xp; +#line 3494 + return status; +#line 3494 +#endif +#line 3494 +} +#line 3494 + +int +#line 3495 +ncx_putn_float_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 3495 +{ +#line 3495 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3495 + +#line 3495 + /* basic algorithm is: +#line 3495 + * - ensure sane alignment of output data +#line 3495 + * - copy (conversion happens automatically) input data +#line 3495 + * to output +#line 3495 + * - update tp to point at next unconverted input, and xpp to point +#line 3495 + * at next location for converted output +#line 3495 + */ +#line 3495 + long i, j, ni; +#line 3495 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3495 + float *xp; +#line 3495 + int nrange = 0; /* number of range errors */ +#line 3495 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3495 + long cxp = (long) *((char**)xpp); +#line 3495 + +#line 3495 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3495 + /* sjl: manually stripmine so we can limit amount of +#line 3495 + * vector work space reserved to LOOPCNT elements. Also +#line 3495 + * makes vectorisation easy */ +#line 3495 + for (j=0; j= 0 */ +#line 3495 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3495 + nrange += tp[i] > X_FLOAT_MAX || tp[i] < X_FLOAT_MIN; +#line 3495 + } +#line 3495 + /* copy workspace back if necessary */ +#line 3495 + if (realign) { +#line 3495 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_FLOAT); +#line 3495 + xp = (float *) *xpp; +#line 3495 + } +#line 3495 + /* update xpp and tp */ +#line 3495 + xp += ni; +#line 3495 + tp += ni; +#line 3495 + *xpp = (void*)xp; +#line 3495 + } +#line 3495 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3495 + +#line 3495 +#else /* not SX */ +#line 3495 + +#line 3495 + char *xp = (char *) *xpp; +#line 3495 + int status = NC_NOERR; +#line 3495 + +#line 3495 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3495 + { +#line 3495 + int lstatus = ncx_put_float_double(xp, tp, fillp); +#line 3495 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3495 + status = lstatus; +#line 3495 + } +#line 3495 + +#line 3495 + *xpp = (void *)xp; +#line 3495 + return status; +#line 3495 +#endif +#line 3495 +} +#line 3495 + +int +#line 3496 +ncx_putn_float_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3496 +{ +#line 3496 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3496 + +#line 3496 + /* basic algorithm is: +#line 3496 + * - ensure sane alignment of output data +#line 3496 + * - copy (conversion happens automatically) input data +#line 3496 + * to output +#line 3496 + * - update tp to point at next unconverted input, and xpp to point +#line 3496 + * at next location for converted output +#line 3496 + */ +#line 3496 + long i, j, ni; +#line 3496 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3496 + float *xp; +#line 3496 + int nrange = 0; /* number of range errors */ +#line 3496 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3496 + long cxp = (long) *((char**)xpp); +#line 3496 + +#line 3496 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3496 + /* sjl: manually stripmine so we can limit amount of +#line 3496 + * vector work space reserved to LOOPCNT elements. Also +#line 3496 + * makes vectorisation easy */ +#line 3496 + for (j=0; j= 0 */ +#line 3496 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3496 + nrange += tp[i] > X_FLOAT_MAX || tp[i] < X_FLOAT_MIN; +#line 3496 + } +#line 3496 + /* copy workspace back if necessary */ +#line 3496 + if (realign) { +#line 3496 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_FLOAT); +#line 3496 + xp = (float *) *xpp; +#line 3496 + } +#line 3496 + /* update xpp and tp */ +#line 3496 + xp += ni; +#line 3496 + tp += ni; +#line 3496 + *xpp = (void*)xp; +#line 3496 + } +#line 3496 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3496 + +#line 3496 +#else /* not SX */ +#line 3496 + +#line 3496 + char *xp = (char *) *xpp; +#line 3496 + int status = NC_NOERR; +#line 3496 + +#line 3496 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3496 + { +#line 3496 + int lstatus = ncx_put_float_longlong(xp, tp, fillp); +#line 3496 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3496 + status = lstatus; +#line 3496 + } +#line 3496 + +#line 3496 + *xpp = (void *)xp; +#line 3496 + return status; +#line 3496 +#endif +#line 3496 +} +#line 3496 + +int +#line 3497 +ncx_putn_float_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 3497 +{ +#line 3497 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3497 + +#line 3497 + /* basic algorithm is: +#line 3497 + * - ensure sane alignment of output data +#line 3497 + * - copy (conversion happens automatically) input data +#line 3497 + * to output +#line 3497 + * - update tp to point at next unconverted input, and xpp to point +#line 3497 + * at next location for converted output +#line 3497 + */ +#line 3497 + long i, j, ni; +#line 3497 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3497 + float *xp; +#line 3497 + int nrange = 0; /* number of range errors */ +#line 3497 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3497 + long cxp = (long) *((char**)xpp); +#line 3497 + +#line 3497 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3497 + /* sjl: manually stripmine so we can limit amount of +#line 3497 + * vector work space reserved to LOOPCNT elements. Also +#line 3497 + * makes vectorisation easy */ +#line 3497 + for (j=0; j= 0 */ +#line 3497 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3497 + nrange += tp[i] > X_FLOAT_MAX ; +#line 3497 + } +#line 3497 + /* copy workspace back if necessary */ +#line 3497 + if (realign) { +#line 3497 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_FLOAT); +#line 3497 + xp = (float *) *xpp; +#line 3497 + } +#line 3497 + /* update xpp and tp */ +#line 3497 + xp += ni; +#line 3497 + tp += ni; +#line 3497 + *xpp = (void*)xp; +#line 3497 + } +#line 3497 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3497 + +#line 3497 +#else /* not SX */ +#line 3497 + +#line 3497 + char *xp = (char *) *xpp; +#line 3497 + int status = NC_NOERR; +#line 3497 + +#line 3497 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3497 + { +#line 3497 + int lstatus = ncx_put_float_uchar(xp, tp, fillp); +#line 3497 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3497 + status = lstatus; +#line 3497 + } +#line 3497 + +#line 3497 + *xpp = (void *)xp; +#line 3497 + return status; +#line 3497 +#endif +#line 3497 +} +#line 3497 + +int +#line 3498 +ncx_putn_float_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3498 +{ +#line 3498 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3498 + +#line 3498 + /* basic algorithm is: +#line 3498 + * - ensure sane alignment of output data +#line 3498 + * - copy (conversion happens automatically) input data +#line 3498 + * to output +#line 3498 + * - update tp to point at next unconverted input, and xpp to point +#line 3498 + * at next location for converted output +#line 3498 + */ +#line 3498 + long i, j, ni; +#line 3498 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3498 + float *xp; +#line 3498 + int nrange = 0; /* number of range errors */ +#line 3498 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3498 + long cxp = (long) *((char**)xpp); +#line 3498 + +#line 3498 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3498 + /* sjl: manually stripmine so we can limit amount of +#line 3498 + * vector work space reserved to LOOPCNT elements. Also +#line 3498 + * makes vectorisation easy */ +#line 3498 + for (j=0; j= 0 */ +#line 3498 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3498 + nrange += tp[i] > X_FLOAT_MAX ; +#line 3498 + } +#line 3498 + /* copy workspace back if necessary */ +#line 3498 + if (realign) { +#line 3498 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_FLOAT); +#line 3498 + xp = (float *) *xpp; +#line 3498 + } +#line 3498 + /* update xpp and tp */ +#line 3498 + xp += ni; +#line 3498 + tp += ni; +#line 3498 + *xpp = (void*)xp; +#line 3498 + } +#line 3498 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3498 + +#line 3498 +#else /* not SX */ +#line 3498 + +#line 3498 + char *xp = (char *) *xpp; +#line 3498 + int status = NC_NOERR; +#line 3498 + +#line 3498 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3498 + { +#line 3498 + int lstatus = ncx_put_float_ushort(xp, tp, fillp); +#line 3498 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3498 + status = lstatus; +#line 3498 + } +#line 3498 + +#line 3498 + *xpp = (void *)xp; +#line 3498 + return status; +#line 3498 +#endif +#line 3498 +} +#line 3498 + +int +#line 3499 +ncx_putn_float_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3499 +{ +#line 3499 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3499 + +#line 3499 + /* basic algorithm is: +#line 3499 + * - ensure sane alignment of output data +#line 3499 + * - copy (conversion happens automatically) input data +#line 3499 + * to output +#line 3499 + * - update tp to point at next unconverted input, and xpp to point +#line 3499 + * at next location for converted output +#line 3499 + */ +#line 3499 + long i, j, ni; +#line 3499 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3499 + float *xp; +#line 3499 + int nrange = 0; /* number of range errors */ +#line 3499 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3499 + long cxp = (long) *((char**)xpp); +#line 3499 + +#line 3499 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3499 + /* sjl: manually stripmine so we can limit amount of +#line 3499 + * vector work space reserved to LOOPCNT elements. Also +#line 3499 + * makes vectorisation easy */ +#line 3499 + for (j=0; j= 0 */ +#line 3499 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3499 + nrange += tp[i] > X_FLOAT_MAX ; +#line 3499 + } +#line 3499 + /* copy workspace back if necessary */ +#line 3499 + if (realign) { +#line 3499 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_FLOAT); +#line 3499 + xp = (float *) *xpp; +#line 3499 + } +#line 3499 + /* update xpp and tp */ +#line 3499 + xp += ni; +#line 3499 + tp += ni; +#line 3499 + *xpp = (void*)xp; +#line 3499 + } +#line 3499 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3499 + +#line 3499 +#else /* not SX */ +#line 3499 + +#line 3499 + char *xp = (char *) *xpp; +#line 3499 + int status = NC_NOERR; +#line 3499 + +#line 3499 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3499 + { +#line 3499 + int lstatus = ncx_put_float_uint(xp, tp, fillp); +#line 3499 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3499 + status = lstatus; +#line 3499 + } +#line 3499 + +#line 3499 + *xpp = (void *)xp; +#line 3499 + return status; +#line 3499 +#endif +#line 3499 +} +#line 3499 + +int +#line 3500 +ncx_putn_float_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3500 +{ +#line 3500 +#if defined(_SX) && _SX != 0 && X_SIZEOF_FLOAT == SIZEOF_FLOAT +#line 3500 + +#line 3500 + /* basic algorithm is: +#line 3500 + * - ensure sane alignment of output data +#line 3500 + * - copy (conversion happens automatically) input data +#line 3500 + * to output +#line 3500 + * - update tp to point at next unconverted input, and xpp to point +#line 3500 + * at next location for converted output +#line 3500 + */ +#line 3500 + long i, j, ni; +#line 3500 + float tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3500 + float *xp; +#line 3500 + int nrange = 0; /* number of range errors */ +#line 3500 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3500 + long cxp = (long) *((char**)xpp); +#line 3500 + +#line 3500 + realign = (cxp & 7) % SIZEOF_FLOAT; +#line 3500 + /* sjl: manually stripmine so we can limit amount of +#line 3500 + * vector work space reserved to LOOPCNT elements. Also +#line 3500 + * makes vectorisation easy */ +#line 3500 + for (j=0; j= 0 */ +#line 3500 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3500 + nrange += tp[i] > X_FLOAT_MAX ; +#line 3500 + } +#line 3500 + /* copy workspace back if necessary */ +#line 3500 + if (realign) { +#line 3500 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_FLOAT); +#line 3500 + xp = (float *) *xpp; +#line 3500 + } +#line 3500 + /* update xpp and tp */ +#line 3500 + xp += ni; +#line 3500 + tp += ni; +#line 3500 + *xpp = (void*)xp; +#line 3500 + } +#line 3500 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3500 + +#line 3500 +#else /* not SX */ +#line 3500 + +#line 3500 + char *xp = (char *) *xpp; +#line 3500 + int status = NC_NOERR; +#line 3500 + +#line 3500 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_FLOAT, tp++) +#line 3500 + { +#line 3500 + int lstatus = ncx_put_float_ulonglong(xp, tp, fillp); +#line 3500 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3500 + status = lstatus; +#line 3500 + } +#line 3500 + +#line 3500 + *xpp = (void *)xp; +#line 3500 + return status; +#line 3500 +#endif +#line 3500 +} +#line 3500 + + +/* double --------------------------------------------------------------------*/ + +#if X_SIZEOF_DOUBLE == SIZEOF_DOUBLE && !defined(NO_IEEE_FLOAT) +/* optimized version */ +int +ncx_getn_double_double(const void **xpp, size_t nelems, double *tp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(tp, *xpp, (size_t)nelems * SIZEOF_DOUBLE); +# else + swapn8b(tp, *xpp, nelems); +# endif + *xpp = (const void *)((const char *)(*xpp) + nelems * X_SIZEOF_DOUBLE); + return NC_NOERR; +} +#elif defined(vax) && vax != 0 +int +ncx_getn_double_double(const void **xpp, size_t ndoubles, double *ip) +{ + double *const end = ip + ndoubles; + + while (ip < end) + { + struct vax_double *const vdp = +#line 3525 + (struct vax_double *)ip; +#line 3525 + const struct ieee_double *const idp = +#line 3525 + (const struct ieee_double *) (*xpp); +#line 3525 + { +#line 3525 + const struct dbl_limits *lim; +#line 3525 + int ii; +#line 3525 + for (ii = 0, lim = dbl_limits; +#line 3525 + ii < sizeof(dbl_limits)/sizeof(struct dbl_limits); +#line 3525 + ii++, lim++) +#line 3525 + { +#line 3525 + if ((idp->mant_lo == lim->ieee.mant_lo) +#line 3525 + && (idp->mant_4 == lim->ieee.mant_4) +#line 3525 + && (idp->mant_5 == lim->ieee.mant_5) +#line 3525 + && (idp->mant_6 == lim->ieee.mant_6) +#line 3525 + && (idp->exp_lo == lim->ieee.exp_lo) +#line 3525 + && (idp->exp_hi == lim->ieee.exp_hi) +#line 3525 + ) +#line 3525 + { +#line 3525 + *vdp = lim->d; +#line 3525 + goto doneit; +#line 3525 + } +#line 3525 + } +#line 3525 + } +#line 3525 + { +#line 3525 + unsigned exp = idp->exp_hi << 4 | idp->exp_lo; +#line 3525 + vdp->exp = exp - IEEE_DBL_BIAS + VAX_DBL_BIAS; +#line 3525 + } +#line 3525 + { +#line 3525 + unsigned mant_hi = ((idp->mant_6 << 16) +#line 3525 + | (idp->mant_5 << 8) +#line 3525 + | idp->mant_4); +#line 3525 + unsigned mant_lo = SWAP4(idp->mant_lo); +#line 3525 + vdp->mantissa1 = (mant_hi >> 13); +#line 3525 + vdp->mantissa2 = ((mant_hi & MASK(13)) << 3) +#line 3525 + | (mant_lo >> 29); +#line 3525 + vdp->mantissa3 = (mant_lo >> 13); +#line 3525 + vdp->mantissa4 = (mant_lo << 3); +#line 3525 + } +#line 3525 + doneit: +#line 3525 + vdp->sign = idp->sign; +#line 3525 + + ip++; + *xpp = (char *)(*xpp) + X_SIZEOF_DOUBLE; + } + return NC_NOERR; +} + /* vax */ +#else +int +ncx_getn_double_double(const void **xpp, size_t nelems, double *tp) +{ + const char *xp = *xpp; + int status = NC_NOERR; + + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) + { + const int lstatus = ncx_get_double_double(xp, tp, fillp); + if (status == NC_NOERR) /* report the first encountered error */ + status = lstatus; + } + + *xpp = (const void *)xp; + return status; +} +#endif +int +#line 3550 +ncx_getn_double_schar(const void **xpp, size_t nelems, schar *tp) +#line 3550 +{ +#line 3550 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3550 + +#line 3550 + /* basic algorithm is: +#line 3550 + * - ensure sane alignment of input data +#line 3550 + * - copy (conversion happens automatically) input data +#line 3550 + * to output +#line 3550 + * - update xpp to point at next unconverted input, and tp to point +#line 3550 + * at next location for converted output +#line 3550 + */ +#line 3550 + long i, j, ni; +#line 3550 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3550 + double *xp; +#line 3550 + int nrange = 0; /* number of range errors */ +#line 3550 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3550 + long cxp = (long) *((char**)xpp); +#line 3550 + +#line 3550 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3550 + /* sjl: manually stripmine so we can limit amount of +#line 3550 + * vector work space reserved to LOOPCNT elements. Also +#line 3550 + * makes vectorisation easy */ +#line 3550 + for (j=0; j= 0 */ +#line 3550 + nrange += xp[i] > SCHAR_MAX || xp[i] < SCHAR_MIN; +#line 3550 + } +#line 3550 + /* update xpp and tp */ +#line 3550 + if (realign) xp = (double *) *xpp; +#line 3550 + xp += ni; +#line 3550 + tp += ni; +#line 3550 + *xpp = (void*)xp; +#line 3550 + } +#line 3550 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3550 + +#line 3550 +#else /* not SX */ +#line 3550 + const char *xp = (const char *) *xpp; +#line 3550 + int status = NC_NOERR; +#line 3550 + +#line 3550 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3550 + { +#line 3550 + const int lstatus = ncx_get_double_schar(xp, tp); +#line 3550 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3550 + status = lstatus; +#line 3550 + } +#line 3550 + +#line 3550 + *xpp = (const void *)xp; +#line 3550 + return status; +#line 3550 +#endif +#line 3550 +} +#line 3550 + +int +#line 3551 +ncx_getn_double_short(const void **xpp, size_t nelems, short *tp) +#line 3551 +{ +#line 3551 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3551 + +#line 3551 + /* basic algorithm is: +#line 3551 + * - ensure sane alignment of input data +#line 3551 + * - copy (conversion happens automatically) input data +#line 3551 + * to output +#line 3551 + * - update xpp to point at next unconverted input, and tp to point +#line 3551 + * at next location for converted output +#line 3551 + */ +#line 3551 + long i, j, ni; +#line 3551 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3551 + double *xp; +#line 3551 + int nrange = 0; /* number of range errors */ +#line 3551 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3551 + long cxp = (long) *((char**)xpp); +#line 3551 + +#line 3551 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3551 + /* sjl: manually stripmine so we can limit amount of +#line 3551 + * vector work space reserved to LOOPCNT elements. Also +#line 3551 + * makes vectorisation easy */ +#line 3551 + for (j=0; j= 0 */ +#line 3551 + nrange += xp[i] > SHORT_MAX || xp[i] < SHORT_MIN; +#line 3551 + } +#line 3551 + /* update xpp and tp */ +#line 3551 + if (realign) xp = (double *) *xpp; +#line 3551 + xp += ni; +#line 3551 + tp += ni; +#line 3551 + *xpp = (void*)xp; +#line 3551 + } +#line 3551 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3551 + +#line 3551 +#else /* not SX */ +#line 3551 + const char *xp = (const char *) *xpp; +#line 3551 + int status = NC_NOERR; +#line 3551 + +#line 3551 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3551 + { +#line 3551 + const int lstatus = ncx_get_double_short(xp, tp); +#line 3551 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3551 + status = lstatus; +#line 3551 + } +#line 3551 + +#line 3551 + *xpp = (const void *)xp; +#line 3551 + return status; +#line 3551 +#endif +#line 3551 +} +#line 3551 + +int +#line 3552 +ncx_getn_double_int(const void **xpp, size_t nelems, int *tp) +#line 3552 +{ +#line 3552 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3552 + +#line 3552 + /* basic algorithm is: +#line 3552 + * - ensure sane alignment of input data +#line 3552 + * - copy (conversion happens automatically) input data +#line 3552 + * to output +#line 3552 + * - update xpp to point at next unconverted input, and tp to point +#line 3552 + * at next location for converted output +#line 3552 + */ +#line 3552 + long i, j, ni; +#line 3552 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3552 + double *xp; +#line 3552 + int nrange = 0; /* number of range errors */ +#line 3552 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3552 + long cxp = (long) *((char**)xpp); +#line 3552 + +#line 3552 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3552 + /* sjl: manually stripmine so we can limit amount of +#line 3552 + * vector work space reserved to LOOPCNT elements. Also +#line 3552 + * makes vectorisation easy */ +#line 3552 + for (j=0; j= 0 */ +#line 3552 + nrange += xp[i] > INT_MAX || xp[i] < INT_MIN; +#line 3552 + } +#line 3552 + /* update xpp and tp */ +#line 3552 + if (realign) xp = (double *) *xpp; +#line 3552 + xp += ni; +#line 3552 + tp += ni; +#line 3552 + *xpp = (void*)xp; +#line 3552 + } +#line 3552 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3552 + +#line 3552 +#else /* not SX */ +#line 3552 + const char *xp = (const char *) *xpp; +#line 3552 + int status = NC_NOERR; +#line 3552 + +#line 3552 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3552 + { +#line 3552 + const int lstatus = ncx_get_double_int(xp, tp); +#line 3552 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3552 + status = lstatus; +#line 3552 + } +#line 3552 + +#line 3552 + *xpp = (const void *)xp; +#line 3552 + return status; +#line 3552 +#endif +#line 3552 +} +#line 3552 + +int +#line 3553 +ncx_getn_double_long(const void **xpp, size_t nelems, long *tp) +#line 3553 +{ +#line 3553 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3553 + +#line 3553 + /* basic algorithm is: +#line 3553 + * - ensure sane alignment of input data +#line 3553 + * - copy (conversion happens automatically) input data +#line 3553 + * to output +#line 3553 + * - update xpp to point at next unconverted input, and tp to point +#line 3553 + * at next location for converted output +#line 3553 + */ +#line 3553 + long i, j, ni; +#line 3553 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3553 + double *xp; +#line 3553 + int nrange = 0; /* number of range errors */ +#line 3553 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3553 + long cxp = (long) *((char**)xpp); +#line 3553 + +#line 3553 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3553 + /* sjl: manually stripmine so we can limit amount of +#line 3553 + * vector work space reserved to LOOPCNT elements. Also +#line 3553 + * makes vectorisation easy */ +#line 3553 + for (j=0; j= 0 */ +#line 3553 + nrange += xp[i] > LONG_MAX || xp[i] < LONG_MIN; +#line 3553 + } +#line 3553 + /* update xpp and tp */ +#line 3553 + if (realign) xp = (double *) *xpp; +#line 3553 + xp += ni; +#line 3553 + tp += ni; +#line 3553 + *xpp = (void*)xp; +#line 3553 + } +#line 3553 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3553 + +#line 3553 +#else /* not SX */ +#line 3553 + const char *xp = (const char *) *xpp; +#line 3553 + int status = NC_NOERR; +#line 3553 + +#line 3553 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3553 + { +#line 3553 + const int lstatus = ncx_get_double_long(xp, tp); +#line 3553 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3553 + status = lstatus; +#line 3553 + } +#line 3553 + +#line 3553 + *xpp = (const void *)xp; +#line 3553 + return status; +#line 3553 +#endif +#line 3553 +} +#line 3553 + +int +#line 3554 +ncx_getn_double_float(const void **xpp, size_t nelems, float *tp) +#line 3554 +{ +#line 3554 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3554 + +#line 3554 + /* basic algorithm is: +#line 3554 + * - ensure sane alignment of input data +#line 3554 + * - copy (conversion happens automatically) input data +#line 3554 + * to output +#line 3554 + * - update xpp to point at next unconverted input, and tp to point +#line 3554 + * at next location for converted output +#line 3554 + */ +#line 3554 + long i, j, ni; +#line 3554 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3554 + double *xp; +#line 3554 + int nrange = 0; /* number of range errors */ +#line 3554 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3554 + long cxp = (long) *((char**)xpp); +#line 3554 + +#line 3554 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3554 + /* sjl: manually stripmine so we can limit amount of +#line 3554 + * vector work space reserved to LOOPCNT elements. Also +#line 3554 + * makes vectorisation easy */ +#line 3554 + for (j=0; j= 0 */ +#line 3554 + nrange += xp[i] > FLOAT_MAX || xp[i] < FLOAT_MIN; +#line 3554 + } +#line 3554 + /* update xpp and tp */ +#line 3554 + if (realign) xp = (double *) *xpp; +#line 3554 + xp += ni; +#line 3554 + tp += ni; +#line 3554 + *xpp = (void*)xp; +#line 3554 + } +#line 3554 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3554 + +#line 3554 +#else /* not SX */ +#line 3554 + const char *xp = (const char *) *xpp; +#line 3554 + int status = NC_NOERR; +#line 3554 + +#line 3554 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3554 + { +#line 3554 + const int lstatus = ncx_get_double_float(xp, tp); +#line 3554 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3554 + status = lstatus; +#line 3554 + } +#line 3554 + +#line 3554 + *xpp = (const void *)xp; +#line 3554 + return status; +#line 3554 +#endif +#line 3554 +} +#line 3554 + +int +#line 3555 +ncx_getn_double_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 3555 +{ +#line 3555 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3555 + +#line 3555 + /* basic algorithm is: +#line 3555 + * - ensure sane alignment of input data +#line 3555 + * - copy (conversion happens automatically) input data +#line 3555 + * to output +#line 3555 + * - update xpp to point at next unconverted input, and tp to point +#line 3555 + * at next location for converted output +#line 3555 + */ +#line 3555 + long i, j, ni; +#line 3555 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3555 + double *xp; +#line 3555 + int nrange = 0; /* number of range errors */ +#line 3555 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3555 + long cxp = (long) *((char**)xpp); +#line 3555 + +#line 3555 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3555 + /* sjl: manually stripmine so we can limit amount of +#line 3555 + * vector work space reserved to LOOPCNT elements. Also +#line 3555 + * makes vectorisation easy */ +#line 3555 + for (j=0; j= 0 */ +#line 3555 + nrange += xp[i] > LONGLONG_MAX || xp[i] < LONGLONG_MIN; +#line 3555 + } +#line 3555 + /* update xpp and tp */ +#line 3555 + if (realign) xp = (double *) *xpp; +#line 3555 + xp += ni; +#line 3555 + tp += ni; +#line 3555 + *xpp = (void*)xp; +#line 3555 + } +#line 3555 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3555 + +#line 3555 +#else /* not SX */ +#line 3555 + const char *xp = (const char *) *xpp; +#line 3555 + int status = NC_NOERR; +#line 3555 + +#line 3555 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3555 + { +#line 3555 + const int lstatus = ncx_get_double_longlong(xp, tp); +#line 3555 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3555 + status = lstatus; +#line 3555 + } +#line 3555 + +#line 3555 + *xpp = (const void *)xp; +#line 3555 + return status; +#line 3555 +#endif +#line 3555 +} +#line 3555 + +int +#line 3556 +ncx_getn_double_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 3556 +{ +#line 3556 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3556 + +#line 3556 + /* basic algorithm is: +#line 3556 + * - ensure sane alignment of input data +#line 3556 + * - copy (conversion happens automatically) input data +#line 3556 + * to output +#line 3556 + * - update xpp to point at next unconverted input, and tp to point +#line 3556 + * at next location for converted output +#line 3556 + */ +#line 3556 + long i, j, ni; +#line 3556 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3556 + double *xp; +#line 3556 + int nrange = 0; /* number of range errors */ +#line 3556 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3556 + long cxp = (long) *((char**)xpp); +#line 3556 + +#line 3556 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3556 + /* sjl: manually stripmine so we can limit amount of +#line 3556 + * vector work space reserved to LOOPCNT elements. Also +#line 3556 + * makes vectorisation easy */ +#line 3556 + for (j=0; j= 0 */ +#line 3556 + nrange += xp[i] > UCHAR_MAX || xp[i] < 0; +#line 3556 + } +#line 3556 + /* update xpp and tp */ +#line 3556 + if (realign) xp = (double *) *xpp; +#line 3556 + xp += ni; +#line 3556 + tp += ni; +#line 3556 + *xpp = (void*)xp; +#line 3556 + } +#line 3556 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3556 + +#line 3556 +#else /* not SX */ +#line 3556 + const char *xp = (const char *) *xpp; +#line 3556 + int status = NC_NOERR; +#line 3556 + +#line 3556 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3556 + { +#line 3556 + const int lstatus = ncx_get_double_uchar(xp, tp); +#line 3556 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3556 + status = lstatus; +#line 3556 + } +#line 3556 + +#line 3556 + *xpp = (const void *)xp; +#line 3556 + return status; +#line 3556 +#endif +#line 3556 +} +#line 3556 + +int +#line 3557 +ncx_getn_double_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 3557 +{ +#line 3557 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3557 + +#line 3557 + /* basic algorithm is: +#line 3557 + * - ensure sane alignment of input data +#line 3557 + * - copy (conversion happens automatically) input data +#line 3557 + * to output +#line 3557 + * - update xpp to point at next unconverted input, and tp to point +#line 3557 + * at next location for converted output +#line 3557 + */ +#line 3557 + long i, j, ni; +#line 3557 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3557 + double *xp; +#line 3557 + int nrange = 0; /* number of range errors */ +#line 3557 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3557 + long cxp = (long) *((char**)xpp); +#line 3557 + +#line 3557 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3557 + /* sjl: manually stripmine so we can limit amount of +#line 3557 + * vector work space reserved to LOOPCNT elements. Also +#line 3557 + * makes vectorisation easy */ +#line 3557 + for (j=0; j= 0 */ +#line 3557 + nrange += xp[i] > USHORT_MAX || xp[i] < 0; +#line 3557 + } +#line 3557 + /* update xpp and tp */ +#line 3557 + if (realign) xp = (double *) *xpp; +#line 3557 + xp += ni; +#line 3557 + tp += ni; +#line 3557 + *xpp = (void*)xp; +#line 3557 + } +#line 3557 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3557 + +#line 3557 +#else /* not SX */ +#line 3557 + const char *xp = (const char *) *xpp; +#line 3557 + int status = NC_NOERR; +#line 3557 + +#line 3557 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3557 + { +#line 3557 + const int lstatus = ncx_get_double_ushort(xp, tp); +#line 3557 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3557 + status = lstatus; +#line 3557 + } +#line 3557 + +#line 3557 + *xpp = (const void *)xp; +#line 3557 + return status; +#line 3557 +#endif +#line 3557 +} +#line 3557 + +int +#line 3558 +ncx_getn_double_uint(const void **xpp, size_t nelems, uint *tp) +#line 3558 +{ +#line 3558 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3558 + +#line 3558 + /* basic algorithm is: +#line 3558 + * - ensure sane alignment of input data +#line 3558 + * - copy (conversion happens automatically) input data +#line 3558 + * to output +#line 3558 + * - update xpp to point at next unconverted input, and tp to point +#line 3558 + * at next location for converted output +#line 3558 + */ +#line 3558 + long i, j, ni; +#line 3558 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3558 + double *xp; +#line 3558 + int nrange = 0; /* number of range errors */ +#line 3558 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3558 + long cxp = (long) *((char**)xpp); +#line 3558 + +#line 3558 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3558 + /* sjl: manually stripmine so we can limit amount of +#line 3558 + * vector work space reserved to LOOPCNT elements. Also +#line 3558 + * makes vectorisation easy */ +#line 3558 + for (j=0; j= 0 */ +#line 3558 + nrange += xp[i] > UINT_MAX || xp[i] < 0; +#line 3558 + } +#line 3558 + /* update xpp and tp */ +#line 3558 + if (realign) xp = (double *) *xpp; +#line 3558 + xp += ni; +#line 3558 + tp += ni; +#line 3558 + *xpp = (void*)xp; +#line 3558 + } +#line 3558 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3558 + +#line 3558 +#else /* not SX */ +#line 3558 + const char *xp = (const char *) *xpp; +#line 3558 + int status = NC_NOERR; +#line 3558 + +#line 3558 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3558 + { +#line 3558 + const int lstatus = ncx_get_double_uint(xp, tp); +#line 3558 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3558 + status = lstatus; +#line 3558 + } +#line 3558 + +#line 3558 + *xpp = (const void *)xp; +#line 3558 + return status; +#line 3558 +#endif +#line 3558 +} +#line 3558 + +int +#line 3559 +ncx_getn_double_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 3559 +{ +#line 3559 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3559 + +#line 3559 + /* basic algorithm is: +#line 3559 + * - ensure sane alignment of input data +#line 3559 + * - copy (conversion happens automatically) input data +#line 3559 + * to output +#line 3559 + * - update xpp to point at next unconverted input, and tp to point +#line 3559 + * at next location for converted output +#line 3559 + */ +#line 3559 + long i, j, ni; +#line 3559 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3559 + double *xp; +#line 3559 + int nrange = 0; /* number of range errors */ +#line 3559 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3559 + long cxp = (long) *((char**)xpp); +#line 3559 + +#line 3559 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3559 + /* sjl: manually stripmine so we can limit amount of +#line 3559 + * vector work space reserved to LOOPCNT elements. Also +#line 3559 + * makes vectorisation easy */ +#line 3559 + for (j=0; j= 0 */ +#line 3559 + nrange += xp[i] > ULONGLONG_MAX || xp[i] < 0; +#line 3559 + } +#line 3559 + /* update xpp and tp */ +#line 3559 + if (realign) xp = (double *) *xpp; +#line 3559 + xp += ni; +#line 3559 + tp += ni; +#line 3559 + *xpp = (void*)xp; +#line 3559 + } +#line 3559 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3559 + +#line 3559 +#else /* not SX */ +#line 3559 + const char *xp = (const char *) *xpp; +#line 3559 + int status = NC_NOERR; +#line 3559 + +#line 3559 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3559 + { +#line 3559 + const int lstatus = ncx_get_double_ulonglong(xp, tp); +#line 3559 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3559 + status = lstatus; +#line 3559 + } +#line 3559 + +#line 3559 + *xpp = (const void *)xp; +#line 3559 + return status; +#line 3559 +#endif +#line 3559 +} +#line 3559 + + +#if X_SIZEOF_DOUBLE == SIZEOF_DOUBLE && !defined(NO_IEEE_FLOAT) +/* optimized version */ +int +ncx_putn_double_double(void **xpp, size_t nelems, const double *tp, void *fillp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(*xpp, tp, (size_t)nelems * X_SIZEOF_DOUBLE); +# else + swapn8b(*xpp, tp, nelems); +# endif + *xpp = (void *)((char *)(*xpp) + nelems * X_SIZEOF_DOUBLE); + return NC_NOERR; +} +#elif defined(vax) && vax != 0 +int +ncx_putn_double_double(void **xpp, size_t ndoubles, const double *ip, void *fillp) +{ + const double *const end = ip + ndoubles; + + while (ip < end) + { + const struct vax_double *const vdp = +#line 3582 + (const struct vax_double *)ip; +#line 3582 + struct ieee_double *const idp = +#line 3582 + (struct ieee_double *) (*xpp); +#line 3582 + +#line 3582 + if ((vdp->mantissa4 > (dbl_limits[0].d.mantissa4 - 3)) && +#line 3582 + (vdp->mantissa3 == dbl_limits[0].d.mantissa3) && +#line 3582 + (vdp->mantissa2 == dbl_limits[0].d.mantissa2) && +#line 3582 + (vdp->mantissa1 == dbl_limits[0].d.mantissa1) && +#line 3582 + (vdp->exp == dbl_limits[0].d.exp)) +#line 3582 + { +#line 3582 + *idp = dbl_limits[0].ieee; +#line 3582 + goto shipit; +#line 3582 + } +#line 3582 + if ((vdp->mantissa4 == dbl_limits[1].d.mantissa4) && +#line 3582 + (vdp->mantissa3 == dbl_limits[1].d.mantissa3) && +#line 3582 + (vdp->mantissa2 == dbl_limits[1].d.mantissa2) && +#line 3582 + (vdp->mantissa1 == dbl_limits[1].d.mantissa1) && +#line 3582 + (vdp->exp == dbl_limits[1].d.exp)) +#line 3582 + { +#line 3582 + *idp = dbl_limits[1].ieee; +#line 3582 + goto shipit; +#line 3582 + } +#line 3582 + +#line 3582 + { +#line 3582 + unsigned exp = vdp->exp - VAX_DBL_BIAS + IEEE_DBL_BIAS; +#line 3582 + +#line 3582 + unsigned mant_lo = ((vdp->mantissa2 & MASK(3)) << 29) | +#line 3582 + (vdp->mantissa3 << 13) | +#line 3582 + ((vdp->mantissa4 >> 3) & MASK(13)); +#line 3582 + +#line 3582 + unsigned mant_hi = (vdp->mantissa1 << 13) +#line 3582 + | (vdp->mantissa2 >> 3); +#line 3582 + +#line 3582 + if ((vdp->mantissa4 & 7) > 4) +#line 3582 + { +#line 3582 + /* round up */ +#line 3582 + mant_lo++; +#line 3582 + if (mant_lo == 0) +#line 3582 + { +#line 3582 + mant_hi++; +#line 3582 + if (mant_hi > 0xffffff) +#line 3582 + { +#line 3582 + mant_hi = 0; +#line 3582 + exp++; +#line 3582 + } +#line 3582 + } +#line 3582 + } +#line 3582 + +#line 3582 + idp->mant_lo = SWAP4(mant_lo); +#line 3582 + idp->mant_6 = mant_hi >> 16; +#line 3582 + idp->mant_5 = (mant_hi & 0xff00) >> 8; +#line 3582 + idp->mant_4 = mant_hi; +#line 3582 + idp->exp_hi = exp >> 4; +#line 3582 + idp->exp_lo = exp; +#line 3582 + } +#line 3582 + +#line 3582 + shipit: +#line 3582 + idp->sign = vdp->sign; +#line 3582 + + ip++; + *xpp = (char *)(*xpp) + X_SIZEOF_DOUBLE; + } + return NC_NOERR; +} + /* vax */ +#else +int +ncx_putn_double_double(void **xpp, size_t nelems, const double *tp, void *fillp) +{ + char *xp = *xpp; + int status = NC_NOERR; + + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) + { + int lstatus = ncx_put_double_double(xp, tp, fillp); + if (status == NC_NOERR) /* report the first encountered error */ + status = lstatus; + } + + *xpp = (void *)xp; + return status; +} +#endif +int +#line 3607 +ncx_putn_double_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +#line 3607 +{ +#line 3607 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3607 + +#line 3607 + /* basic algorithm is: +#line 3607 + * - ensure sane alignment of output data +#line 3607 + * - copy (conversion happens automatically) input data +#line 3607 + * to output +#line 3607 + * - update tp to point at next unconverted input, and xpp to point +#line 3607 + * at next location for converted output +#line 3607 + */ +#line 3607 + long i, j, ni; +#line 3607 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3607 + double *xp; +#line 3607 + int nrange = 0; /* number of range errors */ +#line 3607 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3607 + long cxp = (long) *((char**)xpp); +#line 3607 + +#line 3607 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3607 + /* sjl: manually stripmine so we can limit amount of +#line 3607 + * vector work space reserved to LOOPCNT elements. Also +#line 3607 + * makes vectorisation easy */ +#line 3607 + for (j=0; j= 0 */ +#line 3607 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3607 + nrange += tp[i] > X_DOUBLE_MAX || tp[i] < X_DOUBLE_MIN; +#line 3607 + } +#line 3607 + /* copy workspace back if necessary */ +#line 3607 + if (realign) { +#line 3607 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_DOUBLE); +#line 3607 + xp = (double *) *xpp; +#line 3607 + } +#line 3607 + /* update xpp and tp */ +#line 3607 + xp += ni; +#line 3607 + tp += ni; +#line 3607 + *xpp = (void*)xp; +#line 3607 + } +#line 3607 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3607 + +#line 3607 +#else /* not SX */ +#line 3607 + +#line 3607 + char *xp = (char *) *xpp; +#line 3607 + int status = NC_NOERR; +#line 3607 + +#line 3607 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3607 + { +#line 3607 + int lstatus = ncx_put_double_schar(xp, tp, fillp); +#line 3607 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3607 + status = lstatus; +#line 3607 + } +#line 3607 + +#line 3607 + *xpp = (void *)xp; +#line 3607 + return status; +#line 3607 +#endif +#line 3607 +} +#line 3607 + +int +#line 3608 +ncx_putn_double_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3608 +{ +#line 3608 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3608 + +#line 3608 + /* basic algorithm is: +#line 3608 + * - ensure sane alignment of output data +#line 3608 + * - copy (conversion happens automatically) input data +#line 3608 + * to output +#line 3608 + * - update tp to point at next unconverted input, and xpp to point +#line 3608 + * at next location for converted output +#line 3608 + */ +#line 3608 + long i, j, ni; +#line 3608 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3608 + double *xp; +#line 3608 + int nrange = 0; /* number of range errors */ +#line 3608 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3608 + long cxp = (long) *((char**)xpp); +#line 3608 + +#line 3608 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3608 + /* sjl: manually stripmine so we can limit amount of +#line 3608 + * vector work space reserved to LOOPCNT elements. Also +#line 3608 + * makes vectorisation easy */ +#line 3608 + for (j=0; j= 0 */ +#line 3608 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3608 + nrange += tp[i] > X_DOUBLE_MAX || tp[i] < X_DOUBLE_MIN; +#line 3608 + } +#line 3608 + /* copy workspace back if necessary */ +#line 3608 + if (realign) { +#line 3608 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_DOUBLE); +#line 3608 + xp = (double *) *xpp; +#line 3608 + } +#line 3608 + /* update xpp and tp */ +#line 3608 + xp += ni; +#line 3608 + tp += ni; +#line 3608 + *xpp = (void*)xp; +#line 3608 + } +#line 3608 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3608 + +#line 3608 +#else /* not SX */ +#line 3608 + +#line 3608 + char *xp = (char *) *xpp; +#line 3608 + int status = NC_NOERR; +#line 3608 + +#line 3608 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3608 + { +#line 3608 + int lstatus = ncx_put_double_short(xp, tp, fillp); +#line 3608 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3608 + status = lstatus; +#line 3608 + } +#line 3608 + +#line 3608 + *xpp = (void *)xp; +#line 3608 + return status; +#line 3608 +#endif +#line 3608 +} +#line 3608 + +int +#line 3609 +ncx_putn_double_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3609 +{ +#line 3609 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3609 + +#line 3609 + /* basic algorithm is: +#line 3609 + * - ensure sane alignment of output data +#line 3609 + * - copy (conversion happens automatically) input data +#line 3609 + * to output +#line 3609 + * - update tp to point at next unconverted input, and xpp to point +#line 3609 + * at next location for converted output +#line 3609 + */ +#line 3609 + long i, j, ni; +#line 3609 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3609 + double *xp; +#line 3609 + int nrange = 0; /* number of range errors */ +#line 3609 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3609 + long cxp = (long) *((char**)xpp); +#line 3609 + +#line 3609 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3609 + /* sjl: manually stripmine so we can limit amount of +#line 3609 + * vector work space reserved to LOOPCNT elements. Also +#line 3609 + * makes vectorisation easy */ +#line 3609 + for (j=0; j= 0 */ +#line 3609 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3609 + nrange += tp[i] > X_DOUBLE_MAX || tp[i] < X_DOUBLE_MIN; +#line 3609 + } +#line 3609 + /* copy workspace back if necessary */ +#line 3609 + if (realign) { +#line 3609 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_DOUBLE); +#line 3609 + xp = (double *) *xpp; +#line 3609 + } +#line 3609 + /* update xpp and tp */ +#line 3609 + xp += ni; +#line 3609 + tp += ni; +#line 3609 + *xpp = (void*)xp; +#line 3609 + } +#line 3609 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3609 + +#line 3609 +#else /* not SX */ +#line 3609 + +#line 3609 + char *xp = (char *) *xpp; +#line 3609 + int status = NC_NOERR; +#line 3609 + +#line 3609 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3609 + { +#line 3609 + int lstatus = ncx_put_double_int(xp, tp, fillp); +#line 3609 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3609 + status = lstatus; +#line 3609 + } +#line 3609 + +#line 3609 + *xpp = (void *)xp; +#line 3609 + return status; +#line 3609 +#endif +#line 3609 +} +#line 3609 + +int +#line 3610 +ncx_putn_double_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3610 +{ +#line 3610 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3610 + +#line 3610 + /* basic algorithm is: +#line 3610 + * - ensure sane alignment of output data +#line 3610 + * - copy (conversion happens automatically) input data +#line 3610 + * to output +#line 3610 + * - update tp to point at next unconverted input, and xpp to point +#line 3610 + * at next location for converted output +#line 3610 + */ +#line 3610 + long i, j, ni; +#line 3610 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3610 + double *xp; +#line 3610 + int nrange = 0; /* number of range errors */ +#line 3610 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3610 + long cxp = (long) *((char**)xpp); +#line 3610 + +#line 3610 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3610 + /* sjl: manually stripmine so we can limit amount of +#line 3610 + * vector work space reserved to LOOPCNT elements. Also +#line 3610 + * makes vectorisation easy */ +#line 3610 + for (j=0; j= 0 */ +#line 3610 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3610 + nrange += tp[i] > X_DOUBLE_MAX || tp[i] < X_DOUBLE_MIN; +#line 3610 + } +#line 3610 + /* copy workspace back if necessary */ +#line 3610 + if (realign) { +#line 3610 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_DOUBLE); +#line 3610 + xp = (double *) *xpp; +#line 3610 + } +#line 3610 + /* update xpp and tp */ +#line 3610 + xp += ni; +#line 3610 + tp += ni; +#line 3610 + *xpp = (void*)xp; +#line 3610 + } +#line 3610 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3610 + +#line 3610 +#else /* not SX */ +#line 3610 + +#line 3610 + char *xp = (char *) *xpp; +#line 3610 + int status = NC_NOERR; +#line 3610 + +#line 3610 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3610 + { +#line 3610 + int lstatus = ncx_put_double_long(xp, tp, fillp); +#line 3610 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3610 + status = lstatus; +#line 3610 + } +#line 3610 + +#line 3610 + *xpp = (void *)xp; +#line 3610 + return status; +#line 3610 +#endif +#line 3610 +} +#line 3610 + +int +#line 3611 +ncx_putn_double_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 3611 +{ +#line 3611 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3611 + +#line 3611 + /* basic algorithm is: +#line 3611 + * - ensure sane alignment of output data +#line 3611 + * - copy (conversion happens automatically) input data +#line 3611 + * to output +#line 3611 + * - update tp to point at next unconverted input, and xpp to point +#line 3611 + * at next location for converted output +#line 3611 + */ +#line 3611 + long i, j, ni; +#line 3611 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3611 + double *xp; +#line 3611 + int nrange = 0; /* number of range errors */ +#line 3611 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3611 + long cxp = (long) *((char**)xpp); +#line 3611 + +#line 3611 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3611 + /* sjl: manually stripmine so we can limit amount of +#line 3611 + * vector work space reserved to LOOPCNT elements. Also +#line 3611 + * makes vectorisation easy */ +#line 3611 + for (j=0; j= 0 */ +#line 3611 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3611 + nrange += tp[i] > X_DOUBLE_MAX || tp[i] < X_DOUBLE_MIN; +#line 3611 + } +#line 3611 + /* copy workspace back if necessary */ +#line 3611 + if (realign) { +#line 3611 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_DOUBLE); +#line 3611 + xp = (double *) *xpp; +#line 3611 + } +#line 3611 + /* update xpp and tp */ +#line 3611 + xp += ni; +#line 3611 + tp += ni; +#line 3611 + *xpp = (void*)xp; +#line 3611 + } +#line 3611 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3611 + +#line 3611 +#else /* not SX */ +#line 3611 + +#line 3611 + char *xp = (char *) *xpp; +#line 3611 + int status = NC_NOERR; +#line 3611 + +#line 3611 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3611 + { +#line 3611 + int lstatus = ncx_put_double_float(xp, tp, fillp); +#line 3611 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3611 + status = lstatus; +#line 3611 + } +#line 3611 + +#line 3611 + *xpp = (void *)xp; +#line 3611 + return status; +#line 3611 +#endif +#line 3611 +} +#line 3611 + +int +#line 3612 +ncx_putn_double_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3612 +{ +#line 3612 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3612 + +#line 3612 + /* basic algorithm is: +#line 3612 + * - ensure sane alignment of output data +#line 3612 + * - copy (conversion happens automatically) input data +#line 3612 + * to output +#line 3612 + * - update tp to point at next unconverted input, and xpp to point +#line 3612 + * at next location for converted output +#line 3612 + */ +#line 3612 + long i, j, ni; +#line 3612 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3612 + double *xp; +#line 3612 + int nrange = 0; /* number of range errors */ +#line 3612 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3612 + long cxp = (long) *((char**)xpp); +#line 3612 + +#line 3612 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3612 + /* sjl: manually stripmine so we can limit amount of +#line 3612 + * vector work space reserved to LOOPCNT elements. Also +#line 3612 + * makes vectorisation easy */ +#line 3612 + for (j=0; j= 0 */ +#line 3612 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3612 + nrange += tp[i] > X_DOUBLE_MAX || tp[i] < X_DOUBLE_MIN; +#line 3612 + } +#line 3612 + /* copy workspace back if necessary */ +#line 3612 + if (realign) { +#line 3612 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_DOUBLE); +#line 3612 + xp = (double *) *xpp; +#line 3612 + } +#line 3612 + /* update xpp and tp */ +#line 3612 + xp += ni; +#line 3612 + tp += ni; +#line 3612 + *xpp = (void*)xp; +#line 3612 + } +#line 3612 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3612 + +#line 3612 +#else /* not SX */ +#line 3612 + +#line 3612 + char *xp = (char *) *xpp; +#line 3612 + int status = NC_NOERR; +#line 3612 + +#line 3612 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3612 + { +#line 3612 + int lstatus = ncx_put_double_longlong(xp, tp, fillp); +#line 3612 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3612 + status = lstatus; +#line 3612 + } +#line 3612 + +#line 3612 + *xpp = (void *)xp; +#line 3612 + return status; +#line 3612 +#endif +#line 3612 +} +#line 3612 + +int +#line 3613 +ncx_putn_double_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 3613 +{ +#line 3613 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3613 + +#line 3613 + /* basic algorithm is: +#line 3613 + * - ensure sane alignment of output data +#line 3613 + * - copy (conversion happens automatically) input data +#line 3613 + * to output +#line 3613 + * - update tp to point at next unconverted input, and xpp to point +#line 3613 + * at next location for converted output +#line 3613 + */ +#line 3613 + long i, j, ni; +#line 3613 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3613 + double *xp; +#line 3613 + int nrange = 0; /* number of range errors */ +#line 3613 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3613 + long cxp = (long) *((char**)xpp); +#line 3613 + +#line 3613 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3613 + /* sjl: manually stripmine so we can limit amount of +#line 3613 + * vector work space reserved to LOOPCNT elements. Also +#line 3613 + * makes vectorisation easy */ +#line 3613 + for (j=0; j= 0 */ +#line 3613 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3613 + nrange += tp[i] > X_DOUBLE_MAX ; +#line 3613 + } +#line 3613 + /* copy workspace back if necessary */ +#line 3613 + if (realign) { +#line 3613 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_DOUBLE); +#line 3613 + xp = (double *) *xpp; +#line 3613 + } +#line 3613 + /* update xpp and tp */ +#line 3613 + xp += ni; +#line 3613 + tp += ni; +#line 3613 + *xpp = (void*)xp; +#line 3613 + } +#line 3613 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3613 + +#line 3613 +#else /* not SX */ +#line 3613 + +#line 3613 + char *xp = (char *) *xpp; +#line 3613 + int status = NC_NOERR; +#line 3613 + +#line 3613 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3613 + { +#line 3613 + int lstatus = ncx_put_double_uchar(xp, tp, fillp); +#line 3613 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3613 + status = lstatus; +#line 3613 + } +#line 3613 + +#line 3613 + *xpp = (void *)xp; +#line 3613 + return status; +#line 3613 +#endif +#line 3613 +} +#line 3613 + +int +#line 3614 +ncx_putn_double_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3614 +{ +#line 3614 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3614 + +#line 3614 + /* basic algorithm is: +#line 3614 + * - ensure sane alignment of output data +#line 3614 + * - copy (conversion happens automatically) input data +#line 3614 + * to output +#line 3614 + * - update tp to point at next unconverted input, and xpp to point +#line 3614 + * at next location for converted output +#line 3614 + */ +#line 3614 + long i, j, ni; +#line 3614 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3614 + double *xp; +#line 3614 + int nrange = 0; /* number of range errors */ +#line 3614 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3614 + long cxp = (long) *((char**)xpp); +#line 3614 + +#line 3614 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3614 + /* sjl: manually stripmine so we can limit amount of +#line 3614 + * vector work space reserved to LOOPCNT elements. Also +#line 3614 + * makes vectorisation easy */ +#line 3614 + for (j=0; j= 0 */ +#line 3614 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3614 + nrange += tp[i] > X_DOUBLE_MAX ; +#line 3614 + } +#line 3614 + /* copy workspace back if necessary */ +#line 3614 + if (realign) { +#line 3614 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_DOUBLE); +#line 3614 + xp = (double *) *xpp; +#line 3614 + } +#line 3614 + /* update xpp and tp */ +#line 3614 + xp += ni; +#line 3614 + tp += ni; +#line 3614 + *xpp = (void*)xp; +#line 3614 + } +#line 3614 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3614 + +#line 3614 +#else /* not SX */ +#line 3614 + +#line 3614 + char *xp = (char *) *xpp; +#line 3614 + int status = NC_NOERR; +#line 3614 + +#line 3614 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3614 + { +#line 3614 + int lstatus = ncx_put_double_ushort(xp, tp, fillp); +#line 3614 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3614 + status = lstatus; +#line 3614 + } +#line 3614 + +#line 3614 + *xpp = (void *)xp; +#line 3614 + return status; +#line 3614 +#endif +#line 3614 +} +#line 3614 + +int +#line 3615 +ncx_putn_double_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3615 +{ +#line 3615 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3615 + +#line 3615 + /* basic algorithm is: +#line 3615 + * - ensure sane alignment of output data +#line 3615 + * - copy (conversion happens automatically) input data +#line 3615 + * to output +#line 3615 + * - update tp to point at next unconverted input, and xpp to point +#line 3615 + * at next location for converted output +#line 3615 + */ +#line 3615 + long i, j, ni; +#line 3615 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3615 + double *xp; +#line 3615 + int nrange = 0; /* number of range errors */ +#line 3615 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3615 + long cxp = (long) *((char**)xpp); +#line 3615 + +#line 3615 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3615 + /* sjl: manually stripmine so we can limit amount of +#line 3615 + * vector work space reserved to LOOPCNT elements. Also +#line 3615 + * makes vectorisation easy */ +#line 3615 + for (j=0; j= 0 */ +#line 3615 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3615 + nrange += tp[i] > X_DOUBLE_MAX ; +#line 3615 + } +#line 3615 + /* copy workspace back if necessary */ +#line 3615 + if (realign) { +#line 3615 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_DOUBLE); +#line 3615 + xp = (double *) *xpp; +#line 3615 + } +#line 3615 + /* update xpp and tp */ +#line 3615 + xp += ni; +#line 3615 + tp += ni; +#line 3615 + *xpp = (void*)xp; +#line 3615 + } +#line 3615 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3615 + +#line 3615 +#else /* not SX */ +#line 3615 + +#line 3615 + char *xp = (char *) *xpp; +#line 3615 + int status = NC_NOERR; +#line 3615 + +#line 3615 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3615 + { +#line 3615 + int lstatus = ncx_put_double_uint(xp, tp, fillp); +#line 3615 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3615 + status = lstatus; +#line 3615 + } +#line 3615 + +#line 3615 + *xpp = (void *)xp; +#line 3615 + return status; +#line 3615 +#endif +#line 3615 +} +#line 3615 + +int +#line 3616 +ncx_putn_double_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3616 +{ +#line 3616 +#if defined(_SX) && _SX != 0 && X_SIZEOF_DOUBLE == SIZEOF_DOUBLE +#line 3616 + +#line 3616 + /* basic algorithm is: +#line 3616 + * - ensure sane alignment of output data +#line 3616 + * - copy (conversion happens automatically) input data +#line 3616 + * to output +#line 3616 + * - update tp to point at next unconverted input, and xpp to point +#line 3616 + * at next location for converted output +#line 3616 + */ +#line 3616 + long i, j, ni; +#line 3616 + double tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3616 + double *xp; +#line 3616 + int nrange = 0; /* number of range errors */ +#line 3616 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3616 + long cxp = (long) *((char**)xpp); +#line 3616 + +#line 3616 + realign = (cxp & 7) % SIZEOF_DOUBLE; +#line 3616 + /* sjl: manually stripmine so we can limit amount of +#line 3616 + * vector work space reserved to LOOPCNT elements. Also +#line 3616 + * makes vectorisation easy */ +#line 3616 + for (j=0; j= 0 */ +#line 3616 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3616 + nrange += tp[i] > X_DOUBLE_MAX ; +#line 3616 + } +#line 3616 + /* copy workspace back if necessary */ +#line 3616 + if (realign) { +#line 3616 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_DOUBLE); +#line 3616 + xp = (double *) *xpp; +#line 3616 + } +#line 3616 + /* update xpp and tp */ +#line 3616 + xp += ni; +#line 3616 + tp += ni; +#line 3616 + *xpp = (void*)xp; +#line 3616 + } +#line 3616 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3616 + +#line 3616 +#else /* not SX */ +#line 3616 + +#line 3616 + char *xp = (char *) *xpp; +#line 3616 + int status = NC_NOERR; +#line 3616 + +#line 3616 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_DOUBLE, tp++) +#line 3616 + { +#line 3616 + int lstatus = ncx_put_double_ulonglong(xp, tp, fillp); +#line 3616 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3616 + status = lstatus; +#line 3616 + } +#line 3616 + +#line 3616 + *xpp = (void *)xp; +#line 3616 + return status; +#line 3616 +#endif +#line 3616 +} +#line 3616 + + + +/* longlong ------------------------------------------------------------------*/ + +#if X_SIZEOF_INT64 == SIZEOF_LONGLONG +/* optimized version */ +int +ncx_getn_longlong_longlong(const void **xpp, size_t nelems, long long *tp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(tp, *xpp, (size_t)nelems * SIZEOF_LONG_LONG); +# else + swapn8b(tp, *xpp, nelems); +# endif + *xpp = (const void *)((const char *)(*xpp) + nelems * X_SIZEOF_INT64); + return NC_NOERR; +} +#else +int +#line 3635 +ncx_getn_longlong_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 3635 +{ +#line 3635 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3635 + +#line 3635 + /* basic algorithm is: +#line 3635 + * - ensure sane alignment of input data +#line 3635 + * - copy (conversion happens automatically) input data +#line 3635 + * to output +#line 3635 + * - update xpp to point at next unconverted input, and tp to point +#line 3635 + * at next location for converted output +#line 3635 + */ +#line 3635 + long i, j, ni; +#line 3635 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3635 + int64 *xp; +#line 3635 + int nrange = 0; /* number of range errors */ +#line 3635 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3635 + long cxp = (long) *((char**)xpp); +#line 3635 + +#line 3635 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3635 + /* sjl: manually stripmine so we can limit amount of +#line 3635 + * vector work space reserved to LOOPCNT elements. Also +#line 3635 + * makes vectorisation easy */ +#line 3635 + for (j=0; j= 0 */ +#line 3635 + nrange += xp[i] > LONGLONG_MAX || xp[i] < LONGLONG_MIN; +#line 3635 + } +#line 3635 + /* update xpp and tp */ +#line 3635 + if (realign) xp = (int64 *) *xpp; +#line 3635 + xp += ni; +#line 3635 + tp += ni; +#line 3635 + *xpp = (void*)xp; +#line 3635 + } +#line 3635 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3635 + +#line 3635 +#else /* not SX */ +#line 3635 + const char *xp = (const char *) *xpp; +#line 3635 + int status = NC_NOERR; +#line 3635 + +#line 3635 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3635 + { +#line 3635 + const int lstatus = ncx_get_longlong_longlong(xp, tp); +#line 3635 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3635 + status = lstatus; +#line 3635 + } +#line 3635 + +#line 3635 + *xpp = (const void *)xp; +#line 3635 + return status; +#line 3635 +#endif +#line 3635 +} +#line 3635 + +#endif +int +#line 3637 +ncx_getn_longlong_schar(const void **xpp, size_t nelems, schar *tp) +#line 3637 +{ +#line 3637 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3637 + +#line 3637 + /* basic algorithm is: +#line 3637 + * - ensure sane alignment of input data +#line 3637 + * - copy (conversion happens automatically) input data +#line 3637 + * to output +#line 3637 + * - update xpp to point at next unconverted input, and tp to point +#line 3637 + * at next location for converted output +#line 3637 + */ +#line 3637 + long i, j, ni; +#line 3637 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3637 + int64 *xp; +#line 3637 + int nrange = 0; /* number of range errors */ +#line 3637 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3637 + long cxp = (long) *((char**)xpp); +#line 3637 + +#line 3637 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3637 + /* sjl: manually stripmine so we can limit amount of +#line 3637 + * vector work space reserved to LOOPCNT elements. Also +#line 3637 + * makes vectorisation easy */ +#line 3637 + for (j=0; j= 0 */ +#line 3637 + nrange += xp[i] > SCHAR_MAX || xp[i] < SCHAR_MIN; +#line 3637 + } +#line 3637 + /* update xpp and tp */ +#line 3637 + if (realign) xp = (int64 *) *xpp; +#line 3637 + xp += ni; +#line 3637 + tp += ni; +#line 3637 + *xpp = (void*)xp; +#line 3637 + } +#line 3637 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3637 + +#line 3637 +#else /* not SX */ +#line 3637 + const char *xp = (const char *) *xpp; +#line 3637 + int status = NC_NOERR; +#line 3637 + +#line 3637 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3637 + { +#line 3637 + const int lstatus = ncx_get_longlong_schar(xp, tp); +#line 3637 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3637 + status = lstatus; +#line 3637 + } +#line 3637 + +#line 3637 + *xpp = (const void *)xp; +#line 3637 + return status; +#line 3637 +#endif +#line 3637 +} +#line 3637 + +int +#line 3638 +ncx_getn_longlong_short(const void **xpp, size_t nelems, short *tp) +#line 3638 +{ +#line 3638 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3638 + +#line 3638 + /* basic algorithm is: +#line 3638 + * - ensure sane alignment of input data +#line 3638 + * - copy (conversion happens automatically) input data +#line 3638 + * to output +#line 3638 + * - update xpp to point at next unconverted input, and tp to point +#line 3638 + * at next location for converted output +#line 3638 + */ +#line 3638 + long i, j, ni; +#line 3638 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3638 + int64 *xp; +#line 3638 + int nrange = 0; /* number of range errors */ +#line 3638 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3638 + long cxp = (long) *((char**)xpp); +#line 3638 + +#line 3638 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3638 + /* sjl: manually stripmine so we can limit amount of +#line 3638 + * vector work space reserved to LOOPCNT elements. Also +#line 3638 + * makes vectorisation easy */ +#line 3638 + for (j=0; j= 0 */ +#line 3638 + nrange += xp[i] > SHORT_MAX || xp[i] < SHORT_MIN; +#line 3638 + } +#line 3638 + /* update xpp and tp */ +#line 3638 + if (realign) xp = (int64 *) *xpp; +#line 3638 + xp += ni; +#line 3638 + tp += ni; +#line 3638 + *xpp = (void*)xp; +#line 3638 + } +#line 3638 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3638 + +#line 3638 +#else /* not SX */ +#line 3638 + const char *xp = (const char *) *xpp; +#line 3638 + int status = NC_NOERR; +#line 3638 + +#line 3638 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3638 + { +#line 3638 + const int lstatus = ncx_get_longlong_short(xp, tp); +#line 3638 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3638 + status = lstatus; +#line 3638 + } +#line 3638 + +#line 3638 + *xpp = (const void *)xp; +#line 3638 + return status; +#line 3638 +#endif +#line 3638 +} +#line 3638 + +int +#line 3639 +ncx_getn_longlong_int(const void **xpp, size_t nelems, int *tp) +#line 3639 +{ +#line 3639 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3639 + +#line 3639 + /* basic algorithm is: +#line 3639 + * - ensure sane alignment of input data +#line 3639 + * - copy (conversion happens automatically) input data +#line 3639 + * to output +#line 3639 + * - update xpp to point at next unconverted input, and tp to point +#line 3639 + * at next location for converted output +#line 3639 + */ +#line 3639 + long i, j, ni; +#line 3639 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3639 + int64 *xp; +#line 3639 + int nrange = 0; /* number of range errors */ +#line 3639 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3639 + long cxp = (long) *((char**)xpp); +#line 3639 + +#line 3639 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3639 + /* sjl: manually stripmine so we can limit amount of +#line 3639 + * vector work space reserved to LOOPCNT elements. Also +#line 3639 + * makes vectorisation easy */ +#line 3639 + for (j=0; j= 0 */ +#line 3639 + nrange += xp[i] > INT_MAX || xp[i] < INT_MIN; +#line 3639 + } +#line 3639 + /* update xpp and tp */ +#line 3639 + if (realign) xp = (int64 *) *xpp; +#line 3639 + xp += ni; +#line 3639 + tp += ni; +#line 3639 + *xpp = (void*)xp; +#line 3639 + } +#line 3639 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3639 + +#line 3639 +#else /* not SX */ +#line 3639 + const char *xp = (const char *) *xpp; +#line 3639 + int status = NC_NOERR; +#line 3639 + +#line 3639 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3639 + { +#line 3639 + const int lstatus = ncx_get_longlong_int(xp, tp); +#line 3639 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3639 + status = lstatus; +#line 3639 + } +#line 3639 + +#line 3639 + *xpp = (const void *)xp; +#line 3639 + return status; +#line 3639 +#endif +#line 3639 +} +#line 3639 + +int +#line 3640 +ncx_getn_longlong_long(const void **xpp, size_t nelems, long *tp) +#line 3640 +{ +#line 3640 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3640 + +#line 3640 + /* basic algorithm is: +#line 3640 + * - ensure sane alignment of input data +#line 3640 + * - copy (conversion happens automatically) input data +#line 3640 + * to output +#line 3640 + * - update xpp to point at next unconverted input, and tp to point +#line 3640 + * at next location for converted output +#line 3640 + */ +#line 3640 + long i, j, ni; +#line 3640 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3640 + int64 *xp; +#line 3640 + int nrange = 0; /* number of range errors */ +#line 3640 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3640 + long cxp = (long) *((char**)xpp); +#line 3640 + +#line 3640 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3640 + /* sjl: manually stripmine so we can limit amount of +#line 3640 + * vector work space reserved to LOOPCNT elements. Also +#line 3640 + * makes vectorisation easy */ +#line 3640 + for (j=0; j= 0 */ +#line 3640 + nrange += xp[i] > LONG_MAX || xp[i] < LONG_MIN; +#line 3640 + } +#line 3640 + /* update xpp and tp */ +#line 3640 + if (realign) xp = (int64 *) *xpp; +#line 3640 + xp += ni; +#line 3640 + tp += ni; +#line 3640 + *xpp = (void*)xp; +#line 3640 + } +#line 3640 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3640 + +#line 3640 +#else /* not SX */ +#line 3640 + const char *xp = (const char *) *xpp; +#line 3640 + int status = NC_NOERR; +#line 3640 + +#line 3640 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3640 + { +#line 3640 + const int lstatus = ncx_get_longlong_long(xp, tp); +#line 3640 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3640 + status = lstatus; +#line 3640 + } +#line 3640 + +#line 3640 + *xpp = (const void *)xp; +#line 3640 + return status; +#line 3640 +#endif +#line 3640 +} +#line 3640 + +int +#line 3641 +ncx_getn_longlong_float(const void **xpp, size_t nelems, float *tp) +#line 3641 +{ +#line 3641 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3641 + +#line 3641 + /* basic algorithm is: +#line 3641 + * - ensure sane alignment of input data +#line 3641 + * - copy (conversion happens automatically) input data +#line 3641 + * to output +#line 3641 + * - update xpp to point at next unconverted input, and tp to point +#line 3641 + * at next location for converted output +#line 3641 + */ +#line 3641 + long i, j, ni; +#line 3641 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3641 + int64 *xp; +#line 3641 + int nrange = 0; /* number of range errors */ +#line 3641 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3641 + long cxp = (long) *((char**)xpp); +#line 3641 + +#line 3641 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3641 + /* sjl: manually stripmine so we can limit amount of +#line 3641 + * vector work space reserved to LOOPCNT elements. Also +#line 3641 + * makes vectorisation easy */ +#line 3641 + for (j=0; j= 0 */ +#line 3641 + nrange += xp[i] > FLOAT_MAX || xp[i] < FLOAT_MIN; +#line 3641 + } +#line 3641 + /* update xpp and tp */ +#line 3641 + if (realign) xp = (int64 *) *xpp; +#line 3641 + xp += ni; +#line 3641 + tp += ni; +#line 3641 + *xpp = (void*)xp; +#line 3641 + } +#line 3641 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3641 + +#line 3641 +#else /* not SX */ +#line 3641 + const char *xp = (const char *) *xpp; +#line 3641 + int status = NC_NOERR; +#line 3641 + +#line 3641 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3641 + { +#line 3641 + const int lstatus = ncx_get_longlong_float(xp, tp); +#line 3641 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3641 + status = lstatus; +#line 3641 + } +#line 3641 + +#line 3641 + *xpp = (const void *)xp; +#line 3641 + return status; +#line 3641 +#endif +#line 3641 +} +#line 3641 + +int +#line 3642 +ncx_getn_longlong_double(const void **xpp, size_t nelems, double *tp) +#line 3642 +{ +#line 3642 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3642 + +#line 3642 + /* basic algorithm is: +#line 3642 + * - ensure sane alignment of input data +#line 3642 + * - copy (conversion happens automatically) input data +#line 3642 + * to output +#line 3642 + * - update xpp to point at next unconverted input, and tp to point +#line 3642 + * at next location for converted output +#line 3642 + */ +#line 3642 + long i, j, ni; +#line 3642 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3642 + int64 *xp; +#line 3642 + int nrange = 0; /* number of range errors */ +#line 3642 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3642 + long cxp = (long) *((char**)xpp); +#line 3642 + +#line 3642 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3642 + /* sjl: manually stripmine so we can limit amount of +#line 3642 + * vector work space reserved to LOOPCNT elements. Also +#line 3642 + * makes vectorisation easy */ +#line 3642 + for (j=0; j= 0 */ +#line 3642 + nrange += xp[i] > DOUBLE_MAX || xp[i] < DOUBLE_MIN; +#line 3642 + } +#line 3642 + /* update xpp and tp */ +#line 3642 + if (realign) xp = (int64 *) *xpp; +#line 3642 + xp += ni; +#line 3642 + tp += ni; +#line 3642 + *xpp = (void*)xp; +#line 3642 + } +#line 3642 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3642 + +#line 3642 +#else /* not SX */ +#line 3642 + const char *xp = (const char *) *xpp; +#line 3642 + int status = NC_NOERR; +#line 3642 + +#line 3642 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3642 + { +#line 3642 + const int lstatus = ncx_get_longlong_double(xp, tp); +#line 3642 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3642 + status = lstatus; +#line 3642 + } +#line 3642 + +#line 3642 + *xpp = (const void *)xp; +#line 3642 + return status; +#line 3642 +#endif +#line 3642 +} +#line 3642 + +int +#line 3643 +ncx_getn_longlong_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 3643 +{ +#line 3643 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3643 + +#line 3643 + /* basic algorithm is: +#line 3643 + * - ensure sane alignment of input data +#line 3643 + * - copy (conversion happens automatically) input data +#line 3643 + * to output +#line 3643 + * - update xpp to point at next unconverted input, and tp to point +#line 3643 + * at next location for converted output +#line 3643 + */ +#line 3643 + long i, j, ni; +#line 3643 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3643 + int64 *xp; +#line 3643 + int nrange = 0; /* number of range errors */ +#line 3643 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3643 + long cxp = (long) *((char**)xpp); +#line 3643 + +#line 3643 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3643 + /* sjl: manually stripmine so we can limit amount of +#line 3643 + * vector work space reserved to LOOPCNT elements. Also +#line 3643 + * makes vectorisation easy */ +#line 3643 + for (j=0; j= 0 */ +#line 3643 + nrange += xp[i] > UCHAR_MAX || xp[i] < 0; +#line 3643 + } +#line 3643 + /* update xpp and tp */ +#line 3643 + if (realign) xp = (int64 *) *xpp; +#line 3643 + xp += ni; +#line 3643 + tp += ni; +#line 3643 + *xpp = (void*)xp; +#line 3643 + } +#line 3643 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3643 + +#line 3643 +#else /* not SX */ +#line 3643 + const char *xp = (const char *) *xpp; +#line 3643 + int status = NC_NOERR; +#line 3643 + +#line 3643 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3643 + { +#line 3643 + const int lstatus = ncx_get_longlong_uchar(xp, tp); +#line 3643 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3643 + status = lstatus; +#line 3643 + } +#line 3643 + +#line 3643 + *xpp = (const void *)xp; +#line 3643 + return status; +#line 3643 +#endif +#line 3643 +} +#line 3643 + +int +#line 3644 +ncx_getn_longlong_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 3644 +{ +#line 3644 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3644 + +#line 3644 + /* basic algorithm is: +#line 3644 + * - ensure sane alignment of input data +#line 3644 + * - copy (conversion happens automatically) input data +#line 3644 + * to output +#line 3644 + * - update xpp to point at next unconverted input, and tp to point +#line 3644 + * at next location for converted output +#line 3644 + */ +#line 3644 + long i, j, ni; +#line 3644 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3644 + int64 *xp; +#line 3644 + int nrange = 0; /* number of range errors */ +#line 3644 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3644 + long cxp = (long) *((char**)xpp); +#line 3644 + +#line 3644 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3644 + /* sjl: manually stripmine so we can limit amount of +#line 3644 + * vector work space reserved to LOOPCNT elements. Also +#line 3644 + * makes vectorisation easy */ +#line 3644 + for (j=0; j= 0 */ +#line 3644 + nrange += xp[i] > USHORT_MAX || xp[i] < 0; +#line 3644 + } +#line 3644 + /* update xpp and tp */ +#line 3644 + if (realign) xp = (int64 *) *xpp; +#line 3644 + xp += ni; +#line 3644 + tp += ni; +#line 3644 + *xpp = (void*)xp; +#line 3644 + } +#line 3644 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3644 + +#line 3644 +#else /* not SX */ +#line 3644 + const char *xp = (const char *) *xpp; +#line 3644 + int status = NC_NOERR; +#line 3644 + +#line 3644 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3644 + { +#line 3644 + const int lstatus = ncx_get_longlong_ushort(xp, tp); +#line 3644 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3644 + status = lstatus; +#line 3644 + } +#line 3644 + +#line 3644 + *xpp = (const void *)xp; +#line 3644 + return status; +#line 3644 +#endif +#line 3644 +} +#line 3644 + +int +#line 3645 +ncx_getn_longlong_uint(const void **xpp, size_t nelems, uint *tp) +#line 3645 +{ +#line 3645 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3645 + +#line 3645 + /* basic algorithm is: +#line 3645 + * - ensure sane alignment of input data +#line 3645 + * - copy (conversion happens automatically) input data +#line 3645 + * to output +#line 3645 + * - update xpp to point at next unconverted input, and tp to point +#line 3645 + * at next location for converted output +#line 3645 + */ +#line 3645 + long i, j, ni; +#line 3645 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3645 + int64 *xp; +#line 3645 + int nrange = 0; /* number of range errors */ +#line 3645 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3645 + long cxp = (long) *((char**)xpp); +#line 3645 + +#line 3645 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3645 + /* sjl: manually stripmine so we can limit amount of +#line 3645 + * vector work space reserved to LOOPCNT elements. Also +#line 3645 + * makes vectorisation easy */ +#line 3645 + for (j=0; j= 0 */ +#line 3645 + nrange += xp[i] > UINT_MAX || xp[i] < 0; +#line 3645 + } +#line 3645 + /* update xpp and tp */ +#line 3645 + if (realign) xp = (int64 *) *xpp; +#line 3645 + xp += ni; +#line 3645 + tp += ni; +#line 3645 + *xpp = (void*)xp; +#line 3645 + } +#line 3645 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3645 + +#line 3645 +#else /* not SX */ +#line 3645 + const char *xp = (const char *) *xpp; +#line 3645 + int status = NC_NOERR; +#line 3645 + +#line 3645 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3645 + { +#line 3645 + const int lstatus = ncx_get_longlong_uint(xp, tp); +#line 3645 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3645 + status = lstatus; +#line 3645 + } +#line 3645 + +#line 3645 + *xpp = (const void *)xp; +#line 3645 + return status; +#line 3645 +#endif +#line 3645 +} +#line 3645 + +int +#line 3646 +ncx_getn_longlong_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 3646 +{ +#line 3646 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3646 + +#line 3646 + /* basic algorithm is: +#line 3646 + * - ensure sane alignment of input data +#line 3646 + * - copy (conversion happens automatically) input data +#line 3646 + * to output +#line 3646 + * - update xpp to point at next unconverted input, and tp to point +#line 3646 + * at next location for converted output +#line 3646 + */ +#line 3646 + long i, j, ni; +#line 3646 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3646 + int64 *xp; +#line 3646 + int nrange = 0; /* number of range errors */ +#line 3646 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3646 + long cxp = (long) *((char**)xpp); +#line 3646 + +#line 3646 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3646 + /* sjl: manually stripmine so we can limit amount of +#line 3646 + * vector work space reserved to LOOPCNT elements. Also +#line 3646 + * makes vectorisation easy */ +#line 3646 + for (j=0; j= 0 */ +#line 3646 + nrange += xp[i] > ULONGLONG_MAX || xp[i] < 0; +#line 3646 + } +#line 3646 + /* update xpp and tp */ +#line 3646 + if (realign) xp = (int64 *) *xpp; +#line 3646 + xp += ni; +#line 3646 + tp += ni; +#line 3646 + *xpp = (void*)xp; +#line 3646 + } +#line 3646 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3646 + +#line 3646 +#else /* not SX */ +#line 3646 + const char *xp = (const char *) *xpp; +#line 3646 + int status = NC_NOERR; +#line 3646 + +#line 3646 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3646 + { +#line 3646 + const int lstatus = ncx_get_longlong_ulonglong(xp, tp); +#line 3646 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3646 + status = lstatus; +#line 3646 + } +#line 3646 + +#line 3646 + *xpp = (const void *)xp; +#line 3646 + return status; +#line 3646 +#endif +#line 3646 +} +#line 3646 + + +#if X_SIZEOF_INT64 == SIZEOF_LONGLONG +/* optimized version */ +int +ncx_putn_longlong_longlong(void **xpp, size_t nelems, const long long *tp, void *fillp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(*xpp, tp, (size_t)nelems * X_SIZEOF_INT64); +# else + swapn8b(*xpp, tp, nelems); +# endif + *xpp = (void *)((char *)(*xpp) + nelems * X_SIZEOF_INT64); + return NC_NOERR; +} +#else +int +#line 3662 +ncx_putn_longlong_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3662 +{ +#line 3662 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3662 + +#line 3662 + /* basic algorithm is: +#line 3662 + * - ensure sane alignment of output data +#line 3662 + * - copy (conversion happens automatically) input data +#line 3662 + * to output +#line 3662 + * - update tp to point at next unconverted input, and xpp to point +#line 3662 + * at next location for converted output +#line 3662 + */ +#line 3662 + long i, j, ni; +#line 3662 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3662 + int64 *xp; +#line 3662 + int nrange = 0; /* number of range errors */ +#line 3662 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3662 + long cxp = (long) *((char**)xpp); +#line 3662 + +#line 3662 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3662 + /* sjl: manually stripmine so we can limit amount of +#line 3662 + * vector work space reserved to LOOPCNT elements. Also +#line 3662 + * makes vectorisation easy */ +#line 3662 + for (j=0; j= 0 */ +#line 3662 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3662 + nrange += tp[i] > X_INT64_MAX || tp[i] < X_INT64_MIN; +#line 3662 + } +#line 3662 + /* copy workspace back if necessary */ +#line 3662 + if (realign) { +#line 3662 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT64); +#line 3662 + xp = (int64 *) *xpp; +#line 3662 + } +#line 3662 + /* update xpp and tp */ +#line 3662 + xp += ni; +#line 3662 + tp += ni; +#line 3662 + *xpp = (void*)xp; +#line 3662 + } +#line 3662 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3662 + +#line 3662 +#else /* not SX */ +#line 3662 + +#line 3662 + char *xp = (char *) *xpp; +#line 3662 + int status = NC_NOERR; +#line 3662 + +#line 3662 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3662 + { +#line 3662 + int lstatus = ncx_put_longlong_longlong(xp, tp, fillp); +#line 3662 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3662 + status = lstatus; +#line 3662 + } +#line 3662 + +#line 3662 + *xpp = (void *)xp; +#line 3662 + return status; +#line 3662 +#endif +#line 3662 +} +#line 3662 + +#endif +int +#line 3664 +ncx_putn_longlong_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +#line 3664 +{ +#line 3664 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3664 + +#line 3664 + /* basic algorithm is: +#line 3664 + * - ensure sane alignment of output data +#line 3664 + * - copy (conversion happens automatically) input data +#line 3664 + * to output +#line 3664 + * - update tp to point at next unconverted input, and xpp to point +#line 3664 + * at next location for converted output +#line 3664 + */ +#line 3664 + long i, j, ni; +#line 3664 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3664 + int64 *xp; +#line 3664 + int nrange = 0; /* number of range errors */ +#line 3664 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3664 + long cxp = (long) *((char**)xpp); +#line 3664 + +#line 3664 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3664 + /* sjl: manually stripmine so we can limit amount of +#line 3664 + * vector work space reserved to LOOPCNT elements. Also +#line 3664 + * makes vectorisation easy */ +#line 3664 + for (j=0; j= 0 */ +#line 3664 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3664 + nrange += tp[i] > X_INT64_MAX || tp[i] < X_INT64_MIN; +#line 3664 + } +#line 3664 + /* copy workspace back if necessary */ +#line 3664 + if (realign) { +#line 3664 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT64); +#line 3664 + xp = (int64 *) *xpp; +#line 3664 + } +#line 3664 + /* update xpp and tp */ +#line 3664 + xp += ni; +#line 3664 + tp += ni; +#line 3664 + *xpp = (void*)xp; +#line 3664 + } +#line 3664 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3664 + +#line 3664 +#else /* not SX */ +#line 3664 + +#line 3664 + char *xp = (char *) *xpp; +#line 3664 + int status = NC_NOERR; +#line 3664 + +#line 3664 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3664 + { +#line 3664 + int lstatus = ncx_put_longlong_schar(xp, tp, fillp); +#line 3664 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3664 + status = lstatus; +#line 3664 + } +#line 3664 + +#line 3664 + *xpp = (void *)xp; +#line 3664 + return status; +#line 3664 +#endif +#line 3664 +} +#line 3664 + +int +#line 3665 +ncx_putn_longlong_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3665 +{ +#line 3665 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3665 + +#line 3665 + /* basic algorithm is: +#line 3665 + * - ensure sane alignment of output data +#line 3665 + * - copy (conversion happens automatically) input data +#line 3665 + * to output +#line 3665 + * - update tp to point at next unconverted input, and xpp to point +#line 3665 + * at next location for converted output +#line 3665 + */ +#line 3665 + long i, j, ni; +#line 3665 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3665 + int64 *xp; +#line 3665 + int nrange = 0; /* number of range errors */ +#line 3665 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3665 + long cxp = (long) *((char**)xpp); +#line 3665 + +#line 3665 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3665 + /* sjl: manually stripmine so we can limit amount of +#line 3665 + * vector work space reserved to LOOPCNT elements. Also +#line 3665 + * makes vectorisation easy */ +#line 3665 + for (j=0; j= 0 */ +#line 3665 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3665 + nrange += tp[i] > X_INT64_MAX || tp[i] < X_INT64_MIN; +#line 3665 + } +#line 3665 + /* copy workspace back if necessary */ +#line 3665 + if (realign) { +#line 3665 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT64); +#line 3665 + xp = (int64 *) *xpp; +#line 3665 + } +#line 3665 + /* update xpp and tp */ +#line 3665 + xp += ni; +#line 3665 + tp += ni; +#line 3665 + *xpp = (void*)xp; +#line 3665 + } +#line 3665 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3665 + +#line 3665 +#else /* not SX */ +#line 3665 + +#line 3665 + char *xp = (char *) *xpp; +#line 3665 + int status = NC_NOERR; +#line 3665 + +#line 3665 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3665 + { +#line 3665 + int lstatus = ncx_put_longlong_short(xp, tp, fillp); +#line 3665 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3665 + status = lstatus; +#line 3665 + } +#line 3665 + +#line 3665 + *xpp = (void *)xp; +#line 3665 + return status; +#line 3665 +#endif +#line 3665 +} +#line 3665 + +int +#line 3666 +ncx_putn_longlong_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3666 +{ +#line 3666 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3666 + +#line 3666 + /* basic algorithm is: +#line 3666 + * - ensure sane alignment of output data +#line 3666 + * - copy (conversion happens automatically) input data +#line 3666 + * to output +#line 3666 + * - update tp to point at next unconverted input, and xpp to point +#line 3666 + * at next location for converted output +#line 3666 + */ +#line 3666 + long i, j, ni; +#line 3666 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3666 + int64 *xp; +#line 3666 + int nrange = 0; /* number of range errors */ +#line 3666 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3666 + long cxp = (long) *((char**)xpp); +#line 3666 + +#line 3666 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3666 + /* sjl: manually stripmine so we can limit amount of +#line 3666 + * vector work space reserved to LOOPCNT elements. Also +#line 3666 + * makes vectorisation easy */ +#line 3666 + for (j=0; j= 0 */ +#line 3666 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3666 + nrange += tp[i] > X_INT64_MAX || tp[i] < X_INT64_MIN; +#line 3666 + } +#line 3666 + /* copy workspace back if necessary */ +#line 3666 + if (realign) { +#line 3666 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT64); +#line 3666 + xp = (int64 *) *xpp; +#line 3666 + } +#line 3666 + /* update xpp and tp */ +#line 3666 + xp += ni; +#line 3666 + tp += ni; +#line 3666 + *xpp = (void*)xp; +#line 3666 + } +#line 3666 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3666 + +#line 3666 +#else /* not SX */ +#line 3666 + +#line 3666 + char *xp = (char *) *xpp; +#line 3666 + int status = NC_NOERR; +#line 3666 + +#line 3666 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3666 + { +#line 3666 + int lstatus = ncx_put_longlong_int(xp, tp, fillp); +#line 3666 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3666 + status = lstatus; +#line 3666 + } +#line 3666 + +#line 3666 + *xpp = (void *)xp; +#line 3666 + return status; +#line 3666 +#endif +#line 3666 +} +#line 3666 + +int +#line 3667 +ncx_putn_longlong_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3667 +{ +#line 3667 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3667 + +#line 3667 + /* basic algorithm is: +#line 3667 + * - ensure sane alignment of output data +#line 3667 + * - copy (conversion happens automatically) input data +#line 3667 + * to output +#line 3667 + * - update tp to point at next unconverted input, and xpp to point +#line 3667 + * at next location for converted output +#line 3667 + */ +#line 3667 + long i, j, ni; +#line 3667 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3667 + int64 *xp; +#line 3667 + int nrange = 0; /* number of range errors */ +#line 3667 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3667 + long cxp = (long) *((char**)xpp); +#line 3667 + +#line 3667 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3667 + /* sjl: manually stripmine so we can limit amount of +#line 3667 + * vector work space reserved to LOOPCNT elements. Also +#line 3667 + * makes vectorisation easy */ +#line 3667 + for (j=0; j= 0 */ +#line 3667 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3667 + nrange += tp[i] > X_INT64_MAX || tp[i] < X_INT64_MIN; +#line 3667 + } +#line 3667 + /* copy workspace back if necessary */ +#line 3667 + if (realign) { +#line 3667 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT64); +#line 3667 + xp = (int64 *) *xpp; +#line 3667 + } +#line 3667 + /* update xpp and tp */ +#line 3667 + xp += ni; +#line 3667 + tp += ni; +#line 3667 + *xpp = (void*)xp; +#line 3667 + } +#line 3667 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3667 + +#line 3667 +#else /* not SX */ +#line 3667 + +#line 3667 + char *xp = (char *) *xpp; +#line 3667 + int status = NC_NOERR; +#line 3667 + +#line 3667 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3667 + { +#line 3667 + int lstatus = ncx_put_longlong_long(xp, tp, fillp); +#line 3667 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3667 + status = lstatus; +#line 3667 + } +#line 3667 + +#line 3667 + *xpp = (void *)xp; +#line 3667 + return status; +#line 3667 +#endif +#line 3667 +} +#line 3667 + +int +#line 3668 +ncx_putn_longlong_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 3668 +{ +#line 3668 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3668 + +#line 3668 + /* basic algorithm is: +#line 3668 + * - ensure sane alignment of output data +#line 3668 + * - copy (conversion happens automatically) input data +#line 3668 + * to output +#line 3668 + * - update tp to point at next unconverted input, and xpp to point +#line 3668 + * at next location for converted output +#line 3668 + */ +#line 3668 + long i, j, ni; +#line 3668 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3668 + int64 *xp; +#line 3668 + int nrange = 0; /* number of range errors */ +#line 3668 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3668 + long cxp = (long) *((char**)xpp); +#line 3668 + +#line 3668 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3668 + /* sjl: manually stripmine so we can limit amount of +#line 3668 + * vector work space reserved to LOOPCNT elements. Also +#line 3668 + * makes vectorisation easy */ +#line 3668 + for (j=0; j= 0 */ +#line 3668 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3668 + nrange += tp[i] > X_INT64_MAX || tp[i] < X_INT64_MIN; +#line 3668 + } +#line 3668 + /* copy workspace back if necessary */ +#line 3668 + if (realign) { +#line 3668 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT64); +#line 3668 + xp = (int64 *) *xpp; +#line 3668 + } +#line 3668 + /* update xpp and tp */ +#line 3668 + xp += ni; +#line 3668 + tp += ni; +#line 3668 + *xpp = (void*)xp; +#line 3668 + } +#line 3668 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3668 + +#line 3668 +#else /* not SX */ +#line 3668 + +#line 3668 + char *xp = (char *) *xpp; +#line 3668 + int status = NC_NOERR; +#line 3668 + +#line 3668 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3668 + { +#line 3668 + int lstatus = ncx_put_longlong_float(xp, tp, fillp); +#line 3668 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3668 + status = lstatus; +#line 3668 + } +#line 3668 + +#line 3668 + *xpp = (void *)xp; +#line 3668 + return status; +#line 3668 +#endif +#line 3668 +} +#line 3668 + +int +#line 3669 +ncx_putn_longlong_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 3669 +{ +#line 3669 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3669 + +#line 3669 + /* basic algorithm is: +#line 3669 + * - ensure sane alignment of output data +#line 3669 + * - copy (conversion happens automatically) input data +#line 3669 + * to output +#line 3669 + * - update tp to point at next unconverted input, and xpp to point +#line 3669 + * at next location for converted output +#line 3669 + */ +#line 3669 + long i, j, ni; +#line 3669 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3669 + int64 *xp; +#line 3669 + int nrange = 0; /* number of range errors */ +#line 3669 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3669 + long cxp = (long) *((char**)xpp); +#line 3669 + +#line 3669 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3669 + /* sjl: manually stripmine so we can limit amount of +#line 3669 + * vector work space reserved to LOOPCNT elements. Also +#line 3669 + * makes vectorisation easy */ +#line 3669 + for (j=0; j= 0 */ +#line 3669 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3669 + nrange += tp[i] > X_INT64_MAX || tp[i] < X_INT64_MIN; +#line 3669 + } +#line 3669 + /* copy workspace back if necessary */ +#line 3669 + if (realign) { +#line 3669 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT64); +#line 3669 + xp = (int64 *) *xpp; +#line 3669 + } +#line 3669 + /* update xpp and tp */ +#line 3669 + xp += ni; +#line 3669 + tp += ni; +#line 3669 + *xpp = (void*)xp; +#line 3669 + } +#line 3669 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3669 + +#line 3669 +#else /* not SX */ +#line 3669 + +#line 3669 + char *xp = (char *) *xpp; +#line 3669 + int status = NC_NOERR; +#line 3669 + +#line 3669 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3669 + { +#line 3669 + int lstatus = ncx_put_longlong_double(xp, tp, fillp); +#line 3669 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3669 + status = lstatus; +#line 3669 + } +#line 3669 + +#line 3669 + *xpp = (void *)xp; +#line 3669 + return status; +#line 3669 +#endif +#line 3669 +} +#line 3669 + +int +#line 3670 +ncx_putn_longlong_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 3670 +{ +#line 3670 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3670 + +#line 3670 + /* basic algorithm is: +#line 3670 + * - ensure sane alignment of output data +#line 3670 + * - copy (conversion happens automatically) input data +#line 3670 + * to output +#line 3670 + * - update tp to point at next unconverted input, and xpp to point +#line 3670 + * at next location for converted output +#line 3670 + */ +#line 3670 + long i, j, ni; +#line 3670 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3670 + int64 *xp; +#line 3670 + int nrange = 0; /* number of range errors */ +#line 3670 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3670 + long cxp = (long) *((char**)xpp); +#line 3670 + +#line 3670 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3670 + /* sjl: manually stripmine so we can limit amount of +#line 3670 + * vector work space reserved to LOOPCNT elements. Also +#line 3670 + * makes vectorisation easy */ +#line 3670 + for (j=0; j= 0 */ +#line 3670 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3670 + nrange += tp[i] > X_INT64_MAX ; +#line 3670 + } +#line 3670 + /* copy workspace back if necessary */ +#line 3670 + if (realign) { +#line 3670 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT64); +#line 3670 + xp = (int64 *) *xpp; +#line 3670 + } +#line 3670 + /* update xpp and tp */ +#line 3670 + xp += ni; +#line 3670 + tp += ni; +#line 3670 + *xpp = (void*)xp; +#line 3670 + } +#line 3670 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3670 + +#line 3670 +#else /* not SX */ +#line 3670 + +#line 3670 + char *xp = (char *) *xpp; +#line 3670 + int status = NC_NOERR; +#line 3670 + +#line 3670 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3670 + { +#line 3670 + int lstatus = ncx_put_longlong_uchar(xp, tp, fillp); +#line 3670 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3670 + status = lstatus; +#line 3670 + } +#line 3670 + +#line 3670 + *xpp = (void *)xp; +#line 3670 + return status; +#line 3670 +#endif +#line 3670 +} +#line 3670 + +int +#line 3671 +ncx_putn_longlong_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3671 +{ +#line 3671 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3671 + +#line 3671 + /* basic algorithm is: +#line 3671 + * - ensure sane alignment of output data +#line 3671 + * - copy (conversion happens automatically) input data +#line 3671 + * to output +#line 3671 + * - update tp to point at next unconverted input, and xpp to point +#line 3671 + * at next location for converted output +#line 3671 + */ +#line 3671 + long i, j, ni; +#line 3671 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3671 + int64 *xp; +#line 3671 + int nrange = 0; /* number of range errors */ +#line 3671 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3671 + long cxp = (long) *((char**)xpp); +#line 3671 + +#line 3671 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3671 + /* sjl: manually stripmine so we can limit amount of +#line 3671 + * vector work space reserved to LOOPCNT elements. Also +#line 3671 + * makes vectorisation easy */ +#line 3671 + for (j=0; j= 0 */ +#line 3671 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3671 + nrange += tp[i] > X_INT64_MAX ; +#line 3671 + } +#line 3671 + /* copy workspace back if necessary */ +#line 3671 + if (realign) { +#line 3671 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT64); +#line 3671 + xp = (int64 *) *xpp; +#line 3671 + } +#line 3671 + /* update xpp and tp */ +#line 3671 + xp += ni; +#line 3671 + tp += ni; +#line 3671 + *xpp = (void*)xp; +#line 3671 + } +#line 3671 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3671 + +#line 3671 +#else /* not SX */ +#line 3671 + +#line 3671 + char *xp = (char *) *xpp; +#line 3671 + int status = NC_NOERR; +#line 3671 + +#line 3671 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3671 + { +#line 3671 + int lstatus = ncx_put_longlong_ushort(xp, tp, fillp); +#line 3671 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3671 + status = lstatus; +#line 3671 + } +#line 3671 + +#line 3671 + *xpp = (void *)xp; +#line 3671 + return status; +#line 3671 +#endif +#line 3671 +} +#line 3671 + +int +#line 3672 +ncx_putn_longlong_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3672 +{ +#line 3672 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3672 + +#line 3672 + /* basic algorithm is: +#line 3672 + * - ensure sane alignment of output data +#line 3672 + * - copy (conversion happens automatically) input data +#line 3672 + * to output +#line 3672 + * - update tp to point at next unconverted input, and xpp to point +#line 3672 + * at next location for converted output +#line 3672 + */ +#line 3672 + long i, j, ni; +#line 3672 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3672 + int64 *xp; +#line 3672 + int nrange = 0; /* number of range errors */ +#line 3672 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3672 + long cxp = (long) *((char**)xpp); +#line 3672 + +#line 3672 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3672 + /* sjl: manually stripmine so we can limit amount of +#line 3672 + * vector work space reserved to LOOPCNT elements. Also +#line 3672 + * makes vectorisation easy */ +#line 3672 + for (j=0; j= 0 */ +#line 3672 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3672 + nrange += tp[i] > X_INT64_MAX ; +#line 3672 + } +#line 3672 + /* copy workspace back if necessary */ +#line 3672 + if (realign) { +#line 3672 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT64); +#line 3672 + xp = (int64 *) *xpp; +#line 3672 + } +#line 3672 + /* update xpp and tp */ +#line 3672 + xp += ni; +#line 3672 + tp += ni; +#line 3672 + *xpp = (void*)xp; +#line 3672 + } +#line 3672 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3672 + +#line 3672 +#else /* not SX */ +#line 3672 + +#line 3672 + char *xp = (char *) *xpp; +#line 3672 + int status = NC_NOERR; +#line 3672 + +#line 3672 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3672 + { +#line 3672 + int lstatus = ncx_put_longlong_uint(xp, tp, fillp); +#line 3672 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3672 + status = lstatus; +#line 3672 + } +#line 3672 + +#line 3672 + *xpp = (void *)xp; +#line 3672 + return status; +#line 3672 +#endif +#line 3672 +} +#line 3672 + +int +#line 3673 +ncx_putn_longlong_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3673 +{ +#line 3673 +#if defined(_SX) && _SX != 0 && X_SIZEOF_INT64 == SIZEOF_INT64 +#line 3673 + +#line 3673 + /* basic algorithm is: +#line 3673 + * - ensure sane alignment of output data +#line 3673 + * - copy (conversion happens automatically) input data +#line 3673 + * to output +#line 3673 + * - update tp to point at next unconverted input, and xpp to point +#line 3673 + * at next location for converted output +#line 3673 + */ +#line 3673 + long i, j, ni; +#line 3673 + int64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3673 + int64 *xp; +#line 3673 + int nrange = 0; /* number of range errors */ +#line 3673 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3673 + long cxp = (long) *((char**)xpp); +#line 3673 + +#line 3673 + realign = (cxp & 7) % SIZEOF_INT64; +#line 3673 + /* sjl: manually stripmine so we can limit amount of +#line 3673 + * vector work space reserved to LOOPCNT elements. Also +#line 3673 + * makes vectorisation easy */ +#line 3673 + for (j=0; j= 0 */ +#line 3673 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3673 + nrange += tp[i] > X_INT64_MAX ; +#line 3673 + } +#line 3673 + /* copy workspace back if necessary */ +#line 3673 + if (realign) { +#line 3673 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_INT64); +#line 3673 + xp = (int64 *) *xpp; +#line 3673 + } +#line 3673 + /* update xpp and tp */ +#line 3673 + xp += ni; +#line 3673 + tp += ni; +#line 3673 + *xpp = (void*)xp; +#line 3673 + } +#line 3673 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3673 + +#line 3673 +#else /* not SX */ +#line 3673 + +#line 3673 + char *xp = (char *) *xpp; +#line 3673 + int status = NC_NOERR; +#line 3673 + +#line 3673 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_INT64, tp++) +#line 3673 + { +#line 3673 + int lstatus = ncx_put_longlong_ulonglong(xp, tp, fillp); +#line 3673 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3673 + status = lstatus; +#line 3673 + } +#line 3673 + +#line 3673 + *xpp = (void *)xp; +#line 3673 + return status; +#line 3673 +#endif +#line 3673 +} +#line 3673 + + +/* uint64 --------------------------------------------------------------------*/ + +#if X_SIZEOF_UINT64 == SIZEOF_ULONGLONG +/* optimized version */ +int +ncx_getn_ulonglong_ulonglong(const void **xpp, size_t nelems, unsigned long long *tp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(tp, *xpp, (size_t)nelems * SIZEOF_UNSIGNED_LONG_LONG); +# else + swapn8b(tp, *xpp, nelems); +# endif + *xpp = (const void *)((const char *)(*xpp) + nelems * X_SIZEOF_UINT64); + return NC_NOERR; +} +#else +int +#line 3691 +ncx_getn_ulonglong_ulonglong(const void **xpp, size_t nelems, ulonglong *tp) +#line 3691 +{ +#line 3691 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3691 + +#line 3691 + /* basic algorithm is: +#line 3691 + * - ensure sane alignment of input data +#line 3691 + * - copy (conversion happens automatically) input data +#line 3691 + * to output +#line 3691 + * - update xpp to point at next unconverted input, and tp to point +#line 3691 + * at next location for converted output +#line 3691 + */ +#line 3691 + long i, j, ni; +#line 3691 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3691 + uint64 *xp; +#line 3691 + int nrange = 0; /* number of range errors */ +#line 3691 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3691 + long cxp = (long) *((char**)xpp); +#line 3691 + +#line 3691 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3691 + /* sjl: manually stripmine so we can limit amount of +#line 3691 + * vector work space reserved to LOOPCNT elements. Also +#line 3691 + * makes vectorisation easy */ +#line 3691 + for (j=0; j= 0 */ +#line 3691 + nrange += xp[i] > ULONGLONG_MAX ; +#line 3691 + } +#line 3691 + /* update xpp and tp */ +#line 3691 + if (realign) xp = (uint64 *) *xpp; +#line 3691 + xp += ni; +#line 3691 + tp += ni; +#line 3691 + *xpp = (void*)xp; +#line 3691 + } +#line 3691 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3691 + +#line 3691 +#else /* not SX */ +#line 3691 + const char *xp = (const char *) *xpp; +#line 3691 + int status = NC_NOERR; +#line 3691 + +#line 3691 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3691 + { +#line 3691 + const int lstatus = ncx_get_ulonglong_ulonglong(xp, tp); +#line 3691 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3691 + status = lstatus; +#line 3691 + } +#line 3691 + +#line 3691 + *xpp = (const void *)xp; +#line 3691 + return status; +#line 3691 +#endif +#line 3691 +} +#line 3691 + +#endif +int +#line 3693 +ncx_getn_ulonglong_schar(const void **xpp, size_t nelems, schar *tp) +#line 3693 +{ +#line 3693 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3693 + +#line 3693 + /* basic algorithm is: +#line 3693 + * - ensure sane alignment of input data +#line 3693 + * - copy (conversion happens automatically) input data +#line 3693 + * to output +#line 3693 + * - update xpp to point at next unconverted input, and tp to point +#line 3693 + * at next location for converted output +#line 3693 + */ +#line 3693 + long i, j, ni; +#line 3693 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3693 + uint64 *xp; +#line 3693 + int nrange = 0; /* number of range errors */ +#line 3693 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3693 + long cxp = (long) *((char**)xpp); +#line 3693 + +#line 3693 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3693 + /* sjl: manually stripmine so we can limit amount of +#line 3693 + * vector work space reserved to LOOPCNT elements. Also +#line 3693 + * makes vectorisation easy */ +#line 3693 + for (j=0; j= 0 */ +#line 3693 + nrange += xp[i] > SCHAR_MAX ; +#line 3693 + } +#line 3693 + /* update xpp and tp */ +#line 3693 + if (realign) xp = (uint64 *) *xpp; +#line 3693 + xp += ni; +#line 3693 + tp += ni; +#line 3693 + *xpp = (void*)xp; +#line 3693 + } +#line 3693 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3693 + +#line 3693 +#else /* not SX */ +#line 3693 + const char *xp = (const char *) *xpp; +#line 3693 + int status = NC_NOERR; +#line 3693 + +#line 3693 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3693 + { +#line 3693 + const int lstatus = ncx_get_ulonglong_schar(xp, tp); +#line 3693 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3693 + status = lstatus; +#line 3693 + } +#line 3693 + +#line 3693 + *xpp = (const void *)xp; +#line 3693 + return status; +#line 3693 +#endif +#line 3693 +} +#line 3693 + +int +#line 3694 +ncx_getn_ulonglong_short(const void **xpp, size_t nelems, short *tp) +#line 3694 +{ +#line 3694 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3694 + +#line 3694 + /* basic algorithm is: +#line 3694 + * - ensure sane alignment of input data +#line 3694 + * - copy (conversion happens automatically) input data +#line 3694 + * to output +#line 3694 + * - update xpp to point at next unconverted input, and tp to point +#line 3694 + * at next location for converted output +#line 3694 + */ +#line 3694 + long i, j, ni; +#line 3694 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3694 + uint64 *xp; +#line 3694 + int nrange = 0; /* number of range errors */ +#line 3694 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3694 + long cxp = (long) *((char**)xpp); +#line 3694 + +#line 3694 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3694 + /* sjl: manually stripmine so we can limit amount of +#line 3694 + * vector work space reserved to LOOPCNT elements. Also +#line 3694 + * makes vectorisation easy */ +#line 3694 + for (j=0; j= 0 */ +#line 3694 + nrange += xp[i] > SHORT_MAX ; +#line 3694 + } +#line 3694 + /* update xpp and tp */ +#line 3694 + if (realign) xp = (uint64 *) *xpp; +#line 3694 + xp += ni; +#line 3694 + tp += ni; +#line 3694 + *xpp = (void*)xp; +#line 3694 + } +#line 3694 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3694 + +#line 3694 +#else /* not SX */ +#line 3694 + const char *xp = (const char *) *xpp; +#line 3694 + int status = NC_NOERR; +#line 3694 + +#line 3694 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3694 + { +#line 3694 + const int lstatus = ncx_get_ulonglong_short(xp, tp); +#line 3694 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3694 + status = lstatus; +#line 3694 + } +#line 3694 + +#line 3694 + *xpp = (const void *)xp; +#line 3694 + return status; +#line 3694 +#endif +#line 3694 +} +#line 3694 + +int +#line 3695 +ncx_getn_ulonglong_int(const void **xpp, size_t nelems, int *tp) +#line 3695 +{ +#line 3695 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3695 + +#line 3695 + /* basic algorithm is: +#line 3695 + * - ensure sane alignment of input data +#line 3695 + * - copy (conversion happens automatically) input data +#line 3695 + * to output +#line 3695 + * - update xpp to point at next unconverted input, and tp to point +#line 3695 + * at next location for converted output +#line 3695 + */ +#line 3695 + long i, j, ni; +#line 3695 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3695 + uint64 *xp; +#line 3695 + int nrange = 0; /* number of range errors */ +#line 3695 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3695 + long cxp = (long) *((char**)xpp); +#line 3695 + +#line 3695 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3695 + /* sjl: manually stripmine so we can limit amount of +#line 3695 + * vector work space reserved to LOOPCNT elements. Also +#line 3695 + * makes vectorisation easy */ +#line 3695 + for (j=0; j= 0 */ +#line 3695 + nrange += xp[i] > INT_MAX ; +#line 3695 + } +#line 3695 + /* update xpp and tp */ +#line 3695 + if (realign) xp = (uint64 *) *xpp; +#line 3695 + xp += ni; +#line 3695 + tp += ni; +#line 3695 + *xpp = (void*)xp; +#line 3695 + } +#line 3695 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3695 + +#line 3695 +#else /* not SX */ +#line 3695 + const char *xp = (const char *) *xpp; +#line 3695 + int status = NC_NOERR; +#line 3695 + +#line 3695 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3695 + { +#line 3695 + const int lstatus = ncx_get_ulonglong_int(xp, tp); +#line 3695 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3695 + status = lstatus; +#line 3695 + } +#line 3695 + +#line 3695 + *xpp = (const void *)xp; +#line 3695 + return status; +#line 3695 +#endif +#line 3695 +} +#line 3695 + +int +#line 3696 +ncx_getn_ulonglong_long(const void **xpp, size_t nelems, long *tp) +#line 3696 +{ +#line 3696 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3696 + +#line 3696 + /* basic algorithm is: +#line 3696 + * - ensure sane alignment of input data +#line 3696 + * - copy (conversion happens automatically) input data +#line 3696 + * to output +#line 3696 + * - update xpp to point at next unconverted input, and tp to point +#line 3696 + * at next location for converted output +#line 3696 + */ +#line 3696 + long i, j, ni; +#line 3696 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3696 + uint64 *xp; +#line 3696 + int nrange = 0; /* number of range errors */ +#line 3696 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3696 + long cxp = (long) *((char**)xpp); +#line 3696 + +#line 3696 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3696 + /* sjl: manually stripmine so we can limit amount of +#line 3696 + * vector work space reserved to LOOPCNT elements. Also +#line 3696 + * makes vectorisation easy */ +#line 3696 + for (j=0; j= 0 */ +#line 3696 + nrange += xp[i] > LONG_MAX ; +#line 3696 + } +#line 3696 + /* update xpp and tp */ +#line 3696 + if (realign) xp = (uint64 *) *xpp; +#line 3696 + xp += ni; +#line 3696 + tp += ni; +#line 3696 + *xpp = (void*)xp; +#line 3696 + } +#line 3696 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3696 + +#line 3696 +#else /* not SX */ +#line 3696 + const char *xp = (const char *) *xpp; +#line 3696 + int status = NC_NOERR; +#line 3696 + +#line 3696 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3696 + { +#line 3696 + const int lstatus = ncx_get_ulonglong_long(xp, tp); +#line 3696 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3696 + status = lstatus; +#line 3696 + } +#line 3696 + +#line 3696 + *xpp = (const void *)xp; +#line 3696 + return status; +#line 3696 +#endif +#line 3696 +} +#line 3696 + +int +#line 3697 +ncx_getn_ulonglong_float(const void **xpp, size_t nelems, float *tp) +#line 3697 +{ +#line 3697 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3697 + +#line 3697 + /* basic algorithm is: +#line 3697 + * - ensure sane alignment of input data +#line 3697 + * - copy (conversion happens automatically) input data +#line 3697 + * to output +#line 3697 + * - update xpp to point at next unconverted input, and tp to point +#line 3697 + * at next location for converted output +#line 3697 + */ +#line 3697 + long i, j, ni; +#line 3697 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3697 + uint64 *xp; +#line 3697 + int nrange = 0; /* number of range errors */ +#line 3697 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3697 + long cxp = (long) *((char**)xpp); +#line 3697 + +#line 3697 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3697 + /* sjl: manually stripmine so we can limit amount of +#line 3697 + * vector work space reserved to LOOPCNT elements. Also +#line 3697 + * makes vectorisation easy */ +#line 3697 + for (j=0; j= 0 */ +#line 3697 + nrange += xp[i] > FLOAT_MAX ; +#line 3697 + } +#line 3697 + /* update xpp and tp */ +#line 3697 + if (realign) xp = (uint64 *) *xpp; +#line 3697 + xp += ni; +#line 3697 + tp += ni; +#line 3697 + *xpp = (void*)xp; +#line 3697 + } +#line 3697 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3697 + +#line 3697 +#else /* not SX */ +#line 3697 + const char *xp = (const char *) *xpp; +#line 3697 + int status = NC_NOERR; +#line 3697 + +#line 3697 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3697 + { +#line 3697 + const int lstatus = ncx_get_ulonglong_float(xp, tp); +#line 3697 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3697 + status = lstatus; +#line 3697 + } +#line 3697 + +#line 3697 + *xpp = (const void *)xp; +#line 3697 + return status; +#line 3697 +#endif +#line 3697 +} +#line 3697 + +int +#line 3698 +ncx_getn_ulonglong_double(const void **xpp, size_t nelems, double *tp) +#line 3698 +{ +#line 3698 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3698 + +#line 3698 + /* basic algorithm is: +#line 3698 + * - ensure sane alignment of input data +#line 3698 + * - copy (conversion happens automatically) input data +#line 3698 + * to output +#line 3698 + * - update xpp to point at next unconverted input, and tp to point +#line 3698 + * at next location for converted output +#line 3698 + */ +#line 3698 + long i, j, ni; +#line 3698 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3698 + uint64 *xp; +#line 3698 + int nrange = 0; /* number of range errors */ +#line 3698 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3698 + long cxp = (long) *((char**)xpp); +#line 3698 + +#line 3698 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3698 + /* sjl: manually stripmine so we can limit amount of +#line 3698 + * vector work space reserved to LOOPCNT elements. Also +#line 3698 + * makes vectorisation easy */ +#line 3698 + for (j=0; j= 0 */ +#line 3698 + nrange += xp[i] > DOUBLE_MAX ; +#line 3698 + } +#line 3698 + /* update xpp and tp */ +#line 3698 + if (realign) xp = (uint64 *) *xpp; +#line 3698 + xp += ni; +#line 3698 + tp += ni; +#line 3698 + *xpp = (void*)xp; +#line 3698 + } +#line 3698 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3698 + +#line 3698 +#else /* not SX */ +#line 3698 + const char *xp = (const char *) *xpp; +#line 3698 + int status = NC_NOERR; +#line 3698 + +#line 3698 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3698 + { +#line 3698 + const int lstatus = ncx_get_ulonglong_double(xp, tp); +#line 3698 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3698 + status = lstatus; +#line 3698 + } +#line 3698 + +#line 3698 + *xpp = (const void *)xp; +#line 3698 + return status; +#line 3698 +#endif +#line 3698 +} +#line 3698 + +int +#line 3699 +ncx_getn_ulonglong_longlong(const void **xpp, size_t nelems, longlong *tp) +#line 3699 +{ +#line 3699 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3699 + +#line 3699 + /* basic algorithm is: +#line 3699 + * - ensure sane alignment of input data +#line 3699 + * - copy (conversion happens automatically) input data +#line 3699 + * to output +#line 3699 + * - update xpp to point at next unconverted input, and tp to point +#line 3699 + * at next location for converted output +#line 3699 + */ +#line 3699 + long i, j, ni; +#line 3699 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3699 + uint64 *xp; +#line 3699 + int nrange = 0; /* number of range errors */ +#line 3699 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3699 + long cxp = (long) *((char**)xpp); +#line 3699 + +#line 3699 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3699 + /* sjl: manually stripmine so we can limit amount of +#line 3699 + * vector work space reserved to LOOPCNT elements. Also +#line 3699 + * makes vectorisation easy */ +#line 3699 + for (j=0; j= 0 */ +#line 3699 + nrange += xp[i] > LONGLONG_MAX ; +#line 3699 + } +#line 3699 + /* update xpp and tp */ +#line 3699 + if (realign) xp = (uint64 *) *xpp; +#line 3699 + xp += ni; +#line 3699 + tp += ni; +#line 3699 + *xpp = (void*)xp; +#line 3699 + } +#line 3699 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3699 + +#line 3699 +#else /* not SX */ +#line 3699 + const char *xp = (const char *) *xpp; +#line 3699 + int status = NC_NOERR; +#line 3699 + +#line 3699 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3699 + { +#line 3699 + const int lstatus = ncx_get_ulonglong_longlong(xp, tp); +#line 3699 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3699 + status = lstatus; +#line 3699 + } +#line 3699 + +#line 3699 + *xpp = (const void *)xp; +#line 3699 + return status; +#line 3699 +#endif +#line 3699 +} +#line 3699 + +int +#line 3700 +ncx_getn_ulonglong_uchar(const void **xpp, size_t nelems, uchar *tp) +#line 3700 +{ +#line 3700 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3700 + +#line 3700 + /* basic algorithm is: +#line 3700 + * - ensure sane alignment of input data +#line 3700 + * - copy (conversion happens automatically) input data +#line 3700 + * to output +#line 3700 + * - update xpp to point at next unconverted input, and tp to point +#line 3700 + * at next location for converted output +#line 3700 + */ +#line 3700 + long i, j, ni; +#line 3700 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3700 + uint64 *xp; +#line 3700 + int nrange = 0; /* number of range errors */ +#line 3700 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3700 + long cxp = (long) *((char**)xpp); +#line 3700 + +#line 3700 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3700 + /* sjl: manually stripmine so we can limit amount of +#line 3700 + * vector work space reserved to LOOPCNT elements. Also +#line 3700 + * makes vectorisation easy */ +#line 3700 + for (j=0; j= 0 */ +#line 3700 + nrange += xp[i] > UCHAR_MAX ; +#line 3700 + } +#line 3700 + /* update xpp and tp */ +#line 3700 + if (realign) xp = (uint64 *) *xpp; +#line 3700 + xp += ni; +#line 3700 + tp += ni; +#line 3700 + *xpp = (void*)xp; +#line 3700 + } +#line 3700 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3700 + +#line 3700 +#else /* not SX */ +#line 3700 + const char *xp = (const char *) *xpp; +#line 3700 + int status = NC_NOERR; +#line 3700 + +#line 3700 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3700 + { +#line 3700 + const int lstatus = ncx_get_ulonglong_uchar(xp, tp); +#line 3700 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3700 + status = lstatus; +#line 3700 + } +#line 3700 + +#line 3700 + *xpp = (const void *)xp; +#line 3700 + return status; +#line 3700 +#endif +#line 3700 +} +#line 3700 + +int +#line 3701 +ncx_getn_ulonglong_ushort(const void **xpp, size_t nelems, ushort *tp) +#line 3701 +{ +#line 3701 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3701 + +#line 3701 + /* basic algorithm is: +#line 3701 + * - ensure sane alignment of input data +#line 3701 + * - copy (conversion happens automatically) input data +#line 3701 + * to output +#line 3701 + * - update xpp to point at next unconverted input, and tp to point +#line 3701 + * at next location for converted output +#line 3701 + */ +#line 3701 + long i, j, ni; +#line 3701 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3701 + uint64 *xp; +#line 3701 + int nrange = 0; /* number of range errors */ +#line 3701 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3701 + long cxp = (long) *((char**)xpp); +#line 3701 + +#line 3701 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3701 + /* sjl: manually stripmine so we can limit amount of +#line 3701 + * vector work space reserved to LOOPCNT elements. Also +#line 3701 + * makes vectorisation easy */ +#line 3701 + for (j=0; j= 0 */ +#line 3701 + nrange += xp[i] > USHORT_MAX ; +#line 3701 + } +#line 3701 + /* update xpp and tp */ +#line 3701 + if (realign) xp = (uint64 *) *xpp; +#line 3701 + xp += ni; +#line 3701 + tp += ni; +#line 3701 + *xpp = (void*)xp; +#line 3701 + } +#line 3701 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3701 + +#line 3701 +#else /* not SX */ +#line 3701 + const char *xp = (const char *) *xpp; +#line 3701 + int status = NC_NOERR; +#line 3701 + +#line 3701 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3701 + { +#line 3701 + const int lstatus = ncx_get_ulonglong_ushort(xp, tp); +#line 3701 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3701 + status = lstatus; +#line 3701 + } +#line 3701 + +#line 3701 + *xpp = (const void *)xp; +#line 3701 + return status; +#line 3701 +#endif +#line 3701 +} +#line 3701 + +int +#line 3702 +ncx_getn_ulonglong_uint(const void **xpp, size_t nelems, uint *tp) +#line 3702 +{ +#line 3702 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3702 + +#line 3702 + /* basic algorithm is: +#line 3702 + * - ensure sane alignment of input data +#line 3702 + * - copy (conversion happens automatically) input data +#line 3702 + * to output +#line 3702 + * - update xpp to point at next unconverted input, and tp to point +#line 3702 + * at next location for converted output +#line 3702 + */ +#line 3702 + long i, j, ni; +#line 3702 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3702 + uint64 *xp; +#line 3702 + int nrange = 0; /* number of range errors */ +#line 3702 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3702 + long cxp = (long) *((char**)xpp); +#line 3702 + +#line 3702 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3702 + /* sjl: manually stripmine so we can limit amount of +#line 3702 + * vector work space reserved to LOOPCNT elements. Also +#line 3702 + * makes vectorisation easy */ +#line 3702 + for (j=0; j= 0 */ +#line 3702 + nrange += xp[i] > UINT_MAX ; +#line 3702 + } +#line 3702 + /* update xpp and tp */ +#line 3702 + if (realign) xp = (uint64 *) *xpp; +#line 3702 + xp += ni; +#line 3702 + tp += ni; +#line 3702 + *xpp = (void*)xp; +#line 3702 + } +#line 3702 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3702 + +#line 3702 +#else /* not SX */ +#line 3702 + const char *xp = (const char *) *xpp; +#line 3702 + int status = NC_NOERR; +#line 3702 + +#line 3702 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3702 + { +#line 3702 + const int lstatus = ncx_get_ulonglong_uint(xp, tp); +#line 3702 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3702 + status = lstatus; +#line 3702 + } +#line 3702 + +#line 3702 + *xpp = (const void *)xp; +#line 3702 + return status; +#line 3702 +#endif +#line 3702 +} +#line 3702 + + +#if X_SIZEOF_UINT64 == SIZEOF_ULONGLONG +/* optimized version */ +int +ncx_putn_ulonglong_ulonglong(void **xpp, size_t nelems, const unsigned long long *tp, void *fillp) +{ +#ifdef WORDS_BIGENDIAN + (void) memcpy(*xpp, tp, (size_t)nelems * X_SIZEOF_UINT64); +# else + swapn8b(*xpp, tp, nelems); +# endif + *xpp = (void *)((char *)(*xpp) + nelems * X_SIZEOF_UINT64); + return NC_NOERR; +} +#else +int +#line 3718 +ncx_putn_ulonglong_ulonglong(void **xpp, size_t nelems, const ulonglong *tp, void *fillp) +#line 3718 +{ +#line 3718 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3718 + +#line 3718 + /* basic algorithm is: +#line 3718 + * - ensure sane alignment of output data +#line 3718 + * - copy (conversion happens automatically) input data +#line 3718 + * to output +#line 3718 + * - update tp to point at next unconverted input, and xpp to point +#line 3718 + * at next location for converted output +#line 3718 + */ +#line 3718 + long i, j, ni; +#line 3718 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3718 + uint64 *xp; +#line 3718 + int nrange = 0; /* number of range errors */ +#line 3718 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3718 + long cxp = (long) *((char**)xpp); +#line 3718 + +#line 3718 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3718 + /* sjl: manually stripmine so we can limit amount of +#line 3718 + * vector work space reserved to LOOPCNT elements. Also +#line 3718 + * makes vectorisation easy */ +#line 3718 + for (j=0; j= 0 */ +#line 3718 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3718 + nrange += tp[i] > X_UINT64_MAX ; +#line 3718 + } +#line 3718 + /* copy workspace back if necessary */ +#line 3718 + if (realign) { +#line 3718 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT64); +#line 3718 + xp = (uint64 *) *xpp; +#line 3718 + } +#line 3718 + /* update xpp and tp */ +#line 3718 + xp += ni; +#line 3718 + tp += ni; +#line 3718 + *xpp = (void*)xp; +#line 3718 + } +#line 3718 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3718 + +#line 3718 +#else /* not SX */ +#line 3718 + +#line 3718 + char *xp = (char *) *xpp; +#line 3718 + int status = NC_NOERR; +#line 3718 + +#line 3718 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3718 + { +#line 3718 + int lstatus = ncx_put_ulonglong_ulonglong(xp, tp, fillp); +#line 3718 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3718 + status = lstatus; +#line 3718 + } +#line 3718 + +#line 3718 + *xpp = (void *)xp; +#line 3718 + return status; +#line 3718 +#endif +#line 3718 +} +#line 3718 + +#endif +int +#line 3720 +ncx_putn_ulonglong_schar(void **xpp, size_t nelems, const schar *tp, void *fillp) +#line 3720 +{ +#line 3720 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3720 + +#line 3720 + /* basic algorithm is: +#line 3720 + * - ensure sane alignment of output data +#line 3720 + * - copy (conversion happens automatically) input data +#line 3720 + * to output +#line 3720 + * - update tp to point at next unconverted input, and xpp to point +#line 3720 + * at next location for converted output +#line 3720 + */ +#line 3720 + long i, j, ni; +#line 3720 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3720 + uint64 *xp; +#line 3720 + int nrange = 0; /* number of range errors */ +#line 3720 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3720 + long cxp = (long) *((char**)xpp); +#line 3720 + +#line 3720 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3720 + /* sjl: manually stripmine so we can limit amount of +#line 3720 + * vector work space reserved to LOOPCNT elements. Also +#line 3720 + * makes vectorisation easy */ +#line 3720 + for (j=0; j= 0 */ +#line 3720 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3720 + nrange += tp[i] > X_UINT64_MAX || tp[i] < 0; +#line 3720 + } +#line 3720 + /* copy workspace back if necessary */ +#line 3720 + if (realign) { +#line 3720 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT64); +#line 3720 + xp = (uint64 *) *xpp; +#line 3720 + } +#line 3720 + /* update xpp and tp */ +#line 3720 + xp += ni; +#line 3720 + tp += ni; +#line 3720 + *xpp = (void*)xp; +#line 3720 + } +#line 3720 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3720 + +#line 3720 +#else /* not SX */ +#line 3720 + +#line 3720 + char *xp = (char *) *xpp; +#line 3720 + int status = NC_NOERR; +#line 3720 + +#line 3720 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3720 + { +#line 3720 + int lstatus = ncx_put_ulonglong_schar(xp, tp, fillp); +#line 3720 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3720 + status = lstatus; +#line 3720 + } +#line 3720 + +#line 3720 + *xpp = (void *)xp; +#line 3720 + return status; +#line 3720 +#endif +#line 3720 +} +#line 3720 + +int +#line 3721 +ncx_putn_ulonglong_short(void **xpp, size_t nelems, const short *tp, void *fillp) +#line 3721 +{ +#line 3721 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3721 + +#line 3721 + /* basic algorithm is: +#line 3721 + * - ensure sane alignment of output data +#line 3721 + * - copy (conversion happens automatically) input data +#line 3721 + * to output +#line 3721 + * - update tp to point at next unconverted input, and xpp to point +#line 3721 + * at next location for converted output +#line 3721 + */ +#line 3721 + long i, j, ni; +#line 3721 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3721 + uint64 *xp; +#line 3721 + int nrange = 0; /* number of range errors */ +#line 3721 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3721 + long cxp = (long) *((char**)xpp); +#line 3721 + +#line 3721 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3721 + /* sjl: manually stripmine so we can limit amount of +#line 3721 + * vector work space reserved to LOOPCNT elements. Also +#line 3721 + * makes vectorisation easy */ +#line 3721 + for (j=0; j= 0 */ +#line 3721 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3721 + nrange += tp[i] > X_UINT64_MAX || tp[i] < 0; +#line 3721 + } +#line 3721 + /* copy workspace back if necessary */ +#line 3721 + if (realign) { +#line 3721 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT64); +#line 3721 + xp = (uint64 *) *xpp; +#line 3721 + } +#line 3721 + /* update xpp and tp */ +#line 3721 + xp += ni; +#line 3721 + tp += ni; +#line 3721 + *xpp = (void*)xp; +#line 3721 + } +#line 3721 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3721 + +#line 3721 +#else /* not SX */ +#line 3721 + +#line 3721 + char *xp = (char *) *xpp; +#line 3721 + int status = NC_NOERR; +#line 3721 + +#line 3721 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3721 + { +#line 3721 + int lstatus = ncx_put_ulonglong_short(xp, tp, fillp); +#line 3721 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3721 + status = lstatus; +#line 3721 + } +#line 3721 + +#line 3721 + *xpp = (void *)xp; +#line 3721 + return status; +#line 3721 +#endif +#line 3721 +} +#line 3721 + +int +#line 3722 +ncx_putn_ulonglong_int(void **xpp, size_t nelems, const int *tp, void *fillp) +#line 3722 +{ +#line 3722 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3722 + +#line 3722 + /* basic algorithm is: +#line 3722 + * - ensure sane alignment of output data +#line 3722 + * - copy (conversion happens automatically) input data +#line 3722 + * to output +#line 3722 + * - update tp to point at next unconverted input, and xpp to point +#line 3722 + * at next location for converted output +#line 3722 + */ +#line 3722 + long i, j, ni; +#line 3722 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3722 + uint64 *xp; +#line 3722 + int nrange = 0; /* number of range errors */ +#line 3722 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3722 + long cxp = (long) *((char**)xpp); +#line 3722 + +#line 3722 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3722 + /* sjl: manually stripmine so we can limit amount of +#line 3722 + * vector work space reserved to LOOPCNT elements. Also +#line 3722 + * makes vectorisation easy */ +#line 3722 + for (j=0; j= 0 */ +#line 3722 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3722 + nrange += tp[i] > X_UINT64_MAX || tp[i] < 0; +#line 3722 + } +#line 3722 + /* copy workspace back if necessary */ +#line 3722 + if (realign) { +#line 3722 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT64); +#line 3722 + xp = (uint64 *) *xpp; +#line 3722 + } +#line 3722 + /* update xpp and tp */ +#line 3722 + xp += ni; +#line 3722 + tp += ni; +#line 3722 + *xpp = (void*)xp; +#line 3722 + } +#line 3722 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3722 + +#line 3722 +#else /* not SX */ +#line 3722 + +#line 3722 + char *xp = (char *) *xpp; +#line 3722 + int status = NC_NOERR; +#line 3722 + +#line 3722 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3722 + { +#line 3722 + int lstatus = ncx_put_ulonglong_int(xp, tp, fillp); +#line 3722 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3722 + status = lstatus; +#line 3722 + } +#line 3722 + +#line 3722 + *xpp = (void *)xp; +#line 3722 + return status; +#line 3722 +#endif +#line 3722 +} +#line 3722 + +int +#line 3723 +ncx_putn_ulonglong_long(void **xpp, size_t nelems, const long *tp, void *fillp) +#line 3723 +{ +#line 3723 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3723 + +#line 3723 + /* basic algorithm is: +#line 3723 + * - ensure sane alignment of output data +#line 3723 + * - copy (conversion happens automatically) input data +#line 3723 + * to output +#line 3723 + * - update tp to point at next unconverted input, and xpp to point +#line 3723 + * at next location for converted output +#line 3723 + */ +#line 3723 + long i, j, ni; +#line 3723 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3723 + uint64 *xp; +#line 3723 + int nrange = 0; /* number of range errors */ +#line 3723 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3723 + long cxp = (long) *((char**)xpp); +#line 3723 + +#line 3723 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3723 + /* sjl: manually stripmine so we can limit amount of +#line 3723 + * vector work space reserved to LOOPCNT elements. Also +#line 3723 + * makes vectorisation easy */ +#line 3723 + for (j=0; j= 0 */ +#line 3723 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3723 + nrange += tp[i] > X_UINT64_MAX || tp[i] < 0; +#line 3723 + } +#line 3723 + /* copy workspace back if necessary */ +#line 3723 + if (realign) { +#line 3723 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT64); +#line 3723 + xp = (uint64 *) *xpp; +#line 3723 + } +#line 3723 + /* update xpp and tp */ +#line 3723 + xp += ni; +#line 3723 + tp += ni; +#line 3723 + *xpp = (void*)xp; +#line 3723 + } +#line 3723 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3723 + +#line 3723 +#else /* not SX */ +#line 3723 + +#line 3723 + char *xp = (char *) *xpp; +#line 3723 + int status = NC_NOERR; +#line 3723 + +#line 3723 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3723 + { +#line 3723 + int lstatus = ncx_put_ulonglong_long(xp, tp, fillp); +#line 3723 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3723 + status = lstatus; +#line 3723 + } +#line 3723 + +#line 3723 + *xpp = (void *)xp; +#line 3723 + return status; +#line 3723 +#endif +#line 3723 +} +#line 3723 + +int +#line 3724 +ncx_putn_ulonglong_float(void **xpp, size_t nelems, const float *tp, void *fillp) +#line 3724 +{ +#line 3724 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3724 + +#line 3724 + /* basic algorithm is: +#line 3724 + * - ensure sane alignment of output data +#line 3724 + * - copy (conversion happens automatically) input data +#line 3724 + * to output +#line 3724 + * - update tp to point at next unconverted input, and xpp to point +#line 3724 + * at next location for converted output +#line 3724 + */ +#line 3724 + long i, j, ni; +#line 3724 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3724 + uint64 *xp; +#line 3724 + int nrange = 0; /* number of range errors */ +#line 3724 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3724 + long cxp = (long) *((char**)xpp); +#line 3724 + +#line 3724 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3724 + /* sjl: manually stripmine so we can limit amount of +#line 3724 + * vector work space reserved to LOOPCNT elements. Also +#line 3724 + * makes vectorisation easy */ +#line 3724 + for (j=0; j= 0 */ +#line 3724 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3724 + nrange += tp[i] > X_UINT64_MAX || tp[i] < 0; +#line 3724 + } +#line 3724 + /* copy workspace back if necessary */ +#line 3724 + if (realign) { +#line 3724 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT64); +#line 3724 + xp = (uint64 *) *xpp; +#line 3724 + } +#line 3724 + /* update xpp and tp */ +#line 3724 + xp += ni; +#line 3724 + tp += ni; +#line 3724 + *xpp = (void*)xp; +#line 3724 + } +#line 3724 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3724 + +#line 3724 +#else /* not SX */ +#line 3724 + +#line 3724 + char *xp = (char *) *xpp; +#line 3724 + int status = NC_NOERR; +#line 3724 + +#line 3724 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3724 + { +#line 3724 + int lstatus = ncx_put_ulonglong_float(xp, tp, fillp); +#line 3724 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3724 + status = lstatus; +#line 3724 + } +#line 3724 + +#line 3724 + *xpp = (void *)xp; +#line 3724 + return status; +#line 3724 +#endif +#line 3724 +} +#line 3724 + +int +#line 3725 +ncx_putn_ulonglong_double(void **xpp, size_t nelems, const double *tp, void *fillp) +#line 3725 +{ +#line 3725 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3725 + +#line 3725 + /* basic algorithm is: +#line 3725 + * - ensure sane alignment of output data +#line 3725 + * - copy (conversion happens automatically) input data +#line 3725 + * to output +#line 3725 + * - update tp to point at next unconverted input, and xpp to point +#line 3725 + * at next location for converted output +#line 3725 + */ +#line 3725 + long i, j, ni; +#line 3725 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3725 + uint64 *xp; +#line 3725 + int nrange = 0; /* number of range errors */ +#line 3725 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3725 + long cxp = (long) *((char**)xpp); +#line 3725 + +#line 3725 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3725 + /* sjl: manually stripmine so we can limit amount of +#line 3725 + * vector work space reserved to LOOPCNT elements. Also +#line 3725 + * makes vectorisation easy */ +#line 3725 + for (j=0; j= 0 */ +#line 3725 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3725 + nrange += tp[i] > X_UINT64_MAX || tp[i] < 0; +#line 3725 + } +#line 3725 + /* copy workspace back if necessary */ +#line 3725 + if (realign) { +#line 3725 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT64); +#line 3725 + xp = (uint64 *) *xpp; +#line 3725 + } +#line 3725 + /* update xpp and tp */ +#line 3725 + xp += ni; +#line 3725 + tp += ni; +#line 3725 + *xpp = (void*)xp; +#line 3725 + } +#line 3725 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3725 + +#line 3725 +#else /* not SX */ +#line 3725 + +#line 3725 + char *xp = (char *) *xpp; +#line 3725 + int status = NC_NOERR; +#line 3725 + +#line 3725 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3725 + { +#line 3725 + int lstatus = ncx_put_ulonglong_double(xp, tp, fillp); +#line 3725 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3725 + status = lstatus; +#line 3725 + } +#line 3725 + +#line 3725 + *xpp = (void *)xp; +#line 3725 + return status; +#line 3725 +#endif +#line 3725 +} +#line 3725 + +int +#line 3726 +ncx_putn_ulonglong_longlong(void **xpp, size_t nelems, const longlong *tp, void *fillp) +#line 3726 +{ +#line 3726 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3726 + +#line 3726 + /* basic algorithm is: +#line 3726 + * - ensure sane alignment of output data +#line 3726 + * - copy (conversion happens automatically) input data +#line 3726 + * to output +#line 3726 + * - update tp to point at next unconverted input, and xpp to point +#line 3726 + * at next location for converted output +#line 3726 + */ +#line 3726 + long i, j, ni; +#line 3726 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3726 + uint64 *xp; +#line 3726 + int nrange = 0; /* number of range errors */ +#line 3726 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3726 + long cxp = (long) *((char**)xpp); +#line 3726 + +#line 3726 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3726 + /* sjl: manually stripmine so we can limit amount of +#line 3726 + * vector work space reserved to LOOPCNT elements. Also +#line 3726 + * makes vectorisation easy */ +#line 3726 + for (j=0; j= 0 */ +#line 3726 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3726 + nrange += tp[i] > X_UINT64_MAX || tp[i] < 0; +#line 3726 + } +#line 3726 + /* copy workspace back if necessary */ +#line 3726 + if (realign) { +#line 3726 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT64); +#line 3726 + xp = (uint64 *) *xpp; +#line 3726 + } +#line 3726 + /* update xpp and tp */ +#line 3726 + xp += ni; +#line 3726 + tp += ni; +#line 3726 + *xpp = (void*)xp; +#line 3726 + } +#line 3726 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3726 + +#line 3726 +#else /* not SX */ +#line 3726 + +#line 3726 + char *xp = (char *) *xpp; +#line 3726 + int status = NC_NOERR; +#line 3726 + +#line 3726 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3726 + { +#line 3726 + int lstatus = ncx_put_ulonglong_longlong(xp, tp, fillp); +#line 3726 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3726 + status = lstatus; +#line 3726 + } +#line 3726 + +#line 3726 + *xpp = (void *)xp; +#line 3726 + return status; +#line 3726 +#endif +#line 3726 +} +#line 3726 + +int +#line 3727 +ncx_putn_ulonglong_uchar(void **xpp, size_t nelems, const uchar *tp, void *fillp) +#line 3727 +{ +#line 3727 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3727 + +#line 3727 + /* basic algorithm is: +#line 3727 + * - ensure sane alignment of output data +#line 3727 + * - copy (conversion happens automatically) input data +#line 3727 + * to output +#line 3727 + * - update tp to point at next unconverted input, and xpp to point +#line 3727 + * at next location for converted output +#line 3727 + */ +#line 3727 + long i, j, ni; +#line 3727 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3727 + uint64 *xp; +#line 3727 + int nrange = 0; /* number of range errors */ +#line 3727 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3727 + long cxp = (long) *((char**)xpp); +#line 3727 + +#line 3727 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3727 + /* sjl: manually stripmine so we can limit amount of +#line 3727 + * vector work space reserved to LOOPCNT elements. Also +#line 3727 + * makes vectorisation easy */ +#line 3727 + for (j=0; j= 0 */ +#line 3727 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3727 + nrange += tp[i] > X_UINT64_MAX ; +#line 3727 + } +#line 3727 + /* copy workspace back if necessary */ +#line 3727 + if (realign) { +#line 3727 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT64); +#line 3727 + xp = (uint64 *) *xpp; +#line 3727 + } +#line 3727 + /* update xpp and tp */ +#line 3727 + xp += ni; +#line 3727 + tp += ni; +#line 3727 + *xpp = (void*)xp; +#line 3727 + } +#line 3727 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3727 + +#line 3727 +#else /* not SX */ +#line 3727 + +#line 3727 + char *xp = (char *) *xpp; +#line 3727 + int status = NC_NOERR; +#line 3727 + +#line 3727 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3727 + { +#line 3727 + int lstatus = ncx_put_ulonglong_uchar(xp, tp, fillp); +#line 3727 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3727 + status = lstatus; +#line 3727 + } +#line 3727 + +#line 3727 + *xpp = (void *)xp; +#line 3727 + return status; +#line 3727 +#endif +#line 3727 +} +#line 3727 + +int +#line 3728 +ncx_putn_ulonglong_ushort(void **xpp, size_t nelems, const ushort *tp, void *fillp) +#line 3728 +{ +#line 3728 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3728 + +#line 3728 + /* basic algorithm is: +#line 3728 + * - ensure sane alignment of output data +#line 3728 + * - copy (conversion happens automatically) input data +#line 3728 + * to output +#line 3728 + * - update tp to point at next unconverted input, and xpp to point +#line 3728 + * at next location for converted output +#line 3728 + */ +#line 3728 + long i, j, ni; +#line 3728 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3728 + uint64 *xp; +#line 3728 + int nrange = 0; /* number of range errors */ +#line 3728 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3728 + long cxp = (long) *((char**)xpp); +#line 3728 + +#line 3728 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3728 + /* sjl: manually stripmine so we can limit amount of +#line 3728 + * vector work space reserved to LOOPCNT elements. Also +#line 3728 + * makes vectorisation easy */ +#line 3728 + for (j=0; j= 0 */ +#line 3728 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3728 + nrange += tp[i] > X_UINT64_MAX ; +#line 3728 + } +#line 3728 + /* copy workspace back if necessary */ +#line 3728 + if (realign) { +#line 3728 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT64); +#line 3728 + xp = (uint64 *) *xpp; +#line 3728 + } +#line 3728 + /* update xpp and tp */ +#line 3728 + xp += ni; +#line 3728 + tp += ni; +#line 3728 + *xpp = (void*)xp; +#line 3728 + } +#line 3728 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3728 + +#line 3728 +#else /* not SX */ +#line 3728 + +#line 3728 + char *xp = (char *) *xpp; +#line 3728 + int status = NC_NOERR; +#line 3728 + +#line 3728 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3728 + { +#line 3728 + int lstatus = ncx_put_ulonglong_ushort(xp, tp, fillp); +#line 3728 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3728 + status = lstatus; +#line 3728 + } +#line 3728 + +#line 3728 + *xpp = (void *)xp; +#line 3728 + return status; +#line 3728 +#endif +#line 3728 +} +#line 3728 + +int +#line 3729 +ncx_putn_ulonglong_uint(void **xpp, size_t nelems, const uint *tp, void *fillp) +#line 3729 +{ +#line 3729 +#if defined(_SX) && _SX != 0 && X_SIZEOF_UINT64 == SIZEOF_UINT64 +#line 3729 + +#line 3729 + /* basic algorithm is: +#line 3729 + * - ensure sane alignment of output data +#line 3729 + * - copy (conversion happens automatically) input data +#line 3729 + * to output +#line 3729 + * - update tp to point at next unconverted input, and xpp to point +#line 3729 + * at next location for converted output +#line 3729 + */ +#line 3729 + long i, j, ni; +#line 3729 + uint64 tmp[LOOPCNT]; /* in case input is misaligned */ +#line 3729 + uint64 *xp; +#line 3729 + int nrange = 0; /* number of range errors */ +#line 3729 + int realign = 0; /* "do we need to fix input data alignment?" */ +#line 3729 + long cxp = (long) *((char**)xpp); +#line 3729 + +#line 3729 + realign = (cxp & 7) % SIZEOF_UINT64; +#line 3729 + /* sjl: manually stripmine so we can limit amount of +#line 3729 + * vector work space reserved to LOOPCNT elements. Also +#line 3729 + * makes vectorisation easy */ +#line 3729 + for (j=0; j= 0 */ +#line 3729 + /* if tp is unsigned, we need not check if tp[i] < X__MIN */ +#line 3729 + nrange += tp[i] > X_UINT64_MAX ; +#line 3729 + } +#line 3729 + /* copy workspace back if necessary */ +#line 3729 + if (realign) { +#line 3729 + memcpy(*xpp, tmp, (size_t)*ni*X_SIZEOF_UINT64); +#line 3729 + xp = (uint64 *) *xpp; +#line 3729 + } +#line 3729 + /* update xpp and tp */ +#line 3729 + xp += ni; +#line 3729 + tp += ni; +#line 3729 + *xpp = (void*)xp; +#line 3729 + } +#line 3729 + return nrange == 0 ? NC_NOERR : NC_ERANGE; +#line 3729 + +#line 3729 +#else /* not SX */ +#line 3729 + +#line 3729 + char *xp = (char *) *xpp; +#line 3729 + int status = NC_NOERR; +#line 3729 + +#line 3729 + for( ; nelems != 0; nelems--, xp += X_SIZEOF_UINT64, tp++) +#line 3729 + { +#line 3729 + int lstatus = ncx_put_ulonglong_uint(xp, tp, fillp); +#line 3729 + if (status == NC_NOERR) /* report the first encountered error */ +#line 3729 + status = lstatus; +#line 3729 + } +#line 3729 + +#line 3729 + *xpp = (void *)xp; +#line 3729 + return status; +#line 3729 +#endif +#line 3729 +} +#line 3729 + + + +/* + * Other aggregate conversion functions. + */ + +/* text */ + +int +ncx_getn_text(const void **xpp, size_t nelems, char *tp) +{ + (void) memcpy(tp, *xpp, (size_t)nelems); +#line 3741 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 3741 + return NC_NOERR; +#line 3741 + +} + +int +ncx_pad_getn_text(const void **xpp, size_t nelems, char *tp) +{ + size_t rndup = nelems % X_ALIGN; +#line 3747 + +#line 3747 + if (rndup) +#line 3747 + rndup = X_ALIGN - rndup; +#line 3747 + +#line 3747 + (void) memcpy(tp, *xpp, (size_t)nelems); +#line 3747 + *xpp = (void *)((char *)(*xpp) + nelems + rndup); +#line 3747 + +#line 3747 + return NC_NOERR; +#line 3747 + +} + +int +ncx_putn_text(void **xpp, size_t nelems, const char *tp) +{ + (void) memcpy(*xpp, tp, (size_t)nelems); +#line 3753 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 3753 + +#line 3753 + return NC_NOERR; +#line 3753 + +} + +int +ncx_pad_putn_text(void **xpp, size_t nelems, const char *tp) +{ + size_t rndup = nelems % X_ALIGN; +#line 3759 + +#line 3759 + if (rndup) +#line 3759 + rndup = X_ALIGN - rndup; +#line 3759 + +#line 3759 + (void) memcpy(*xpp, tp, (size_t)nelems); +#line 3759 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 3759 + +#line 3759 + if (rndup) +#line 3759 + { +#line 3759 + (void) memcpy(*xpp, nada, (size_t)rndup); +#line 3759 + *xpp = (void *)((char *)(*xpp) + rndup); +#line 3759 + } +#line 3759 + +#line 3759 + return NC_NOERR; +#line 3759 + +} + + +/* opaque */ + +int +ncx_getn_void(const void **xpp, size_t nelems, void *tp) +{ + (void) memcpy(tp, *xpp, (size_t)nelems); +#line 3768 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 3768 + return NC_NOERR; +#line 3768 + +} + +int +ncx_pad_getn_void(const void **xpp, size_t nelems, void *tp) +{ + size_t rndup = nelems % X_ALIGN; +#line 3774 + +#line 3774 + if (rndup) +#line 3774 + rndup = X_ALIGN - rndup; +#line 3774 + +#line 3774 + (void) memcpy(tp, *xpp, (size_t)nelems); +#line 3774 + *xpp = (void *)((char *)(*xpp) + nelems + rndup); +#line 3774 + +#line 3774 + return NC_NOERR; +#line 3774 + +} + +int +ncx_putn_void(void **xpp, size_t nelems, const void *tp) +{ + (void) memcpy(*xpp, tp, (size_t)nelems); +#line 3780 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 3780 + +#line 3780 + return NC_NOERR; +#line 3780 + +} + +int +ncx_pad_putn_void(void **xpp, size_t nelems, const void *tp) +{ + size_t rndup = nelems % X_ALIGN; +#line 3786 + +#line 3786 + if (rndup) +#line 3786 + rndup = X_ALIGN - rndup; +#line 3786 + +#line 3786 + (void) memcpy(*xpp, tp, (size_t)nelems); +#line 3786 + *xpp = (void *)((char *)(*xpp) + nelems); +#line 3786 + +#line 3786 + if (rndup) +#line 3786 + { +#line 3786 + (void) memcpy(*xpp, nada, (size_t)rndup); +#line 3786 + *xpp = (void *)((char *)(*xpp) + rndup); +#line 3786 + } +#line 3786 + +#line 3786 + return NC_NOERR; +#line 3786 + +} diff --git a/libsrc/netcdf.3 b/libsrc/netcdf.3 new file mode 100644 index 0000000000..89985eda96 --- /dev/null +++ b/libsrc/netcdf.3 @@ -0,0 +1,1405 @@ +.nr yr \n(yr+1900 +.af mo 01 +.af dy 01 +.TH NETCDF 3 "1997-04-18" "Printed: \n(yr-\n(mo-\n(dy" "UNIDATA LIBRARY FUNCTIONS" +.SH NAME +netcdf \- Unidata's Network Common Data Form (netCDF) library interface +.SH SYNOPSIS +.ft B +.na +.nh +#include "netcdf.h" +.sp + +cc ... \-lnetcdf \-lhdf5_hl \-lhdf5 \-lz \-lm + +.ad +.hy +Complete documentation for the netCDF libraries can be found at the netCDF website: http://www.unidata.ucar.edu/software/netcdf/. +.sp +.SH "LIBRARY VERSION" +.LP +This document describes versions 3 and 4 +of Unidata netCDF data-access interface +for the C programming language. +.HP +\fBconst char* nc_inq_libvers()\fR +.sp +Returns a string identifying the version of the netCDF library, and +when it was built, like: "3.1a of Aug 22 1996 12:57:47 $". +.LP +The RCS \fBident(1)\fP command will find a string like +"$\|Id: @\|(#) netcdf library version 3.1a of Sep 6 1996 15:56:26 $" +in the library. The SCCS \fBwhat(1)\fP command will find a string like +"netcdf library version 3.1a of Aug 23 1996 16:07:40 $". +.SH "RETURN VALUES" +.LP +All netCDF functions (except +\fBnc_inq_libvers(\|)\fR and \fBnc_strerror(\|)\fR) return an integer status. + +If this returned status value is not equal to +\fBNC_NOERR\fR (zero), it +indicates that an error occurred. The possible status values are defined in +system include file and in "netcdf.h". +.HP +\fBconst char* nc_strerror(int \fIstatus\fP)\fR +.sp +Returns a string textual translation of the \fIstatus\fP +value, like "Attribute or variable name contains illegal characters" +or "No such file or directory". +.sp +.SH "FILE OPERATIONS" +.LP +.HP +\fBint nc_create(const char \fIpath\fP[], int \fIcmode\fP, int* \fIncid\fP)\fR +.sp +Creates a new netCDF dataset at \fIpath\fP, +returning a netCDF ID in \fIncid\fP. +The argument \fIcmode\fP may include the bitwise-or +of the following flags: +\fBNC_NOCLOBBER\fR +to protect existing datasets (default +silently blows them away), +\fBNC_SHARE\fR +for synchronous dataset updates for classic format files +(default is to buffer accesses), +.sp +When a netCDF dataset is created, is is opened +\fBNC_WRITE\fR. +The new netCDF dataset is in define mode. +\fBNC_64BIT_OFFSET\fR. +to create a file in the 64-bit offset format +(as opposed to classic format, the default). +\fBNC_TRUE\fR to create a netCDF-4/HDF5 file, +and \fBNC_CLASSIC_MODEL\fR to guarantee that netCDF-4/HDF5 files maintain compatibility +with the netCDF classic data model. +.HP +\fBint nc__create(const char \fIpath\fP[], int \fIcmode\fP, size_t \fIinitialsize\fP, size_t* \fIchunksize\fP, int* \fIncid\fP)\fR +.sp +Like \fBnc_create(\|)\fR but has additional performance tuning parameters. +.sp +The argument \fIinitialsize\fP sets the initial size of the file at +creation time. +.sp +See \fBnc__open(\|)\fR below for an explanation of the \fIchunksize\fP +parameter. +.HP +\fBint nc_open(const char \fIpath\fP[], int \fImode\fP, int* \fIncid\fP)\fR +.sp +(Corresponds to \fBncopen(\|)\fR in version 2) +.sp +Opens a existing netCDF dataset at \fIpath\fP +returning a netCDF ID +in \fIncid\fP. +The type of access is described by the \fImode\fP parameter, +which may include the bitwise-or +of the following flags: +\fBNC_WRITE\fR +for read-write access (default +read-only), +\fBNC_SHARE\fR +for synchronous dataset updates (default is +to buffer accesses), and +\fBNC_LOCK\fR +(not yet implemented). +.sp +As of NetCDF version 4.1, and if TRUE support was enabled +when the NetCDF library was built, the path parameter +may specify a TRUE URL. In this case, the access mode is +forced to be read-only. +.HP +\fBint nc__open(const char \fIpath\fP[], int \fImode\fP, size_t* \fIchunksize\fP, int* \fIncid\fP)\fR +.sp +Like \fBnc_open(\|)\fR but has an additional performance tuning parameter. +.sp +The argument referenced by \fIchunksize\fP controls a space versus time +tradeoff, memory allocated in the netcdf library versus number of system +calls. +Because of internal requirements, the value may not be set to exactly +the value requested. +The actual value chosen is returned by reference. +Using the value \fBNC_SIZEHINT_DEFAULT\fR causes the library to choose a +default. +How the system choses the default depends on the system. +On many systems, the "preferred I/O block size" is available from the +\fBstat()\fR system call, \fBstruct stat\fR member \fBst_blksize\fR. +If this is available it is used. Lacking that, twice the system pagesize +is used. +Lacking a call to discover the system pagesize, we just set default +chunksize to 8192. +.sp +The chunksize is a property of a given open netcdf descriptor +\fIncid\fP, it is not a persistent property of the netcdf dataset. +.sp +As with \fBnc__open(\|)\fR, the path parameter +may specify a TRUE URL, but the tuning parameters are ignored. +.HP +\fBint nc_redef(int \fIncid\fP)\fR +.sp +(Corresponds to \fBncredef(\|)\fR in version 2) +.sp +Puts an open netCDF dataset into define mode, +so dimensions, variables, and attributes can be added or renamed and +attributes can be deleted. +.HP +\fBint nc_enddef(int \fIncid\fP)\fR +.sp +(Corresponds to \fBncendef(\|)\fR in version 2) +.sp +Takes an open netCDF dataset out of define mode. +The changes made to the netCDF dataset +while it was in define mode are checked and committed to disk if no +problems occurred. Some data values may be written as well, +see "VARIABLE PREFILLING" below. +After a successful call, variable data can be read or written to the dataset. +.HP +\fBint nc__enddef(int \fIncid\fP, size_t \fIh_minfree\fP, size_t \fIv_align\fP, size_t \fIv_minfree\fP, size_t \fIr_align\fP)\fR +.sp +Like \fBnc_enddef(\|)\fR but has additional performance tuning parameters. +.sp +Caution: this function exposes internals of the netcdf version 1 file +format. +It may not be available on future netcdf implementations. +.sp +The current netcdf file format has three sections, +the "header" section, the data section for fixed size variables, and +the data section for variables which have an unlimited dimension (record +variables). +The header begins at the beginning of the file. The index +(offset) of the beginning of the other two sections is contained in the +header. Typically, there is no space between the sections. This causes +copying overhead to accrue if one wishes to change the size of the +sections, +as may happen when changing names of things, text attribute values, +adding +attributes or adding variables. Also, for buffered i/o, there may be +advantages +to aligning sections in certain ways. +.sp +The minfree parameters allow one to control costs of future calls +to \fBnc_redef(\|)\fR, \fBnc_enddef(\|)\fR by requesting that \fIminfree\fP bytes be +available at the end of the section. +The \fIh_minfree\fP parameter sets the pad +at the end of the "header" section. The \fIv_minfree\fP parameter sets +the pad at the end of the data section for fixed size variables. +.sp +The align parameters allow one to set the alignment of the beginning of +the corresponding sections. The beginning of the section is rounded up +to an index which is a multiple of the align parameter. The flag value +\fBNC_ALIGN_CHUNK\fR tells the library to use the chunksize (see above) +as the align parameter. +The \fIv_align\fP parameter controls the alignment of the beginning of +the data section for fixed size variables. +The \fIr_align\fP parameter controls the alignment of the beginning of +the data section for variables which have an unlimited dimension (record +variables). +.sp +The file format requires mod 4 alignment, so the align parameters +are silently rounded up to multiples of 4. The usual call, +\fBnc_enddef(\fIncid\fP)\fR +is equivalent to +\fBnc__enddef(\fIncid\fP, 0, 4, 0, 4)\fR. +.sp +The file format does not contain a "record size" value, this is +calculated from the sizes of the record variables. This unfortunate fact +prevents us from providing minfree and alignment control of the +"records" +in a netcdf file. If you add a variable which has an unlimited +dimension, +the third section will always be copied with the new variable added. +.HP +\fBint nc_sync(int \fIncid\fP)\fR +.sp +(Corresponds to \fBncsync(\|)\fR in version 2) +.sp +Unless the +\fBNC_SHARE\fR +bit is set in +\fBnc_open(\|)\fR or \fBnc_create(\|)\fR, +accesses to the underlying netCDF dataset are +buffered by the library. This function synchronizes the state of +the underlying dataset and the library. +This is done automatically by +\fBnc_close(\|)\fR and \fBnc_enddef(\|)\fR. +.HP +\fBint nc_abort(int \fIncid\fP)\fR +.sp +(Corresponds to \fBncabort(\|)\fR in version 2) +.sp +You don't need to call this function. +This function is called automatically by +\fBnc_close(\|)\fR +if the netCDF was in define mode and something goes wrong with the commit. +If the netCDF dataset isn't in define mode, then this function is equivalent to +\fBnc_close(\|)\fR. +If it is called after +\fBnc_redef(\|)\fR, +but before +\fBnc_enddef(\|)\fR, +the new definitions are not committed and the dataset is closed. +If it is called after +\fBnc_create(\|)\fR +but before +\fBnc_enddef(\|)\fR, +the dataset disappears. +.HP +\fBint nc_close(int \fIncid\fP)\fR +.sp +(Corresponds to +\fBncclose(\|)\fR in version 2) +.sp +Closes an open netCDF dataset. +If the dataset is in define mode, +\fBnc_enddef(\|)\fR +will be called before closing. +After a dataset is closed, its ID may be reassigned to another dataset. +.HP +\fBint nc_inq(int \fIncid\fP, int* \fIndims\fP, int* \fInvars\fP, +int* \fInatts\fP, int* \fIunlimdimid\fP)\fR +.HP +\fBint nc_inq_ndims(int \fIncid\fP, int* \fIndims\fP)\fR +.HP +\fBint nc_inq_nvars(int \fIncid\fP, int* \fInvars\fP)\fR +.HP +\fBint nc_inq_natts(int \fIncid\fP, int* \fInatts\fP)\fR +.HP +\fBint nc_inq_unlimdim(int \fIncid\fP, int* \fIunlimdimid\fP)\fR +.HP +\fBint nc_inq_format(int \fIncid\fP, int* \fIformatn\fP)\fR +.sp +Use these functions to find out what is in a netCDF dataset. +Upon successful return, +\fIndims\fP will contain the +number of dimensions defined for this netCDF dataset, +\fInvars\fP will contain the number of variables, +\fInatts\fP will contain the number of attributes, and +\fIunlimdimid\fP will contain the +dimension ID of the unlimited dimension if one exists, or +\-1 otherwise. +\fIformatn\fP will contain the version number of the dataset , one of +\fBNC_FORMAT_CLASSIC\fR, \fBNC_FORMAT_64BIT_OFFSET\fR, \fBNC_FORMAT_NETCDF4\fR, or +\fBNC_FORMAT_NETCDF4_CLASSIC\fR. +If any of the +return parameters is a \fBNULL\fR pointer, then the corresponding information +will not be returned; hence, no space need be allocated for it. +.HP +\fBint nc_def_dim(int \fIncid\fP, const char \fIname\fP[], size_t \fIlen\fP, int* \fIdimid\fP)\fR +.sp +(Corresponds to \fBncdimdef(\|)\fR in version 2) +.sp +Adds a new dimension to an open netCDF dataset, which must be +in define mode. +\fIname\fP is the dimension name. +If \fIdimid\fP is not a \fBNULL\fR pointer then upon successful completion \fIdimid\fP will contain the dimension ID of the newly created dimension. + +.SH "USER DEFINED TYPES" +.LP +Users many define types for a netCDF-4/HDF5 file (unless the +\fBNC_CLASSIC_MODEL\fR was used when the file was creates). Users may +define compound types, variable length arrays, enumeration types, and +opaque types. +.sp + +.HP +\fBint nc_def_compound(int \fIncid\fP, size_t \fIsize\fP, const char \fIname\fP[], int* \fItypeidp\fP)\fR +.sp +Define a compound type. +.HP +\fBint nc_insert_compound(int \fIncid\fP, nc_type \fI\fP, const char \fIname\fP[], size_t \fIoffset\fP, nc_type \fIfield_typeid\fP)\fR +.sp +Insert an element into a compound type. May not be done after type has been used, or after the type has been written by an enddef. +.HP +\fBint nc_insert_array_compound(int \fIncid\fP, nc_type \fI\fP, const char \fIname\fP[], size_t \fIoffset\fP, nc_type \fIfield_typeid\fP, int \fIndims\fP, const int \fIdim_sizes\fP[])\fR +.sp +Insert an array into a compound type. +.HP +\fBint nc_inq_type(int \fIncid\fP, nc_type \fI\fP, char \fIname\fP[], size_t* \fIsizep\fP)\fR +.sp +Learn about a type. +.HP +\fBint nc_inq_compound(int \fIncid\fP, nc_type \fI\fP, char \fIname\fP[], size_t* \fIsizep\fP, size_t* \fInfieldsp\fP)\fR +.HP +\fBint nc_inq_compound_name(int \fIncid\fP, nc_type \fI\fP, char \fIname\fP[])\fR +.HP +\fBint nc_inq_compound_size(int \fIncid\fP, nc_type \fI\fP, size_t* \fIsizep\fP)\fR +.HP +\fBint nc_inq_compound_nfields(int \fIncid\fP, nc_type \fI\fP, size_t* \fInfieldsp\fP)\fR +.HP +\fBint nc_inq_compound_fieldname(int \fIncid\fP, nc_type \fI\fP, int \fIfieldid\fP, char \fIname\fP[])\fR +.HP +\fBint nc_inq_compound_fieldindex(int \fIncid\fP, nc_type \fI\fP, const char \fIname\fP[], int* \fIfieldidp\fP)\fR +.HP +\fBint nc_inq_compound_fieldoffset(int \fIncid\fP, nc_type \fI\fP, int \fIfieldid\fP, size_t* \fIoffsetp\fP)\fR +.HP +\fBint nc_inq_compound_fieldtype(int \fIncid\fP, nc_type \fI\fP, int \fIfieldid\fP, nc_type* \fIfield_typeid\fP)\fR +.HP +\fBint nc_inq_compound_fieldndims(int \fIncid\fP, nc_type \fI\fP, int \fIfieldid\fP, int* \fIndims\fP)\fR +.HP +\fBint nc_inq_compound_fielddim_sizes(int \fIncid\fP, nc_type \fI\fP, int \fIfieldid\fP, int \fIdim_sizes\fP[])\fR +.sp +Learn about a compound type. +.HP +\fBint nc_def_vlen(int \fIncid\fP, const char \fIname\fP[], nc_type \fIbase_typeid\fP, nc_type* \fIxtypep\fP)\fR +.sp +Create a variable length array type. +.HP +\fBint nc_inq_vlen(int \fIncid\fP, nc_type \fI\fP, char \fIname\fP[], size_t* \fIdatum_sizep\fP, nc_type* \fIbase_nc_typep\fP)\fR +.sp +Learn about a variable length array type. +.HP +\fBint nc_free_vlen(nc_vlen_t *vl)\fR +.sp +Free memory comsumed by reading data of a variable length array type. +.HP +\fBint nc_put_vlen_element(int \fIncid\fP, nc_type \fI\fP, void * \fIvlen_element\fP, size_t \fIlen\fP, void * \fIdata\fP)\fR +.sp +Write one VLEN. +.HP +\fBint nc_get_vlen_element(int \fIncid\fP, nc_type \fI\fP, void ** \fIvlen_element\fP, size_t \fIlen\fP, void ** \fIdata\fP)\fR +.sp +Read one VLEN. +.HP +\fBint nc_free_string(size_t \fIlen\fP, char **data)\fR +.sp +Free memory comsumed by reading data of a string type. +.HP +\fBint nc_inq_user_type(int \fIncid\fP, nc_type \fI\fP, char \fIname\fP[], size_t* \fI\fP, nc_type* \fI\fP, size_t* \fI\fP, int* \fI\fP)\fR +.sp +Learn about a user define type. +.HP +\fBint nc_def_enum(int \fIncid\fP, nc_type \fIbase_typeid\fP, const char \fIname\fP[], nc_type* \fItypeidp\fP)\fR +.sp +Define an enumeration type. +.HP +\fBint nc_insert_enum(int \fIncid\fP, nc_type \fIbase_typeid\fP, const char \fIname\fP[], const void *value)\fR +.sp +Insert a name-value pair into enumeration type. +.HP +\fBint nc_inq_enum_member(int \fIncid\fP, nc_type \fIxtype\fP, int \fIidx\fP, char \fIname\fP[], void *value)\fR +.HP +\fBint nc_inq_enum_ident(int \fIncid\fP, nc_type \fIxtype\fP, int \fIidx\fP, long long \fIvalue\fP, char \fIidentifier\fP[])\fR +.sp +Learn about a name-value pair into enumeration type. +.HP +\fBint nc_def_opaque(int \fIncid\fP, size_t \fIsize\fP, const char \fIname\fP[], nc_type* \fIxtypep\fP)\fR +.sp +Create an opaque type. +.HP +\fBint nc_inq_opaque(int \fIncid\fP, nc_type \fIxtype\fP, char \fIname\fP[], size_t* \fIsizep\fP)\fR +.sp +Learn about opaque type. +.HP +.SH "GROUPS" +.sp +Users may organize data into hierarchical groups in netCDF-4/HDF5 files (unless \fBNC_CLASSIC_MODEL\fR was used when creating the file). +.HP +\fBint nc_inq_grps(int \fIncid\fP, int* \fInumgrps\fP, int \fIncids\fP[])\fR +.sp +Learn how many groups (and their ncids) are available from the group represented by ncid. +.HP +\fBint nc_inq_grpname(int \fIncid\fP, char \fIname\fP[])\fR +.HP +\fBint nc_inq_grpname_full(int \fIncid\fP, size_t* \fIlen\fP, char \fIname\fP[])\fR +.HP +\fBint nc_inq_grpname_len(int \fIncid\fP, size_t* \fIlen\fP)\fR +.HP +\fBint nc_inq_grp_parent(int \fIncid\fP, int* \fIncid\fP)\fR +.HP +\fBint nc_inq_grp_ncid(int \fIncid\fP, char \fIname\fP[], int* \fIncid\fP)\fR +.HP +\fBint nc_inq_full_ncid(int \fIncid\fP, char \fIname\fP[], int* \fIncid\fP)\fR +.sp +Learn about a group. +.HP +\fBint nc_inq_varids(int \fIncid\fP, int* \fInvars\fP, int* \fI\fP)\fR +.sp +Get the varids in a group. +.HP +\fBint nc_inq_dimids(int \fIncid\fP, int* \fIndims\fP, int* \fIdimids\fP, int \fIinclude_parents\fP)\fR +.sp +Get the dimids in a group and (potentially) its parents. +.HP +\fBint nc_inq_typeids(int \fIncid\fP, int* \fIntypes\fP, int \fItypeids\fP[])\fR +.sp +Get the typeids of user-defined types in a group. +.HP +\fBint nc_def_grp(int \fIncid\fP, char \fIname\fP[], int* \fIncid\fP)\fR +.sp +Create a group. +.LP + +.SH "DIMENSIONS" +.LP +.HP +\fBint nc_inq_dimid(int \fIncid\fP, const char \fIname\fP[], int* \fIdimid\fP)\fR +.sp +(Corresponds to \fBncdimid(\|)\fR in version 2) +.sp +Given a dimension name, returns the ID of a netCDF dimension in \fIdimid\fP. +.HP +\fBint nc_inq_dim(int \fIncid\fP, int \fIdimid\fP, char \fIname\fP[], size_t* \fIlen\fP)\fR +.HP +\fBint nc_inq_dimname(int \fIncid\fP, int \fIdimid\fP, char \fIname\fP[])\fR +.HP +\fBint nc_inq_dimlen(int \fIncid\fP, int \fIdimid\fP, size_t* \fIlen\fP)\fR +.sp +Use these functions to find out about a dimension. +If either the \fIname\fP +argument or \fIlen\fP argument is a \fBNULL\fR pointer, then +the associated information will not be returned. Otherwise, +\fIname\fP should be big enough (\fBNC_MAX_NAME\fR) +to hold the dimension name as the name will be copied into your storage. +The length return parameter, \fIlen\fP +will contain the size of the dimension. +For the unlimited dimension, the returned length is the current +maximum value used for writing into any of the variables which use +the dimension. +.HP +\fBint nc_rename_dim(int \fIncid\fP, int \fIdimid\fP, const char \fIname\fP[])\fR +.sp +(Corresponds to \fBncdimrename(\|)\fR in version 2) +.sp +Renames an existing dimension in an open netCDF dataset. +If the new name is longer than the old name, the netCDF dataset must be in +define mode. +You cannot rename a dimension to have the same name as another dimension. +.SH "VARIABLES" +.LP +.HP +\fBint nc_def_var(int \fIncid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, int \fIndims\fP, const int \fIdimids\fP[], int* \fIvarid\fP)\fR +.sp +(Corresponds to \fBncvardef(\|)\fR in version 2) +.sp +Adds a new variable to a netCDF dataset. The netCDF must be in define mode. +If not \fBNULL\fR, then \fIvarid\fP will be set to the netCDF variable ID. +.HP +\fBint nc_inq_varid(int \fIncid\fP, const char \fIname\fP[], int* \fIvarid\fP)\fR +.sp +(Corresponds to \fBncvarid(\|)\fR in version 2) +.sp +Returns the ID of a netCDF variable in \fIvarid\fP given its name. +.HP +\fBint nc_inq_var(int \fIncid\fP, int \fIvarid\fP, char \fIname\fP[], nc_type* \fIxtype\fP, int* \fIndims\fP, int \fIdimids\fP[], +int* \fInatts\fP)\fR +.HP +\fBint nc_inq_varname(int \fIncid\fP, int \fIvarid\fP, char \fIname\fP[])\fR +.HP +\fBint nc_inq_vartype(int \fIncid\fP, int \fIvarid\fP, nc_type* \fIxtype\fP)\fR +.HP +\fBint nc_inq_varndims(int \fIncid\fP, int \fIvarid\fP, int* \fIndims\fP)\fR +.HP +\fBint nc_inq_vardimid(int \fIncid\fP, int \fIvarid\fP, int \fIdimids\fP[])\fR +.HP +\fBint nc_inq_varnatts(int \fIncid\fP, int \fIvarid\fP, int* \fInatts\fP)\fR +.sp +Returns information about a netCDF variable, given its ID. +If any of the +return parameters (\fIname\fP, \fIxtype\fP, \fIndims\fP, \fIdimids\fP, or +\fInatts\fP) is a \fBNULL\fR pointer, then the corresponding information +will not be returned; hence, no space need be allocated for it. +.HP +\fBint nc_rename_var(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[])\fR +.sp +(Corresponds to \fBncvarrename(\|)\fR in version 2) +.sp +Changes the name of a netCDF variable. +If the new name is longer than the old name, the netCDF must be in define mode. +You cannot rename a variable to have the name of any existing variable. + +.SH "VARIABLES \fIin\fP NETCDF-4 FILES" +.LP +The following functions may only be used on variables in a +netCDF-4/HDF5 data file. These functions must be called after the +variable is defined, but before an enddef call. +.sp +\fBint nc_def_var_deflate(int \fIncid\fP, int \fIvarid\fP, int \fIshuffle\fP, int \fIdeflate\fP, int \fIdeflate_level\fP)\fR +.sp +Turn on compression and/or shuffle filter. (Shuffle filter is only useful for integer data.) +.HP +\fBint nc_inq_var_deflate(int \fIncid\fP, int \fIvarid\fP, int* \fIshufflep\fP, int* \fIdeflatep\fP, int* \fIdeflate_levelp\fP)\fR +.sp +Learn about a variable's deflate settings. +.HP +\fBint nc_def_var_fletcher32(int \fIncid\fP, int \fIvarid\fP, int \fIfletcher32\fP)\fR +.sp +Turn on checksumming for a variable. +.HP +\fBint nc_inq_var_fletcher32(int \fIncid\fP, int \fIvarid\fP, int* \fIfletcher32\fP)\fR +.sp +Learn about checksumming for a variable. +.HP +\fBint nc_def_var_chunking(int \fIncid\fP, int \fIvarid\fP, int \fIstorage\fP, const size_t \fIchunksizesp\fP[])\fR +.sp +Set chunksizes for a variable. +.HP +\fBint nc_inq_var_chunking(int \fIncid\fP, int \fIvarid\fP, int* \fIstoragep\fP, size_t \fIchunksizesp\fP[])\fR +.sp +Learn about chunksizes for a variable. +.HP +\fBint nc_def_var_fill(int \fIncid\fP, int \fIvarid\fP, int \fIno_fill\fP, const size_t \fIchunksizesp\fP[])\fR +.sp +Set a fill value for a variable. +.HP +\fBint nc_inq_var_fill(int \fIncid\fP, int \fIvarid\fP, int* \fIstoragep\fP, size_t \fIchunksizesp\fP[])\fR +.sp +Learn the fill value for a variable. +.HP +\fBint nc_def_var_endian(int \fIncid\fP, int \fIvarid\fP, int \fIendian\fP)\fR +.sp +Set endianness of variable. +.HP +\fBint nc_inq_var_endian(int \fIncid\fP, int \fIvarid\fP, int* \fIendianp\fP)\fR +.sp +Learn the endianness of a variable. +.HP + +.SH "WRITING AND READING WHOLE VARIABLES" +.LP +.HP +\fBint nc_put_var_text(int \fIncid\fP, int \fIvarid\fP, const char \fIout\fP[])\fR +.HP +\fBint nc_put_var_uchar(int \fIncid\fP, int \fIvarid\fP, const unsigned char \fIout\fP[])\fR +.HP +\fBint nc_put_var_schar(int \fIncid\fP, int \fIvarid\fP, const signed char \fIout\fP[])\fR +.HP +\fBint nc_put_var_short(int \fIncid\fP, int \fIvarid\fP, const short \fIout\fP[])\fR +.HP +\fBint nc_put_var_int(int \fIncid\fP, int \fIvarid\fP, const int \fIout\fP[])\fR +.HP +\fBint nc_put_var_long(int \fIncid\fP, int \fIvarid\fP, const long \fIout\fP[])\fR +.HP +\fBint nc_put_var_float(int \fIncid\fP, int \fIvarid\fP, const float \fIout\fP[])\fR +.HP +\fBint nc_put_var_double(int \fIncid\fP, int \fIvarid\fP, const double \fIout\fP[])\fR +.HP +\fBint nc_put_var_ubyte(int \fIncid\fP, int \fIvarid\fP, const unsigned char \fIout\fP[])\fR +.HP +\fBint nc_put_var_ushort(int \fIncid\fP, int \fIvarid\fP, const unsigned short \fIout\fP[])\fR +.HP +\fBint nc_put_var_uint(int \fIncid\fP, int \fIvarid\fP, const unsigned int \fIout\fP[])\fR +.HP +\fBint nc_put_var_int64(int \fIncid\fP, int \fIvarid\fP, const long long \fIout\fP[])\fR +.HP +\fBint nc_put_var_uint64(int \fIncid\fP, int \fIvarid\fP, const unsigned long long \fIout\fP[])\fR +.HP +\fBint nc_put_var_string(int \fIncid\fP, int \fIvarid\fP, const char * \fIout\fP[])\fR + + +.sp +Writes an entire netCDF variable (i.e. all the values). The netCDF +dataset must be open and in data mode. The type of the data is +specified in the function name, and it is converted to the external +type of the specified variable, if possible, otherwise an +\fBNC_ERANGE\fR error is returned. Note that rounding is not performed +during the conversion. Floating point numbers are truncated when +converted to integers. +.HP +\fBint nc_get_var_text(int \fIncid\fP, int \fIvarid\fP, char \fIin\fP[])\fR +.HP +\fBint nc_get_var_uchar(int \fIncid\fP, int \fIvarid\fP, unsigned char \fIin\fP[])\fR +.HP +\fBint nc_get_var_schar(int \fIncid\fP, int \fIvarid\fP, signed char \fIin\fP[])\fR +.HP +\fBint nc_get_var_short(int \fIncid\fP, int \fIvarid\fP, short \fIin\fP[])\fR +.HP +\fBint nc_get_var_int(int \fIncid\fP, int \fIvarid\fP, int \fIin\fP[])\fR +.HP +\fBint nc_get_var_long(int \fIncid\fP, int \fIvarid\fP, long \fIin\fP[])\fR +.HP +\fBint nc_get_var_float(int \fIncid\fP, int \fIvarid\fP, float \fIin\fP[])\fR +.HP +\fBint nc_get_var_double(int \fIncid\fP, int \fIvarid\fP, double \fIin\fP[])\fR +.HP +\fBint nc_get_var_ubyte(int \fIncid\fP, int \fIvarid\fP, unsigned char \fIin\fP[])\fR +.HP +\fBint nc_get_var_ushort(int \fIncid\fP, int \fIvarid\fP, unsigned short \fIin\fP[])\fR +.HP +\fBint nc_get_var_uint(int \fIncid\fP, int \fIvarid\fP, unsigned int \fIin\fP[])\fR +.HP +\fBint nc_get_var_int64(int \fIncid\fP, int \fIvarid\fP, long long \fIin\fP[])\fR +.HP +\fBint nc_get_var_uint64(int \fIncid\fP, int \fIvarid\fP, unsigned long long \fIin\fP[])\fR +.HP +\fBint nc_get_var_string(int \fIncid\fP, int \fIvarid\fP, char * \fIin\fP[])\fR + + +.sp +Reads an entire netCDF variable (i.e. all the values). +The netCDF dataset must be open and in data mode. +The data is converted from the external type of the specified variable, +if necessary, to the type specified in the function name. If conversion is +not possible, an \fBNC_ERANGE\fR error is returned. +.SH "WRITING AND READING ONE DATUM" +.LP +.HP +\fBint nc_put_var1_text(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], char \fI*out\fP)\fR +.HP +\fBint nc_put_var1_uchar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], unsigned char \fI*out\fP)\fR +.HP +\fBint nc_put_var1_schar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], signed char \fI*out\fP)\fR +.HP +\fBint nc_put_var1_short(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], short \fI*out\fP)\fR +.HP +\fBint nc_put_var1_int(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], int \fI*out\fP)\fR +.HP +\fBint nc_put_var1_long(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], long \fI*out\fP)\fR +.HP +\fBint nc_put_var1_float(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], float \fI*out\fP)\fR +.HP +\fBint nc_put_var1_double(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], double \fI*out\fP)\fR +.HP +\fBint nc_put_var1_ubyte(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], unsigned char \fI*out\fP)\fR +.HP +\fBint nc_put_var1_ushort(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], unsigned short \fI*out\fP)\fR +.HP +\fBint nc_put_var1_uint(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], unsigned int \fI*out\fP)\fR +.HP +\fBint nc_put_var1_int64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], long long \fI*out\fP)\fR +.HP +\fBint nc_put_var1_uint64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], unsigned long long \fI*out\fP)\fR +.HP +\fBint nc_put_var1_string(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], char * \fI*out\fP)\fR + + +.sp +Puts a single data value into a variable at the position \fIindex\fP of an +open netCDF dataset that is in data mode. The type of the data is +specified in the function name, and it is converted to the external type +of the specified variable, if possible, otherwise an \fBNC_ERANGE\fR +error is returned. +.HP +\fBint nc_get_var1_text(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], char* \fIin\fP)\fR +.HP +\fBint nc_get_var1_uchar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], unsigned char* \fIin\fP)\fR +.HP +\fBint nc_get_var1_schar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], signed char* \fIin\fP)\fR +.HP +\fBint nc_get_var1_short(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], short* \fIin\fP)\fR +.HP +\fBint nc_get_var1_int(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], int* \fIin\fP)\fR +.HP +\fBint nc_get_var1_long(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], long* \fIin\fP)\fR +.HP +\fBint nc_get_var1_float(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], float* \fIin\fP)\fR +.HP +\fBint nc_get_var1_double(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], double* \fIin\fP)\fR +.HP +\fBint nc_get_var1_ubyte(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], unsigned char* \fIin\fP)\fR +.HP +\fBint nc_get_var1_ushort(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], unsigned short* \fIin\fP)\fR +.HP +\fBint nc_get_var1_uint(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], unsigned int* \fIin\fP)\fR +.HP +\fBint nc_get_var1_int64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], long long* \fIin\fP)\fR +.HP +\fBint nc_get_var1_uint64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], unsigned long long* \fIin\fP)\fR +.HP +\fBint nc_get_var1_string(int \fIncid\fP, int \fIvarid\fP, const size_t \fIindex\fP[], char ** \fIin\fP)\fR + + +.sp +Gets a single data value from a variable at the position \fIindex\fP +of an open netCDF dataset that is in data mode. +The data is converted from the external type of the specified variable, +if necessary, to the type specified in the function name. If conversion is +not possible, an \fBNC_ERANGE\fR error is returned. +.SH "WRITING AND READING AN ARRAY" +.LP +.HP +\fBint nc_put_vara_text(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const char \fIout\fP[])\fR +.HP +\fBint nc_put_vara_uchar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const unsigned char \fIout\fP[])\fR +.HP +\fBint nc_put_vara_schar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const signed char \fIout\fP[])\fR +.HP +\fBint nc_put_vara_short(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const short \fIout\fP[])\fR +.HP +\fBint nc_put_vara_int(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const int \fIout\fP[])\fR +.HP +\fBint nc_put_vara_long(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const long \fIout\fP[])\fR +.HP +\fBint nc_put_vara_float(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const float \fIout\fP[])\fR +.HP +\fBint nc_put_vara_double(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const double \fIout\fP[])\fR +.HP +\fBint nc_put_vara_ubyte(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const unsigned char \fIout\fP[])\fR +.HP +\fBint nc_put_vara_ushort(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const unsigned short \fIout\fP[])\fR +.HP +\fBint nc_put_vara_uint(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const unsigned int \fIout\fP[])\fR +.HP +\fBint nc_put_vara_int64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const long long \fIout\fP[])\fR +.HP +\fBint nc_put_vara_uint64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const unsigned long long \fIout\fP[])\fR +.HP +\fBint nc_put_vara_string(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const char * \fIout\fP[])\fR + + +.sp +Writes an array section of values into a netCDF variable of an open +netCDF dataset, which must be in data mode. The array section is specified +by the \fIstart\fP and \fIcount\fP vectors, which give the starting index +and count of values along each dimension of the specified variable. +The type of the data is +specified in the function name and is converted to the external type +of the specified variable, if possible, otherwise an \fBNC_ERANGE\fR +error is returned. +.HP +\fBint nc_get_vara_text(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], char \fIin\fP[])\fR +.HP +\fBint nc_get_vara_uchar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], unsigned char \fIin\fP[])\fR +.HP +\fBint nc_get_vara_schar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], signed char \fIin\fP[])\fR +.HP +\fBint nc_get_vara_short(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], short \fIin\fP[])\fR +.HP +\fBint nc_get_vara_int(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], int \fIin\fP[])\fR +.HP +\fBint nc_get_vara_long(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], long \fIin\fP[])\fR +.HP +\fBint nc_get_vara_float(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], float \fIin\fP[])\fR +.HP +\fBint nc_get_vara_double(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], double \fIin\fP[])\fR +.HP +\fBint nc_get_vara_ubyte(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], unsigned char \fIin\fP[])\fR +.HP +\fBint nc_get_vara_ushort(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], unsigned short \fIin\fP[])\fR +.HP +\fBint nc_get_vara_uint(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], unsigned int \fIin\fP[])\fR +.HP +\fBint nc_get_vara_int64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], long long \fIin\fP[])\fR +.HP +\fBint nc_get_vara_uint64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], unsigned long long \fIin\fP[])\fR +.HP +\fBint nc_get_vara_string(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], char * \fIin\fP[])\fR + + +.sp +Reads an array section of values from a netCDF variable of an open +netCDF dataset, which must be in data mode. The array section is specified +by the \fIstart\fP and \fIcount\fP vectors, which give the starting index +and count of values along each dimension of the specified variable. +The data is converted from the external type of the specified variable, +if necessary, to the type specified in the function name. If conversion is +not possible, an \fBNC_ERANGE\fR error is returned. +.SH "WRITING AND READING A SLICED ARRAY" +.LP +.HP +\fBint nc_put_vars_text(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const char \fIout\fP[])\fR +.HP +\fBint nc_put_vars_uchar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const unsigned char \fIout\fP[])\fR +.HP +\fBint nc_put_vars_schar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const signed char \fIout\fP[])\fR +.HP +\fBint nc_put_vars_short(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const short \fIout\fP[])\fR +.HP +\fBint nc_put_vars_int(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const int \fIout\fP[])\fR +.HP +\fBint nc_put_vars_long(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const long \fIout\fP[])\fR +.HP +\fBint nc_put_vars_float(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const float \fIout\fP[])\fR +.HP +\fBint nc_put_vars_double(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const double \fIout\fP[])\fR +.HP +\fBint nc_put_vars_ubyte(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const unsigned char \fIout\fP[])\fR +.HP +\fBint nc_put_vars_ushort(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const unsigned short \fIout\fP[])\fR +.HP +\fBint nc_put_vars_uint(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const unsigned int \fIout\fP[])\fR +.HP +\fBint nc_put_vars_int64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const long long \fIout\fP[])\fR +.HP +\fBint nc_put_vars_uint64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const unsigned long long \fIout\fP[])\fR +.HP +\fBint nc_put_vars_string(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], const char * \fIout\fP[])\fR + + +.sp +These functions are used for \fIstrided output\fP, which is like the +array section output described above, except that +the sampling stride (the interval between accessed values) is +specified for each dimension. +For an explanation of the sampling stride +vector, see COMMON ARGUMENTS DESCRIPTIONS below. +.HP +\fBint nc_get_vars_text(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], char \fIin\fP[])\fR +.HP +\fBint nc_get_vars_uchar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], unsigned char \fIin\fP[])\fR +.HP +\fBint nc_get_vars_schar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], signed char \fIin\fP[])\fR +.HP +\fBint nc_get_vars_short(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], short \fIin\fP[])\fR +.HP +\fBint nc_get_vars_int(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], int \fIin\fP[])\fR +.HP +\fBint nc_get_vars_long(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], long \fIin\fP[])\fR +.HP +\fBint nc_get_vars_float(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], float \fIin\fP[])\fR +.HP +\fBint nc_get_vars_double(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], double \fIin\fP[])\fR +.HP +\fBint nc_get_vars_ubyte(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], unsigned char \fIin\fP[])\fR +.HP +\fBint nc_get_vars_ushort(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], unsigned short \fIin\fP[])\fR +.HP +\fBint nc_get_vars_uint(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], unsigned int \fIin\fP[])\fR +.HP +\fBint nc_get_vars_int64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], long long \fIin\fP[])\fR +.HP +\fBint nc_get_vars_uint64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], unsigned long long \fIin\fP[])\fR +.HP +\fBint nc_get_vars_string(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], char * \fIin\fP[])\fR + + +.sp +These functions are used for \fIstrided input\fP, which is like the +array section input described above, except that +the sampling stride (the interval between accessed values) is +specified for each dimension. +For an explanation of the sampling stride +vector, see COMMON ARGUMENTS DESCRIPTIONS below. +.SH "WRITING AND READING A MAPPED ARRAY" +.LP +.HP +\fBint nc_put_varm_text(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const char \fIout\fP[])\fR +.HP +\fBint nc_put_varm_uchar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const unsigned char \fIout\fP[])\fR +.HP +\fBint nc_put_varm_schar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const signed char \fIout\fP[])\fR +.HP +\fBint nc_put_varm_short(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const short \fIout\fP[])\fR +.HP +\fBint nc_put_varm_int(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const int \fIout\fP[])\fR +.HP +\fBint nc_put_varm_long(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const long \fIout\fP[])\fR +.HP +\fBint nc_put_varm_float(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const float \fIout\fP[])\fR +.HP +\fBint nc_put_varm_double(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const double \fIout\fP[])\fR +.HP +\fBint nc_put_varm_ubyte(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const unsigned char \fIout\fP[])\fR +.HP +\fBint nc_put_varm_ushort(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const unsigned short \fIout\fP[])\fR +.HP +\fBint nc_put_varm_uint(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const unsigned int \fIout\fP[])\fR +.HP +\fBint nc_put_varm_int64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const long long \fIout\fP[])\fR +.HP +\fBint nc_put_varm_uint64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const unsigned long long \fIout\fP[])\fR +.HP +\fBint nc_put_varm_string(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, const char * \fIout\fP[])\fR + + +.sp +These functions are used for \fImapped output\fP, which is like +strided output described above, except that an additional index mapping +vector is provided to specify the in-memory arrangement of the data +values. +For an explanation of the index +mapping vector, see COMMON ARGUMENTS DESCRIPTIONS below. +.HP +\fBint nc_get_varm_text(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, char \fIin\fP[])\fR +.HP +\fBint nc_get_varm_uchar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, unsigned char \fIin\fP[])\fR +.HP +\fBint nc_get_varm_schar(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, signed char \fIin\fP[])\fR +.HP +\fBint nc_get_varm_short(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, short \fIin\fP[])\fR +.HP +\fBint nc_get_varm_int(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, int \fIin\fP[])\fR +.HP +\fBint nc_get_varm_long(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, long \fIin\fP[])\fR +.HP +\fBint nc_get_varm_float(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, float \fIin\fP[])\fR +.HP +\fBint nc_get_varm_double(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, double \fIin\fP[])\fR +.HP +\fBint nc_get_varm_ubyte(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, unsigned char \fIin\fP[])\fR +.HP +\fBint nc_get_varm_ushort(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, unsigned short \fIin\fP[])\fR +.HP +\fBint nc_get_varm_uint(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, unsigned int \fIin\fP[])\fR +.HP +\fBint nc_get_varm_int64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, long long \fIin\fP[])\fR +.HP +\fBint nc_get_varm_uint64(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, unsigned long long \fIin\fP[])\fR +.HP +\fBint nc_get_varm_string(int \fIncid\fP, int \fIvarid\fP, const size_t \fIstart\fP[], const size_t \fIcount\fP[], const size_t \fIstride\fP[], \fIimap\fP, char * \fIin\fP[])\fR + + +.sp +These functions are used for \fImapped input\fP, which is like +strided input described above, except that an additional index mapping +vector is provided to specify the in-memory arrangement of the data +values. +For an explanation of the index +mapping vector, see COMMON ARGUMENTS DESCRIPTIONS below. +.SH "ATTRIBUTES" +.LP +.HP +\fBint nc_put_att_text(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const char \fIout\fP[])\fR +.HP +\fBint nc_put_att_uchar(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const unsigned char \fIout\fP[])\fR +.HP +\fBint nc_put_att_schar(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const signed char \fIout\fP[])\fR +.HP +\fBint nc_put_att_short(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const short \fIout\fP[])\fR +.HP +\fBint nc_put_att_int(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const int \fIout\fP[])\fR +.HP +\fBint nc_put_att_long(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const long \fIout\fP[])\fR +.HP +\fBint nc_put_att_float(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const float \fIout\fP[])\fR +.HP +\fBint nc_put_att_double(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const double \fIout\fP[])\fR +.HP +\fBint nc_put_att_ubyte(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const unsigned char \fIout\fP[])\fR +.HP +\fBint nc_put_att_ushort(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const unsigned short \fIout\fP[])\fR +.HP +\fBint nc_put_att_uint(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const unsigned int \fIout\fP[])\fR +.HP +\fBint nc_put_att_int64(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const long long \fIout\fP[])\fR +.HP +\fBint nc_put_att_uint64(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const unsigned long long \fIout\fP[])\fR +.HP +\fBint nc_put_att_string(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, const char * \fIout\fP[])\fR + + +.HP +\fBint nc_put_att(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type \fIxtype\fP, size_t \fIlen\fP, void * \fIip\fP)\fR +.HP +\fBint nc_get_att(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], void ** \fIip\fP)\fR +.sp +Unlike variables, attributes do not have +separate functions for defining and writing values. +This family of functions defines a new attribute with a value or changes +the value of an existing attribute. +If the attribute is new, or if the space required to +store the attribute value is greater than before, +the netCDF dataset must be in define mode. +The parameter \fIlen\fP is the number of values from \fIout\fP to transfer. +It is often one, except that for +\fBnc_put_att_text(\|)\fR it will usually be +\fBstrlen(\fIout\fP)\fR. +.sp +For these functions, the type component of the function name refers to +the in-memory type of the value, whereas the \fIxtype\fP argument refers to the +external type for storing the value. An \fBNC_ERANGE\fR +error results if +a conversion between these types is not possible. In this case the value +is represented with the appropriate fill-value for the associated +external type. +.HP +\fBint nc_inq_attname(int \fIncid\fP, int \fIvarid\fP, int \fIattnum\fP, char \fIname\fP[])\fR +.sp +Gets the +name of an attribute, given its variable ID and attribute number. +This function is useful in generic applications that +need to get the names of all the attributes associated with a variable, +since attributes are accessed by name rather than number in all other +attribute functions. The number of an attribute is more volatile than +the name, since it can change when other attributes of the same variable +are deleted. The attributes for each variable are numbered +from 0 (the first attribute) to +\fInvatts\fP-1, +where \fInvatts\fP is +the number of attributes for the variable, as returned from a call to +\fBnc_inq_varnatts(\|)\fR. +If the \fIname\fP parameter is a \fBNULL\fR pointer, no name will be +returned and no space need be allocated. +.HP +\fBint nc_inq_att(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type* \fIxtype\fP, size_t* \fIlen\fP)\fR +.HP +\fBint nc_inq_attid(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], int* \fIattnum\fP)\fR +.HP +\fBint nc_inq_atttype(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], nc_type* \fIxtype\fP)\fR +.HP +\fBint nc_inq_attlen(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], size_t* \fIlen\fP)\fR +.sp +These functions return information about a netCDF attribute, +given its variable ID and name. The information returned is the +external type in \fIxtype\fP +and the number of elements in the attribute as \fIlen\fP. +If any of the return arguments is a \fBNULL\fR pointer, +the specified information will not be returned. +.HP +\fBint nc_copy_att(int \fIncid\fP, int \fIvarid_in\fP, const char \fIname\fP[], int \fIncid_out\fP, int \fIvarid_out\fP)\fR +.sp +Copies an +attribute from one netCDF dataset to another. It can also be used to +copy an attribute from one variable to another within the same netCDF. +\fIncid_in\fP is the netCDF ID of an input netCDF dataset from which the +attribute will be copied. +\fIvarid_in\fP +is the ID of the variable in the input netCDF dataset from which the +attribute will be copied, or \fBNC_GLOBAL\fR +for a global attribute. +\fIname\fP +is the name of the attribute in the input netCDF dataset to be copied. +\fIncid_out\fP +is the netCDF ID of the output netCDF dataset to which the attribute will be +copied. +It is permissible for the input and output netCDF ID's to be the same. The +output netCDF dataset should be in define mode if the attribute to be +copied does not already exist for the target variable, or if it would +cause an existing target attribute to grow. +\fIvarid_out\fP +is the ID of the variable in the output netCDF dataset to which the attribute will +be copied, or \fBNC_GLOBAL\fR to copy to a global attribute. +.HP +\fBint nc_rename_att(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], const char \fInewname\fP[])\fR +.sp +Changes the +name of an attribute. If the new name is longer than the original name, +the netCDF must be in define mode. You cannot rename an attribute to +have the same name as another attribute of the same variable. +\fIname\fP is the original attribute name. +\fInewname\fP +is the new name to be assigned to the specified attribute. If the new name +is longer than the old name, the netCDF dataset must be in define mode. +.HP +\fBint nc_del_att(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[])\fR +.sp +Deletes an attribute from a netCDF dataset. The dataset must be in +define mode. +.HP +\fBint nc_get_att_text(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], char \fIin\fP[])\fR +.HP +\fBint nc_get_att_uchar(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], unsigned char \fIin\fP[])\fR +.HP +\fBint nc_get_att_schar(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], signed char \fIin\fP[])\fR +.HP +\fBint nc_get_att_short(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], short \fIin\fP[])\fR +.HP +\fBint nc_get_att_int(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], int \fIin\fP[])\fR +.HP +\fBint nc_get_att_long(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], long \fIin\fP[])\fR +.HP +\fBint nc_get_att_float(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], float \fIin\fP[])\fR +.HP +\fBint nc_get_att_double(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], double \fIin\fP[])\fR +.HP +\fBint nc_get_att_ubyte(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], unsigned char \fIin\fP[])\fR +.HP +\fBint nc_get_att_ushort(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], unsigned short \fIin\fP[])\fR +.HP +\fBint nc_get_att_uint(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], unsigned int \fIin\fP[])\fR +.HP +\fBint nc_get_att_int64(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], long long \fIin\fP[])\fR +.HP +\fBint nc_get_att_uint64(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], unsigned long long \fIin\fP[])\fR +.HP +\fBint nc_get_att_string(int \fIncid\fP, int \fIvarid\fP, const char \fIname\fP[], char * \fIin\fP[])\fR + + +.sp +Gets the value(s) of a netCDF attribute, given its +variable ID and name. Converts from the external type to the type +specified in +the function name, if possible, otherwise returns an \fBNC_ERANGE\fR +error. +All elements of the vector of attribute +values are returned, so you must allocate enough space to hold +them. If you don't know how much space to reserve, call +\fBnc_inq_attlen(\|)\fR +first to find out the length of the attribute. +.SH "COMMON ARGUMENT DESCRIPTIONS" +.LP +In this section we define some common arguments which are used in the +"FUNCTION DESCRIPTIONS" section. +.TP +int \fIncid\fP +is the netCDF ID returned from a previous, successful call to +\fBnc_open(\|)\fR or \fBnc_create(\|)\fR +.TP +char \fIname\fP[] +is the name of a dimension, variable, or attribute. The names of +dimensions, variables and attributes consist of arbitrary +sequences of alphanumeric characters (as well as underscore '_', +period '.' and hyphen '-'), beginning with a letter or +underscore. (However names commencing with underscore are reserved for +system use.) Case is significant in netCDF names. A zero-length name +is not allowed. +As an input argument, +it shall be a pointer to a 0-terminated string; as an output argument, it +shall be the address of a buffer in which to hold such a string. +The maximum allowable number of characters +(excluding the terminating 0) is \fBNC_MAX_NAME\fR. +.TP +nc_type \fIxtype\fP +specifies the external data type of a netCDF variable or attribute and +is one of the following: +\fBNC_BYTE\fR, \fBNC_CHAR\fR, \fBNC_SHORT\fR, \fBNC_INT\fR, +\fBNC_FLOAT\fR, or \fBNC_DOUBLE\fR. +These are used to specify 8-bit integers, +characters, 16-bit integers, 32-bit integers, 32-bit IEEE floating point +numbers, and 64-bit IEEE floating-point numbers, respectively. +(\fBNC_INT\fR corresponds to \fBNC_LONG\fR in version 2, to specify a +32-bit integer). +.TP +int \fIdimids\fP[] +is a vector of dimension ID's and defines the shape of a netCDF variable. +The size of the vector shall be greater than or equal to the +rank (i.e. the number of dimensions) of the variable (\fIndims\fP). +The vector shall be ordered by the speed with which a dimension varies: +\fIdimids\fP[\fIndims\fP-1] +shall be the dimension ID of the most rapidly +varying dimension and +\fIdimids\fP[0] +shall be the dimension ID of the most slowly +varying dimension. +The maximum possible number of +dimensions for a variable is given by the symbolic constant +\fBNC_MAX_VAR_DIMS\fR. +.TP +int \fIdimid\fP +is the ID of a netCDF dimension. +netCDF dimension ID's are allocated sequentially from the +non-negative +integers beginning with 0. +.TP +int \fIndims\fP +is either the total number of dimensions in a netCDF dataset or the rank +(i.e. the number of dimensions) of a netCDF variable. +The value shall not be negative or greater than the symbolic constant +\fBNC_MAX_VAR_DIMS\fR. +.TP +int \fIvarid\fP +is the ID of a netCDF variable or (for the attribute-access functions) +the symbolic constant +\fBNC_GLOBAL\fR, +which is used to reference global attributes. +netCDF variable ID's are allocated sequentially from the +non-negative +integers beginning with 0. +.TP +int* \fInatts\fP +is the number of global attributes in a netCDF dataset for the +\fBnc_inquire(\|)\fR +function or the number +of attributes associated with a netCDF variable for the +\fBnc_varinq(\|)\fR +function. +.TP +const size_t \fIindex\fP[] +specifies the indicial coordinates of the netCDF data value to be accessed. +The indices start at 0; +thus, for example, the first data value of a +two-dimensional variable is (0,0). +The size of the vector shall be at least the rank of the associated +netCDF variable and its elements shall correspond, in order, to the +variable's dimensions. +.TP +const size_t \fIstart\fP[] +specifies the starting point +for accessing a netCDF variable's data values +in terms of the indicial coordinates of +the corner of the array section. +The indices start at 0; +thus, the first data +value of a variable is (0, 0, ..., 0). +The size of the vector shall be at least the rank of the associated +netCDF variable and its elements shall correspond, in order, to the +variable's dimensions. +.TP +const size_t \fIcount\fP[] +specifies the number of indices selected along each dimension of the +array section. +Thus, to access a single value, for example, specify \fIcount\fP as +(1, 1, ..., 1). +Note that, for strided I/O, this argument must be adjusted +to be compatible with the \fIstride\fP and \fIstart\fP arguments so that +the interaction of the +three does not attempt to access an invalid data co-ordinate. +The elements of the +\fIcount\fP vector correspond, in order, to the variable's dimensions. +.TP +const size_t \fIstride\fP[] +specifies the sampling interval along each dimension of the netCDF +variable. The elements of the stride vector correspond, in order, +to the netCDF variable's dimensions (\fIstride\fP[0]) +gives the sampling interval along the most slowly +varying dimension of the netCDF variable). Sampling intervals are +specified in type-independent units of elements (a value of 1 selects +consecutive elements of the netCDF variable along the corresponding +dimension, a value of 2 selects every other element, etc.). +A \fBNULL\fR stride argument is treated as (1, 1, ... , 1). +.TP +\fIimap\fP +specifies the mapping between the dimensions of a netCDF variable and +the in-memory structure of the internal data array. The elements of +the index mapping vector correspond, in order, to the netCDF variable's +dimensions (\fIimap\fP[0] gives the distance +between elements of the internal array corresponding to the most +slowly varying dimension of the netCDF variable). +Distances between elements are specified in type-independent units of +elements (the distance between internal elements that occupy adjacent +memory locations is 1 and not the element's byte-length as in netCDF 2). +A \fBNULL\fR pointer means the memory-resident values have +the same structure as the associated netCDF variable. +.SH "VARIABLE PREFILLING" +.LP +By default, the netCDF interface sets the values of +all newly-defined variables of finite length (i.e. those that do not have +an unlimited, dimension) to the type-dependent fill-value associated with each +variable. This is done when \fBnc_enddef(\|)\fR +is called. The +fill-value for a variable may be changed from the default value by +defining the attribute `\fB_FillValue\fR' for the variable. This +attribute must have the same type as the variable and be of length one. +.LP +Variables with an unlimited dimension are also prefilled, but on +an `as needed' basis. For example, if the first write of such a +variable is to position 5, then +positions +0 through 4 +(and no others) +would be set to the fill-value at the same time. +.LP +This default prefilling of data values may be disabled by +or'ing the +\fBNC_NOFILL\fR +flag into the mode parameter of \fBnc_open(\|)\fR or \fBnc_create(\|)\fR, +or, by calling the function \fBnc_set_fill(\|)\fR +with the argument \fBNC_NOFILL\fR. +For variables that do not use the unlimited dimension, +this call must +be made before +\fBnc_enddef(\|)\fR. +For variables that +use the unlimited dimension, this call +may be made at any time. +.LP +One can obtain increased performance of the netCDF interface by using +this feature, but only at the expense of requiring the application to set +every single data value. The performance +enhancing behavior of this function is dependent on the particulars of +the implementation and dataset format. +The flag value controlled by \fBnc_set_fill(\|)\fR +is per netCDF ID, +not per variable or per write. +Allowing this to change affects the degree to which +a program can be effectively parallelized. +Given all of this, we state that the use +of this feature may not be available (or even needed) in future +releases. Programmers are cautioned against heavy reliance upon this +feature. +.HP +\fBint nc_setfill(int \fIncid\fP, int \fIfillmode\fP, int* \fIold_fillemode\fP)\fR +.sp +(Corresponds to \fBncsetfill(\|)\fR in version 2) +.sp +Determines whether or not variable prefilling will be done (see +above). +The netCDF dataset shall be writable. +\fIfillmode\fP is either \fBNC_FILL\fR +to enable prefilling (the +default) or \fBNC_NOFILL\fR +to disable prefilling. +This function returns the previous setting in \fIold_fillmode\fP. + +.HP +.SH "MPP FUNCTION DESCRIPTIONS" +.LP +Additional functions for use on SGI/Cray MPP machines (_CRAYMPP). +These are used to set and inquire which PE is the base for MPP +for a particular netCDF. These are only relevant when +using the SGI/Cray ``global'' +Flexible File I/O layer and desire to have +only a subset of PEs to open the specific netCDF file. +For technical reasons, these functions are available on all platforms. +On a platform other than SGI/Cray MPP, it is as if +only processor available were processor 0. +.LP +To use this feature, you need to specify a communicator group and call +\fBglio_group_mpi(\|)\fR or \fBglio_group_shmem(\|)\fR prior to the netCDF +\fBnc_open(\|)\fR and \fBnc_create(\|)\fR calls. +.HP +\fBint nc__create_mp(const char \fIpath\fP[], int \fIcmode\fP, size_t \fIinitialsize\fP, int \fIpe\fP, size_t* \fIchunksize\fP, int* \fIncid\fP)\fR +.sp +Like \fBnc__create(\|)\fR but allows the base PE to be set. +.sp +The argument \fIpe\fP sets the base PE at creation time. In the MPP +environment, \fBnc__create(\|)\fR and \fBnc_create(\|)\fR set the base PE to processor +zero by default. +.HP +\fBint nc__open_mp(const char \fIpath\fP[], int \fImode\fP, int \fIpe\fP, size_t* \fIchunksize\fP, int* \fIncid\fP)\fR +.sp +Like \fBnc__open(\|)\fR but allows the base PE to be set. +The argument \fIpe\fP sets the base PE at creation time. In the MPP +environment, \fBnc__open(\|)\fR and \fBnc_open(\|)\fR set the base PE to processor +zero by default. +.HP +\fBint nc_inq_base_pe(int \fIncid\fP, int* \fIpe\fP)\fR +.sp +Inquires of the netCDF dataset which PE is being used as the base for MPP use. +This is safe to use at any time. +.HP +\fBint nc_set_base_pe(int \fIncid\fP, int \fIpe\fP)\fR +.sp +Resets the base PE for the netCDF dataset. +Only perform this operation when the affected communicator group +synchronizes before and after the call. +This operation is very risky and should only be contemplated +under only the most extreme cases. +.SH "ENVIRONMENT VARIABLES" +.TP 4 +.B NETCDF_FFIOSPEC +Specifies the Flexible File I/O buffers for netCDF I/O when executing +under the UNICOS operating system (the variable is ignored on other +operating systems). +An appropriate specification can greatly increase the efficiency of +netCDF I/O -- to the extent that it can actually surpass FORTRAN binary +I/O. +This environment variable has been made a little more generalized, +such that other FFIO option specifications can now be added. +The default specification is \fBbufa:336:2\fP, +unless a current FFIO specification is in operation, +which will be honored. +See UNICOS Flexible File I/O for more information. +.SH "MAILING-LISTS" +.LP +Both a mailing list and a digest are available for +discussion of the netCDF interface and announcements about netCDF bugs, +fixes, and enhancements. +To begin or change your subscription to either the mailing-list or the +digest, send one of the following in the body (not +the subject line) of an email message to "majordomo@unidata.ucar.edu". +Use your email address in place of \fIjdoe@host.inst.domain\fP. +.sp +To subscribe to the netCDF mailing list: +.RS +\fBsubscribe netcdfgroup \fIjdoe@host.inst.domain\fR +.RE +To unsubscribe from the netCDF mailing list: +.RS +\fBunsubscribe netcdfgroup \fIjdoe@host.inst.domain\fR +.RE +To subscribe to the netCDF digest: +.RS +\fBsubscribe netcdfdigest \fIjdoe@host.inst.domain\fR +.RE +To unsubscribe from the netCDF digest: +.RS +\fBunsubscribe netcdfdigest \fIjdoe@host.inst.domain\fR +.RE +To retrieve the general introductory information for the mailing list: +.RS +\fBinfo netcdfgroup\fR +.RE +To get a synopsis of other majordomo commands: +.RS +\fBhelp\fR +.RE +.SH "SEE ALSO" +.LP +.BR ncdump (1), +.BR ncgen (1), +.BR netcdf (3). +.LP +\fInetCDF User's Guide\fP, published +by the Unidata Program Center, University Corporation for Atmospheric +Research, located in Boulder, Colorado. + +NetCDF home page at http:/www.unidata.ucar.edu/netcdf. diff --git a/libsrc/putget.c b/libsrc/putget.c new file mode 100644 index 0000000000..c60bc49f67 --- /dev/null +++ b/libsrc/putget.c @@ -0,0 +1,21072 @@ +#line 9 "putget.m4" +/* Do not edit this file. It is produced from the corresponding .m4 source */ +#line 11 +/* + * Copyright 2018, University Corporation for Atmospheric Research + * See netcdf/COPYRIGHT file for copying and redistribution conditions. + */ +/* $Id: putget.m4 2783 2014-10-26 05:19:35Z wkliao $ */ + +#if HAVE_CONFIG_H +#include +#endif + +#include +#include +#include + +#include "netcdf.h" +#include "nc3dispatch.h" +#include "nc3internal.h" +#include "ncx.h" +#include "fbits.h" +#include "onstack.h" +#ifdef LOCKNUMREC +# include /* for SGI/Cray SHMEM routines */ +# ifdef LN_TEST +# include +# endif +#endif + + +#undef MIN /* system may define MIN somewhere and complain */ +#define MIN(mm,nn) (((mm) < (nn)) ? (mm) : (nn)) + +static int +readNCv(const NC3_INFO* ncp, const NC_var* varp, const size_t* start, + const size_t nelems, void* value, const nc_type memtype); +static int +writeNCv(NC3_INFO* ncp, const NC_var* varp, const size_t* start, + const size_t nelems, const void* value, const nc_type memtype); + + +/* #define ODEBUG 1 */ + +#if ODEBUG +#include +/* + * Print the values of an array of size_t + */ +void +arrayp(const char *label, size_t count, const size_t *array) +{ + (void) fprintf(stderr, "%s", label); + (void) fputc('\t',stderr); + for(; count > 0; count--, array++) + (void) fprintf(stderr," %lu", (unsigned long)*array); + (void) fputc('\n',stderr); +} +#endif /* ODEBUG */ + + +/* Begin fill */ +/* + * This is tunable parameter. + * It essentially controls the tradeoff between the number of times + * memcpy() gets called to copy the external data to fill + * a large buffer vs the number of times its called to + * prepare the external data. + */ +#if _SX +/* NEC SX specific optimization */ +#define NFILL 2048 +#else +#define NFILL 16 +#endif + + +#line 110 + +/* + * Next 6 type specific functions + * Fill a some memory with the default special value. + * Formerly +NC_arrayfill() + */ +static int +#line 117 +NC_fill_schar( +#line 117 + void **xpp, +#line 117 + size_t nelems) /* how many */ +#line 117 +{ +#line 117 + schar fillp[NFILL * sizeof(double)/X_SIZEOF_CHAR]; +#line 117 + +#line 117 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 117 + +#line 117 + { +#line 117 + schar *vp = fillp; /* lower bound of area to be filled */ +#line 117 + const schar *const end = vp + nelems; +#line 117 + while(vp < end) +#line 117 + { +#line 117 + *vp++ = NC_FILL_BYTE; +#line 117 + } +#line 117 + } +#line 117 + return ncx_putn_schar_schar(xpp, nelems, fillp ,NULL); +#line 117 +} +#line 117 + +static int +#line 118 +NC_fill_char( +#line 118 + void **xpp, +#line 118 + size_t nelems) /* how many */ +#line 118 +{ +#line 118 + char fillp[NFILL * sizeof(double)/X_SIZEOF_CHAR]; +#line 118 + +#line 118 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 118 + +#line 118 + { +#line 118 + char *vp = fillp; /* lower bound of area to be filled */ +#line 118 + const char *const end = vp + nelems; +#line 118 + while(vp < end) +#line 118 + { +#line 118 + *vp++ = NC_FILL_CHAR; +#line 118 + } +#line 118 + } +#line 118 + return ncx_putn_char_char(xpp, nelems, fillp ); +#line 118 +} +#line 118 + +static int +#line 119 +NC_fill_short( +#line 119 + void **xpp, +#line 119 + size_t nelems) /* how many */ +#line 119 +{ +#line 119 + short fillp[NFILL * sizeof(double)/X_SIZEOF_SHORT]; +#line 119 + +#line 119 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 119 + +#line 119 + { +#line 119 + short *vp = fillp; /* lower bound of area to be filled */ +#line 119 + const short *const end = vp + nelems; +#line 119 + while(vp < end) +#line 119 + { +#line 119 + *vp++ = NC_FILL_SHORT; +#line 119 + } +#line 119 + } +#line 119 + return ncx_putn_short_short(xpp, nelems, fillp ,NULL); +#line 119 +} +#line 119 + + +#if (SIZEOF_INT >= X_SIZEOF_INT) +static int +#line 122 +NC_fill_int( +#line 122 + void **xpp, +#line 122 + size_t nelems) /* how many */ +#line 122 +{ +#line 122 + int fillp[NFILL * sizeof(double)/X_SIZEOF_INT]; +#line 122 + +#line 122 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 122 + +#line 122 + { +#line 122 + int *vp = fillp; /* lower bound of area to be filled */ +#line 122 + const int *const end = vp + nelems; +#line 122 + while(vp < end) +#line 122 + { +#line 122 + *vp++ = NC_FILL_INT; +#line 122 + } +#line 122 + } +#line 122 + return ncx_putn_int_int(xpp, nelems, fillp ,NULL); +#line 122 +} +#line 122 + +#elif SIZEOF_LONG == X_SIZEOF_INT +static int +#line 124 +NC_fill_int( +#line 124 + void **xpp, +#line 124 + size_t nelems) /* how many */ +#line 124 +{ +#line 124 + long fillp[NFILL * sizeof(double)/X_SIZEOF_INT]; +#line 124 + +#line 124 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 124 + +#line 124 + { +#line 124 + long *vp = fillp; /* lower bound of area to be filled */ +#line 124 + const long *const end = vp + nelems; +#line 124 + while(vp < end) +#line 124 + { +#line 124 + *vp++ = NC_FILL_INT; +#line 124 + } +#line 124 + } +#line 124 + return ncx_putn_int_long(xpp, nelems, fillp ,NULL); +#line 124 +} +#line 124 + +#else +#error "NC_fill_int implementation" +#endif + +static int +#line 129 +NC_fill_float( +#line 129 + void **xpp, +#line 129 + size_t nelems) /* how many */ +#line 129 +{ +#line 129 + float fillp[NFILL * sizeof(double)/X_SIZEOF_FLOAT]; +#line 129 + +#line 129 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 129 + +#line 129 + { +#line 129 + float *vp = fillp; /* lower bound of area to be filled */ +#line 129 + const float *const end = vp + nelems; +#line 129 + while(vp < end) +#line 129 + { +#line 129 + *vp++ = NC_FILL_FLOAT; +#line 129 + } +#line 129 + } +#line 129 + return ncx_putn_float_float(xpp, nelems, fillp ,NULL); +#line 129 +} +#line 129 + +static int +#line 130 +NC_fill_double( +#line 130 + void **xpp, +#line 130 + size_t nelems) /* how many */ +#line 130 +{ +#line 130 + double fillp[NFILL * sizeof(double)/X_SIZEOF_DOUBLE]; +#line 130 + +#line 130 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 130 + +#line 130 + { +#line 130 + double *vp = fillp; /* lower bound of area to be filled */ +#line 130 + const double *const end = vp + nelems; +#line 130 + while(vp < end) +#line 130 + { +#line 130 + *vp++ = NC_FILL_DOUBLE; +#line 130 + } +#line 130 + } +#line 130 + return ncx_putn_double_double(xpp, nelems, fillp ,NULL); +#line 130 +} +#line 130 + + +static int +#line 132 +NC_fill_uchar( +#line 132 + void **xpp, +#line 132 + size_t nelems) /* how many */ +#line 132 +{ +#line 132 + uchar fillp[NFILL * sizeof(double)/X_SIZEOF_UBYTE]; +#line 132 + +#line 132 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 132 + +#line 132 + { +#line 132 + uchar *vp = fillp; /* lower bound of area to be filled */ +#line 132 + const uchar *const end = vp + nelems; +#line 132 + while(vp < end) +#line 132 + { +#line 132 + *vp++ = NC_FILL_UBYTE; +#line 132 + } +#line 132 + } +#line 132 + return ncx_putn_uchar_uchar(xpp, nelems, fillp ,NULL); +#line 132 +} +#line 132 + +static int +#line 133 +NC_fill_ushort( +#line 133 + void **xpp, +#line 133 + size_t nelems) /* how many */ +#line 133 +{ +#line 133 + ushort fillp[NFILL * sizeof(double)/X_SIZEOF_USHORT]; +#line 133 + +#line 133 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 133 + +#line 133 + { +#line 133 + ushort *vp = fillp; /* lower bound of area to be filled */ +#line 133 + const ushort *const end = vp + nelems; +#line 133 + while(vp < end) +#line 133 + { +#line 133 + *vp++ = NC_FILL_USHORT; +#line 133 + } +#line 133 + } +#line 133 + return ncx_putn_ushort_ushort(xpp, nelems, fillp ,NULL); +#line 133 +} +#line 133 + +static int +#line 134 +NC_fill_uint( +#line 134 + void **xpp, +#line 134 + size_t nelems) /* how many */ +#line 134 +{ +#line 134 + uint fillp[NFILL * sizeof(double)/X_SIZEOF_UINT]; +#line 134 + +#line 134 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 134 + +#line 134 + { +#line 134 + uint *vp = fillp; /* lower bound of area to be filled */ +#line 134 + const uint *const end = vp + nelems; +#line 134 + while(vp < end) +#line 134 + { +#line 134 + *vp++ = NC_FILL_UINT; +#line 134 + } +#line 134 + } +#line 134 + return ncx_putn_uint_uint(xpp, nelems, fillp ,NULL); +#line 134 +} +#line 134 + +static int +#line 135 +NC_fill_longlong( +#line 135 + void **xpp, +#line 135 + size_t nelems) /* how many */ +#line 135 +{ +#line 135 + longlong fillp[NFILL * sizeof(double)/X_SIZEOF_LONGLONG]; +#line 135 + +#line 135 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 135 + +#line 135 + { +#line 135 + longlong *vp = fillp; /* lower bound of area to be filled */ +#line 135 + const longlong *const end = vp + nelems; +#line 135 + while(vp < end) +#line 135 + { +#line 135 + *vp++ = NC_FILL_INT64; +#line 135 + } +#line 135 + } +#line 135 + return ncx_putn_longlong_longlong(xpp, nelems, fillp ,NULL); +#line 135 +} +#line 135 + +static int +#line 136 +NC_fill_ulonglong( +#line 136 + void **xpp, +#line 136 + size_t nelems) /* how many */ +#line 136 +{ +#line 136 + ulonglong fillp[NFILL * sizeof(double)/X_SIZEOF_ULONGLONG]; +#line 136 + +#line 136 + assert(nelems <= sizeof(fillp)/sizeof(fillp[0])); +#line 136 + +#line 136 + { +#line 136 + ulonglong *vp = fillp; /* lower bound of area to be filled */ +#line 136 + const ulonglong *const end = vp + nelems; +#line 136 + while(vp < end) +#line 136 + { +#line 136 + *vp++ = NC_FILL_UINT64; +#line 136 + } +#line 136 + } +#line 136 + return ncx_putn_ulonglong_ulonglong(xpp, nelems, fillp ,NULL); +#line 136 +} +#line 136 + + + + +/* + * Fill the external space for variable 'varp' values at 'recno' with + * the appropriate value. If 'varp' is not a record variable, fill the + * whole thing. For the special case when 'varp' is the only record + * variable and it is of type byte, char, or short, varsize should be + * ncp->recsize, otherwise it should be varp->len. + * Formerly +xdr_NC_fill() + */ +int +fill_NC_var(NC3_INFO* ncp, const NC_var *varp, long long varsize, size_t recno) +{ + char xfillp[NFILL * X_SIZEOF_DOUBLE]; + const size_t step = varp->xsz; + const size_t nelems = sizeof(xfillp)/step; + const size_t xsz = varp->xsz * nelems; + NC_attr **attrpp = NULL; + off_t offset; + long long remaining = varsize; + + void *xp; + int status = NC_NOERR; + + /* + * Set up fill value + */ + attrpp = NC_findattr(&varp->attrs, _FillValue); + if( attrpp != NULL ) + { + /* User defined fill value */ + if( (*attrpp)->type != varp->type || (*attrpp)->nelems != 1 ) + { + return NC_EBADTYPE; + } + else + { + /* Use the user defined value */ + char *cp = xfillp; + const char *const end = &xfillp[sizeof(xfillp)]; + + assert(step <= (*attrpp)->xsz); + + for( /*NADA*/; cp < end; cp += step) + { + (void) memcpy(cp, (*attrpp)->xvalue, step); + } + } + } + else + { + /* use the default */ + + assert(xsz % X_ALIGN == 0); + assert(xsz <= sizeof(xfillp)); + + xp = xfillp; + + switch(varp->type){ + case NC_BYTE : + status = NC_fill_schar(&xp, nelems); + break; + case NC_CHAR : + status = NC_fill_char(&xp, nelems); + break; + case NC_SHORT : + status = NC_fill_short(&xp, nelems); + break; + case NC_INT : + status = NC_fill_int(&xp, nelems); + break; + case NC_FLOAT : + status = NC_fill_float(&xp, nelems); + break; + case NC_DOUBLE : + status = NC_fill_double(&xp, nelems); + break; + case NC_UBYTE : + status = NC_fill_uchar(&xp, nelems); + break; + case NC_USHORT : + status = NC_fill_ushort(&xp, nelems); + break; + case NC_UINT : + status = NC_fill_uint(&xp, nelems); + break; + case NC_INT64 : + status = NC_fill_longlong(&xp, nelems); + break; + case NC_UINT64 : + status = NC_fill_ulonglong(&xp, nelems); + break; + default : + assert("fill_NC_var invalid type" == 0); + status = NC_EBADTYPE; + break; + } + if(status != NC_NOERR) + return status; + + assert(xp == xfillp + xsz); + } + + /* + * copyout: + * xfillp now contains 'nelems' elements of the fill value + * in external representation. + */ + + /* + * Copy it out. + */ + + offset = varp->begin; + if(IS_RECVAR(varp)) + { + offset += (off_t)ncp->recsize * recno; + } + + assert(remaining > 0); + for(;;) + { + const size_t chunksz = MIN(remaining, ncp->chunk); + size_t ii; + + status = ncio_get(ncp->nciop, offset, chunksz, + RGN_WRITE, &xp); + if(status != NC_NOERR) + { + return status; + } + + /* + * fill the chunksz buffer in units of xsz + */ + for(ii = 0; ii < chunksz/xsz; ii++) + { + (void) memcpy(xp, xfillp, xsz); + xp = (char *)xp + xsz; + } + /* + * Deal with any remainder + */ + { + const size_t rem = chunksz % xsz; + if(rem != 0) + { + (void) memcpy(xp, xfillp, rem); + /* xp = (char *)xp + xsz; */ + } + + } + + status = ncio_rel(ncp->nciop, offset, RGN_MODIFIED); + + if(status != NC_NOERR) + { + break; + } + + remaining -= chunksz; + if(remaining == 0) + break; /* normal loop exit */ + offset += chunksz; + + } + + return status; +} +/* End fill */ + + +/* + * Add a record containing the fill values. + */ +static int +NCfillrecord(NC3_INFO* ncp, const NC_var *const *varpp, size_t recno) +{ + size_t ii = 0; + for(; ii < ncp->vars.nelems; ii++, varpp++) + { + if( !IS_RECVAR(*varpp) ) + { + continue; /* skip non-record variables */ + } + { + const int status = fill_NC_var(ncp, *varpp, (*varpp)->len, recno); + if(status != NC_NOERR) + return status; + } + } + return NC_NOERR; +} + + +/* + * Add a record containing the fill values in the special case when + * there is exactly one record variable, where we don't require each + * record to be four-byte aligned (no record padding). + */ +static int +NCfillspecialrecord(NC3_INFO* ncp, const NC_var *varp, size_t recno) +{ + int status; + assert(IS_RECVAR(varp)); + status = fill_NC_var(ncp, varp, ncp->recsize, recno); + if(status != NC_NOERR) + return status; + return NC_NOERR; +} + + +/* + * It is advantageous to + * #define TOUCH_LAST + * when using memory mapped io. + */ +#if TOUCH_LAST +/* + * Grow the file to a size which can contain recno + */ +static int +NCtouchlast(NC3_INFO* ncp, const NC_var *const *varpp, size_t recno) +{ + int status = NC_NOERR; + const NC_var *varp = NULL; + + { + size_t ii = 0; + for(; ii < ncp->vars.nelems; ii++, varpp++) + { + if( !IS_RECVAR(*varpp) ) + { + continue; /* skip non-record variables */ + } + varp = *varpp; + } + } + assert(varp != NULL); + assert( IS_RECVAR(varp) ); + { + const off_t offset = varp->begin + + (off_t)(recno-1) * (off_t)ncp->recsize + + (off_t)(varp->len - varp->xsz); + void *xp; + + + status = ncio_get(ncp->nciop, offset, varp->xsz, + RGN_WRITE, &xp); + if(status != NC_NOERR) + return status; + (void)memset(xp, 0, varp->xsz); + status = ncio_rel(ncp->nciop, offset, RGN_MODIFIED); + } + return status; +} +#endif /* TOUCH_LAST */ + + +/* + * Ensure that the netcdf file has 'numrecs' records, + * add records and fill as necessary. + */ +static int +NCvnrecs(NC3_INFO* ncp, size_t numrecs) +{ + int status = NC_NOERR; +#ifdef LOCKNUMREC + ushmem_t myticket = 0, nowserving = 0; + ushmem_t numpe = (ushmem_t) _num_pes(); + + /* get ticket and wait */ + myticket = shmem_short_finc((shmem_t *) ncp->lock + LOCKNUMREC_LOCK, + ncp->lock[LOCKNUMREC_BASEPE]); +#ifdef LN_TEST + fprintf(stderr,"%d of %d : ticket = %hu\n", + _my_pe(), _num_pes(), myticket); +#endif + do { + shmem_short_get((shmem_t *) &nowserving, + (shmem_t *) ncp->lock + LOCKNUMREC_SERVING, 1, + ncp->lock[LOCKNUMREC_BASEPE]); +#ifdef LN_TEST + fprintf(stderr,"%d of %d : serving = %hu\n", + _my_pe(), _num_pes(), nowserving); +#endif + /* work-around for non-unique tickets */ + if (nowserving > myticket && nowserving < myticket + numpe ) { + /* get a new ticket ... you've been bypassed */ + /* and handle the unlikely wrap-around effect */ + myticket = shmem_short_finc( + (shmem_t *) ncp->lock + LOCKNUMREC_LOCK, + ncp->lock[LOCKNUMREC_BASEPE]); +#ifdef LN_TEST + fprintf(stderr,"%d of %d : new ticket = %hu\n", + _my_pe(), _num_pes(), myticket); +#endif + } + } while(nowserving != myticket); + /* now our turn to check & update value */ +#endif + + if(numrecs > NC_get_numrecs(ncp)) + { + + +#if TOUCH_LAST + status = NCtouchlast(ncp, + (const NC_var *const*)ncp->vars.value, + numrecs); + if(status != NC_NOERR) + goto common_return; +#endif /* TOUCH_LAST */ + + set_NC_ndirty(ncp); + + if(!NC_dofill(ncp)) + { + /* Simply set the new numrecs value */ + NC_set_numrecs(ncp, numrecs); + } + else + { + /* Treat two cases differently: + - exactly one record variable (no padding) + - multiple record variables (each record padded + to 4-byte alignment) + */ + NC_var **vpp = (NC_var **)ncp->vars.value; + NC_var *const *const end = &vpp[ncp->vars.nelems]; + NC_var *recvarp = NULL; /* last record var */ + int numrecvars = 0; + size_t cur_nrecs; + + /* determine how many record variables */ + for( /*NADA*/; vpp < end; vpp++) { + if(IS_RECVAR(*vpp)) { + recvarp = *vpp; + numrecvars++; + } + } + + if (numrecvars != 1) { /* usual case */ + /* Fill each record out to numrecs */ + while((cur_nrecs = NC_get_numrecs(ncp)) < numrecs) + { + status = NCfillrecord(ncp, + (const NC_var *const*)ncp->vars.value, + cur_nrecs); + if(status != NC_NOERR) + { + break; + } + NC_increase_numrecs(ncp, cur_nrecs +1); + } + if(status != NC_NOERR) + goto common_return; + } else { /* special case */ + /* Fill each record out to numrecs */ + while((cur_nrecs = NC_get_numrecs(ncp)) < numrecs) + { + status = NCfillspecialrecord(ncp, + recvarp, + cur_nrecs); + if(status != NC_NOERR) + { + break; + } + NC_increase_numrecs(ncp, cur_nrecs +1); + } + if(status != NC_NOERR) + goto common_return; + + } + } + + if(NC_doNsync(ncp)) + { + status = write_numrecs(ncp); + } + + } +common_return: +#ifdef LOCKNUMREC + /* finished with our lock - increment serving number */ + (void) shmem_short_finc((shmem_t *) ncp->lock + LOCKNUMREC_SERVING, + ncp->lock[LOCKNUMREC_BASEPE]); +#endif + return status; +} + + +/* + * Check whether 'coord' values are valid for the variable. + */ +static int +NCcoordck(NC3_INFO* ncp, const NC_var *varp, const size_t *coord) +{ + const size_t *ip; + size_t *up; + + if(varp->ndims == 0) + return NC_NOERR; /* 'scalar' variable */ + + if(IS_RECVAR(varp)) + { + if(*coord > X_UINT_MAX) /* rkr: bug fix from previous X_INT_MAX */ + return NC_EINVALCOORDS; /* sanity check */ +#ifdef RELAX_COORD_BOUND + if(NC_readonly(ncp) && *coord > NC_get_numrecs(ncp)) +#else + if(NC_readonly(ncp) && *coord >= NC_get_numrecs(ncp)) +#endif + { + if(!NC_doNsync(ncp)) + return NC_EINVALCOORDS; + /* else */ + { + /* Update from disk and check again */ + const int status = read_numrecs(ncp); + if(status != NC_NOERR) + return status; +#ifdef RELAX_COORD_BOUND + if(*coord > NC_get_numrecs(ncp)) +#else + if(*coord >= NC_get_numrecs(ncp)) +#endif + return NC_EINVALCOORDS; + } + } + ip = coord + 1; + up = varp->shape + 1; + } + else + { + ip = coord; + up = varp->shape; + } + +#ifdef CDEBUG +fprintf(stderr," NCcoordck: coord %ld, count %d, ip %ld\n", + coord, varp->ndims, ip ); +#endif /* CDEBUG */ + + for(; ip < coord + varp->ndims; ip++, up++) + { + +#ifdef CDEBUG +fprintf(stderr," NCcoordck: ip %p, *ip %ld, up %p, *up %lu\n", + ip, *ip, up, *up ); +#endif /* CDEBUG */ + + /* cast needed for braindead systems with signed size_t */ +#ifdef RELAX_COORD_BOUND + if((unsigned long) *ip > (unsigned long) *up ) +#else + if((unsigned long) *ip >= (unsigned long) *up ) +#endif + return NC_EINVALCOORDS; + } + + return NC_NOERR; +} + + +/* + * Check whether 'edges' are valid for the variable and 'start' + */ +/*ARGSUSED*/ +static int +NCedgeck(const NC3_INFO* ncp, const NC_var *varp, + const size_t *start, const size_t *edges) +{ + const size_t *const end = start + varp->ndims; + const size_t *shp = varp->shape; + + if(varp->ndims == 0) + return NC_NOERR; /* 'scalar' variable */ + + if(IS_RECVAR(varp)) + { +#ifdef RELAX_COORD_BOUND + if (NC_readonly(ncp) && + (start[0] == NC_get_numrecs(ncp) && edges[0] > 0)) + return(NC_EINVALCOORDS); +#endif + start++; + edges++; + shp++; + } + + for(; start < end; start++, edges++, shp++) + { +#ifdef RELAX_COORD_BOUND + if ((unsigned long) *start == *shp && *edges > 0) + return(NC_EINVALCOORDS); +#endif + /* cast needed for braindead systems with signed size_t */ + if((unsigned long) *edges > *shp || + (unsigned long) *start + (unsigned long) *edges > *shp) + { + return(NC_EEDGE); + } + } + return NC_NOERR; +} + + +/* + * Translate the (variable, coord) pair into a seek index + */ +static off_t +NC_varoffset(const NC3_INFO* ncp, const NC_var *varp, const size_t *coord) +{ + if(varp->ndims == 0) /* 'scalar' variable */ + return varp->begin; + + if(varp->ndims == 1) + { + if(IS_RECVAR(varp)) + return varp->begin + + (off_t)(*coord) * (off_t)ncp->recsize; + /* else */ + return varp->begin + (off_t)(*coord) * (off_t)varp->xsz; + } + /* else */ + { + off_t lcoord = (off_t)coord[varp->ndims -1]; + + off_t *up = varp->dsizes +1; + const size_t *ip = coord; + const off_t *const end = varp->dsizes + varp->ndims; + + if(IS_RECVAR(varp)) + up++, ip++; + + for(; up < end; up++, ip++) + lcoord += (off_t)(*up) * (off_t)(*ip); + + lcoord *= varp->xsz; + + if(IS_RECVAR(varp)) + lcoord += (off_t)(*coord) * ncp->recsize; + + lcoord += varp->begin; + return lcoord; + } +} + + +#line 753 + +static int +#line 754 +putNCvx_char_char(NC3_INFO* ncp, const NC_var *varp, +#line 754 + const size_t *start, size_t nelems, const char *value) +#line 754 +{ +#line 754 + off_t offset = NC_varoffset(ncp, varp, start); +#line 754 + size_t remaining = varp->xsz * nelems; +#line 754 + int status = NC_NOERR; +#line 754 + void *xp; +#line 754 + void *fillp=NULL; +#line 754 + +#line 754 + if(nelems == 0) +#line 754 + return NC_NOERR; +#line 754 + +#line 754 + assert(value != NULL); +#line 754 + +#line 754 +#ifdef ERANGE_FILL +#line 754 + fillp = malloc(varp->xsz); +#line 754 + status = NC3_inq_var_fill(varp, fillp); +#line 754 +#endif +#line 754 + +#line 754 + for(;;) +#line 754 + { +#line 754 + size_t extent = MIN(remaining, ncp->chunk); +#line 754 + size_t nput = ncx_howmany(varp->type, extent); +#line 754 + +#line 754 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 754 + RGN_WRITE, &xp); +#line 754 + if(lstatus != NC_NOERR) +#line 754 + return lstatus; +#line 754 + +#line 754 + lstatus = ncx_putn_char_char(&xp, nput, value ); +#line 754 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 754 + { +#line 754 + /* not fatal to the loop */ +#line 754 + status = lstatus; +#line 754 + } +#line 754 + +#line 754 + (void) ncio_rel(ncp->nciop, offset, +#line 754 + RGN_MODIFIED); +#line 754 + +#line 754 + remaining -= extent; +#line 754 + if(remaining == 0) +#line 754 + break; /* normal loop exit */ +#line 754 + offset += (off_t)extent; +#line 754 + value += nput; +#line 754 + +#line 754 + } +#line 754 +#ifdef ERANGE_FILL +#line 754 + free(fillp); +#line 754 +#endif +#line 754 + +#line 754 + return status; +#line 754 +} +#line 754 + + +static int +#line 756 +putNCvx_schar_schar(NC3_INFO* ncp, const NC_var *varp, +#line 756 + const size_t *start, size_t nelems, const schar *value) +#line 756 +{ +#line 756 + off_t offset = NC_varoffset(ncp, varp, start); +#line 756 + size_t remaining = varp->xsz * nelems; +#line 756 + int status = NC_NOERR; +#line 756 + void *xp; +#line 756 + void *fillp=NULL; +#line 756 + +#line 756 + if(nelems == 0) +#line 756 + return NC_NOERR; +#line 756 + +#line 756 + assert(value != NULL); +#line 756 + +#line 756 +#ifdef ERANGE_FILL +#line 756 + fillp = malloc(varp->xsz); +#line 756 + status = NC3_inq_var_fill(varp, fillp); +#line 756 +#endif +#line 756 + +#line 756 + for(;;) +#line 756 + { +#line 756 + size_t extent = MIN(remaining, ncp->chunk); +#line 756 + size_t nput = ncx_howmany(varp->type, extent); +#line 756 + +#line 756 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 756 + RGN_WRITE, &xp); +#line 756 + if(lstatus != NC_NOERR) +#line 756 + return lstatus; +#line 756 + +#line 756 + lstatus = ncx_putn_schar_schar(&xp, nput, value ,fillp); +#line 756 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 756 + { +#line 756 + /* not fatal to the loop */ +#line 756 + status = lstatus; +#line 756 + } +#line 756 + +#line 756 + (void) ncio_rel(ncp->nciop, offset, +#line 756 + RGN_MODIFIED); +#line 756 + +#line 756 + remaining -= extent; +#line 756 + if(remaining == 0) +#line 756 + break; /* normal loop exit */ +#line 756 + offset += (off_t)extent; +#line 756 + value += nput; +#line 756 + +#line 756 + } +#line 756 +#ifdef ERANGE_FILL +#line 756 + free(fillp); +#line 756 +#endif +#line 756 + +#line 756 + return status; +#line 756 +} +#line 756 + +static int +#line 757 +putNCvx_schar_uchar(NC3_INFO* ncp, const NC_var *varp, +#line 757 + const size_t *start, size_t nelems, const uchar *value) +#line 757 +{ +#line 757 + off_t offset = NC_varoffset(ncp, varp, start); +#line 757 + size_t remaining = varp->xsz * nelems; +#line 757 + int status = NC_NOERR; +#line 757 + void *xp; +#line 757 + void *fillp=NULL; +#line 757 + +#line 757 + if(nelems == 0) +#line 757 + return NC_NOERR; +#line 757 + +#line 757 + assert(value != NULL); +#line 757 + +#line 757 +#ifdef ERANGE_FILL +#line 757 + fillp = malloc(varp->xsz); +#line 757 + status = NC3_inq_var_fill(varp, fillp); +#line 757 +#endif +#line 757 + +#line 757 + for(;;) +#line 757 + { +#line 757 + size_t extent = MIN(remaining, ncp->chunk); +#line 757 + size_t nput = ncx_howmany(varp->type, extent); +#line 757 + +#line 757 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 757 + RGN_WRITE, &xp); +#line 757 + if(lstatus != NC_NOERR) +#line 757 + return lstatus; +#line 757 + +#line 757 + lstatus = ncx_putn_schar_uchar(&xp, nput, value ,fillp); +#line 757 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 757 + { +#line 757 + /* not fatal to the loop */ +#line 757 + status = lstatus; +#line 757 + } +#line 757 + +#line 757 + (void) ncio_rel(ncp->nciop, offset, +#line 757 + RGN_MODIFIED); +#line 757 + +#line 757 + remaining -= extent; +#line 757 + if(remaining == 0) +#line 757 + break; /* normal loop exit */ +#line 757 + offset += (off_t)extent; +#line 757 + value += nput; +#line 757 + +#line 757 + } +#line 757 +#ifdef ERANGE_FILL +#line 757 + free(fillp); +#line 757 +#endif +#line 757 + +#line 757 + return status; +#line 757 +} +#line 757 + +static int +#line 758 +putNCvx_schar_short(NC3_INFO* ncp, const NC_var *varp, +#line 758 + const size_t *start, size_t nelems, const short *value) +#line 758 +{ +#line 758 + off_t offset = NC_varoffset(ncp, varp, start); +#line 758 + size_t remaining = varp->xsz * nelems; +#line 758 + int status = NC_NOERR; +#line 758 + void *xp; +#line 758 + void *fillp=NULL; +#line 758 + +#line 758 + if(nelems == 0) +#line 758 + return NC_NOERR; +#line 758 + +#line 758 + assert(value != NULL); +#line 758 + +#line 758 +#ifdef ERANGE_FILL +#line 758 + fillp = malloc(varp->xsz); +#line 758 + status = NC3_inq_var_fill(varp, fillp); +#line 758 +#endif +#line 758 + +#line 758 + for(;;) +#line 758 + { +#line 758 + size_t extent = MIN(remaining, ncp->chunk); +#line 758 + size_t nput = ncx_howmany(varp->type, extent); +#line 758 + +#line 758 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 758 + RGN_WRITE, &xp); +#line 758 + if(lstatus != NC_NOERR) +#line 758 + return lstatus; +#line 758 + +#line 758 + lstatus = ncx_putn_schar_short(&xp, nput, value ,fillp); +#line 758 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 758 + { +#line 758 + /* not fatal to the loop */ +#line 758 + status = lstatus; +#line 758 + } +#line 758 + +#line 758 + (void) ncio_rel(ncp->nciop, offset, +#line 758 + RGN_MODIFIED); +#line 758 + +#line 758 + remaining -= extent; +#line 758 + if(remaining == 0) +#line 758 + break; /* normal loop exit */ +#line 758 + offset += (off_t)extent; +#line 758 + value += nput; +#line 758 + +#line 758 + } +#line 758 +#ifdef ERANGE_FILL +#line 758 + free(fillp); +#line 758 +#endif +#line 758 + +#line 758 + return status; +#line 758 +} +#line 758 + +static int +#line 759 +putNCvx_schar_int(NC3_INFO* ncp, const NC_var *varp, +#line 759 + const size_t *start, size_t nelems, const int *value) +#line 759 +{ +#line 759 + off_t offset = NC_varoffset(ncp, varp, start); +#line 759 + size_t remaining = varp->xsz * nelems; +#line 759 + int status = NC_NOERR; +#line 759 + void *xp; +#line 759 + void *fillp=NULL; +#line 759 + +#line 759 + if(nelems == 0) +#line 759 + return NC_NOERR; +#line 759 + +#line 759 + assert(value != NULL); +#line 759 + +#line 759 +#ifdef ERANGE_FILL +#line 759 + fillp = malloc(varp->xsz); +#line 759 + status = NC3_inq_var_fill(varp, fillp); +#line 759 +#endif +#line 759 + +#line 759 + for(;;) +#line 759 + { +#line 759 + size_t extent = MIN(remaining, ncp->chunk); +#line 759 + size_t nput = ncx_howmany(varp->type, extent); +#line 759 + +#line 759 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 759 + RGN_WRITE, &xp); +#line 759 + if(lstatus != NC_NOERR) +#line 759 + return lstatus; +#line 759 + +#line 759 + lstatus = ncx_putn_schar_int(&xp, nput, value ,fillp); +#line 759 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 759 + { +#line 759 + /* not fatal to the loop */ +#line 759 + status = lstatus; +#line 759 + } +#line 759 + +#line 759 + (void) ncio_rel(ncp->nciop, offset, +#line 759 + RGN_MODIFIED); +#line 759 + +#line 759 + remaining -= extent; +#line 759 + if(remaining == 0) +#line 759 + break; /* normal loop exit */ +#line 759 + offset += (off_t)extent; +#line 759 + value += nput; +#line 759 + +#line 759 + } +#line 759 +#ifdef ERANGE_FILL +#line 759 + free(fillp); +#line 759 +#endif +#line 759 + +#line 759 + return status; +#line 759 +} +#line 759 + +static int +#line 760 +putNCvx_schar_float(NC3_INFO* ncp, const NC_var *varp, +#line 760 + const size_t *start, size_t nelems, const float *value) +#line 760 +{ +#line 760 + off_t offset = NC_varoffset(ncp, varp, start); +#line 760 + size_t remaining = varp->xsz * nelems; +#line 760 + int status = NC_NOERR; +#line 760 + void *xp; +#line 760 + void *fillp=NULL; +#line 760 + +#line 760 + if(nelems == 0) +#line 760 + return NC_NOERR; +#line 760 + +#line 760 + assert(value != NULL); +#line 760 + +#line 760 +#ifdef ERANGE_FILL +#line 760 + fillp = malloc(varp->xsz); +#line 760 + status = NC3_inq_var_fill(varp, fillp); +#line 760 +#endif +#line 760 + +#line 760 + for(;;) +#line 760 + { +#line 760 + size_t extent = MIN(remaining, ncp->chunk); +#line 760 + size_t nput = ncx_howmany(varp->type, extent); +#line 760 + +#line 760 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 760 + RGN_WRITE, &xp); +#line 760 + if(lstatus != NC_NOERR) +#line 760 + return lstatus; +#line 760 + +#line 760 + lstatus = ncx_putn_schar_float(&xp, nput, value ,fillp); +#line 760 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 760 + { +#line 760 + /* not fatal to the loop */ +#line 760 + status = lstatus; +#line 760 + } +#line 760 + +#line 760 + (void) ncio_rel(ncp->nciop, offset, +#line 760 + RGN_MODIFIED); +#line 760 + +#line 760 + remaining -= extent; +#line 760 + if(remaining == 0) +#line 760 + break; /* normal loop exit */ +#line 760 + offset += (off_t)extent; +#line 760 + value += nput; +#line 760 + +#line 760 + } +#line 760 +#ifdef ERANGE_FILL +#line 760 + free(fillp); +#line 760 +#endif +#line 760 + +#line 760 + return status; +#line 760 +} +#line 760 + +static int +#line 761 +putNCvx_schar_double(NC3_INFO* ncp, const NC_var *varp, +#line 761 + const size_t *start, size_t nelems, const double *value) +#line 761 +{ +#line 761 + off_t offset = NC_varoffset(ncp, varp, start); +#line 761 + size_t remaining = varp->xsz * nelems; +#line 761 + int status = NC_NOERR; +#line 761 + void *xp; +#line 761 + void *fillp=NULL; +#line 761 + +#line 761 + if(nelems == 0) +#line 761 + return NC_NOERR; +#line 761 + +#line 761 + assert(value != NULL); +#line 761 + +#line 761 +#ifdef ERANGE_FILL +#line 761 + fillp = malloc(varp->xsz); +#line 761 + status = NC3_inq_var_fill(varp, fillp); +#line 761 +#endif +#line 761 + +#line 761 + for(;;) +#line 761 + { +#line 761 + size_t extent = MIN(remaining, ncp->chunk); +#line 761 + size_t nput = ncx_howmany(varp->type, extent); +#line 761 + +#line 761 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 761 + RGN_WRITE, &xp); +#line 761 + if(lstatus != NC_NOERR) +#line 761 + return lstatus; +#line 761 + +#line 761 + lstatus = ncx_putn_schar_double(&xp, nput, value ,fillp); +#line 761 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 761 + { +#line 761 + /* not fatal to the loop */ +#line 761 + status = lstatus; +#line 761 + } +#line 761 + +#line 761 + (void) ncio_rel(ncp->nciop, offset, +#line 761 + RGN_MODIFIED); +#line 761 + +#line 761 + remaining -= extent; +#line 761 + if(remaining == 0) +#line 761 + break; /* normal loop exit */ +#line 761 + offset += (off_t)extent; +#line 761 + value += nput; +#line 761 + +#line 761 + } +#line 761 +#ifdef ERANGE_FILL +#line 761 + free(fillp); +#line 761 +#endif +#line 761 + +#line 761 + return status; +#line 761 +} +#line 761 + +static int +#line 762 +putNCvx_schar_longlong(NC3_INFO* ncp, const NC_var *varp, +#line 762 + const size_t *start, size_t nelems, const longlong *value) +#line 762 +{ +#line 762 + off_t offset = NC_varoffset(ncp, varp, start); +#line 762 + size_t remaining = varp->xsz * nelems; +#line 762 + int status = NC_NOERR; +#line 762 + void *xp; +#line 762 + void *fillp=NULL; +#line 762 + +#line 762 + if(nelems == 0) +#line 762 + return NC_NOERR; +#line 762 + +#line 762 + assert(value != NULL); +#line 762 + +#line 762 +#ifdef ERANGE_FILL +#line 762 + fillp = malloc(varp->xsz); +#line 762 + status = NC3_inq_var_fill(varp, fillp); +#line 762 +#endif +#line 762 + +#line 762 + for(;;) +#line 762 + { +#line 762 + size_t extent = MIN(remaining, ncp->chunk); +#line 762 + size_t nput = ncx_howmany(varp->type, extent); +#line 762 + +#line 762 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 762 + RGN_WRITE, &xp); +#line 762 + if(lstatus != NC_NOERR) +#line 762 + return lstatus; +#line 762 + +#line 762 + lstatus = ncx_putn_schar_longlong(&xp, nput, value ,fillp); +#line 762 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 762 + { +#line 762 + /* not fatal to the loop */ +#line 762 + status = lstatus; +#line 762 + } +#line 762 + +#line 762 + (void) ncio_rel(ncp->nciop, offset, +#line 762 + RGN_MODIFIED); +#line 762 + +#line 762 + remaining -= extent; +#line 762 + if(remaining == 0) +#line 762 + break; /* normal loop exit */ +#line 762 + offset += (off_t)extent; +#line 762 + value += nput; +#line 762 + +#line 762 + } +#line 762 +#ifdef ERANGE_FILL +#line 762 + free(fillp); +#line 762 +#endif +#line 762 + +#line 762 + return status; +#line 762 +} +#line 762 + +static int +#line 763 +putNCvx_schar_ushort(NC3_INFO* ncp, const NC_var *varp, +#line 763 + const size_t *start, size_t nelems, const ushort *value) +#line 763 +{ +#line 763 + off_t offset = NC_varoffset(ncp, varp, start); +#line 763 + size_t remaining = varp->xsz * nelems; +#line 763 + int status = NC_NOERR; +#line 763 + void *xp; +#line 763 + void *fillp=NULL; +#line 763 + +#line 763 + if(nelems == 0) +#line 763 + return NC_NOERR; +#line 763 + +#line 763 + assert(value != NULL); +#line 763 + +#line 763 +#ifdef ERANGE_FILL +#line 763 + fillp = malloc(varp->xsz); +#line 763 + status = NC3_inq_var_fill(varp, fillp); +#line 763 +#endif +#line 763 + +#line 763 + for(;;) +#line 763 + { +#line 763 + size_t extent = MIN(remaining, ncp->chunk); +#line 763 + size_t nput = ncx_howmany(varp->type, extent); +#line 763 + +#line 763 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 763 + RGN_WRITE, &xp); +#line 763 + if(lstatus != NC_NOERR) +#line 763 + return lstatus; +#line 763 + +#line 763 + lstatus = ncx_putn_schar_ushort(&xp, nput, value ,fillp); +#line 763 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 763 + { +#line 763 + /* not fatal to the loop */ +#line 763 + status = lstatus; +#line 763 + } +#line 763 + +#line 763 + (void) ncio_rel(ncp->nciop, offset, +#line 763 + RGN_MODIFIED); +#line 763 + +#line 763 + remaining -= extent; +#line 763 + if(remaining == 0) +#line 763 + break; /* normal loop exit */ +#line 763 + offset += (off_t)extent; +#line 763 + value += nput; +#line 763 + +#line 763 + } +#line 763 +#ifdef ERANGE_FILL +#line 763 + free(fillp); +#line 763 +#endif +#line 763 + +#line 763 + return status; +#line 763 +} +#line 763 + +static int +#line 764 +putNCvx_schar_uint(NC3_INFO* ncp, const NC_var *varp, +#line 764 + const size_t *start, size_t nelems, const uint *value) +#line 764 +{ +#line 764 + off_t offset = NC_varoffset(ncp, varp, start); +#line 764 + size_t remaining = varp->xsz * nelems; +#line 764 + int status = NC_NOERR; +#line 764 + void *xp; +#line 764 + void *fillp=NULL; +#line 764 + +#line 764 + if(nelems == 0) +#line 764 + return NC_NOERR; +#line 764 + +#line 764 + assert(value != NULL); +#line 764 + +#line 764 +#ifdef ERANGE_FILL +#line 764 + fillp = malloc(varp->xsz); +#line 764 + status = NC3_inq_var_fill(varp, fillp); +#line 764 +#endif +#line 764 + +#line 764 + for(;;) +#line 764 + { +#line 764 + size_t extent = MIN(remaining, ncp->chunk); +#line 764 + size_t nput = ncx_howmany(varp->type, extent); +#line 764 + +#line 764 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 764 + RGN_WRITE, &xp); +#line 764 + if(lstatus != NC_NOERR) +#line 764 + return lstatus; +#line 764 + +#line 764 + lstatus = ncx_putn_schar_uint(&xp, nput, value ,fillp); +#line 764 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 764 + { +#line 764 + /* not fatal to the loop */ +#line 764 + status = lstatus; +#line 764 + } +#line 764 + +#line 764 + (void) ncio_rel(ncp->nciop, offset, +#line 764 + RGN_MODIFIED); +#line 764 + +#line 764 + remaining -= extent; +#line 764 + if(remaining == 0) +#line 764 + break; /* normal loop exit */ +#line 764 + offset += (off_t)extent; +#line 764 + value += nput; +#line 764 + +#line 764 + } +#line 764 +#ifdef ERANGE_FILL +#line 764 + free(fillp); +#line 764 +#endif +#line 764 + +#line 764 + return status; +#line 764 +} +#line 764 + +static int +#line 765 +putNCvx_schar_ulonglong(NC3_INFO* ncp, const NC_var *varp, +#line 765 + const size_t *start, size_t nelems, const ulonglong *value) +#line 765 +{ +#line 765 + off_t offset = NC_varoffset(ncp, varp, start); +#line 765 + size_t remaining = varp->xsz * nelems; +#line 765 + int status = NC_NOERR; +#line 765 + void *xp; +#line 765 + void *fillp=NULL; +#line 765 + +#line 765 + if(nelems == 0) +#line 765 + return NC_NOERR; +#line 765 + +#line 765 + assert(value != NULL); +#line 765 + +#line 765 +#ifdef ERANGE_FILL +#line 765 + fillp = malloc(varp->xsz); +#line 765 + status = NC3_inq_var_fill(varp, fillp); +#line 765 +#endif +#line 765 + +#line 765 + for(;;) +#line 765 + { +#line 765 + size_t extent = MIN(remaining, ncp->chunk); +#line 765 + size_t nput = ncx_howmany(varp->type, extent); +#line 765 + +#line 765 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 765 + RGN_WRITE, &xp); +#line 765 + if(lstatus != NC_NOERR) +#line 765 + return lstatus; +#line 765 + +#line 765 + lstatus = ncx_putn_schar_ulonglong(&xp, nput, value ,fillp); +#line 765 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 765 + { +#line 765 + /* not fatal to the loop */ +#line 765 + status = lstatus; +#line 765 + } +#line 765 + +#line 765 + (void) ncio_rel(ncp->nciop, offset, +#line 765 + RGN_MODIFIED); +#line 765 + +#line 765 + remaining -= extent; +#line 765 + if(remaining == 0) +#line 765 + break; /* normal loop exit */ +#line 765 + offset += (off_t)extent; +#line 765 + value += nput; +#line 765 + +#line 765 + } +#line 765 +#ifdef ERANGE_FILL +#line 765 + free(fillp); +#line 765 +#endif +#line 765 + +#line 765 + return status; +#line 765 +} +#line 765 + + +static int +#line 767 +putNCvx_short_schar(NC3_INFO* ncp, const NC_var *varp, +#line 767 + const size_t *start, size_t nelems, const schar *value) +#line 767 +{ +#line 767 + off_t offset = NC_varoffset(ncp, varp, start); +#line 767 + size_t remaining = varp->xsz * nelems; +#line 767 + int status = NC_NOERR; +#line 767 + void *xp; +#line 767 + void *fillp=NULL; +#line 767 + +#line 767 + if(nelems == 0) +#line 767 + return NC_NOERR; +#line 767 + +#line 767 + assert(value != NULL); +#line 767 + +#line 767 +#ifdef ERANGE_FILL +#line 767 + fillp = malloc(varp->xsz); +#line 767 + status = NC3_inq_var_fill(varp, fillp); +#line 767 +#endif +#line 767 + +#line 767 + for(;;) +#line 767 + { +#line 767 + size_t extent = MIN(remaining, ncp->chunk); +#line 767 + size_t nput = ncx_howmany(varp->type, extent); +#line 767 + +#line 767 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 767 + RGN_WRITE, &xp); +#line 767 + if(lstatus != NC_NOERR) +#line 767 + return lstatus; +#line 767 + +#line 767 + lstatus = ncx_putn_short_schar(&xp, nput, value ,fillp); +#line 767 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 767 + { +#line 767 + /* not fatal to the loop */ +#line 767 + status = lstatus; +#line 767 + } +#line 767 + +#line 767 + (void) ncio_rel(ncp->nciop, offset, +#line 767 + RGN_MODIFIED); +#line 767 + +#line 767 + remaining -= extent; +#line 767 + if(remaining == 0) +#line 767 + break; /* normal loop exit */ +#line 767 + offset += (off_t)extent; +#line 767 + value += nput; +#line 767 + +#line 767 + } +#line 767 +#ifdef ERANGE_FILL +#line 767 + free(fillp); +#line 767 +#endif +#line 767 + +#line 767 + return status; +#line 767 +} +#line 767 + +static int +#line 768 +putNCvx_short_uchar(NC3_INFO* ncp, const NC_var *varp, +#line 768 + const size_t *start, size_t nelems, const uchar *value) +#line 768 +{ +#line 768 + off_t offset = NC_varoffset(ncp, varp, start); +#line 768 + size_t remaining = varp->xsz * nelems; +#line 768 + int status = NC_NOERR; +#line 768 + void *xp; +#line 768 + void *fillp=NULL; +#line 768 + +#line 768 + if(nelems == 0) +#line 768 + return NC_NOERR; +#line 768 + +#line 768 + assert(value != NULL); +#line 768 + +#line 768 +#ifdef ERANGE_FILL +#line 768 + fillp = malloc(varp->xsz); +#line 768 + status = NC3_inq_var_fill(varp, fillp); +#line 768 +#endif +#line 768 + +#line 768 + for(;;) +#line 768 + { +#line 768 + size_t extent = MIN(remaining, ncp->chunk); +#line 768 + size_t nput = ncx_howmany(varp->type, extent); +#line 768 + +#line 768 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 768 + RGN_WRITE, &xp); +#line 768 + if(lstatus != NC_NOERR) +#line 768 + return lstatus; +#line 768 + +#line 768 + lstatus = ncx_putn_short_uchar(&xp, nput, value ,fillp); +#line 768 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 768 + { +#line 768 + /* not fatal to the loop */ +#line 768 + status = lstatus; +#line 768 + } +#line 768 + +#line 768 + (void) ncio_rel(ncp->nciop, offset, +#line 768 + RGN_MODIFIED); +#line 768 + +#line 768 + remaining -= extent; +#line 768 + if(remaining == 0) +#line 768 + break; /* normal loop exit */ +#line 768 + offset += (off_t)extent; +#line 768 + value += nput; +#line 768 + +#line 768 + } +#line 768 +#ifdef ERANGE_FILL +#line 768 + free(fillp); +#line 768 +#endif +#line 768 + +#line 768 + return status; +#line 768 +} +#line 768 + +static int +#line 769 +putNCvx_short_short(NC3_INFO* ncp, const NC_var *varp, +#line 769 + const size_t *start, size_t nelems, const short *value) +#line 769 +{ +#line 769 + off_t offset = NC_varoffset(ncp, varp, start); +#line 769 + size_t remaining = varp->xsz * nelems; +#line 769 + int status = NC_NOERR; +#line 769 + void *xp; +#line 769 + void *fillp=NULL; +#line 769 + +#line 769 + if(nelems == 0) +#line 769 + return NC_NOERR; +#line 769 + +#line 769 + assert(value != NULL); +#line 769 + +#line 769 +#ifdef ERANGE_FILL +#line 769 + fillp = malloc(varp->xsz); +#line 769 + status = NC3_inq_var_fill(varp, fillp); +#line 769 +#endif +#line 769 + +#line 769 + for(;;) +#line 769 + { +#line 769 + size_t extent = MIN(remaining, ncp->chunk); +#line 769 + size_t nput = ncx_howmany(varp->type, extent); +#line 769 + +#line 769 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 769 + RGN_WRITE, &xp); +#line 769 + if(lstatus != NC_NOERR) +#line 769 + return lstatus; +#line 769 + +#line 769 + lstatus = ncx_putn_short_short(&xp, nput, value ,fillp); +#line 769 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 769 + { +#line 769 + /* not fatal to the loop */ +#line 769 + status = lstatus; +#line 769 + } +#line 769 + +#line 769 + (void) ncio_rel(ncp->nciop, offset, +#line 769 + RGN_MODIFIED); +#line 769 + +#line 769 + remaining -= extent; +#line 769 + if(remaining == 0) +#line 769 + break; /* normal loop exit */ +#line 769 + offset += (off_t)extent; +#line 769 + value += nput; +#line 769 + +#line 769 + } +#line 769 +#ifdef ERANGE_FILL +#line 769 + free(fillp); +#line 769 +#endif +#line 769 + +#line 769 + return status; +#line 769 +} +#line 769 + +static int +#line 770 +putNCvx_short_int(NC3_INFO* ncp, const NC_var *varp, +#line 770 + const size_t *start, size_t nelems, const int *value) +#line 770 +{ +#line 770 + off_t offset = NC_varoffset(ncp, varp, start); +#line 770 + size_t remaining = varp->xsz * nelems; +#line 770 + int status = NC_NOERR; +#line 770 + void *xp; +#line 770 + void *fillp=NULL; +#line 770 + +#line 770 + if(nelems == 0) +#line 770 + return NC_NOERR; +#line 770 + +#line 770 + assert(value != NULL); +#line 770 + +#line 770 +#ifdef ERANGE_FILL +#line 770 + fillp = malloc(varp->xsz); +#line 770 + status = NC3_inq_var_fill(varp, fillp); +#line 770 +#endif +#line 770 + +#line 770 + for(;;) +#line 770 + { +#line 770 + size_t extent = MIN(remaining, ncp->chunk); +#line 770 + size_t nput = ncx_howmany(varp->type, extent); +#line 770 + +#line 770 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 770 + RGN_WRITE, &xp); +#line 770 + if(lstatus != NC_NOERR) +#line 770 + return lstatus; +#line 770 + +#line 770 + lstatus = ncx_putn_short_int(&xp, nput, value ,fillp); +#line 770 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 770 + { +#line 770 + /* not fatal to the loop */ +#line 770 + status = lstatus; +#line 770 + } +#line 770 + +#line 770 + (void) ncio_rel(ncp->nciop, offset, +#line 770 + RGN_MODIFIED); +#line 770 + +#line 770 + remaining -= extent; +#line 770 + if(remaining == 0) +#line 770 + break; /* normal loop exit */ +#line 770 + offset += (off_t)extent; +#line 770 + value += nput; +#line 770 + +#line 770 + } +#line 770 +#ifdef ERANGE_FILL +#line 770 + free(fillp); +#line 770 +#endif +#line 770 + +#line 770 + return status; +#line 770 +} +#line 770 + +static int +#line 771 +putNCvx_short_float(NC3_INFO* ncp, const NC_var *varp, +#line 771 + const size_t *start, size_t nelems, const float *value) +#line 771 +{ +#line 771 + off_t offset = NC_varoffset(ncp, varp, start); +#line 771 + size_t remaining = varp->xsz * nelems; +#line 771 + int status = NC_NOERR; +#line 771 + void *xp; +#line 771 + void *fillp=NULL; +#line 771 + +#line 771 + if(nelems == 0) +#line 771 + return NC_NOERR; +#line 771 + +#line 771 + assert(value != NULL); +#line 771 + +#line 771 +#ifdef ERANGE_FILL +#line 771 + fillp = malloc(varp->xsz); +#line 771 + status = NC3_inq_var_fill(varp, fillp); +#line 771 +#endif +#line 771 + +#line 771 + for(;;) +#line 771 + { +#line 771 + size_t extent = MIN(remaining, ncp->chunk); +#line 771 + size_t nput = ncx_howmany(varp->type, extent); +#line 771 + +#line 771 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 771 + RGN_WRITE, &xp); +#line 771 + if(lstatus != NC_NOERR) +#line 771 + return lstatus; +#line 771 + +#line 771 + lstatus = ncx_putn_short_float(&xp, nput, value ,fillp); +#line 771 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 771 + { +#line 771 + /* not fatal to the loop */ +#line 771 + status = lstatus; +#line 771 + } +#line 771 + +#line 771 + (void) ncio_rel(ncp->nciop, offset, +#line 771 + RGN_MODIFIED); +#line 771 + +#line 771 + remaining -= extent; +#line 771 + if(remaining == 0) +#line 771 + break; /* normal loop exit */ +#line 771 + offset += (off_t)extent; +#line 771 + value += nput; +#line 771 + +#line 771 + } +#line 771 +#ifdef ERANGE_FILL +#line 771 + free(fillp); +#line 771 +#endif +#line 771 + +#line 771 + return status; +#line 771 +} +#line 771 + +static int +#line 772 +putNCvx_short_double(NC3_INFO* ncp, const NC_var *varp, +#line 772 + const size_t *start, size_t nelems, const double *value) +#line 772 +{ +#line 772 + off_t offset = NC_varoffset(ncp, varp, start); +#line 772 + size_t remaining = varp->xsz * nelems; +#line 772 + int status = NC_NOERR; +#line 772 + void *xp; +#line 772 + void *fillp=NULL; +#line 772 + +#line 772 + if(nelems == 0) +#line 772 + return NC_NOERR; +#line 772 + +#line 772 + assert(value != NULL); +#line 772 + +#line 772 +#ifdef ERANGE_FILL +#line 772 + fillp = malloc(varp->xsz); +#line 772 + status = NC3_inq_var_fill(varp, fillp); +#line 772 +#endif +#line 772 + +#line 772 + for(;;) +#line 772 + { +#line 772 + size_t extent = MIN(remaining, ncp->chunk); +#line 772 + size_t nput = ncx_howmany(varp->type, extent); +#line 772 + +#line 772 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 772 + RGN_WRITE, &xp); +#line 772 + if(lstatus != NC_NOERR) +#line 772 + return lstatus; +#line 772 + +#line 772 + lstatus = ncx_putn_short_double(&xp, nput, value ,fillp); +#line 772 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 772 + { +#line 772 + /* not fatal to the loop */ +#line 772 + status = lstatus; +#line 772 + } +#line 772 + +#line 772 + (void) ncio_rel(ncp->nciop, offset, +#line 772 + RGN_MODIFIED); +#line 772 + +#line 772 + remaining -= extent; +#line 772 + if(remaining == 0) +#line 772 + break; /* normal loop exit */ +#line 772 + offset += (off_t)extent; +#line 772 + value += nput; +#line 772 + +#line 772 + } +#line 772 +#ifdef ERANGE_FILL +#line 772 + free(fillp); +#line 772 +#endif +#line 772 + +#line 772 + return status; +#line 772 +} +#line 772 + +static int +#line 773 +putNCvx_short_longlong(NC3_INFO* ncp, const NC_var *varp, +#line 773 + const size_t *start, size_t nelems, const longlong *value) +#line 773 +{ +#line 773 + off_t offset = NC_varoffset(ncp, varp, start); +#line 773 + size_t remaining = varp->xsz * nelems; +#line 773 + int status = NC_NOERR; +#line 773 + void *xp; +#line 773 + void *fillp=NULL; +#line 773 + +#line 773 + if(nelems == 0) +#line 773 + return NC_NOERR; +#line 773 + +#line 773 + assert(value != NULL); +#line 773 + +#line 773 +#ifdef ERANGE_FILL +#line 773 + fillp = malloc(varp->xsz); +#line 773 + status = NC3_inq_var_fill(varp, fillp); +#line 773 +#endif +#line 773 + +#line 773 + for(;;) +#line 773 + { +#line 773 + size_t extent = MIN(remaining, ncp->chunk); +#line 773 + size_t nput = ncx_howmany(varp->type, extent); +#line 773 + +#line 773 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 773 + RGN_WRITE, &xp); +#line 773 + if(lstatus != NC_NOERR) +#line 773 + return lstatus; +#line 773 + +#line 773 + lstatus = ncx_putn_short_longlong(&xp, nput, value ,fillp); +#line 773 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 773 + { +#line 773 + /* not fatal to the loop */ +#line 773 + status = lstatus; +#line 773 + } +#line 773 + +#line 773 + (void) ncio_rel(ncp->nciop, offset, +#line 773 + RGN_MODIFIED); +#line 773 + +#line 773 + remaining -= extent; +#line 773 + if(remaining == 0) +#line 773 + break; /* normal loop exit */ +#line 773 + offset += (off_t)extent; +#line 773 + value += nput; +#line 773 + +#line 773 + } +#line 773 +#ifdef ERANGE_FILL +#line 773 + free(fillp); +#line 773 +#endif +#line 773 + +#line 773 + return status; +#line 773 +} +#line 773 + +static int +#line 774 +putNCvx_short_ushort(NC3_INFO* ncp, const NC_var *varp, +#line 774 + const size_t *start, size_t nelems, const ushort *value) +#line 774 +{ +#line 774 + off_t offset = NC_varoffset(ncp, varp, start); +#line 774 + size_t remaining = varp->xsz * nelems; +#line 774 + int status = NC_NOERR; +#line 774 + void *xp; +#line 774 + void *fillp=NULL; +#line 774 + +#line 774 + if(nelems == 0) +#line 774 + return NC_NOERR; +#line 774 + +#line 774 + assert(value != NULL); +#line 774 + +#line 774 +#ifdef ERANGE_FILL +#line 774 + fillp = malloc(varp->xsz); +#line 774 + status = NC3_inq_var_fill(varp, fillp); +#line 774 +#endif +#line 774 + +#line 774 + for(;;) +#line 774 + { +#line 774 + size_t extent = MIN(remaining, ncp->chunk); +#line 774 + size_t nput = ncx_howmany(varp->type, extent); +#line 774 + +#line 774 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 774 + RGN_WRITE, &xp); +#line 774 + if(lstatus != NC_NOERR) +#line 774 + return lstatus; +#line 774 + +#line 774 + lstatus = ncx_putn_short_ushort(&xp, nput, value ,fillp); +#line 774 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 774 + { +#line 774 + /* not fatal to the loop */ +#line 774 + status = lstatus; +#line 774 + } +#line 774 + +#line 774 + (void) ncio_rel(ncp->nciop, offset, +#line 774 + RGN_MODIFIED); +#line 774 + +#line 774 + remaining -= extent; +#line 774 + if(remaining == 0) +#line 774 + break; /* normal loop exit */ +#line 774 + offset += (off_t)extent; +#line 774 + value += nput; +#line 774 + +#line 774 + } +#line 774 +#ifdef ERANGE_FILL +#line 774 + free(fillp); +#line 774 +#endif +#line 774 + +#line 774 + return status; +#line 774 +} +#line 774 + +static int +#line 775 +putNCvx_short_uint(NC3_INFO* ncp, const NC_var *varp, +#line 775 + const size_t *start, size_t nelems, const uint *value) +#line 775 +{ +#line 775 + off_t offset = NC_varoffset(ncp, varp, start); +#line 775 + size_t remaining = varp->xsz * nelems; +#line 775 + int status = NC_NOERR; +#line 775 + void *xp; +#line 775 + void *fillp=NULL; +#line 775 + +#line 775 + if(nelems == 0) +#line 775 + return NC_NOERR; +#line 775 + +#line 775 + assert(value != NULL); +#line 775 + +#line 775 +#ifdef ERANGE_FILL +#line 775 + fillp = malloc(varp->xsz); +#line 775 + status = NC3_inq_var_fill(varp, fillp); +#line 775 +#endif +#line 775 + +#line 775 + for(;;) +#line 775 + { +#line 775 + size_t extent = MIN(remaining, ncp->chunk); +#line 775 + size_t nput = ncx_howmany(varp->type, extent); +#line 775 + +#line 775 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 775 + RGN_WRITE, &xp); +#line 775 + if(lstatus != NC_NOERR) +#line 775 + return lstatus; +#line 775 + +#line 775 + lstatus = ncx_putn_short_uint(&xp, nput, value ,fillp); +#line 775 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 775 + { +#line 775 + /* not fatal to the loop */ +#line 775 + status = lstatus; +#line 775 + } +#line 775 + +#line 775 + (void) ncio_rel(ncp->nciop, offset, +#line 775 + RGN_MODIFIED); +#line 775 + +#line 775 + remaining -= extent; +#line 775 + if(remaining == 0) +#line 775 + break; /* normal loop exit */ +#line 775 + offset += (off_t)extent; +#line 775 + value += nput; +#line 775 + +#line 775 + } +#line 775 +#ifdef ERANGE_FILL +#line 775 + free(fillp); +#line 775 +#endif +#line 775 + +#line 775 + return status; +#line 775 +} +#line 775 + +static int +#line 776 +putNCvx_short_ulonglong(NC3_INFO* ncp, const NC_var *varp, +#line 776 + const size_t *start, size_t nelems, const ulonglong *value) +#line 776 +{ +#line 776 + off_t offset = NC_varoffset(ncp, varp, start); +#line 776 + size_t remaining = varp->xsz * nelems; +#line 776 + int status = NC_NOERR; +#line 776 + void *xp; +#line 776 + void *fillp=NULL; +#line 776 + +#line 776 + if(nelems == 0) +#line 776 + return NC_NOERR; +#line 776 + +#line 776 + assert(value != NULL); +#line 776 + +#line 776 +#ifdef ERANGE_FILL +#line 776 + fillp = malloc(varp->xsz); +#line 776 + status = NC3_inq_var_fill(varp, fillp); +#line 776 +#endif +#line 776 + +#line 776 + for(;;) +#line 776 + { +#line 776 + size_t extent = MIN(remaining, ncp->chunk); +#line 776 + size_t nput = ncx_howmany(varp->type, extent); +#line 776 + +#line 776 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 776 + RGN_WRITE, &xp); +#line 776 + if(lstatus != NC_NOERR) +#line 776 + return lstatus; +#line 776 + +#line 776 + lstatus = ncx_putn_short_ulonglong(&xp, nput, value ,fillp); +#line 776 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 776 + { +#line 776 + /* not fatal to the loop */ +#line 776 + status = lstatus; +#line 776 + } +#line 776 + +#line 776 + (void) ncio_rel(ncp->nciop, offset, +#line 776 + RGN_MODIFIED); +#line 776 + +#line 776 + remaining -= extent; +#line 776 + if(remaining == 0) +#line 776 + break; /* normal loop exit */ +#line 776 + offset += (off_t)extent; +#line 776 + value += nput; +#line 776 + +#line 776 + } +#line 776 +#ifdef ERANGE_FILL +#line 776 + free(fillp); +#line 776 +#endif +#line 776 + +#line 776 + return status; +#line 776 +} +#line 776 + + +static int +#line 778 +putNCvx_int_schar(NC3_INFO* ncp, const NC_var *varp, +#line 778 + const size_t *start, size_t nelems, const schar *value) +#line 778 +{ +#line 778 + off_t offset = NC_varoffset(ncp, varp, start); +#line 778 + size_t remaining = varp->xsz * nelems; +#line 778 + int status = NC_NOERR; +#line 778 + void *xp; +#line 778 + void *fillp=NULL; +#line 778 + +#line 778 + if(nelems == 0) +#line 778 + return NC_NOERR; +#line 778 + +#line 778 + assert(value != NULL); +#line 778 + +#line 778 +#ifdef ERANGE_FILL +#line 778 + fillp = malloc(varp->xsz); +#line 778 + status = NC3_inq_var_fill(varp, fillp); +#line 778 +#endif +#line 778 + +#line 778 + for(;;) +#line 778 + { +#line 778 + size_t extent = MIN(remaining, ncp->chunk); +#line 778 + size_t nput = ncx_howmany(varp->type, extent); +#line 778 + +#line 778 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 778 + RGN_WRITE, &xp); +#line 778 + if(lstatus != NC_NOERR) +#line 778 + return lstatus; +#line 778 + +#line 778 + lstatus = ncx_putn_int_schar(&xp, nput, value ,fillp); +#line 778 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 778 + { +#line 778 + /* not fatal to the loop */ +#line 778 + status = lstatus; +#line 778 + } +#line 778 + +#line 778 + (void) ncio_rel(ncp->nciop, offset, +#line 778 + RGN_MODIFIED); +#line 778 + +#line 778 + remaining -= extent; +#line 778 + if(remaining == 0) +#line 778 + break; /* normal loop exit */ +#line 778 + offset += (off_t)extent; +#line 778 + value += nput; +#line 778 + +#line 778 + } +#line 778 +#ifdef ERANGE_FILL +#line 778 + free(fillp); +#line 778 +#endif +#line 778 + +#line 778 + return status; +#line 778 +} +#line 778 + +static int +#line 779 +putNCvx_int_uchar(NC3_INFO* ncp, const NC_var *varp, +#line 779 + const size_t *start, size_t nelems, const uchar *value) +#line 779 +{ +#line 779 + off_t offset = NC_varoffset(ncp, varp, start); +#line 779 + size_t remaining = varp->xsz * nelems; +#line 779 + int status = NC_NOERR; +#line 779 + void *xp; +#line 779 + void *fillp=NULL; +#line 779 + +#line 779 + if(nelems == 0) +#line 779 + return NC_NOERR; +#line 779 + +#line 779 + assert(value != NULL); +#line 779 + +#line 779 +#ifdef ERANGE_FILL +#line 779 + fillp = malloc(varp->xsz); +#line 779 + status = NC3_inq_var_fill(varp, fillp); +#line 779 +#endif +#line 779 + +#line 779 + for(;;) +#line 779 + { +#line 779 + size_t extent = MIN(remaining, ncp->chunk); +#line 779 + size_t nput = ncx_howmany(varp->type, extent); +#line 779 + +#line 779 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 779 + RGN_WRITE, &xp); +#line 779 + if(lstatus != NC_NOERR) +#line 779 + return lstatus; +#line 779 + +#line 779 + lstatus = ncx_putn_int_uchar(&xp, nput, value ,fillp); +#line 779 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 779 + { +#line 779 + /* not fatal to the loop */ +#line 779 + status = lstatus; +#line 779 + } +#line 779 + +#line 779 + (void) ncio_rel(ncp->nciop, offset, +#line 779 + RGN_MODIFIED); +#line 779 + +#line 779 + remaining -= extent; +#line 779 + if(remaining == 0) +#line 779 + break; /* normal loop exit */ +#line 779 + offset += (off_t)extent; +#line 779 + value += nput; +#line 779 + +#line 779 + } +#line 779 +#ifdef ERANGE_FILL +#line 779 + free(fillp); +#line 779 +#endif +#line 779 + +#line 779 + return status; +#line 779 +} +#line 779 + +static int +#line 780 +putNCvx_int_short(NC3_INFO* ncp, const NC_var *varp, +#line 780 + const size_t *start, size_t nelems, const short *value) +#line 780 +{ +#line 780 + off_t offset = NC_varoffset(ncp, varp, start); +#line 780 + size_t remaining = varp->xsz * nelems; +#line 780 + int status = NC_NOERR; +#line 780 + void *xp; +#line 780 + void *fillp=NULL; +#line 780 + +#line 780 + if(nelems == 0) +#line 780 + return NC_NOERR; +#line 780 + +#line 780 + assert(value != NULL); +#line 780 + +#line 780 +#ifdef ERANGE_FILL +#line 780 + fillp = malloc(varp->xsz); +#line 780 + status = NC3_inq_var_fill(varp, fillp); +#line 780 +#endif +#line 780 + +#line 780 + for(;;) +#line 780 + { +#line 780 + size_t extent = MIN(remaining, ncp->chunk); +#line 780 + size_t nput = ncx_howmany(varp->type, extent); +#line 780 + +#line 780 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 780 + RGN_WRITE, &xp); +#line 780 + if(lstatus != NC_NOERR) +#line 780 + return lstatus; +#line 780 + +#line 780 + lstatus = ncx_putn_int_short(&xp, nput, value ,fillp); +#line 780 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 780 + { +#line 780 + /* not fatal to the loop */ +#line 780 + status = lstatus; +#line 780 + } +#line 780 + +#line 780 + (void) ncio_rel(ncp->nciop, offset, +#line 780 + RGN_MODIFIED); +#line 780 + +#line 780 + remaining -= extent; +#line 780 + if(remaining == 0) +#line 780 + break; /* normal loop exit */ +#line 780 + offset += (off_t)extent; +#line 780 + value += nput; +#line 780 + +#line 780 + } +#line 780 +#ifdef ERANGE_FILL +#line 780 + free(fillp); +#line 780 +#endif +#line 780 + +#line 780 + return status; +#line 780 +} +#line 780 + +static int +#line 781 +putNCvx_int_int(NC3_INFO* ncp, const NC_var *varp, +#line 781 + const size_t *start, size_t nelems, const int *value) +#line 781 +{ +#line 781 + off_t offset = NC_varoffset(ncp, varp, start); +#line 781 + size_t remaining = varp->xsz * nelems; +#line 781 + int status = NC_NOERR; +#line 781 + void *xp; +#line 781 + void *fillp=NULL; +#line 781 + +#line 781 + if(nelems == 0) +#line 781 + return NC_NOERR; +#line 781 + +#line 781 + assert(value != NULL); +#line 781 + +#line 781 +#ifdef ERANGE_FILL +#line 781 + fillp = malloc(varp->xsz); +#line 781 + status = NC3_inq_var_fill(varp, fillp); +#line 781 +#endif +#line 781 + +#line 781 + for(;;) +#line 781 + { +#line 781 + size_t extent = MIN(remaining, ncp->chunk); +#line 781 + size_t nput = ncx_howmany(varp->type, extent); +#line 781 + +#line 781 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 781 + RGN_WRITE, &xp); +#line 781 + if(lstatus != NC_NOERR) +#line 781 + return lstatus; +#line 781 + +#line 781 + lstatus = ncx_putn_int_int(&xp, nput, value ,fillp); +#line 781 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 781 + { +#line 781 + /* not fatal to the loop */ +#line 781 + status = lstatus; +#line 781 + } +#line 781 + +#line 781 + (void) ncio_rel(ncp->nciop, offset, +#line 781 + RGN_MODIFIED); +#line 781 + +#line 781 + remaining -= extent; +#line 781 + if(remaining == 0) +#line 781 + break; /* normal loop exit */ +#line 781 + offset += (off_t)extent; +#line 781 + value += nput; +#line 781 + +#line 781 + } +#line 781 +#ifdef ERANGE_FILL +#line 781 + free(fillp); +#line 781 +#endif +#line 781 + +#line 781 + return status; +#line 781 +} +#line 781 + +static int +#line 782 +putNCvx_int_float(NC3_INFO* ncp, const NC_var *varp, +#line 782 + const size_t *start, size_t nelems, const float *value) +#line 782 +{ +#line 782 + off_t offset = NC_varoffset(ncp, varp, start); +#line 782 + size_t remaining = varp->xsz * nelems; +#line 782 + int status = NC_NOERR; +#line 782 + void *xp; +#line 782 + void *fillp=NULL; +#line 782 + +#line 782 + if(nelems == 0) +#line 782 + return NC_NOERR; +#line 782 + +#line 782 + assert(value != NULL); +#line 782 + +#line 782 +#ifdef ERANGE_FILL +#line 782 + fillp = malloc(varp->xsz); +#line 782 + status = NC3_inq_var_fill(varp, fillp); +#line 782 +#endif +#line 782 + +#line 782 + for(;;) +#line 782 + { +#line 782 + size_t extent = MIN(remaining, ncp->chunk); +#line 782 + size_t nput = ncx_howmany(varp->type, extent); +#line 782 + +#line 782 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 782 + RGN_WRITE, &xp); +#line 782 + if(lstatus != NC_NOERR) +#line 782 + return lstatus; +#line 782 + +#line 782 + lstatus = ncx_putn_int_float(&xp, nput, value ,fillp); +#line 782 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 782 + { +#line 782 + /* not fatal to the loop */ +#line 782 + status = lstatus; +#line 782 + } +#line 782 + +#line 782 + (void) ncio_rel(ncp->nciop, offset, +#line 782 + RGN_MODIFIED); +#line 782 + +#line 782 + remaining -= extent; +#line 782 + if(remaining == 0) +#line 782 + break; /* normal loop exit */ +#line 782 + offset += (off_t)extent; +#line 782 + value += nput; +#line 782 + +#line 782 + } +#line 782 +#ifdef ERANGE_FILL +#line 782 + free(fillp); +#line 782 +#endif +#line 782 + +#line 782 + return status; +#line 782 +} +#line 782 + +static int +#line 783 +putNCvx_int_double(NC3_INFO* ncp, const NC_var *varp, +#line 783 + const size_t *start, size_t nelems, const double *value) +#line 783 +{ +#line 783 + off_t offset = NC_varoffset(ncp, varp, start); +#line 783 + size_t remaining = varp->xsz * nelems; +#line 783 + int status = NC_NOERR; +#line 783 + void *xp; +#line 783 + void *fillp=NULL; +#line 783 + +#line 783 + if(nelems == 0) +#line 783 + return NC_NOERR; +#line 783 + +#line 783 + assert(value != NULL); +#line 783 + +#line 783 +#ifdef ERANGE_FILL +#line 783 + fillp = malloc(varp->xsz); +#line 783 + status = NC3_inq_var_fill(varp, fillp); +#line 783 +#endif +#line 783 + +#line 783 + for(;;) +#line 783 + { +#line 783 + size_t extent = MIN(remaining, ncp->chunk); +#line 783 + size_t nput = ncx_howmany(varp->type, extent); +#line 783 + +#line 783 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 783 + RGN_WRITE, &xp); +#line 783 + if(lstatus != NC_NOERR) +#line 783 + return lstatus; +#line 783 + +#line 783 + lstatus = ncx_putn_int_double(&xp, nput, value ,fillp); +#line 783 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 783 + { +#line 783 + /* not fatal to the loop */ +#line 783 + status = lstatus; +#line 783 + } +#line 783 + +#line 783 + (void) ncio_rel(ncp->nciop, offset, +#line 783 + RGN_MODIFIED); +#line 783 + +#line 783 + remaining -= extent; +#line 783 + if(remaining == 0) +#line 783 + break; /* normal loop exit */ +#line 783 + offset += (off_t)extent; +#line 783 + value += nput; +#line 783 + +#line 783 + } +#line 783 +#ifdef ERANGE_FILL +#line 783 + free(fillp); +#line 783 +#endif +#line 783 + +#line 783 + return status; +#line 783 +} +#line 783 + +static int +#line 784 +putNCvx_int_longlong(NC3_INFO* ncp, const NC_var *varp, +#line 784 + const size_t *start, size_t nelems, const longlong *value) +#line 784 +{ +#line 784 + off_t offset = NC_varoffset(ncp, varp, start); +#line 784 + size_t remaining = varp->xsz * nelems; +#line 784 + int status = NC_NOERR; +#line 784 + void *xp; +#line 784 + void *fillp=NULL; +#line 784 + +#line 784 + if(nelems == 0) +#line 784 + return NC_NOERR; +#line 784 + +#line 784 + assert(value != NULL); +#line 784 + +#line 784 +#ifdef ERANGE_FILL +#line 784 + fillp = malloc(varp->xsz); +#line 784 + status = NC3_inq_var_fill(varp, fillp); +#line 784 +#endif +#line 784 + +#line 784 + for(;;) +#line 784 + { +#line 784 + size_t extent = MIN(remaining, ncp->chunk); +#line 784 + size_t nput = ncx_howmany(varp->type, extent); +#line 784 + +#line 784 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 784 + RGN_WRITE, &xp); +#line 784 + if(lstatus != NC_NOERR) +#line 784 + return lstatus; +#line 784 + +#line 784 + lstatus = ncx_putn_int_longlong(&xp, nput, value ,fillp); +#line 784 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 784 + { +#line 784 + /* not fatal to the loop */ +#line 784 + status = lstatus; +#line 784 + } +#line 784 + +#line 784 + (void) ncio_rel(ncp->nciop, offset, +#line 784 + RGN_MODIFIED); +#line 784 + +#line 784 + remaining -= extent; +#line 784 + if(remaining == 0) +#line 784 + break; /* normal loop exit */ +#line 784 + offset += (off_t)extent; +#line 784 + value += nput; +#line 784 + +#line 784 + } +#line 784 +#ifdef ERANGE_FILL +#line 784 + free(fillp); +#line 784 +#endif +#line 784 + +#line 784 + return status; +#line 784 +} +#line 784 + +static int +#line 785 +putNCvx_int_ushort(NC3_INFO* ncp, const NC_var *varp, +#line 785 + const size_t *start, size_t nelems, const ushort *value) +#line 785 +{ +#line 785 + off_t offset = NC_varoffset(ncp, varp, start); +#line 785 + size_t remaining = varp->xsz * nelems; +#line 785 + int status = NC_NOERR; +#line 785 + void *xp; +#line 785 + void *fillp=NULL; +#line 785 + +#line 785 + if(nelems == 0) +#line 785 + return NC_NOERR; +#line 785 + +#line 785 + assert(value != NULL); +#line 785 + +#line 785 +#ifdef ERANGE_FILL +#line 785 + fillp = malloc(varp->xsz); +#line 785 + status = NC3_inq_var_fill(varp, fillp); +#line 785 +#endif +#line 785 + +#line 785 + for(;;) +#line 785 + { +#line 785 + size_t extent = MIN(remaining, ncp->chunk); +#line 785 + size_t nput = ncx_howmany(varp->type, extent); +#line 785 + +#line 785 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 785 + RGN_WRITE, &xp); +#line 785 + if(lstatus != NC_NOERR) +#line 785 + return lstatus; +#line 785 + +#line 785 + lstatus = ncx_putn_int_ushort(&xp, nput, value ,fillp); +#line 785 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 785 + { +#line 785 + /* not fatal to the loop */ +#line 785 + status = lstatus; +#line 785 + } +#line 785 + +#line 785 + (void) ncio_rel(ncp->nciop, offset, +#line 785 + RGN_MODIFIED); +#line 785 + +#line 785 + remaining -= extent; +#line 785 + if(remaining == 0) +#line 785 + break; /* normal loop exit */ +#line 785 + offset += (off_t)extent; +#line 785 + value += nput; +#line 785 + +#line 785 + } +#line 785 +#ifdef ERANGE_FILL +#line 785 + free(fillp); +#line 785 +#endif +#line 785 + +#line 785 + return status; +#line 785 +} +#line 785 + +static int +#line 786 +putNCvx_int_uint(NC3_INFO* ncp, const NC_var *varp, +#line 786 + const size_t *start, size_t nelems, const uint *value) +#line 786 +{ +#line 786 + off_t offset = NC_varoffset(ncp, varp, start); +#line 786 + size_t remaining = varp->xsz * nelems; +#line 786 + int status = NC_NOERR; +#line 786 + void *xp; +#line 786 + void *fillp=NULL; +#line 786 + +#line 786 + if(nelems == 0) +#line 786 + return NC_NOERR; +#line 786 + +#line 786 + assert(value != NULL); +#line 786 + +#line 786 +#ifdef ERANGE_FILL +#line 786 + fillp = malloc(varp->xsz); +#line 786 + status = NC3_inq_var_fill(varp, fillp); +#line 786 +#endif +#line 786 + +#line 786 + for(;;) +#line 786 + { +#line 786 + size_t extent = MIN(remaining, ncp->chunk); +#line 786 + size_t nput = ncx_howmany(varp->type, extent); +#line 786 + +#line 786 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 786 + RGN_WRITE, &xp); +#line 786 + if(lstatus != NC_NOERR) +#line 786 + return lstatus; +#line 786 + +#line 786 + lstatus = ncx_putn_int_uint(&xp, nput, value ,fillp); +#line 786 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 786 + { +#line 786 + /* not fatal to the loop */ +#line 786 + status = lstatus; +#line 786 + } +#line 786 + +#line 786 + (void) ncio_rel(ncp->nciop, offset, +#line 786 + RGN_MODIFIED); +#line 786 + +#line 786 + remaining -= extent; +#line 786 + if(remaining == 0) +#line 786 + break; /* normal loop exit */ +#line 786 + offset += (off_t)extent; +#line 786 + value += nput; +#line 786 + +#line 786 + } +#line 786 +#ifdef ERANGE_FILL +#line 786 + free(fillp); +#line 786 +#endif +#line 786 + +#line 786 + return status; +#line 786 +} +#line 786 + +static int +#line 787 +putNCvx_int_ulonglong(NC3_INFO* ncp, const NC_var *varp, +#line 787 + const size_t *start, size_t nelems, const ulonglong *value) +#line 787 +{ +#line 787 + off_t offset = NC_varoffset(ncp, varp, start); +#line 787 + size_t remaining = varp->xsz * nelems; +#line 787 + int status = NC_NOERR; +#line 787 + void *xp; +#line 787 + void *fillp=NULL; +#line 787 + +#line 787 + if(nelems == 0) +#line 787 + return NC_NOERR; +#line 787 + +#line 787 + assert(value != NULL); +#line 787 + +#line 787 +#ifdef ERANGE_FILL +#line 787 + fillp = malloc(varp->xsz); +#line 787 + status = NC3_inq_var_fill(varp, fillp); +#line 787 +#endif +#line 787 + +#line 787 + for(;;) +#line 787 + { +#line 787 + size_t extent = MIN(remaining, ncp->chunk); +#line 787 + size_t nput = ncx_howmany(varp->type, extent); +#line 787 + +#line 787 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 787 + RGN_WRITE, &xp); +#line 787 + if(lstatus != NC_NOERR) +#line 787 + return lstatus; +#line 787 + +#line 787 + lstatus = ncx_putn_int_ulonglong(&xp, nput, value ,fillp); +#line 787 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 787 + { +#line 787 + /* not fatal to the loop */ +#line 787 + status = lstatus; +#line 787 + } +#line 787 + +#line 787 + (void) ncio_rel(ncp->nciop, offset, +#line 787 + RGN_MODIFIED); +#line 787 + +#line 787 + remaining -= extent; +#line 787 + if(remaining == 0) +#line 787 + break; /* normal loop exit */ +#line 787 + offset += (off_t)extent; +#line 787 + value += nput; +#line 787 + +#line 787 + } +#line 787 +#ifdef ERANGE_FILL +#line 787 + free(fillp); +#line 787 +#endif +#line 787 + +#line 787 + return status; +#line 787 +} +#line 787 + + +static int +#line 789 +putNCvx_float_schar(NC3_INFO* ncp, const NC_var *varp, +#line 789 + const size_t *start, size_t nelems, const schar *value) +#line 789 +{ +#line 789 + off_t offset = NC_varoffset(ncp, varp, start); +#line 789 + size_t remaining = varp->xsz * nelems; +#line 789 + int status = NC_NOERR; +#line 789 + void *xp; +#line 789 + void *fillp=NULL; +#line 789 + +#line 789 + if(nelems == 0) +#line 789 + return NC_NOERR; +#line 789 + +#line 789 + assert(value != NULL); +#line 789 + +#line 789 +#ifdef ERANGE_FILL +#line 789 + fillp = malloc(varp->xsz); +#line 789 + status = NC3_inq_var_fill(varp, fillp); +#line 789 +#endif +#line 789 + +#line 789 + for(;;) +#line 789 + { +#line 789 + size_t extent = MIN(remaining, ncp->chunk); +#line 789 + size_t nput = ncx_howmany(varp->type, extent); +#line 789 + +#line 789 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 789 + RGN_WRITE, &xp); +#line 789 + if(lstatus != NC_NOERR) +#line 789 + return lstatus; +#line 789 + +#line 789 + lstatus = ncx_putn_float_schar(&xp, nput, value ,fillp); +#line 789 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 789 + { +#line 789 + /* not fatal to the loop */ +#line 789 + status = lstatus; +#line 789 + } +#line 789 + +#line 789 + (void) ncio_rel(ncp->nciop, offset, +#line 789 + RGN_MODIFIED); +#line 789 + +#line 789 + remaining -= extent; +#line 789 + if(remaining == 0) +#line 789 + break; /* normal loop exit */ +#line 789 + offset += (off_t)extent; +#line 789 + value += nput; +#line 789 + +#line 789 + } +#line 789 +#ifdef ERANGE_FILL +#line 789 + free(fillp); +#line 789 +#endif +#line 789 + +#line 789 + return status; +#line 789 +} +#line 789 + +static int +#line 790 +putNCvx_float_uchar(NC3_INFO* ncp, const NC_var *varp, +#line 790 + const size_t *start, size_t nelems, const uchar *value) +#line 790 +{ +#line 790 + off_t offset = NC_varoffset(ncp, varp, start); +#line 790 + size_t remaining = varp->xsz * nelems; +#line 790 + int status = NC_NOERR; +#line 790 + void *xp; +#line 790 + void *fillp=NULL; +#line 790 + +#line 790 + if(nelems == 0) +#line 790 + return NC_NOERR; +#line 790 + +#line 790 + assert(value != NULL); +#line 790 + +#line 790 +#ifdef ERANGE_FILL +#line 790 + fillp = malloc(varp->xsz); +#line 790 + status = NC3_inq_var_fill(varp, fillp); +#line 790 +#endif +#line 790 + +#line 790 + for(;;) +#line 790 + { +#line 790 + size_t extent = MIN(remaining, ncp->chunk); +#line 790 + size_t nput = ncx_howmany(varp->type, extent); +#line 790 + +#line 790 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 790 + RGN_WRITE, &xp); +#line 790 + if(lstatus != NC_NOERR) +#line 790 + return lstatus; +#line 790 + +#line 790 + lstatus = ncx_putn_float_uchar(&xp, nput, value ,fillp); +#line 790 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 790 + { +#line 790 + /* not fatal to the loop */ +#line 790 + status = lstatus; +#line 790 + } +#line 790 + +#line 790 + (void) ncio_rel(ncp->nciop, offset, +#line 790 + RGN_MODIFIED); +#line 790 + +#line 790 + remaining -= extent; +#line 790 + if(remaining == 0) +#line 790 + break; /* normal loop exit */ +#line 790 + offset += (off_t)extent; +#line 790 + value += nput; +#line 790 + +#line 790 + } +#line 790 +#ifdef ERANGE_FILL +#line 790 + free(fillp); +#line 790 +#endif +#line 790 + +#line 790 + return status; +#line 790 +} +#line 790 + +static int +#line 791 +putNCvx_float_short(NC3_INFO* ncp, const NC_var *varp, +#line 791 + const size_t *start, size_t nelems, const short *value) +#line 791 +{ +#line 791 + off_t offset = NC_varoffset(ncp, varp, start); +#line 791 + size_t remaining = varp->xsz * nelems; +#line 791 + int status = NC_NOERR; +#line 791 + void *xp; +#line 791 + void *fillp=NULL; +#line 791 + +#line 791 + if(nelems == 0) +#line 791 + return NC_NOERR; +#line 791 + +#line 791 + assert(value != NULL); +#line 791 + +#line 791 +#ifdef ERANGE_FILL +#line 791 + fillp = malloc(varp->xsz); +#line 791 + status = NC3_inq_var_fill(varp, fillp); +#line 791 +#endif +#line 791 + +#line 791 + for(;;) +#line 791 + { +#line 791 + size_t extent = MIN(remaining, ncp->chunk); +#line 791 + size_t nput = ncx_howmany(varp->type, extent); +#line 791 + +#line 791 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 791 + RGN_WRITE, &xp); +#line 791 + if(lstatus != NC_NOERR) +#line 791 + return lstatus; +#line 791 + +#line 791 + lstatus = ncx_putn_float_short(&xp, nput, value ,fillp); +#line 791 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 791 + { +#line 791 + /* not fatal to the loop */ +#line 791 + status = lstatus; +#line 791 + } +#line 791 + +#line 791 + (void) ncio_rel(ncp->nciop, offset, +#line 791 + RGN_MODIFIED); +#line 791 + +#line 791 + remaining -= extent; +#line 791 + if(remaining == 0) +#line 791 + break; /* normal loop exit */ +#line 791 + offset += (off_t)extent; +#line 791 + value += nput; +#line 791 + +#line 791 + } +#line 791 +#ifdef ERANGE_FILL +#line 791 + free(fillp); +#line 791 +#endif +#line 791 + +#line 791 + return status; +#line 791 +} +#line 791 + +static int +#line 792 +putNCvx_float_int(NC3_INFO* ncp, const NC_var *varp, +#line 792 + const size_t *start, size_t nelems, const int *value) +#line 792 +{ +#line 792 + off_t offset = NC_varoffset(ncp, varp, start); +#line 792 + size_t remaining = varp->xsz * nelems; +#line 792 + int status = NC_NOERR; +#line 792 + void *xp; +#line 792 + void *fillp=NULL; +#line 792 + +#line 792 + if(nelems == 0) +#line 792 + return NC_NOERR; +#line 792 + +#line 792 + assert(value != NULL); +#line 792 + +#line 792 +#ifdef ERANGE_FILL +#line 792 + fillp = malloc(varp->xsz); +#line 792 + status = NC3_inq_var_fill(varp, fillp); +#line 792 +#endif +#line 792 + +#line 792 + for(;;) +#line 792 + { +#line 792 + size_t extent = MIN(remaining, ncp->chunk); +#line 792 + size_t nput = ncx_howmany(varp->type, extent); +#line 792 + +#line 792 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 792 + RGN_WRITE, &xp); +#line 792 + if(lstatus != NC_NOERR) +#line 792 + return lstatus; +#line 792 + +#line 792 + lstatus = ncx_putn_float_int(&xp, nput, value ,fillp); +#line 792 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 792 + { +#line 792 + /* not fatal to the loop */ +#line 792 + status = lstatus; +#line 792 + } +#line 792 + +#line 792 + (void) ncio_rel(ncp->nciop, offset, +#line 792 + RGN_MODIFIED); +#line 792 + +#line 792 + remaining -= extent; +#line 792 + if(remaining == 0) +#line 792 + break; /* normal loop exit */ +#line 792 + offset += (off_t)extent; +#line 792 + value += nput; +#line 792 + +#line 792 + } +#line 792 +#ifdef ERANGE_FILL +#line 792 + free(fillp); +#line 792 +#endif +#line 792 + +#line 792 + return status; +#line 792 +} +#line 792 + +static int +#line 793 +putNCvx_float_float(NC3_INFO* ncp, const NC_var *varp, +#line 793 + const size_t *start, size_t nelems, const float *value) +#line 793 +{ +#line 793 + off_t offset = NC_varoffset(ncp, varp, start); +#line 793 + size_t remaining = varp->xsz * nelems; +#line 793 + int status = NC_NOERR; +#line 793 + void *xp; +#line 793 + void *fillp=NULL; +#line 793 + +#line 793 + if(nelems == 0) +#line 793 + return NC_NOERR; +#line 793 + +#line 793 + assert(value != NULL); +#line 793 + +#line 793 +#ifdef ERANGE_FILL +#line 793 + fillp = malloc(varp->xsz); +#line 793 + status = NC3_inq_var_fill(varp, fillp); +#line 793 +#endif +#line 793 + +#line 793 + for(;;) +#line 793 + { +#line 793 + size_t extent = MIN(remaining, ncp->chunk); +#line 793 + size_t nput = ncx_howmany(varp->type, extent); +#line 793 + +#line 793 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 793 + RGN_WRITE, &xp); +#line 793 + if(lstatus != NC_NOERR) +#line 793 + return lstatus; +#line 793 + +#line 793 + lstatus = ncx_putn_float_float(&xp, nput, value ,fillp); +#line 793 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 793 + { +#line 793 + /* not fatal to the loop */ +#line 793 + status = lstatus; +#line 793 + } +#line 793 + +#line 793 + (void) ncio_rel(ncp->nciop, offset, +#line 793 + RGN_MODIFIED); +#line 793 + +#line 793 + remaining -= extent; +#line 793 + if(remaining == 0) +#line 793 + break; /* normal loop exit */ +#line 793 + offset += (off_t)extent; +#line 793 + value += nput; +#line 793 + +#line 793 + } +#line 793 +#ifdef ERANGE_FILL +#line 793 + free(fillp); +#line 793 +#endif +#line 793 + +#line 793 + return status; +#line 793 +} +#line 793 + +static int +#line 794 +putNCvx_float_double(NC3_INFO* ncp, const NC_var *varp, +#line 794 + const size_t *start, size_t nelems, const double *value) +#line 794 +{ +#line 794 + off_t offset = NC_varoffset(ncp, varp, start); +#line 794 + size_t remaining = varp->xsz * nelems; +#line 794 + int status = NC_NOERR; +#line 794 + void *xp; +#line 794 + void *fillp=NULL; +#line 794 + +#line 794 + if(nelems == 0) +#line 794 + return NC_NOERR; +#line 794 + +#line 794 + assert(value != NULL); +#line 794 + +#line 794 +#ifdef ERANGE_FILL +#line 794 + fillp = malloc(varp->xsz); +#line 794 + status = NC3_inq_var_fill(varp, fillp); +#line 794 +#endif +#line 794 + +#line 794 + for(;;) +#line 794 + { +#line 794 + size_t extent = MIN(remaining, ncp->chunk); +#line 794 + size_t nput = ncx_howmany(varp->type, extent); +#line 794 + +#line 794 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 794 + RGN_WRITE, &xp); +#line 794 + if(lstatus != NC_NOERR) +#line 794 + return lstatus; +#line 794 + +#line 794 + lstatus = ncx_putn_float_double(&xp, nput, value ,fillp); +#line 794 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 794 + { +#line 794 + /* not fatal to the loop */ +#line 794 + status = lstatus; +#line 794 + } +#line 794 + +#line 794 + (void) ncio_rel(ncp->nciop, offset, +#line 794 + RGN_MODIFIED); +#line 794 + +#line 794 + remaining -= extent; +#line 794 + if(remaining == 0) +#line 794 + break; /* normal loop exit */ +#line 794 + offset += (off_t)extent; +#line 794 + value += nput; +#line 794 + +#line 794 + } +#line 794 +#ifdef ERANGE_FILL +#line 794 + free(fillp); +#line 794 +#endif +#line 794 + +#line 794 + return status; +#line 794 +} +#line 794 + +static int +#line 795 +putNCvx_float_longlong(NC3_INFO* ncp, const NC_var *varp, +#line 795 + const size_t *start, size_t nelems, const longlong *value) +#line 795 +{ +#line 795 + off_t offset = NC_varoffset(ncp, varp, start); +#line 795 + size_t remaining = varp->xsz * nelems; +#line 795 + int status = NC_NOERR; +#line 795 + void *xp; +#line 795 + void *fillp=NULL; +#line 795 + +#line 795 + if(nelems == 0) +#line 795 + return NC_NOERR; +#line 795 + +#line 795 + assert(value != NULL); +#line 795 + +#line 795 +#ifdef ERANGE_FILL +#line 795 + fillp = malloc(varp->xsz); +#line 795 + status = NC3_inq_var_fill(varp, fillp); +#line 795 +#endif +#line 795 + +#line 795 + for(;;) +#line 795 + { +#line 795 + size_t extent = MIN(remaining, ncp->chunk); +#line 795 + size_t nput = ncx_howmany(varp->type, extent); +#line 795 + +#line 795 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 795 + RGN_WRITE, &xp); +#line 795 + if(lstatus != NC_NOERR) +#line 795 + return lstatus; +#line 795 + +#line 795 + lstatus = ncx_putn_float_longlong(&xp, nput, value ,fillp); +#line 795 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 795 + { +#line 795 + /* not fatal to the loop */ +#line 795 + status = lstatus; +#line 795 + } +#line 795 + +#line 795 + (void) ncio_rel(ncp->nciop, offset, +#line 795 + RGN_MODIFIED); +#line 795 + +#line 795 + remaining -= extent; +#line 795 + if(remaining == 0) +#line 795 + break; /* normal loop exit */ +#line 795 + offset += (off_t)extent; +#line 795 + value += nput; +#line 795 + +#line 795 + } +#line 795 +#ifdef ERANGE_FILL +#line 795 + free(fillp); +#line 795 +#endif +#line 795 + +#line 795 + return status; +#line 795 +} +#line 795 + +static int +#line 796 +putNCvx_float_ushort(NC3_INFO* ncp, const NC_var *varp, +#line 796 + const size_t *start, size_t nelems, const ushort *value) +#line 796 +{ +#line 796 + off_t offset = NC_varoffset(ncp, varp, start); +#line 796 + size_t remaining = varp->xsz * nelems; +#line 796 + int status = NC_NOERR; +#line 796 + void *xp; +#line 796 + void *fillp=NULL; +#line 796 + +#line 796 + if(nelems == 0) +#line 796 + return NC_NOERR; +#line 796 + +#line 796 + assert(value != NULL); +#line 796 + +#line 796 +#ifdef ERANGE_FILL +#line 796 + fillp = malloc(varp->xsz); +#line 796 + status = NC3_inq_var_fill(varp, fillp); +#line 796 +#endif +#line 796 + +#line 796 + for(;;) +#line 796 + { +#line 796 + size_t extent = MIN(remaining, ncp->chunk); +#line 796 + size_t nput = ncx_howmany(varp->type, extent); +#line 796 + +#line 796 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 796 + RGN_WRITE, &xp); +#line 796 + if(lstatus != NC_NOERR) +#line 796 + return lstatus; +#line 796 + +#line 796 + lstatus = ncx_putn_float_ushort(&xp, nput, value ,fillp); +#line 796 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 796 + { +#line 796 + /* not fatal to the loop */ +#line 796 + status = lstatus; +#line 796 + } +#line 796 + +#line 796 + (void) ncio_rel(ncp->nciop, offset, +#line 796 + RGN_MODIFIED); +#line 796 + +#line 796 + remaining -= extent; +#line 796 + if(remaining == 0) +#line 796 + break; /* normal loop exit */ +#line 796 + offset += (off_t)extent; +#line 796 + value += nput; +#line 796 + +#line 796 + } +#line 796 +#ifdef ERANGE_FILL +#line 796 + free(fillp); +#line 796 +#endif +#line 796 + +#line 796 + return status; +#line 796 +} +#line 796 + +static int +#line 797 +putNCvx_float_uint(NC3_INFO* ncp, const NC_var *varp, +#line 797 + const size_t *start, size_t nelems, const uint *value) +#line 797 +{ +#line 797 + off_t offset = NC_varoffset(ncp, varp, start); +#line 797 + size_t remaining = varp->xsz * nelems; +#line 797 + int status = NC_NOERR; +#line 797 + void *xp; +#line 797 + void *fillp=NULL; +#line 797 + +#line 797 + if(nelems == 0) +#line 797 + return NC_NOERR; +#line 797 + +#line 797 + assert(value != NULL); +#line 797 + +#line 797 +#ifdef ERANGE_FILL +#line 797 + fillp = malloc(varp->xsz); +#line 797 + status = NC3_inq_var_fill(varp, fillp); +#line 797 +#endif +#line 797 + +#line 797 + for(;;) +#line 797 + { +#line 797 + size_t extent = MIN(remaining, ncp->chunk); +#line 797 + size_t nput = ncx_howmany(varp->type, extent); +#line 797 + +#line 797 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 797 + RGN_WRITE, &xp); +#line 797 + if(lstatus != NC_NOERR) +#line 797 + return lstatus; +#line 797 + +#line 797 + lstatus = ncx_putn_float_uint(&xp, nput, value ,fillp); +#line 797 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 797 + { +#line 797 + /* not fatal to the loop */ +#line 797 + status = lstatus; +#line 797 + } +#line 797 + +#line 797 + (void) ncio_rel(ncp->nciop, offset, +#line 797 + RGN_MODIFIED); +#line 797 + +#line 797 + remaining -= extent; +#line 797 + if(remaining == 0) +#line 797 + break; /* normal loop exit */ +#line 797 + offset += (off_t)extent; +#line 797 + value += nput; +#line 797 + +#line 797 + } +#line 797 +#ifdef ERANGE_FILL +#line 797 + free(fillp); +#line 797 +#endif +#line 797 + +#line 797 + return status; +#line 797 +} +#line 797 + +static int +#line 798 +putNCvx_float_ulonglong(NC3_INFO* ncp, const NC_var *varp, +#line 798 + const size_t *start, size_t nelems, const ulonglong *value) +#line 798 +{ +#line 798 + off_t offset = NC_varoffset(ncp, varp, start); +#line 798 + size_t remaining = varp->xsz * nelems; +#line 798 + int status = NC_NOERR; +#line 798 + void *xp; +#line 798 + void *fillp=NULL; +#line 798 + +#line 798 + if(nelems == 0) +#line 798 + return NC_NOERR; +#line 798 + +#line 798 + assert(value != NULL); +#line 798 + +#line 798 +#ifdef ERANGE_FILL +#line 798 + fillp = malloc(varp->xsz); +#line 798 + status = NC3_inq_var_fill(varp, fillp); +#line 798 +#endif +#line 798 + +#line 798 + for(;;) +#line 798 + { +#line 798 + size_t extent = MIN(remaining, ncp->chunk); +#line 798 + size_t nput = ncx_howmany(varp->type, extent); +#line 798 + +#line 798 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 798 + RGN_WRITE, &xp); +#line 798 + if(lstatus != NC_NOERR) +#line 798 + return lstatus; +#line 798 + +#line 798 + lstatus = ncx_putn_float_ulonglong(&xp, nput, value ,fillp); +#line 798 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 798 + { +#line 798 + /* not fatal to the loop */ +#line 798 + status = lstatus; +#line 798 + } +#line 798 + +#line 798 + (void) ncio_rel(ncp->nciop, offset, +#line 798 + RGN_MODIFIED); +#line 798 + +#line 798 + remaining -= extent; +#line 798 + if(remaining == 0) +#line 798 + break; /* normal loop exit */ +#line 798 + offset += (off_t)extent; +#line 798 + value += nput; +#line 798 + +#line 798 + } +#line 798 +#ifdef ERANGE_FILL +#line 798 + free(fillp); +#line 798 +#endif +#line 798 + +#line 798 + return status; +#line 798 +} +#line 798 + + +static int +#line 800 +putNCvx_double_schar(NC3_INFO* ncp, const NC_var *varp, +#line 800 + const size_t *start, size_t nelems, const schar *value) +#line 800 +{ +#line 800 + off_t offset = NC_varoffset(ncp, varp, start); +#line 800 + size_t remaining = varp->xsz * nelems; +#line 800 + int status = NC_NOERR; +#line 800 + void *xp; +#line 800 + void *fillp=NULL; +#line 800 + +#line 800 + if(nelems == 0) +#line 800 + return NC_NOERR; +#line 800 + +#line 800 + assert(value != NULL); +#line 800 + +#line 800 +#ifdef ERANGE_FILL +#line 800 + fillp = malloc(varp->xsz); +#line 800 + status = NC3_inq_var_fill(varp, fillp); +#line 800 +#endif +#line 800 + +#line 800 + for(;;) +#line 800 + { +#line 800 + size_t extent = MIN(remaining, ncp->chunk); +#line 800 + size_t nput = ncx_howmany(varp->type, extent); +#line 800 + +#line 800 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 800 + RGN_WRITE, &xp); +#line 800 + if(lstatus != NC_NOERR) +#line 800 + return lstatus; +#line 800 + +#line 800 + lstatus = ncx_putn_double_schar(&xp, nput, value ,fillp); +#line 800 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 800 + { +#line 800 + /* not fatal to the loop */ +#line 800 + status = lstatus; +#line 800 + } +#line 800 + +#line 800 + (void) ncio_rel(ncp->nciop, offset, +#line 800 + RGN_MODIFIED); +#line 800 + +#line 800 + remaining -= extent; +#line 800 + if(remaining == 0) +#line 800 + break; /* normal loop exit */ +#line 800 + offset += (off_t)extent; +#line 800 + value += nput; +#line 800 + +#line 800 + } +#line 800 +#ifdef ERANGE_FILL +#line 800 + free(fillp); +#line 800 +#endif +#line 800 + +#line 800 + return status; +#line 800 +} +#line 800 + +static int +#line 801 +putNCvx_double_uchar(NC3_INFO* ncp, const NC_var *varp, +#line 801 + const size_t *start, size_t nelems, const uchar *value) +#line 801 +{ +#line 801 + off_t offset = NC_varoffset(ncp, varp, start); +#line 801 + size_t remaining = varp->xsz * nelems; +#line 801 + int status = NC_NOERR; +#line 801 + void *xp; +#line 801 + void *fillp=NULL; +#line 801 + +#line 801 + if(nelems == 0) +#line 801 + return NC_NOERR; +#line 801 + +#line 801 + assert(value != NULL); +#line 801 + +#line 801 +#ifdef ERANGE_FILL +#line 801 + fillp = malloc(varp->xsz); +#line 801 + status = NC3_inq_var_fill(varp, fillp); +#line 801 +#endif +#line 801 + +#line 801 + for(;;) +#line 801 + { +#line 801 + size_t extent = MIN(remaining, ncp->chunk); +#line 801 + size_t nput = ncx_howmany(varp->type, extent); +#line 801 + +#line 801 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 801 + RGN_WRITE, &xp); +#line 801 + if(lstatus != NC_NOERR) +#line 801 + return lstatus; +#line 801 + +#line 801 + lstatus = ncx_putn_double_uchar(&xp, nput, value ,fillp); +#line 801 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 801 + { +#line 801 + /* not fatal to the loop */ +#line 801 + status = lstatus; +#line 801 + } +#line 801 + +#line 801 + (void) ncio_rel(ncp->nciop, offset, +#line 801 + RGN_MODIFIED); +#line 801 + +#line 801 + remaining -= extent; +#line 801 + if(remaining == 0) +#line 801 + break; /* normal loop exit */ +#line 801 + offset += (off_t)extent; +#line 801 + value += nput; +#line 801 + +#line 801 + } +#line 801 +#ifdef ERANGE_FILL +#line 801 + free(fillp); +#line 801 +#endif +#line 801 + +#line 801 + return status; +#line 801 +} +#line 801 + +static int +#line 802 +putNCvx_double_short(NC3_INFO* ncp, const NC_var *varp, +#line 802 + const size_t *start, size_t nelems, const short *value) +#line 802 +{ +#line 802 + off_t offset = NC_varoffset(ncp, varp, start); +#line 802 + size_t remaining = varp->xsz * nelems; +#line 802 + int status = NC_NOERR; +#line 802 + void *xp; +#line 802 + void *fillp=NULL; +#line 802 + +#line 802 + if(nelems == 0) +#line 802 + return NC_NOERR; +#line 802 + +#line 802 + assert(value != NULL); +#line 802 + +#line 802 +#ifdef ERANGE_FILL +#line 802 + fillp = malloc(varp->xsz); +#line 802 + status = NC3_inq_var_fill(varp, fillp); +#line 802 +#endif +#line 802 + +#line 802 + for(;;) +#line 802 + { +#line 802 + size_t extent = MIN(remaining, ncp->chunk); +#line 802 + size_t nput = ncx_howmany(varp->type, extent); +#line 802 + +#line 802 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 802 + RGN_WRITE, &xp); +#line 802 + if(lstatus != NC_NOERR) +#line 802 + return lstatus; +#line 802 + +#line 802 + lstatus = ncx_putn_double_short(&xp, nput, value ,fillp); +#line 802 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 802 + { +#line 802 + /* not fatal to the loop */ +#line 802 + status = lstatus; +#line 802 + } +#line 802 + +#line 802 + (void) ncio_rel(ncp->nciop, offset, +#line 802 + RGN_MODIFIED); +#line 802 + +#line 802 + remaining -= extent; +#line 802 + if(remaining == 0) +#line 802 + break; /* normal loop exit */ +#line 802 + offset += (off_t)extent; +#line 802 + value += nput; +#line 802 + +#line 802 + } +#line 802 +#ifdef ERANGE_FILL +#line 802 + free(fillp); +#line 802 +#endif +#line 802 + +#line 802 + return status; +#line 802 +} +#line 802 + +static int +#line 803 +putNCvx_double_int(NC3_INFO* ncp, const NC_var *varp, +#line 803 + const size_t *start, size_t nelems, const int *value) +#line 803 +{ +#line 803 + off_t offset = NC_varoffset(ncp, varp, start); +#line 803 + size_t remaining = varp->xsz * nelems; +#line 803 + int status = NC_NOERR; +#line 803 + void *xp; +#line 803 + void *fillp=NULL; +#line 803 + +#line 803 + if(nelems == 0) +#line 803 + return NC_NOERR; +#line 803 + +#line 803 + assert(value != NULL); +#line 803 + +#line 803 +#ifdef ERANGE_FILL +#line 803 + fillp = malloc(varp->xsz); +#line 803 + status = NC3_inq_var_fill(varp, fillp); +#line 803 +#endif +#line 803 + +#line 803 + for(;;) +#line 803 + { +#line 803 + size_t extent = MIN(remaining, ncp->chunk); +#line 803 + size_t nput = ncx_howmany(varp->type, extent); +#line 803 + +#line 803 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 803 + RGN_WRITE, &xp); +#line 803 + if(lstatus != NC_NOERR) +#line 803 + return lstatus; +#line 803 + +#line 803 + lstatus = ncx_putn_double_int(&xp, nput, value ,fillp); +#line 803 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 803 + { +#line 803 + /* not fatal to the loop */ +#line 803 + status = lstatus; +#line 803 + } +#line 803 + +#line 803 + (void) ncio_rel(ncp->nciop, offset, +#line 803 + RGN_MODIFIED); +#line 803 + +#line 803 + remaining -= extent; +#line 803 + if(remaining == 0) +#line 803 + break; /* normal loop exit */ +#line 803 + offset += (off_t)extent; +#line 803 + value += nput; +#line 803 + +#line 803 + } +#line 803 +#ifdef ERANGE_FILL +#line 803 + free(fillp); +#line 803 +#endif +#line 803 + +#line 803 + return status; +#line 803 +} +#line 803 + +static int +#line 804 +putNCvx_double_float(NC3_INFO* ncp, const NC_var *varp, +#line 804 + const size_t *start, size_t nelems, const float *value) +#line 804 +{ +#line 804 + off_t offset = NC_varoffset(ncp, varp, start); +#line 804 + size_t remaining = varp->xsz * nelems; +#line 804 + int status = NC_NOERR; +#line 804 + void *xp; +#line 804 + void *fillp=NULL; +#line 804 + +#line 804 + if(nelems == 0) +#line 804 + return NC_NOERR; +#line 804 + +#line 804 + assert(value != NULL); +#line 804 + +#line 804 +#ifdef ERANGE_FILL +#line 804 + fillp = malloc(varp->xsz); +#line 804 + status = NC3_inq_var_fill(varp, fillp); +#line 804 +#endif +#line 804 + +#line 804 + for(;;) +#line 804 + { +#line 804 + size_t extent = MIN(remaining, ncp->chunk); +#line 804 + size_t nput = ncx_howmany(varp->type, extent); +#line 804 + +#line 804 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 804 + RGN_WRITE, &xp); +#line 804 + if(lstatus != NC_NOERR) +#line 804 + return lstatus; +#line 804 + +#line 804 + lstatus = ncx_putn_double_float(&xp, nput, value ,fillp); +#line 804 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 804 + { +#line 804 + /* not fatal to the loop */ +#line 804 + status = lstatus; +#line 804 + } +#line 804 + +#line 804 + (void) ncio_rel(ncp->nciop, offset, +#line 804 + RGN_MODIFIED); +#line 804 + +#line 804 + remaining -= extent; +#line 804 + if(remaining == 0) +#line 804 + break; /* normal loop exit */ +#line 804 + offset += (off_t)extent; +#line 804 + value += nput; +#line 804 + +#line 804 + } +#line 804 +#ifdef ERANGE_FILL +#line 804 + free(fillp); +#line 804 +#endif +#line 804 + +#line 804 + return status; +#line 804 +} +#line 804 + +static int +#line 805 +putNCvx_double_double(NC3_INFO* ncp, const NC_var *varp, +#line 805 + const size_t *start, size_t nelems, const double *value) +#line 805 +{ +#line 805 + off_t offset = NC_varoffset(ncp, varp, start); +#line 805 + size_t remaining = varp->xsz * nelems; +#line 805 + int status = NC_NOERR; +#line 805 + void *xp; +#line 805 + void *fillp=NULL; +#line 805 + +#line 805 + if(nelems == 0) +#line 805 + return NC_NOERR; +#line 805 + +#line 805 + assert(value != NULL); +#line 805 + +#line 805 +#ifdef ERANGE_FILL +#line 805 + fillp = malloc(varp->xsz); +#line 805 + status = NC3_inq_var_fill(varp, fillp); +#line 805 +#endif +#line 805 + +#line 805 + for(;;) +#line 805 + { +#line 805 + size_t extent = MIN(remaining, ncp->chunk); +#line 805 + size_t nput = ncx_howmany(varp->type, extent); +#line 805 + +#line 805 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 805 + RGN_WRITE, &xp); +#line 805 + if(lstatus != NC_NOERR) +#line 805 + return lstatus; +#line 805 + +#line 805 + lstatus = ncx_putn_double_double(&xp, nput, value ,fillp); +#line 805 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 805 + { +#line 805 + /* not fatal to the loop */ +#line 805 + status = lstatus; +#line 805 + } +#line 805 + +#line 805 + (void) ncio_rel(ncp->nciop, offset, +#line 805 + RGN_MODIFIED); +#line 805 + +#line 805 + remaining -= extent; +#line 805 + if(remaining == 0) +#line 805 + break; /* normal loop exit */ +#line 805 + offset += (off_t)extent; +#line 805 + value += nput; +#line 805 + +#line 805 + } +#line 805 +#ifdef ERANGE_FILL +#line 805 + free(fillp); +#line 805 +#endif +#line 805 + +#line 805 + return status; +#line 805 +} +#line 805 + +static int +#line 806 +putNCvx_double_longlong(NC3_INFO* ncp, const NC_var *varp, +#line 806 + const size_t *start, size_t nelems, const longlong *value) +#line 806 +{ +#line 806 + off_t offset = NC_varoffset(ncp, varp, start); +#line 806 + size_t remaining = varp->xsz * nelems; +#line 806 + int status = NC_NOERR; +#line 806 + void *xp; +#line 806 + void *fillp=NULL; +#line 806 + +#line 806 + if(nelems == 0) +#line 806 + return NC_NOERR; +#line 806 + +#line 806 + assert(value != NULL); +#line 806 + +#line 806 +#ifdef ERANGE_FILL +#line 806 + fillp = malloc(varp->xsz); +#line 806 + status = NC3_inq_var_fill(varp, fillp); +#line 806 +#endif +#line 806 + +#line 806 + for(;;) +#line 806 + { +#line 806 + size_t extent = MIN(remaining, ncp->chunk); +#line 806 + size_t nput = ncx_howmany(varp->type, extent); +#line 806 + +#line 806 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 806 + RGN_WRITE, &xp); +#line 806 + if(lstatus != NC_NOERR) +#line 806 + return lstatus; +#line 806 + +#line 806 + lstatus = ncx_putn_double_longlong(&xp, nput, value ,fillp); +#line 806 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 806 + { +#line 806 + /* not fatal to the loop */ +#line 806 + status = lstatus; +#line 806 + } +#line 806 + +#line 806 + (void) ncio_rel(ncp->nciop, offset, +#line 806 + RGN_MODIFIED); +#line 806 + +#line 806 + remaining -= extent; +#line 806 + if(remaining == 0) +#line 806 + break; /* normal loop exit */ +#line 806 + offset += (off_t)extent; +#line 806 + value += nput; +#line 806 + +#line 806 + } +#line 806 +#ifdef ERANGE_FILL +#line 806 + free(fillp); +#line 806 +#endif +#line 806 + +#line 806 + return status; +#line 806 +} +#line 806 + +static int +#line 807 +putNCvx_double_ushort(NC3_INFO* ncp, const NC_var *varp, +#line 807 + const size_t *start, size_t nelems, const ushort *value) +#line 807 +{ +#line 807 + off_t offset = NC_varoffset(ncp, varp, start); +#line 807 + size_t remaining = varp->xsz * nelems; +#line 807 + int status = NC_NOERR; +#line 807 + void *xp; +#line 807 + void *fillp=NULL; +#line 807 + +#line 807 + if(nelems == 0) +#line 807 + return NC_NOERR; +#line 807 + +#line 807 + assert(value != NULL); +#line 807 + +#line 807 +#ifdef ERANGE_FILL +#line 807 + fillp = malloc(varp->xsz); +#line 807 + status = NC3_inq_var_fill(varp, fillp); +#line 807 +#endif +#line 807 + +#line 807 + for(;;) +#line 807 + { +#line 807 + size_t extent = MIN(remaining, ncp->chunk); +#line 807 + size_t nput = ncx_howmany(varp->type, extent); +#line 807 + +#line 807 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 807 + RGN_WRITE, &xp); +#line 807 + if(lstatus != NC_NOERR) +#line 807 + return lstatus; +#line 807 + +#line 807 + lstatus = ncx_putn_double_ushort(&xp, nput, value ,fillp); +#line 807 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 807 + { +#line 807 + /* not fatal to the loop */ +#line 807 + status = lstatus; +#line 807 + } +#line 807 + +#line 807 + (void) ncio_rel(ncp->nciop, offset, +#line 807 + RGN_MODIFIED); +#line 807 + +#line 807 + remaining -= extent; +#line 807 + if(remaining == 0) +#line 807 + break; /* normal loop exit */ +#line 807 + offset += (off_t)extent; +#line 807 + value += nput; +#line 807 + +#line 807 + } +#line 807 +#ifdef ERANGE_FILL +#line 807 + free(fillp); +#line 807 +#endif +#line 807 + +#line 807 + return status; +#line 807 +} +#line 807 + +static int +#line 808 +putNCvx_double_uint(NC3_INFO* ncp, const NC_var *varp, +#line 808 + const size_t *start, size_t nelems, const uint *value) +#line 808 +{ +#line 808 + off_t offset = NC_varoffset(ncp, varp, start); +#line 808 + size_t remaining = varp->xsz * nelems; +#line 808 + int status = NC_NOERR; +#line 808 + void *xp; +#line 808 + void *fillp=NULL; +#line 808 + +#line 808 + if(nelems == 0) +#line 808 + return NC_NOERR; +#line 808 + +#line 808 + assert(value != NULL); +#line 808 + +#line 808 +#ifdef ERANGE_FILL +#line 808 + fillp = malloc(varp->xsz); +#line 808 + status = NC3_inq_var_fill(varp, fillp); +#line 808 +#endif +#line 808 + +#line 808 + for(;;) +#line 808 + { +#line 808 + size_t extent = MIN(remaining, ncp->chunk); +#line 808 + size_t nput = ncx_howmany(varp->type, extent); +#line 808 + +#line 808 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 808 + RGN_WRITE, &xp); +#line 808 + if(lstatus != NC_NOERR) +#line 808 + return lstatus; +#line 808 + +#line 808 + lstatus = ncx_putn_double_uint(&xp, nput, value ,fillp); +#line 808 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 808 + { +#line 808 + /* not fatal to the loop */ +#line 808 + status = lstatus; +#line 808 + } +#line 808 + +#line 808 + (void) ncio_rel(ncp->nciop, offset, +#line 808 + RGN_MODIFIED); +#line 808 + +#line 808 + remaining -= extent; +#line 808 + if(remaining == 0) +#line 808 + break; /* normal loop exit */ +#line 808 + offset += (off_t)extent; +#line 808 + value += nput; +#line 808 + +#line 808 + } +#line 808 +#ifdef ERANGE_FILL +#line 808 + free(fillp); +#line 808 +#endif +#line 808 + +#line 808 + return status; +#line 808 +} +#line 808 + +static int +#line 809 +putNCvx_double_ulonglong(NC3_INFO* ncp, const NC_var *varp, +#line 809 + const size_t *start, size_t nelems, const ulonglong *value) +#line 809 +{ +#line 809 + off_t offset = NC_varoffset(ncp, varp, start); +#line 809 + size_t remaining = varp->xsz * nelems; +#line 809 + int status = NC_NOERR; +#line 809 + void *xp; +#line 809 + void *fillp=NULL; +#line 809 + +#line 809 + if(nelems == 0) +#line 809 + return NC_NOERR; +#line 809 + +#line 809 + assert(value != NULL); +#line 809 + +#line 809 +#ifdef ERANGE_FILL +#line 809 + fillp = malloc(varp->xsz); +#line 809 + status = NC3_inq_var_fill(varp, fillp); +#line 809 +#endif +#line 809 + +#line 809 + for(;;) +#line 809 + { +#line 809 + size_t extent = MIN(remaining, ncp->chunk); +#line 809 + size_t nput = ncx_howmany(varp->type, extent); +#line 809 + +#line 809 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 809 + RGN_WRITE, &xp); +#line 809 + if(lstatus != NC_NOERR) +#line 809 + return lstatus; +#line 809 + +#line 809 + lstatus = ncx_putn_double_ulonglong(&xp, nput, value ,fillp); +#line 809 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 809 + { +#line 809 + /* not fatal to the loop */ +#line 809 + status = lstatus; +#line 809 + } +#line 809 + +#line 809 + (void) ncio_rel(ncp->nciop, offset, +#line 809 + RGN_MODIFIED); +#line 809 + +#line 809 + remaining -= extent; +#line 809 + if(remaining == 0) +#line 809 + break; /* normal loop exit */ +#line 809 + offset += (off_t)extent; +#line 809 + value += nput; +#line 809 + +#line 809 + } +#line 809 +#ifdef ERANGE_FILL +#line 809 + free(fillp); +#line 809 +#endif +#line 809 + +#line 809 + return status; +#line 809 +} +#line 809 + + +static int +#line 811 +putNCvx_uchar_schar(NC3_INFO* ncp, const NC_var *varp, +#line 811 + const size_t *start, size_t nelems, const schar *value) +#line 811 +{ +#line 811 + off_t offset = NC_varoffset(ncp, varp, start); +#line 811 + size_t remaining = varp->xsz * nelems; +#line 811 + int status = NC_NOERR; +#line 811 + void *xp; +#line 811 + void *fillp=NULL; +#line 811 + +#line 811 + if(nelems == 0) +#line 811 + return NC_NOERR; +#line 811 + +#line 811 + assert(value != NULL); +#line 811 + +#line 811 +#ifdef ERANGE_FILL +#line 811 + fillp = malloc(varp->xsz); +#line 811 + status = NC3_inq_var_fill(varp, fillp); +#line 811 +#endif +#line 811 + +#line 811 + for(;;) +#line 811 + { +#line 811 + size_t extent = MIN(remaining, ncp->chunk); +#line 811 + size_t nput = ncx_howmany(varp->type, extent); +#line 811 + +#line 811 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 811 + RGN_WRITE, &xp); +#line 811 + if(lstatus != NC_NOERR) +#line 811 + return lstatus; +#line 811 + +#line 811 + lstatus = ncx_putn_uchar_schar(&xp, nput, value ,fillp); +#line 811 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 811 + { +#line 811 + /* not fatal to the loop */ +#line 811 + status = lstatus; +#line 811 + } +#line 811 + +#line 811 + (void) ncio_rel(ncp->nciop, offset, +#line 811 + RGN_MODIFIED); +#line 811 + +#line 811 + remaining -= extent; +#line 811 + if(remaining == 0) +#line 811 + break; /* normal loop exit */ +#line 811 + offset += (off_t)extent; +#line 811 + value += nput; +#line 811 + +#line 811 + } +#line 811 +#ifdef ERANGE_FILL +#line 811 + free(fillp); +#line 811 +#endif +#line 811 + +#line 811 + return status; +#line 811 +} +#line 811 + +static int +#line 812 +putNCvx_uchar_uchar(NC3_INFO* ncp, const NC_var *varp, +#line 812 + const size_t *start, size_t nelems, const uchar *value) +#line 812 +{ +#line 812 + off_t offset = NC_varoffset(ncp, varp, start); +#line 812 + size_t remaining = varp->xsz * nelems; +#line 812 + int status = NC_NOERR; +#line 812 + void *xp; +#line 812 + void *fillp=NULL; +#line 812 + +#line 812 + if(nelems == 0) +#line 812 + return NC_NOERR; +#line 812 + +#line 812 + assert(value != NULL); +#line 812 + +#line 812 +#ifdef ERANGE_FILL +#line 812 + fillp = malloc(varp->xsz); +#line 812 + status = NC3_inq_var_fill(varp, fillp); +#line 812 +#endif +#line 812 + +#line 812 + for(;;) +#line 812 + { +#line 812 + size_t extent = MIN(remaining, ncp->chunk); +#line 812 + size_t nput = ncx_howmany(varp->type, extent); +#line 812 + +#line 812 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 812 + RGN_WRITE, &xp); +#line 812 + if(lstatus != NC_NOERR) +#line 812 + return lstatus; +#line 812 + +#line 812 + lstatus = ncx_putn_uchar_uchar(&xp, nput, value ,fillp); +#line 812 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 812 + { +#line 812 + /* not fatal to the loop */ +#line 812 + status = lstatus; +#line 812 + } +#line 812 + +#line 812 + (void) ncio_rel(ncp->nciop, offset, +#line 812 + RGN_MODIFIED); +#line 812 + +#line 812 + remaining -= extent; +#line 812 + if(remaining == 0) +#line 812 + break; /* normal loop exit */ +#line 812 + offset += (off_t)extent; +#line 812 + value += nput; +#line 812 + +#line 812 + } +#line 812 +#ifdef ERANGE_FILL +#line 812 + free(fillp); +#line 812 +#endif +#line 812 + +#line 812 + return status; +#line 812 +} +#line 812 + +static int +#line 813 +putNCvx_uchar_short(NC3_INFO* ncp, const NC_var *varp, +#line 813 + const size_t *start, size_t nelems, const short *value) +#line 813 +{ +#line 813 + off_t offset = NC_varoffset(ncp, varp, start); +#line 813 + size_t remaining = varp->xsz * nelems; +#line 813 + int status = NC_NOERR; +#line 813 + void *xp; +#line 813 + void *fillp=NULL; +#line 813 + +#line 813 + if(nelems == 0) +#line 813 + return NC_NOERR; +#line 813 + +#line 813 + assert(value != NULL); +#line 813 + +#line 813 +#ifdef ERANGE_FILL +#line 813 + fillp = malloc(varp->xsz); +#line 813 + status = NC3_inq_var_fill(varp, fillp); +#line 813 +#endif +#line 813 + +#line 813 + for(;;) +#line 813 + { +#line 813 + size_t extent = MIN(remaining, ncp->chunk); +#line 813 + size_t nput = ncx_howmany(varp->type, extent); +#line 813 + +#line 813 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 813 + RGN_WRITE, &xp); +#line 813 + if(lstatus != NC_NOERR) +#line 813 + return lstatus; +#line 813 + +#line 813 + lstatus = ncx_putn_uchar_short(&xp, nput, value ,fillp); +#line 813 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 813 + { +#line 813 + /* not fatal to the loop */ +#line 813 + status = lstatus; +#line 813 + } +#line 813 + +#line 813 + (void) ncio_rel(ncp->nciop, offset, +#line 813 + RGN_MODIFIED); +#line 813 + +#line 813 + remaining -= extent; +#line 813 + if(remaining == 0) +#line 813 + break; /* normal loop exit */ +#line 813 + offset += (off_t)extent; +#line 813 + value += nput; +#line 813 + +#line 813 + } +#line 813 +#ifdef ERANGE_FILL +#line 813 + free(fillp); +#line 813 +#endif +#line 813 + +#line 813 + return status; +#line 813 +} +#line 813 + +static int +#line 814 +putNCvx_uchar_int(NC3_INFO* ncp, const NC_var *varp, +#line 814 + const size_t *start, size_t nelems, const int *value) +#line 814 +{ +#line 814 + off_t offset = NC_varoffset(ncp, varp, start); +#line 814 + size_t remaining = varp->xsz * nelems; +#line 814 + int status = NC_NOERR; +#line 814 + void *xp; +#line 814 + void *fillp=NULL; +#line 814 + +#line 814 + if(nelems == 0) +#line 814 + return NC_NOERR; +#line 814 + +#line 814 + assert(value != NULL); +#line 814 + +#line 814 +#ifdef ERANGE_FILL +#line 814 + fillp = malloc(varp->xsz); +#line 814 + status = NC3_inq_var_fill(varp, fillp); +#line 814 +#endif +#line 814 + +#line 814 + for(;;) +#line 814 + { +#line 814 + size_t extent = MIN(remaining, ncp->chunk); +#line 814 + size_t nput = ncx_howmany(varp->type, extent); +#line 814 + +#line 814 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 814 + RGN_WRITE, &xp); +#line 814 + if(lstatus != NC_NOERR) +#line 814 + return lstatus; +#line 814 + +#line 814 + lstatus = ncx_putn_uchar_int(&xp, nput, value ,fillp); +#line 814 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 814 + { +#line 814 + /* not fatal to the loop */ +#line 814 + status = lstatus; +#line 814 + } +#line 814 + +#line 814 + (void) ncio_rel(ncp->nciop, offset, +#line 814 + RGN_MODIFIED); +#line 814 + +#line 814 + remaining -= extent; +#line 814 + if(remaining == 0) +#line 814 + break; /* normal loop exit */ +#line 814 + offset += (off_t)extent; +#line 814 + value += nput; +#line 814 + +#line 814 + } +#line 814 +#ifdef ERANGE_FILL +#line 814 + free(fillp); +#line 814 +#endif +#line 814 + +#line 814 + return status; +#line 814 +} +#line 814 + +static int +#line 815 +putNCvx_uchar_float(NC3_INFO* ncp, const NC_var *varp, +#line 815 + const size_t *start, size_t nelems, const float *value) +#line 815 +{ +#line 815 + off_t offset = NC_varoffset(ncp, varp, start); +#line 815 + size_t remaining = varp->xsz * nelems; +#line 815 + int status = NC_NOERR; +#line 815 + void *xp; +#line 815 + void *fillp=NULL; +#line 815 + +#line 815 + if(nelems == 0) +#line 815 + return NC_NOERR; +#line 815 + +#line 815 + assert(value != NULL); +#line 815 + +#line 815 +#ifdef ERANGE_FILL +#line 815 + fillp = malloc(varp->xsz); +#line 815 + status = NC3_inq_var_fill(varp, fillp); +#line 815 +#endif +#line 815 + +#line 815 + for(;;) +#line 815 + { +#line 815 + size_t extent = MIN(remaining, ncp->chunk); +#line 815 + size_t nput = ncx_howmany(varp->type, extent); +#line 815 + +#line 815 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 815 + RGN_WRITE, &xp); +#line 815 + if(lstatus != NC_NOERR) +#line 815 + return lstatus; +#line 815 + +#line 815 + lstatus = ncx_putn_uchar_float(&xp, nput, value ,fillp); +#line 815 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 815 + { +#line 815 + /* not fatal to the loop */ +#line 815 + status = lstatus; +#line 815 + } +#line 815 + +#line 815 + (void) ncio_rel(ncp->nciop, offset, +#line 815 + RGN_MODIFIED); +#line 815 + +#line 815 + remaining -= extent; +#line 815 + if(remaining == 0) +#line 815 + break; /* normal loop exit */ +#line 815 + offset += (off_t)extent; +#line 815 + value += nput; +#line 815 + +#line 815 + } +#line 815 +#ifdef ERANGE_FILL +#line 815 + free(fillp); +#line 815 +#endif +#line 815 + +#line 815 + return status; +#line 815 +} +#line 815 + +static int +#line 816 +putNCvx_uchar_double(NC3_INFO* ncp, const NC_var *varp, +#line 816 + const size_t *start, size_t nelems, const double *value) +#line 816 +{ +#line 816 + off_t offset = NC_varoffset(ncp, varp, start); +#line 816 + size_t remaining = varp->xsz * nelems; +#line 816 + int status = NC_NOERR; +#line 816 + void *xp; +#line 816 + void *fillp=NULL; +#line 816 + +#line 816 + if(nelems == 0) +#line 816 + return NC_NOERR; +#line 816 + +#line 816 + assert(value != NULL); +#line 816 + +#line 816 +#ifdef ERANGE_FILL +#line 816 + fillp = malloc(varp->xsz); +#line 816 + status = NC3_inq_var_fill(varp, fillp); +#line 816 +#endif +#line 816 + +#line 816 + for(;;) +#line 816 + { +#line 816 + size_t extent = MIN(remaining, ncp->chunk); +#line 816 + size_t nput = ncx_howmany(varp->type, extent); +#line 816 + +#line 816 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 816 + RGN_WRITE, &xp); +#line 816 + if(lstatus != NC_NOERR) +#line 816 + return lstatus; +#line 816 + +#line 816 + lstatus = ncx_putn_uchar_double(&xp, nput, value ,fillp); +#line 816 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 816 + { +#line 816 + /* not fatal to the loop */ +#line 816 + status = lstatus; +#line 816 + } +#line 816 + +#line 816 + (void) ncio_rel(ncp->nciop, offset, +#line 816 + RGN_MODIFIED); +#line 816 + +#line 816 + remaining -= extent; +#line 816 + if(remaining == 0) +#line 816 + break; /* normal loop exit */ +#line 816 + offset += (off_t)extent; +#line 816 + value += nput; +#line 816 + +#line 816 + } +#line 816 +#ifdef ERANGE_FILL +#line 816 + free(fillp); +#line 816 +#endif +#line 816 + +#line 816 + return status; +#line 816 +} +#line 816 + +static int +#line 817 +putNCvx_uchar_longlong(NC3_INFO* ncp, const NC_var *varp, +#line 817 + const size_t *start, size_t nelems, const longlong *value) +#line 817 +{ +#line 817 + off_t offset = NC_varoffset(ncp, varp, start); +#line 817 + size_t remaining = varp->xsz * nelems; +#line 817 + int status = NC_NOERR; +#line 817 + void *xp; +#line 817 + void *fillp=NULL; +#line 817 + +#line 817 + if(nelems == 0) +#line 817 + return NC_NOERR; +#line 817 + +#line 817 + assert(value != NULL); +#line 817 + +#line 817 +#ifdef ERANGE_FILL +#line 817 + fillp = malloc(varp->xsz); +#line 817 + status = NC3_inq_var_fill(varp, fillp); +#line 817 +#endif +#line 817 + +#line 817 + for(;;) +#line 817 + { +#line 817 + size_t extent = MIN(remaining, ncp->chunk); +#line 817 + size_t nput = ncx_howmany(varp->type, extent); +#line 817 + +#line 817 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 817 + RGN_WRITE, &xp); +#line 817 + if(lstatus != NC_NOERR) +#line 817 + return lstatus; +#line 817 + +#line 817 + lstatus = ncx_putn_uchar_longlong(&xp, nput, value ,fillp); +#line 817 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 817 + { +#line 817 + /* not fatal to the loop */ +#line 817 + status = lstatus; +#line 817 + } +#line 817 + +#line 817 + (void) ncio_rel(ncp->nciop, offset, +#line 817 + RGN_MODIFIED); +#line 817 + +#line 817 + remaining -= extent; +#line 817 + if(remaining == 0) +#line 817 + break; /* normal loop exit */ +#line 817 + offset += (off_t)extent; +#line 817 + value += nput; +#line 817 + +#line 817 + } +#line 817 +#ifdef ERANGE_FILL +#line 817 + free(fillp); +#line 817 +#endif +#line 817 + +#line 817 + return status; +#line 817 +} +#line 817 + +static int +#line 818 +putNCvx_uchar_ushort(NC3_INFO* ncp, const NC_var *varp, +#line 818 + const size_t *start, size_t nelems, const ushort *value) +#line 818 +{ +#line 818 + off_t offset = NC_varoffset(ncp, varp, start); +#line 818 + size_t remaining = varp->xsz * nelems; +#line 818 + int status = NC_NOERR; +#line 818 + void *xp; +#line 818 + void *fillp=NULL; +#line 818 + +#line 818 + if(nelems == 0) +#line 818 + return NC_NOERR; +#line 818 + +#line 818 + assert(value != NULL); +#line 818 + +#line 818 +#ifdef ERANGE_FILL +#line 818 + fillp = malloc(varp->xsz); +#line 818 + status = NC3_inq_var_fill(varp, fillp); +#line 818 +#endif +#line 818 + +#line 818 + for(;;) +#line 818 + { +#line 818 + size_t extent = MIN(remaining, ncp->chunk); +#line 818 + size_t nput = ncx_howmany(varp->type, extent); +#line 818 + +#line 818 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 818 + RGN_WRITE, &xp); +#line 818 + if(lstatus != NC_NOERR) +#line 818 + return lstatus; +#line 818 + +#line 818 + lstatus = ncx_putn_uchar_ushort(&xp, nput, value ,fillp); +#line 818 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 818 + { +#line 818 + /* not fatal to the loop */ +#line 818 + status = lstatus; +#line 818 + } +#line 818 + +#line 818 + (void) ncio_rel(ncp->nciop, offset, +#line 818 + RGN_MODIFIED); +#line 818 + +#line 818 + remaining -= extent; +#line 818 + if(remaining == 0) +#line 818 + break; /* normal loop exit */ +#line 818 + offset += (off_t)extent; +#line 818 + value += nput; +#line 818 + +#line 818 + } +#line 818 +#ifdef ERANGE_FILL +#line 818 + free(fillp); +#line 818 +#endif +#line 818 + +#line 818 + return status; +#line 818 +} +#line 818 + +static int +#line 819 +putNCvx_uchar_uint(NC3_INFO* ncp, const NC_var *varp, +#line 819 + const size_t *start, size_t nelems, const uint *value) +#line 819 +{ +#line 819 + off_t offset = NC_varoffset(ncp, varp, start); +#line 819 + size_t remaining = varp->xsz * nelems; +#line 819 + int status = NC_NOERR; +#line 819 + void *xp; +#line 819 + void *fillp=NULL; +#line 819 + +#line 819 + if(nelems == 0) +#line 819 + return NC_NOERR; +#line 819 + +#line 819 + assert(value != NULL); +#line 819 + +#line 819 +#ifdef ERANGE_FILL +#line 819 + fillp = malloc(varp->xsz); +#line 819 + status = NC3_inq_var_fill(varp, fillp); +#line 819 +#endif +#line 819 + +#line 819 + for(;;) +#line 819 + { +#line 819 + size_t extent = MIN(remaining, ncp->chunk); +#line 819 + size_t nput = ncx_howmany(varp->type, extent); +#line 819 + +#line 819 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 819 + RGN_WRITE, &xp); +#line 819 + if(lstatus != NC_NOERR) +#line 819 + return lstatus; +#line 819 + +#line 819 + lstatus = ncx_putn_uchar_uint(&xp, nput, value ,fillp); +#line 819 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 819 + { +#line 819 + /* not fatal to the loop */ +#line 819 + status = lstatus; +#line 819 + } +#line 819 + +#line 819 + (void) ncio_rel(ncp->nciop, offset, +#line 819 + RGN_MODIFIED); +#line 819 + +#line 819 + remaining -= extent; +#line 819 + if(remaining == 0) +#line 819 + break; /* normal loop exit */ +#line 819 + offset += (off_t)extent; +#line 819 + value += nput; +#line 819 + +#line 819 + } +#line 819 +#ifdef ERANGE_FILL +#line 819 + free(fillp); +#line 819 +#endif +#line 819 + +#line 819 + return status; +#line 819 +} +#line 819 + +static int +#line 820 +putNCvx_uchar_ulonglong(NC3_INFO* ncp, const NC_var *varp, +#line 820 + const size_t *start, size_t nelems, const ulonglong *value) +#line 820 +{ +#line 820 + off_t offset = NC_varoffset(ncp, varp, start); +#line 820 + size_t remaining = varp->xsz * nelems; +#line 820 + int status = NC_NOERR; +#line 820 + void *xp; +#line 820 + void *fillp=NULL; +#line 820 + +#line 820 + if(nelems == 0) +#line 820 + return NC_NOERR; +#line 820 + +#line 820 + assert(value != NULL); +#line 820 + +#line 820 +#ifdef ERANGE_FILL +#line 820 + fillp = malloc(varp->xsz); +#line 820 + status = NC3_inq_var_fill(varp, fillp); +#line 820 +#endif +#line 820 + +#line 820 + for(;;) +#line 820 + { +#line 820 + size_t extent = MIN(remaining, ncp->chunk); +#line 820 + size_t nput = ncx_howmany(varp->type, extent); +#line 820 + +#line 820 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 820 + RGN_WRITE, &xp); +#line 820 + if(lstatus != NC_NOERR) +#line 820 + return lstatus; +#line 820 + +#line 820 + lstatus = ncx_putn_uchar_ulonglong(&xp, nput, value ,fillp); +#line 820 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 820 + { +#line 820 + /* not fatal to the loop */ +#line 820 + status = lstatus; +#line 820 + } +#line 820 + +#line 820 + (void) ncio_rel(ncp->nciop, offset, +#line 820 + RGN_MODIFIED); +#line 820 + +#line 820 + remaining -= extent; +#line 820 + if(remaining == 0) +#line 820 + break; /* normal loop exit */ +#line 820 + offset += (off_t)extent; +#line 820 + value += nput; +#line 820 + +#line 820 + } +#line 820 +#ifdef ERANGE_FILL +#line 820 + free(fillp); +#line 820 +#endif +#line 820 + +#line 820 + return status; +#line 820 +} +#line 820 + + +static int +#line 822 +putNCvx_ushort_schar(NC3_INFO* ncp, const NC_var *varp, +#line 822 + const size_t *start, size_t nelems, const schar *value) +#line 822 +{ +#line 822 + off_t offset = NC_varoffset(ncp, varp, start); +#line 822 + size_t remaining = varp->xsz * nelems; +#line 822 + int status = NC_NOERR; +#line 822 + void *xp; +#line 822 + void *fillp=NULL; +#line 822 + +#line 822 + if(nelems == 0) +#line 822 + return NC_NOERR; +#line 822 + +#line 822 + assert(value != NULL); +#line 822 + +#line 822 +#ifdef ERANGE_FILL +#line 822 + fillp = malloc(varp->xsz); +#line 822 + status = NC3_inq_var_fill(varp, fillp); +#line 822 +#endif +#line 822 + +#line 822 + for(;;) +#line 822 + { +#line 822 + size_t extent = MIN(remaining, ncp->chunk); +#line 822 + size_t nput = ncx_howmany(varp->type, extent); +#line 822 + +#line 822 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 822 + RGN_WRITE, &xp); +#line 822 + if(lstatus != NC_NOERR) +#line 822 + return lstatus; +#line 822 + +#line 822 + lstatus = ncx_putn_ushort_schar(&xp, nput, value ,fillp); +#line 822 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 822 + { +#line 822 + /* not fatal to the loop */ +#line 822 + status = lstatus; +#line 822 + } +#line 822 + +#line 822 + (void) ncio_rel(ncp->nciop, offset, +#line 822 + RGN_MODIFIED); +#line 822 + +#line 822 + remaining -= extent; +#line 822 + if(remaining == 0) +#line 822 + break; /* normal loop exit */ +#line 822 + offset += (off_t)extent; +#line 822 + value += nput; +#line 822 + +#line 822 + } +#line 822 +#ifdef ERANGE_FILL +#line 822 + free(fillp); +#line 822 +#endif +#line 822 + +#line 822 + return status; +#line 822 +} +#line 822 + +static int +#line 823 +putNCvx_ushort_uchar(NC3_INFO* ncp, const NC_var *varp, +#line 823 + const size_t *start, size_t nelems, const uchar *value) +#line 823 +{ +#line 823 + off_t offset = NC_varoffset(ncp, varp, start); +#line 823 + size_t remaining = varp->xsz * nelems; +#line 823 + int status = NC_NOERR; +#line 823 + void *xp; +#line 823 + void *fillp=NULL; +#line 823 + +#line 823 + if(nelems == 0) +#line 823 + return NC_NOERR; +#line 823 + +#line 823 + assert(value != NULL); +#line 823 + +#line 823 +#ifdef ERANGE_FILL +#line 823 + fillp = malloc(varp->xsz); +#line 823 + status = NC3_inq_var_fill(varp, fillp); +#line 823 +#endif +#line 823 + +#line 823 + for(;;) +#line 823 + { +#line 823 + size_t extent = MIN(remaining, ncp->chunk); +#line 823 + size_t nput = ncx_howmany(varp->type, extent); +#line 823 + +#line 823 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 823 + RGN_WRITE, &xp); +#line 823 + if(lstatus != NC_NOERR) +#line 823 + return lstatus; +#line 823 + +#line 823 + lstatus = ncx_putn_ushort_uchar(&xp, nput, value ,fillp); +#line 823 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 823 + { +#line 823 + /* not fatal to the loop */ +#line 823 + status = lstatus; +#line 823 + } +#line 823 + +#line 823 + (void) ncio_rel(ncp->nciop, offset, +#line 823 + RGN_MODIFIED); +#line 823 + +#line 823 + remaining -= extent; +#line 823 + if(remaining == 0) +#line 823 + break; /* normal loop exit */ +#line 823 + offset += (off_t)extent; +#line 823 + value += nput; +#line 823 + +#line 823 + } +#line 823 +#ifdef ERANGE_FILL +#line 823 + free(fillp); +#line 823 +#endif +#line 823 + +#line 823 + return status; +#line 823 +} +#line 823 + +static int +#line 824 +putNCvx_ushort_short(NC3_INFO* ncp, const NC_var *varp, +#line 824 + const size_t *start, size_t nelems, const short *value) +#line 824 +{ +#line 824 + off_t offset = NC_varoffset(ncp, varp, start); +#line 824 + size_t remaining = varp->xsz * nelems; +#line 824 + int status = NC_NOERR; +#line 824 + void *xp; +#line 824 + void *fillp=NULL; +#line 824 + +#line 824 + if(nelems == 0) +#line 824 + return NC_NOERR; +#line 824 + +#line 824 + assert(value != NULL); +#line 824 + +#line 824 +#ifdef ERANGE_FILL +#line 824 + fillp = malloc(varp->xsz); +#line 824 + status = NC3_inq_var_fill(varp, fillp); +#line 824 +#endif +#line 824 + +#line 824 + for(;;) +#line 824 + { +#line 824 + size_t extent = MIN(remaining, ncp->chunk); +#line 824 + size_t nput = ncx_howmany(varp->type, extent); +#line 824 + +#line 824 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 824 + RGN_WRITE, &xp); +#line 824 + if(lstatus != NC_NOERR) +#line 824 + return lstatus; +#line 824 + +#line 824 + lstatus = ncx_putn_ushort_short(&xp, nput, value ,fillp); +#line 824 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 824 + { +#line 824 + /* not fatal to the loop */ +#line 824 + status = lstatus; +#line 824 + } +#line 824 + +#line 824 + (void) ncio_rel(ncp->nciop, offset, +#line 824 + RGN_MODIFIED); +#line 824 + +#line 824 + remaining -= extent; +#line 824 + if(remaining == 0) +#line 824 + break; /* normal loop exit */ +#line 824 + offset += (off_t)extent; +#line 824 + value += nput; +#line 824 + +#line 824 + } +#line 824 +#ifdef ERANGE_FILL +#line 824 + free(fillp); +#line 824 +#endif +#line 824 + +#line 824 + return status; +#line 824 +} +#line 824 + +static int +#line 825 +putNCvx_ushort_int(NC3_INFO* ncp, const NC_var *varp, +#line 825 + const size_t *start, size_t nelems, const int *value) +#line 825 +{ +#line 825 + off_t offset = NC_varoffset(ncp, varp, start); +#line 825 + size_t remaining = varp->xsz * nelems; +#line 825 + int status = NC_NOERR; +#line 825 + void *xp; +#line 825 + void *fillp=NULL; +#line 825 + +#line 825 + if(nelems == 0) +#line 825 + return NC_NOERR; +#line 825 + +#line 825 + assert(value != NULL); +#line 825 + +#line 825 +#ifdef ERANGE_FILL +#line 825 + fillp = malloc(varp->xsz); +#line 825 + status = NC3_inq_var_fill(varp, fillp); +#line 825 +#endif +#line 825 + +#line 825 + for(;;) +#line 825 + { +#line 825 + size_t extent = MIN(remaining, ncp->chunk); +#line 825 + size_t nput = ncx_howmany(varp->type, extent); +#line 825 + +#line 825 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 825 + RGN_WRITE, &xp); +#line 825 + if(lstatus != NC_NOERR) +#line 825 + return lstatus; +#line 825 + +#line 825 + lstatus = ncx_putn_ushort_int(&xp, nput, value ,fillp); +#line 825 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 825 + { +#line 825 + /* not fatal to the loop */ +#line 825 + status = lstatus; +#line 825 + } +#line 825 + +#line 825 + (void) ncio_rel(ncp->nciop, offset, +#line 825 + RGN_MODIFIED); +#line 825 + +#line 825 + remaining -= extent; +#line 825 + if(remaining == 0) +#line 825 + break; /* normal loop exit */ +#line 825 + offset += (off_t)extent; +#line 825 + value += nput; +#line 825 + +#line 825 + } +#line 825 +#ifdef ERANGE_FILL +#line 825 + free(fillp); +#line 825 +#endif +#line 825 + +#line 825 + return status; +#line 825 +} +#line 825 + +static int +#line 826 +putNCvx_ushort_float(NC3_INFO* ncp, const NC_var *varp, +#line 826 + const size_t *start, size_t nelems, const float *value) +#line 826 +{ +#line 826 + off_t offset = NC_varoffset(ncp, varp, start); +#line 826 + size_t remaining = varp->xsz * nelems; +#line 826 + int status = NC_NOERR; +#line 826 + void *xp; +#line 826 + void *fillp=NULL; +#line 826 + +#line 826 + if(nelems == 0) +#line 826 + return NC_NOERR; +#line 826 + +#line 826 + assert(value != NULL); +#line 826 + +#line 826 +#ifdef ERANGE_FILL +#line 826 + fillp = malloc(varp->xsz); +#line 826 + status = NC3_inq_var_fill(varp, fillp); +#line 826 +#endif +#line 826 + +#line 826 + for(;;) +#line 826 + { +#line 826 + size_t extent = MIN(remaining, ncp->chunk); +#line 826 + size_t nput = ncx_howmany(varp->type, extent); +#line 826 + +#line 826 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 826 + RGN_WRITE, &xp); +#line 826 + if(lstatus != NC_NOERR) +#line 826 + return lstatus; +#line 826 + +#line 826 + lstatus = ncx_putn_ushort_float(&xp, nput, value ,fillp); +#line 826 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 826 + { +#line 826 + /* not fatal to the loop */ +#line 826 + status = lstatus; +#line 826 + } +#line 826 + +#line 826 + (void) ncio_rel(ncp->nciop, offset, +#line 826 + RGN_MODIFIED); +#line 826 + +#line 826 + remaining -= extent; +#line 826 + if(remaining == 0) +#line 826 + break; /* normal loop exit */ +#line 826 + offset += (off_t)extent; +#line 826 + value += nput; +#line 826 + +#line 826 + } +#line 826 +#ifdef ERANGE_FILL +#line 826 + free(fillp); +#line 826 +#endif +#line 826 + +#line 826 + return status; +#line 826 +} +#line 826 + +static int +#line 827 +putNCvx_ushort_double(NC3_INFO* ncp, const NC_var *varp, +#line 827 + const size_t *start, size_t nelems, const double *value) +#line 827 +{ +#line 827 + off_t offset = NC_varoffset(ncp, varp, start); +#line 827 + size_t remaining = varp->xsz * nelems; +#line 827 + int status = NC_NOERR; +#line 827 + void *xp; +#line 827 + void *fillp=NULL; +#line 827 + +#line 827 + if(nelems == 0) +#line 827 + return NC_NOERR; +#line 827 + +#line 827 + assert(value != NULL); +#line 827 + +#line 827 +#ifdef ERANGE_FILL +#line 827 + fillp = malloc(varp->xsz); +#line 827 + status = NC3_inq_var_fill(varp, fillp); +#line 827 +#endif +#line 827 + +#line 827 + for(;;) +#line 827 + { +#line 827 + size_t extent = MIN(remaining, ncp->chunk); +#line 827 + size_t nput = ncx_howmany(varp->type, extent); +#line 827 + +#line 827 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 827 + RGN_WRITE, &xp); +#line 827 + if(lstatus != NC_NOERR) +#line 827 + return lstatus; +#line 827 + +#line 827 + lstatus = ncx_putn_ushort_double(&xp, nput, value ,fillp); +#line 827 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 827 + { +#line 827 + /* not fatal to the loop */ +#line 827 + status = lstatus; +#line 827 + } +#line 827 + +#line 827 + (void) ncio_rel(ncp->nciop, offset, +#line 827 + RGN_MODIFIED); +#line 827 + +#line 827 + remaining -= extent; +#line 827 + if(remaining == 0) +#line 827 + break; /* normal loop exit */ +#line 827 + offset += (off_t)extent; +#line 827 + value += nput; +#line 827 + +#line 827 + } +#line 827 +#ifdef ERANGE_FILL +#line 827 + free(fillp); +#line 827 +#endif +#line 827 + +#line 827 + return status; +#line 827 +} +#line 827 + +static int +#line 828 +putNCvx_ushort_longlong(NC3_INFO* ncp, const NC_var *varp, +#line 828 + const size_t *start, size_t nelems, const longlong *value) +#line 828 +{ +#line 828 + off_t offset = NC_varoffset(ncp, varp, start); +#line 828 + size_t remaining = varp->xsz * nelems; +#line 828 + int status = NC_NOERR; +#line 828 + void *xp; +#line 828 + void *fillp=NULL; +#line 828 + +#line 828 + if(nelems == 0) +#line 828 + return NC_NOERR; +#line 828 + +#line 828 + assert(value != NULL); +#line 828 + +#line 828 +#ifdef ERANGE_FILL +#line 828 + fillp = malloc(varp->xsz); +#line 828 + status = NC3_inq_var_fill(varp, fillp); +#line 828 +#endif +#line 828 + +#line 828 + for(;;) +#line 828 + { +#line 828 + size_t extent = MIN(remaining, ncp->chunk); +#line 828 + size_t nput = ncx_howmany(varp->type, extent); +#line 828 + +#line 828 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 828 + RGN_WRITE, &xp); +#line 828 + if(lstatus != NC_NOERR) +#line 828 + return lstatus; +#line 828 + +#line 828 + lstatus = ncx_putn_ushort_longlong(&xp, nput, value ,fillp); +#line 828 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 828 + { +#line 828 + /* not fatal to the loop */ +#line 828 + status = lstatus; +#line 828 + } +#line 828 + +#line 828 + (void) ncio_rel(ncp->nciop, offset, +#line 828 + RGN_MODIFIED); +#line 828 + +#line 828 + remaining -= extent; +#line 828 + if(remaining == 0) +#line 828 + break; /* normal loop exit */ +#line 828 + offset += (off_t)extent; +#line 828 + value += nput; +#line 828 + +#line 828 + } +#line 828 +#ifdef ERANGE_FILL +#line 828 + free(fillp); +#line 828 +#endif +#line 828 + +#line 828 + return status; +#line 828 +} +#line 828 + +static int +#line 829 +putNCvx_ushort_ushort(NC3_INFO* ncp, const NC_var *varp, +#line 829 + const size_t *start, size_t nelems, const ushort *value) +#line 829 +{ +#line 829 + off_t offset = NC_varoffset(ncp, varp, start); +#line 829 + size_t remaining = varp->xsz * nelems; +#line 829 + int status = NC_NOERR; +#line 829 + void *xp; +#line 829 + void *fillp=NULL; +#line 829 + +#line 829 + if(nelems == 0) +#line 829 + return NC_NOERR; +#line 829 + +#line 829 + assert(value != NULL); +#line 829 + +#line 829 +#ifdef ERANGE_FILL +#line 829 + fillp = malloc(varp->xsz); +#line 829 + status = NC3_inq_var_fill(varp, fillp); +#line 829 +#endif +#line 829 + +#line 829 + for(;;) +#line 829 + { +#line 829 + size_t extent = MIN(remaining, ncp->chunk); +#line 829 + size_t nput = ncx_howmany(varp->type, extent); +#line 829 + +#line 829 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 829 + RGN_WRITE, &xp); +#line 829 + if(lstatus != NC_NOERR) +#line 829 + return lstatus; +#line 829 + +#line 829 + lstatus = ncx_putn_ushort_ushort(&xp, nput, value ,fillp); +#line 829 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 829 + { +#line 829 + /* not fatal to the loop */ +#line 829 + status = lstatus; +#line 829 + } +#line 829 + +#line 829 + (void) ncio_rel(ncp->nciop, offset, +#line 829 + RGN_MODIFIED); +#line 829 + +#line 829 + remaining -= extent; +#line 829 + if(remaining == 0) +#line 829 + break; /* normal loop exit */ +#line 829 + offset += (off_t)extent; +#line 829 + value += nput; +#line 829 + +#line 829 + } +#line 829 +#ifdef ERANGE_FILL +#line 829 + free(fillp); +#line 829 +#endif +#line 829 + +#line 829 + return status; +#line 829 +} +#line 829 + +static int +#line 830 +putNCvx_ushort_uint(NC3_INFO* ncp, const NC_var *varp, +#line 830 + const size_t *start, size_t nelems, const uint *value) +#line 830 +{ +#line 830 + off_t offset = NC_varoffset(ncp, varp, start); +#line 830 + size_t remaining = varp->xsz * nelems; +#line 830 + int status = NC_NOERR; +#line 830 + void *xp; +#line 830 + void *fillp=NULL; +#line 830 + +#line 830 + if(nelems == 0) +#line 830 + return NC_NOERR; +#line 830 + +#line 830 + assert(value != NULL); +#line 830 + +#line 830 +#ifdef ERANGE_FILL +#line 830 + fillp = malloc(varp->xsz); +#line 830 + status = NC3_inq_var_fill(varp, fillp); +#line 830 +#endif +#line 830 + +#line 830 + for(;;) +#line 830 + { +#line 830 + size_t extent = MIN(remaining, ncp->chunk); +#line 830 + size_t nput = ncx_howmany(varp->type, extent); +#line 830 + +#line 830 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 830 + RGN_WRITE, &xp); +#line 830 + if(lstatus != NC_NOERR) +#line 830 + return lstatus; +#line 830 + +#line 830 + lstatus = ncx_putn_ushort_uint(&xp, nput, value ,fillp); +#line 830 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 830 + { +#line 830 + /* not fatal to the loop */ +#line 830 + status = lstatus; +#line 830 + } +#line 830 + +#line 830 + (void) ncio_rel(ncp->nciop, offset, +#line 830 + RGN_MODIFIED); +#line 830 + +#line 830 + remaining -= extent; +#line 830 + if(remaining == 0) +#line 830 + break; /* normal loop exit */ +#line 830 + offset += (off_t)extent; +#line 830 + value += nput; +#line 830 + +#line 830 + } +#line 830 +#ifdef ERANGE_FILL +#line 830 + free(fillp); +#line 830 +#endif +#line 830 + +#line 830 + return status; +#line 830 +} +#line 830 + +static int +#line 831 +putNCvx_ushort_ulonglong(NC3_INFO* ncp, const NC_var *varp, +#line 831 + const size_t *start, size_t nelems, const ulonglong *value) +#line 831 +{ +#line 831 + off_t offset = NC_varoffset(ncp, varp, start); +#line 831 + size_t remaining = varp->xsz * nelems; +#line 831 + int status = NC_NOERR; +#line 831 + void *xp; +#line 831 + void *fillp=NULL; +#line 831 + +#line 831 + if(nelems == 0) +#line 831 + return NC_NOERR; +#line 831 + +#line 831 + assert(value != NULL); +#line 831 + +#line 831 +#ifdef ERANGE_FILL +#line 831 + fillp = malloc(varp->xsz); +#line 831 + status = NC3_inq_var_fill(varp, fillp); +#line 831 +#endif +#line 831 + +#line 831 + for(;;) +#line 831 + { +#line 831 + size_t extent = MIN(remaining, ncp->chunk); +#line 831 + size_t nput = ncx_howmany(varp->type, extent); +#line 831 + +#line 831 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 831 + RGN_WRITE, &xp); +#line 831 + if(lstatus != NC_NOERR) +#line 831 + return lstatus; +#line 831 + +#line 831 + lstatus = ncx_putn_ushort_ulonglong(&xp, nput, value ,fillp); +#line 831 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 831 + { +#line 831 + /* not fatal to the loop */ +#line 831 + status = lstatus; +#line 831 + } +#line 831 + +#line 831 + (void) ncio_rel(ncp->nciop, offset, +#line 831 + RGN_MODIFIED); +#line 831 + +#line 831 + remaining -= extent; +#line 831 + if(remaining == 0) +#line 831 + break; /* normal loop exit */ +#line 831 + offset += (off_t)extent; +#line 831 + value += nput; +#line 831 + +#line 831 + } +#line 831 +#ifdef ERANGE_FILL +#line 831 + free(fillp); +#line 831 +#endif +#line 831 + +#line 831 + return status; +#line 831 +} +#line 831 + + +static int +#line 833 +putNCvx_uint_schar(NC3_INFO* ncp, const NC_var *varp, +#line 833 + const size_t *start, size_t nelems, const schar *value) +#line 833 +{ +#line 833 + off_t offset = NC_varoffset(ncp, varp, start); +#line 833 + size_t remaining = varp->xsz * nelems; +#line 833 + int status = NC_NOERR; +#line 833 + void *xp; +#line 833 + void *fillp=NULL; +#line 833 + +#line 833 + if(nelems == 0) +#line 833 + return NC_NOERR; +#line 833 + +#line 833 + assert(value != NULL); +#line 833 + +#line 833 +#ifdef ERANGE_FILL +#line 833 + fillp = malloc(varp->xsz); +#line 833 + status = NC3_inq_var_fill(varp, fillp); +#line 833 +#endif +#line 833 + +#line 833 + for(;;) +#line 833 + { +#line 833 + size_t extent = MIN(remaining, ncp->chunk); +#line 833 + size_t nput = ncx_howmany(varp->type, extent); +#line 833 + +#line 833 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 833 + RGN_WRITE, &xp); +#line 833 + if(lstatus != NC_NOERR) +#line 833 + return lstatus; +#line 833 + +#line 833 + lstatus = ncx_putn_uint_schar(&xp, nput, value ,fillp); +#line 833 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 833 + { +#line 833 + /* not fatal to the loop */ +#line 833 + status = lstatus; +#line 833 + } +#line 833 + +#line 833 + (void) ncio_rel(ncp->nciop, offset, +#line 833 + RGN_MODIFIED); +#line 833 + +#line 833 + remaining -= extent; +#line 833 + if(remaining == 0) +#line 833 + break; /* normal loop exit */ +#line 833 + offset += (off_t)extent; +#line 833 + value += nput; +#line 833 + +#line 833 + } +#line 833 +#ifdef ERANGE_FILL +#line 833 + free(fillp); +#line 833 +#endif +#line 833 + +#line 833 + return status; +#line 833 +} +#line 833 + +static int +#line 834 +putNCvx_uint_uchar(NC3_INFO* ncp, const NC_var *varp, +#line 834 + const size_t *start, size_t nelems, const uchar *value) +#line 834 +{ +#line 834 + off_t offset = NC_varoffset(ncp, varp, start); +#line 834 + size_t remaining = varp->xsz * nelems; +#line 834 + int status = NC_NOERR; +#line 834 + void *xp; +#line 834 + void *fillp=NULL; +#line 834 + +#line 834 + if(nelems == 0) +#line 834 + return NC_NOERR; +#line 834 + +#line 834 + assert(value != NULL); +#line 834 + +#line 834 +#ifdef ERANGE_FILL +#line 834 + fillp = malloc(varp->xsz); +#line 834 + status = NC3_inq_var_fill(varp, fillp); +#line 834 +#endif +#line 834 + +#line 834 + for(;;) +#line 834 + { +#line 834 + size_t extent = MIN(remaining, ncp->chunk); +#line 834 + size_t nput = ncx_howmany(varp->type, extent); +#line 834 + +#line 834 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 834 + RGN_WRITE, &xp); +#line 834 + if(lstatus != NC_NOERR) +#line 834 + return lstatus; +#line 834 + +#line 834 + lstatus = ncx_putn_uint_uchar(&xp, nput, value ,fillp); +#line 834 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 834 + { +#line 834 + /* not fatal to the loop */ +#line 834 + status = lstatus; +#line 834 + } +#line 834 + +#line 834 + (void) ncio_rel(ncp->nciop, offset, +#line 834 + RGN_MODIFIED); +#line 834 + +#line 834 + remaining -= extent; +#line 834 + if(remaining == 0) +#line 834 + break; /* normal loop exit */ +#line 834 + offset += (off_t)extent; +#line 834 + value += nput; +#line 834 + +#line 834 + } +#line 834 +#ifdef ERANGE_FILL +#line 834 + free(fillp); +#line 834 +#endif +#line 834 + +#line 834 + return status; +#line 834 +} +#line 834 + +static int +#line 835 +putNCvx_uint_short(NC3_INFO* ncp, const NC_var *varp, +#line 835 + const size_t *start, size_t nelems, const short *value) +#line 835 +{ +#line 835 + off_t offset = NC_varoffset(ncp, varp, start); +#line 835 + size_t remaining = varp->xsz * nelems; +#line 835 + int status = NC_NOERR; +#line 835 + void *xp; +#line 835 + void *fillp=NULL; +#line 835 + +#line 835 + if(nelems == 0) +#line 835 + return NC_NOERR; +#line 835 + +#line 835 + assert(value != NULL); +#line 835 + +#line 835 +#ifdef ERANGE_FILL +#line 835 + fillp = malloc(varp->xsz); +#line 835 + status = NC3_inq_var_fill(varp, fillp); +#line 835 +#endif +#line 835 + +#line 835 + for(;;) +#line 835 + { +#line 835 + size_t extent = MIN(remaining, ncp->chunk); +#line 835 + size_t nput = ncx_howmany(varp->type, extent); +#line 835 + +#line 835 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 835 + RGN_WRITE, &xp); +#line 835 + if(lstatus != NC_NOERR) +#line 835 + return lstatus; +#line 835 + +#line 835 + lstatus = ncx_putn_uint_short(&xp, nput, value ,fillp); +#line 835 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 835 + { +#line 835 + /* not fatal to the loop */ +#line 835 + status = lstatus; +#line 835 + } +#line 835 + +#line 835 + (void) ncio_rel(ncp->nciop, offset, +#line 835 + RGN_MODIFIED); +#line 835 + +#line 835 + remaining -= extent; +#line 835 + if(remaining == 0) +#line 835 + break; /* normal loop exit */ +#line 835 + offset += (off_t)extent; +#line 835 + value += nput; +#line 835 + +#line 835 + } +#line 835 +#ifdef ERANGE_FILL +#line 835 + free(fillp); +#line 835 +#endif +#line 835 + +#line 835 + return status; +#line 835 +} +#line 835 + +static int +#line 836 +putNCvx_uint_int(NC3_INFO* ncp, const NC_var *varp, +#line 836 + const size_t *start, size_t nelems, const int *value) +#line 836 +{ +#line 836 + off_t offset = NC_varoffset(ncp, varp, start); +#line 836 + size_t remaining = varp->xsz * nelems; +#line 836 + int status = NC_NOERR; +#line 836 + void *xp; +#line 836 + void *fillp=NULL; +#line 836 + +#line 836 + if(nelems == 0) +#line 836 + return NC_NOERR; +#line 836 + +#line 836 + assert(value != NULL); +#line 836 + +#line 836 +#ifdef ERANGE_FILL +#line 836 + fillp = malloc(varp->xsz); +#line 836 + status = NC3_inq_var_fill(varp, fillp); +#line 836 +#endif +#line 836 + +#line 836 + for(;;) +#line 836 + { +#line 836 + size_t extent = MIN(remaining, ncp->chunk); +#line 836 + size_t nput = ncx_howmany(varp->type, extent); +#line 836 + +#line 836 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 836 + RGN_WRITE, &xp); +#line 836 + if(lstatus != NC_NOERR) +#line 836 + return lstatus; +#line 836 + +#line 836 + lstatus = ncx_putn_uint_int(&xp, nput, value ,fillp); +#line 836 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 836 + { +#line 836 + /* not fatal to the loop */ +#line 836 + status = lstatus; +#line 836 + } +#line 836 + +#line 836 + (void) ncio_rel(ncp->nciop, offset, +#line 836 + RGN_MODIFIED); +#line 836 + +#line 836 + remaining -= extent; +#line 836 + if(remaining == 0) +#line 836 + break; /* normal loop exit */ +#line 836 + offset += (off_t)extent; +#line 836 + value += nput; +#line 836 + +#line 836 + } +#line 836 +#ifdef ERANGE_FILL +#line 836 + free(fillp); +#line 836 +#endif +#line 836 + +#line 836 + return status; +#line 836 +} +#line 836 + +static int +#line 837 +putNCvx_uint_float(NC3_INFO* ncp, const NC_var *varp, +#line 837 + const size_t *start, size_t nelems, const float *value) +#line 837 +{ +#line 837 + off_t offset = NC_varoffset(ncp, varp, start); +#line 837 + size_t remaining = varp->xsz * nelems; +#line 837 + int status = NC_NOERR; +#line 837 + void *xp; +#line 837 + void *fillp=NULL; +#line 837 + +#line 837 + if(nelems == 0) +#line 837 + return NC_NOERR; +#line 837 + +#line 837 + assert(value != NULL); +#line 837 + +#line 837 +#ifdef ERANGE_FILL +#line 837 + fillp = malloc(varp->xsz); +#line 837 + status = NC3_inq_var_fill(varp, fillp); +#line 837 +#endif +#line 837 + +#line 837 + for(;;) +#line 837 + { +#line 837 + size_t extent = MIN(remaining, ncp->chunk); +#line 837 + size_t nput = ncx_howmany(varp->type, extent); +#line 837 + +#line 837 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 837 + RGN_WRITE, &xp); +#line 837 + if(lstatus != NC_NOERR) +#line 837 + return lstatus; +#line 837 + +#line 837 + lstatus = ncx_putn_uint_float(&xp, nput, value ,fillp); +#line 837 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 837 + { +#line 837 + /* not fatal to the loop */ +#line 837 + status = lstatus; +#line 837 + } +#line 837 + +#line 837 + (void) ncio_rel(ncp->nciop, offset, +#line 837 + RGN_MODIFIED); +#line 837 + +#line 837 + remaining -= extent; +#line 837 + if(remaining == 0) +#line 837 + break; /* normal loop exit */ +#line 837 + offset += (off_t)extent; +#line 837 + value += nput; +#line 837 + +#line 837 + } +#line 837 +#ifdef ERANGE_FILL +#line 837 + free(fillp); +#line 837 +#endif +#line 837 + +#line 837 + return status; +#line 837 +} +#line 837 + +static int +#line 838 +putNCvx_uint_double(NC3_INFO* ncp, const NC_var *varp, +#line 838 + const size_t *start, size_t nelems, const double *value) +#line 838 +{ +#line 838 + off_t offset = NC_varoffset(ncp, varp, start); +#line 838 + size_t remaining = varp->xsz * nelems; +#line 838 + int status = NC_NOERR; +#line 838 + void *xp; +#line 838 + void *fillp=NULL; +#line 838 + +#line 838 + if(nelems == 0) +#line 838 + return NC_NOERR; +#line 838 + +#line 838 + assert(value != NULL); +#line 838 + +#line 838 +#ifdef ERANGE_FILL +#line 838 + fillp = malloc(varp->xsz); +#line 838 + status = NC3_inq_var_fill(varp, fillp); +#line 838 +#endif +#line 838 + +#line 838 + for(;;) +#line 838 + { +#line 838 + size_t extent = MIN(remaining, ncp->chunk); +#line 838 + size_t nput = ncx_howmany(varp->type, extent); +#line 838 + +#line 838 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 838 + RGN_WRITE, &xp); +#line 838 + if(lstatus != NC_NOERR) +#line 838 + return lstatus; +#line 838 + +#line 838 + lstatus = ncx_putn_uint_double(&xp, nput, value ,fillp); +#line 838 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 838 + { +#line 838 + /* not fatal to the loop */ +#line 838 + status = lstatus; +#line 838 + } +#line 838 + +#line 838 + (void) ncio_rel(ncp->nciop, offset, +#line 838 + RGN_MODIFIED); +#line 838 + +#line 838 + remaining -= extent; +#line 838 + if(remaining == 0) +#line 838 + break; /* normal loop exit */ +#line 838 + offset += (off_t)extent; +#line 838 + value += nput; +#line 838 + +#line 838 + } +#line 838 +#ifdef ERANGE_FILL +#line 838 + free(fillp); +#line 838 +#endif +#line 838 + +#line 838 + return status; +#line 838 +} +#line 838 + +static int +#line 839 +putNCvx_uint_longlong(NC3_INFO* ncp, const NC_var *varp, +#line 839 + const size_t *start, size_t nelems, const longlong *value) +#line 839 +{ +#line 839 + off_t offset = NC_varoffset(ncp, varp, start); +#line 839 + size_t remaining = varp->xsz * nelems; +#line 839 + int status = NC_NOERR; +#line 839 + void *xp; +#line 839 + void *fillp=NULL; +#line 839 + +#line 839 + if(nelems == 0) +#line 839 + return NC_NOERR; +#line 839 + +#line 839 + assert(value != NULL); +#line 839 + +#line 839 +#ifdef ERANGE_FILL +#line 839 + fillp = malloc(varp->xsz); +#line 839 + status = NC3_inq_var_fill(varp, fillp); +#line 839 +#endif +#line 839 + +#line 839 + for(;;) +#line 839 + { +#line 839 + size_t extent = MIN(remaining, ncp->chunk); +#line 839 + size_t nput = ncx_howmany(varp->type, extent); +#line 839 + +#line 839 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 839 + RGN_WRITE, &xp); +#line 839 + if(lstatus != NC_NOERR) +#line 839 + return lstatus; +#line 839 + +#line 839 + lstatus = ncx_putn_uint_longlong(&xp, nput, value ,fillp); +#line 839 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 839 + { +#line 839 + /* not fatal to the loop */ +#line 839 + status = lstatus; +#line 839 + } +#line 839 + +#line 839 + (void) ncio_rel(ncp->nciop, offset, +#line 839 + RGN_MODIFIED); +#line 839 + +#line 839 + remaining -= extent; +#line 839 + if(remaining == 0) +#line 839 + break; /* normal loop exit */ +#line 839 + offset += (off_t)extent; +#line 839 + value += nput; +#line 839 + +#line 839 + } +#line 839 +#ifdef ERANGE_FILL +#line 839 + free(fillp); +#line 839 +#endif +#line 839 + +#line 839 + return status; +#line 839 +} +#line 839 + +static int +#line 840 +putNCvx_uint_ushort(NC3_INFO* ncp, const NC_var *varp, +#line 840 + const size_t *start, size_t nelems, const ushort *value) +#line 840 +{ +#line 840 + off_t offset = NC_varoffset(ncp, varp, start); +#line 840 + size_t remaining = varp->xsz * nelems; +#line 840 + int status = NC_NOERR; +#line 840 + void *xp; +#line 840 + void *fillp=NULL; +#line 840 + +#line 840 + if(nelems == 0) +#line 840 + return NC_NOERR; +#line 840 + +#line 840 + assert(value != NULL); +#line 840 + +#line 840 +#ifdef ERANGE_FILL +#line 840 + fillp = malloc(varp->xsz); +#line 840 + status = NC3_inq_var_fill(varp, fillp); +#line 840 +#endif +#line 840 + +#line 840 + for(;;) +#line 840 + { +#line 840 + size_t extent = MIN(remaining, ncp->chunk); +#line 840 + size_t nput = ncx_howmany(varp->type, extent); +#line 840 + +#line 840 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 840 + RGN_WRITE, &xp); +#line 840 + if(lstatus != NC_NOERR) +#line 840 + return lstatus; +#line 840 + +#line 840 + lstatus = ncx_putn_uint_ushort(&xp, nput, value ,fillp); +#line 840 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 840 + { +#line 840 + /* not fatal to the loop */ +#line 840 + status = lstatus; +#line 840 + } +#line 840 + +#line 840 + (void) ncio_rel(ncp->nciop, offset, +#line 840 + RGN_MODIFIED); +#line 840 + +#line 840 + remaining -= extent; +#line 840 + if(remaining == 0) +#line 840 + break; /* normal loop exit */ +#line 840 + offset += (off_t)extent; +#line 840 + value += nput; +#line 840 + +#line 840 + } +#line 840 +#ifdef ERANGE_FILL +#line 840 + free(fillp); +#line 840 +#endif +#line 840 + +#line 840 + return status; +#line 840 +} +#line 840 + +static int +#line 841 +putNCvx_uint_uint(NC3_INFO* ncp, const NC_var *varp, +#line 841 + const size_t *start, size_t nelems, const uint *value) +#line 841 +{ +#line 841 + off_t offset = NC_varoffset(ncp, varp, start); +#line 841 + size_t remaining = varp->xsz * nelems; +#line 841 + int status = NC_NOERR; +#line 841 + void *xp; +#line 841 + void *fillp=NULL; +#line 841 + +#line 841 + if(nelems == 0) +#line 841 + return NC_NOERR; +#line 841 + +#line 841 + assert(value != NULL); +#line 841 + +#line 841 +#ifdef ERANGE_FILL +#line 841 + fillp = malloc(varp->xsz); +#line 841 + status = NC3_inq_var_fill(varp, fillp); +#line 841 +#endif +#line 841 + +#line 841 + for(;;) +#line 841 + { +#line 841 + size_t extent = MIN(remaining, ncp->chunk); +#line 841 + size_t nput = ncx_howmany(varp->type, extent); +#line 841 + +#line 841 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 841 + RGN_WRITE, &xp); +#line 841 + if(lstatus != NC_NOERR) +#line 841 + return lstatus; +#line 841 + +#line 841 + lstatus = ncx_putn_uint_uint(&xp, nput, value ,fillp); +#line 841 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 841 + { +#line 841 + /* not fatal to the loop */ +#line 841 + status = lstatus; +#line 841 + } +#line 841 + +#line 841 + (void) ncio_rel(ncp->nciop, offset, +#line 841 + RGN_MODIFIED); +#line 841 + +#line 841 + remaining -= extent; +#line 841 + if(remaining == 0) +#line 841 + break; /* normal loop exit */ +#line 841 + offset += (off_t)extent; +#line 841 + value += nput; +#line 841 + +#line 841 + } +#line 841 +#ifdef ERANGE_FILL +#line 841 + free(fillp); +#line 841 +#endif +#line 841 + +#line 841 + return status; +#line 841 +} +#line 841 + +static int +#line 842 +putNCvx_uint_ulonglong(NC3_INFO* ncp, const NC_var *varp, +#line 842 + const size_t *start, size_t nelems, const ulonglong *value) +#line 842 +{ +#line 842 + off_t offset = NC_varoffset(ncp, varp, start); +#line 842 + size_t remaining = varp->xsz * nelems; +#line 842 + int status = NC_NOERR; +#line 842 + void *xp; +#line 842 + void *fillp=NULL; +#line 842 + +#line 842 + if(nelems == 0) +#line 842 + return NC_NOERR; +#line 842 + +#line 842 + assert(value != NULL); +#line 842 + +#line 842 +#ifdef ERANGE_FILL +#line 842 + fillp = malloc(varp->xsz); +#line 842 + status = NC3_inq_var_fill(varp, fillp); +#line 842 +#endif +#line 842 + +#line 842 + for(;;) +#line 842 + { +#line 842 + size_t extent = MIN(remaining, ncp->chunk); +#line 842 + size_t nput = ncx_howmany(varp->type, extent); +#line 842 + +#line 842 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 842 + RGN_WRITE, &xp); +#line 842 + if(lstatus != NC_NOERR) +#line 842 + return lstatus; +#line 842 + +#line 842 + lstatus = ncx_putn_uint_ulonglong(&xp, nput, value ,fillp); +#line 842 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 842 + { +#line 842 + /* not fatal to the loop */ +#line 842 + status = lstatus; +#line 842 + } +#line 842 + +#line 842 + (void) ncio_rel(ncp->nciop, offset, +#line 842 + RGN_MODIFIED); +#line 842 + +#line 842 + remaining -= extent; +#line 842 + if(remaining == 0) +#line 842 + break; /* normal loop exit */ +#line 842 + offset += (off_t)extent; +#line 842 + value += nput; +#line 842 + +#line 842 + } +#line 842 +#ifdef ERANGE_FILL +#line 842 + free(fillp); +#line 842 +#endif +#line 842 + +#line 842 + return status; +#line 842 +} +#line 842 + + +static int +#line 844 +putNCvx_longlong_schar(NC3_INFO* ncp, const NC_var *varp, +#line 844 + const size_t *start, size_t nelems, const schar *value) +#line 844 +{ +#line 844 + off_t offset = NC_varoffset(ncp, varp, start); +#line 844 + size_t remaining = varp->xsz * nelems; +#line 844 + int status = NC_NOERR; +#line 844 + void *xp; +#line 844 + void *fillp=NULL; +#line 844 + +#line 844 + if(nelems == 0) +#line 844 + return NC_NOERR; +#line 844 + +#line 844 + assert(value != NULL); +#line 844 + +#line 844 +#ifdef ERANGE_FILL +#line 844 + fillp = malloc(varp->xsz); +#line 844 + status = NC3_inq_var_fill(varp, fillp); +#line 844 +#endif +#line 844 + +#line 844 + for(;;) +#line 844 + { +#line 844 + size_t extent = MIN(remaining, ncp->chunk); +#line 844 + size_t nput = ncx_howmany(varp->type, extent); +#line 844 + +#line 844 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 844 + RGN_WRITE, &xp); +#line 844 + if(lstatus != NC_NOERR) +#line 844 + return lstatus; +#line 844 + +#line 844 + lstatus = ncx_putn_longlong_schar(&xp, nput, value ,fillp); +#line 844 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 844 + { +#line 844 + /* not fatal to the loop */ +#line 844 + status = lstatus; +#line 844 + } +#line 844 + +#line 844 + (void) ncio_rel(ncp->nciop, offset, +#line 844 + RGN_MODIFIED); +#line 844 + +#line 844 + remaining -= extent; +#line 844 + if(remaining == 0) +#line 844 + break; /* normal loop exit */ +#line 844 + offset += (off_t)extent; +#line 844 + value += nput; +#line 844 + +#line 844 + } +#line 844 +#ifdef ERANGE_FILL +#line 844 + free(fillp); +#line 844 +#endif +#line 844 + +#line 844 + return status; +#line 844 +} +#line 844 + +static int +#line 845 +putNCvx_longlong_uchar(NC3_INFO* ncp, const NC_var *varp, +#line 845 + const size_t *start, size_t nelems, const uchar *value) +#line 845 +{ +#line 845 + off_t offset = NC_varoffset(ncp, varp, start); +#line 845 + size_t remaining = varp->xsz * nelems; +#line 845 + int status = NC_NOERR; +#line 845 + void *xp; +#line 845 + void *fillp=NULL; +#line 845 + +#line 845 + if(nelems == 0) +#line 845 + return NC_NOERR; +#line 845 + +#line 845 + assert(value != NULL); +#line 845 + +#line 845 +#ifdef ERANGE_FILL +#line 845 + fillp = malloc(varp->xsz); +#line 845 + status = NC3_inq_var_fill(varp, fillp); +#line 845 +#endif +#line 845 + +#line 845 + for(;;) +#line 845 + { +#line 845 + size_t extent = MIN(remaining, ncp->chunk); +#line 845 + size_t nput = ncx_howmany(varp->type, extent); +#line 845 + +#line 845 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 845 + RGN_WRITE, &xp); +#line 845 + if(lstatus != NC_NOERR) +#line 845 + return lstatus; +#line 845 + +#line 845 + lstatus = ncx_putn_longlong_uchar(&xp, nput, value ,fillp); +#line 845 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 845 + { +#line 845 + /* not fatal to the loop */ +#line 845 + status = lstatus; +#line 845 + } +#line 845 + +#line 845 + (void) ncio_rel(ncp->nciop, offset, +#line 845 + RGN_MODIFIED); +#line 845 + +#line 845 + remaining -= extent; +#line 845 + if(remaining == 0) +#line 845 + break; /* normal loop exit */ +#line 845 + offset += (off_t)extent; +#line 845 + value += nput; +#line 845 + +#line 845 + } +#line 845 +#ifdef ERANGE_FILL +#line 845 + free(fillp); +#line 845 +#endif +#line 845 + +#line 845 + return status; +#line 845 +} +#line 845 + +static int +#line 846 +putNCvx_longlong_short(NC3_INFO* ncp, const NC_var *varp, +#line 846 + const size_t *start, size_t nelems, const short *value) +#line 846 +{ +#line 846 + off_t offset = NC_varoffset(ncp, varp, start); +#line 846 + size_t remaining = varp->xsz * nelems; +#line 846 + int status = NC_NOERR; +#line 846 + void *xp; +#line 846 + void *fillp=NULL; +#line 846 + +#line 846 + if(nelems == 0) +#line 846 + return NC_NOERR; +#line 846 + +#line 846 + assert(value != NULL); +#line 846 + +#line 846 +#ifdef ERANGE_FILL +#line 846 + fillp = malloc(varp->xsz); +#line 846 + status = NC3_inq_var_fill(varp, fillp); +#line 846 +#endif +#line 846 + +#line 846 + for(;;) +#line 846 + { +#line 846 + size_t extent = MIN(remaining, ncp->chunk); +#line 846 + size_t nput = ncx_howmany(varp->type, extent); +#line 846 + +#line 846 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 846 + RGN_WRITE, &xp); +#line 846 + if(lstatus != NC_NOERR) +#line 846 + return lstatus; +#line 846 + +#line 846 + lstatus = ncx_putn_longlong_short(&xp, nput, value ,fillp); +#line 846 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 846 + { +#line 846 + /* not fatal to the loop */ +#line 846 + status = lstatus; +#line 846 + } +#line 846 + +#line 846 + (void) ncio_rel(ncp->nciop, offset, +#line 846 + RGN_MODIFIED); +#line 846 + +#line 846 + remaining -= extent; +#line 846 + if(remaining == 0) +#line 846 + break; /* normal loop exit */ +#line 846 + offset += (off_t)extent; +#line 846 + value += nput; +#line 846 + +#line 846 + } +#line 846 +#ifdef ERANGE_FILL +#line 846 + free(fillp); +#line 846 +#endif +#line 846 + +#line 846 + return status; +#line 846 +} +#line 846 + +static int +#line 847 +putNCvx_longlong_int(NC3_INFO* ncp, const NC_var *varp, +#line 847 + const size_t *start, size_t nelems, const int *value) +#line 847 +{ +#line 847 + off_t offset = NC_varoffset(ncp, varp, start); +#line 847 + size_t remaining = varp->xsz * nelems; +#line 847 + int status = NC_NOERR; +#line 847 + void *xp; +#line 847 + void *fillp=NULL; +#line 847 + +#line 847 + if(nelems == 0) +#line 847 + return NC_NOERR; +#line 847 + +#line 847 + assert(value != NULL); +#line 847 + +#line 847 +#ifdef ERANGE_FILL +#line 847 + fillp = malloc(varp->xsz); +#line 847 + status = NC3_inq_var_fill(varp, fillp); +#line 847 +#endif +#line 847 + +#line 847 + for(;;) +#line 847 + { +#line 847 + size_t extent = MIN(remaining, ncp->chunk); +#line 847 + size_t nput = ncx_howmany(varp->type, extent); +#line 847 + +#line 847 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 847 + RGN_WRITE, &xp); +#line 847 + if(lstatus != NC_NOERR) +#line 847 + return lstatus; +#line 847 + +#line 847 + lstatus = ncx_putn_longlong_int(&xp, nput, value ,fillp); +#line 847 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 847 + { +#line 847 + /* not fatal to the loop */ +#line 847 + status = lstatus; +#line 847 + } +#line 847 + +#line 847 + (void) ncio_rel(ncp->nciop, offset, +#line 847 + RGN_MODIFIED); +#line 847 + +#line 847 + remaining -= extent; +#line 847 + if(remaining == 0) +#line 847 + break; /* normal loop exit */ +#line 847 + offset += (off_t)extent; +#line 847 + value += nput; +#line 847 + +#line 847 + } +#line 847 +#ifdef ERANGE_FILL +#line 847 + free(fillp); +#line 847 +#endif +#line 847 + +#line 847 + return status; +#line 847 +} +#line 847 + +static int +#line 848 +putNCvx_longlong_float(NC3_INFO* ncp, const NC_var *varp, +#line 848 + const size_t *start, size_t nelems, const float *value) +#line 848 +{ +#line 848 + off_t offset = NC_varoffset(ncp, varp, start); +#line 848 + size_t remaining = varp->xsz * nelems; +#line 848 + int status = NC_NOERR; +#line 848 + void *xp; +#line 848 + void *fillp=NULL; +#line 848 + +#line 848 + if(nelems == 0) +#line 848 + return NC_NOERR; +#line 848 + +#line 848 + assert(value != NULL); +#line 848 + +#line 848 +#ifdef ERANGE_FILL +#line 848 + fillp = malloc(varp->xsz); +#line 848 + status = NC3_inq_var_fill(varp, fillp); +#line 848 +#endif +#line 848 + +#line 848 + for(;;) +#line 848 + { +#line 848 + size_t extent = MIN(remaining, ncp->chunk); +#line 848 + size_t nput = ncx_howmany(varp->type, extent); +#line 848 + +#line 848 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 848 + RGN_WRITE, &xp); +#line 848 + if(lstatus != NC_NOERR) +#line 848 + return lstatus; +#line 848 + +#line 848 + lstatus = ncx_putn_longlong_float(&xp, nput, value ,fillp); +#line 848 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 848 + { +#line 848 + /* not fatal to the loop */ +#line 848 + status = lstatus; +#line 848 + } +#line 848 + +#line 848 + (void) ncio_rel(ncp->nciop, offset, +#line 848 + RGN_MODIFIED); +#line 848 + +#line 848 + remaining -= extent; +#line 848 + if(remaining == 0) +#line 848 + break; /* normal loop exit */ +#line 848 + offset += (off_t)extent; +#line 848 + value += nput; +#line 848 + +#line 848 + } +#line 848 +#ifdef ERANGE_FILL +#line 848 + free(fillp); +#line 848 +#endif +#line 848 + +#line 848 + return status; +#line 848 +} +#line 848 + +static int +#line 849 +putNCvx_longlong_double(NC3_INFO* ncp, const NC_var *varp, +#line 849 + const size_t *start, size_t nelems, const double *value) +#line 849 +{ +#line 849 + off_t offset = NC_varoffset(ncp, varp, start); +#line 849 + size_t remaining = varp->xsz * nelems; +#line 849 + int status = NC_NOERR; +#line 849 + void *xp; +#line 849 + void *fillp=NULL; +#line 849 + +#line 849 + if(nelems == 0) +#line 849 + return NC_NOERR; +#line 849 + +#line 849 + assert(value != NULL); +#line 849 + +#line 849 +#ifdef ERANGE_FILL +#line 849 + fillp = malloc(varp->xsz); +#line 849 + status = NC3_inq_var_fill(varp, fillp); +#line 849 +#endif +#line 849 + +#line 849 + for(;;) +#line 849 + { +#line 849 + size_t extent = MIN(remaining, ncp->chunk); +#line 849 + size_t nput = ncx_howmany(varp->type, extent); +#line 849 + +#line 849 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 849 + RGN_WRITE, &xp); +#line 849 + if(lstatus != NC_NOERR) +#line 849 + return lstatus; +#line 849 + +#line 849 + lstatus = ncx_putn_longlong_double(&xp, nput, value ,fillp); +#line 849 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 849 + { +#line 849 + /* not fatal to the loop */ +#line 849 + status = lstatus; +#line 849 + } +#line 849 + +#line 849 + (void) ncio_rel(ncp->nciop, offset, +#line 849 + RGN_MODIFIED); +#line 849 + +#line 849 + remaining -= extent; +#line 849 + if(remaining == 0) +#line 849 + break; /* normal loop exit */ +#line 849 + offset += (off_t)extent; +#line 849 + value += nput; +#line 849 + +#line 849 + } +#line 849 +#ifdef ERANGE_FILL +#line 849 + free(fillp); +#line 849 +#endif +#line 849 + +#line 849 + return status; +#line 849 +} +#line 849 + +static int +#line 850 +putNCvx_longlong_longlong(NC3_INFO* ncp, const NC_var *varp, +#line 850 + const size_t *start, size_t nelems, const longlong *value) +#line 850 +{ +#line 850 + off_t offset = NC_varoffset(ncp, varp, start); +#line 850 + size_t remaining = varp->xsz * nelems; +#line 850 + int status = NC_NOERR; +#line 850 + void *xp; +#line 850 + void *fillp=NULL; +#line 850 + +#line 850 + if(nelems == 0) +#line 850 + return NC_NOERR; +#line 850 + +#line 850 + assert(value != NULL); +#line 850 + +#line 850 +#ifdef ERANGE_FILL +#line 850 + fillp = malloc(varp->xsz); +#line 850 + status = NC3_inq_var_fill(varp, fillp); +#line 850 +#endif +#line 850 + +#line 850 + for(;;) +#line 850 + { +#line 850 + size_t extent = MIN(remaining, ncp->chunk); +#line 850 + size_t nput = ncx_howmany(varp->type, extent); +#line 850 + +#line 850 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 850 + RGN_WRITE, &xp); +#line 850 + if(lstatus != NC_NOERR) +#line 850 + return lstatus; +#line 850 + +#line 850 + lstatus = ncx_putn_longlong_longlong(&xp, nput, value ,fillp); +#line 850 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 850 + { +#line 850 + /* not fatal to the loop */ +#line 850 + status = lstatus; +#line 850 + } +#line 850 + +#line 850 + (void) ncio_rel(ncp->nciop, offset, +#line 850 + RGN_MODIFIED); +#line 850 + +#line 850 + remaining -= extent; +#line 850 + if(remaining == 0) +#line 850 + break; /* normal loop exit */ +#line 850 + offset += (off_t)extent; +#line 850 + value += nput; +#line 850 + +#line 850 + } +#line 850 +#ifdef ERANGE_FILL +#line 850 + free(fillp); +#line 850 +#endif +#line 850 + +#line 850 + return status; +#line 850 +} +#line 850 + +static int +#line 851 +putNCvx_longlong_ushort(NC3_INFO* ncp, const NC_var *varp, +#line 851 + const size_t *start, size_t nelems, const ushort *value) +#line 851 +{ +#line 851 + off_t offset = NC_varoffset(ncp, varp, start); +#line 851 + size_t remaining = varp->xsz * nelems; +#line 851 + int status = NC_NOERR; +#line 851 + void *xp; +#line 851 + void *fillp=NULL; +#line 851 + +#line 851 + if(nelems == 0) +#line 851 + return NC_NOERR; +#line 851 + +#line 851 + assert(value != NULL); +#line 851 + +#line 851 +#ifdef ERANGE_FILL +#line 851 + fillp = malloc(varp->xsz); +#line 851 + status = NC3_inq_var_fill(varp, fillp); +#line 851 +#endif +#line 851 + +#line 851 + for(;;) +#line 851 + { +#line 851 + size_t extent = MIN(remaining, ncp->chunk); +#line 851 + size_t nput = ncx_howmany(varp->type, extent); +#line 851 + +#line 851 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 851 + RGN_WRITE, &xp); +#line 851 + if(lstatus != NC_NOERR) +#line 851 + return lstatus; +#line 851 + +#line 851 + lstatus = ncx_putn_longlong_ushort(&xp, nput, value ,fillp); +#line 851 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 851 + { +#line 851 + /* not fatal to the loop */ +#line 851 + status = lstatus; +#line 851 + } +#line 851 + +#line 851 + (void) ncio_rel(ncp->nciop, offset, +#line 851 + RGN_MODIFIED); +#line 851 + +#line 851 + remaining -= extent; +#line 851 + if(remaining == 0) +#line 851 + break; /* normal loop exit */ +#line 851 + offset += (off_t)extent; +#line 851 + value += nput; +#line 851 + +#line 851 + } +#line 851 +#ifdef ERANGE_FILL +#line 851 + free(fillp); +#line 851 +#endif +#line 851 + +#line 851 + return status; +#line 851 +} +#line 851 + +static int +#line 852 +putNCvx_longlong_uint(NC3_INFO* ncp, const NC_var *varp, +#line 852 + const size_t *start, size_t nelems, const uint *value) +#line 852 +{ +#line 852 + off_t offset = NC_varoffset(ncp, varp, start); +#line 852 + size_t remaining = varp->xsz * nelems; +#line 852 + int status = NC_NOERR; +#line 852 + void *xp; +#line 852 + void *fillp=NULL; +#line 852 + +#line 852 + if(nelems == 0) +#line 852 + return NC_NOERR; +#line 852 + +#line 852 + assert(value != NULL); +#line 852 + +#line 852 +#ifdef ERANGE_FILL +#line 852 + fillp = malloc(varp->xsz); +#line 852 + status = NC3_inq_var_fill(varp, fillp); +#line 852 +#endif +#line 852 + +#line 852 + for(;;) +#line 852 + { +#line 852 + size_t extent = MIN(remaining, ncp->chunk); +#line 852 + size_t nput = ncx_howmany(varp->type, extent); +#line 852 + +#line 852 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 852 + RGN_WRITE, &xp); +#line 852 + if(lstatus != NC_NOERR) +#line 852 + return lstatus; +#line 852 + +#line 852 + lstatus = ncx_putn_longlong_uint(&xp, nput, value ,fillp); +#line 852 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 852 + { +#line 852 + /* not fatal to the loop */ +#line 852 + status = lstatus; +#line 852 + } +#line 852 + +#line 852 + (void) ncio_rel(ncp->nciop, offset, +#line 852 + RGN_MODIFIED); +#line 852 + +#line 852 + remaining -= extent; +#line 852 + if(remaining == 0) +#line 852 + break; /* normal loop exit */ +#line 852 + offset += (off_t)extent; +#line 852 + value += nput; +#line 852 + +#line 852 + } +#line 852 +#ifdef ERANGE_FILL +#line 852 + free(fillp); +#line 852 +#endif +#line 852 + +#line 852 + return status; +#line 852 +} +#line 852 + +static int +#line 853 +putNCvx_longlong_ulonglong(NC3_INFO* ncp, const NC_var *varp, +#line 853 + const size_t *start, size_t nelems, const ulonglong *value) +#line 853 +{ +#line 853 + off_t offset = NC_varoffset(ncp, varp, start); +#line 853 + size_t remaining = varp->xsz * nelems; +#line 853 + int status = NC_NOERR; +#line 853 + void *xp; +#line 853 + void *fillp=NULL; +#line 853 + +#line 853 + if(nelems == 0) +#line 853 + return NC_NOERR; +#line 853 + +#line 853 + assert(value != NULL); +#line 853 + +#line 853 +#ifdef ERANGE_FILL +#line 853 + fillp = malloc(varp->xsz); +#line 853 + status = NC3_inq_var_fill(varp, fillp); +#line 853 +#endif +#line 853 + +#line 853 + for(;;) +#line 853 + { +#line 853 + size_t extent = MIN(remaining, ncp->chunk); +#line 853 + size_t nput = ncx_howmany(varp->type, extent); +#line 853 + +#line 853 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 853 + RGN_WRITE, &xp); +#line 853 + if(lstatus != NC_NOERR) +#line 853 + return lstatus; +#line 853 + +#line 853 + lstatus = ncx_putn_longlong_ulonglong(&xp, nput, value ,fillp); +#line 853 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 853 + { +#line 853 + /* not fatal to the loop */ +#line 853 + status = lstatus; +#line 853 + } +#line 853 + +#line 853 + (void) ncio_rel(ncp->nciop, offset, +#line 853 + RGN_MODIFIED); +#line 853 + +#line 853 + remaining -= extent; +#line 853 + if(remaining == 0) +#line 853 + break; /* normal loop exit */ +#line 853 + offset += (off_t)extent; +#line 853 + value += nput; +#line 853 + +#line 853 + } +#line 853 +#ifdef ERANGE_FILL +#line 853 + free(fillp); +#line 853 +#endif +#line 853 + +#line 853 + return status; +#line 853 +} +#line 853 + + +static int +#line 855 +putNCvx_ulonglong_schar(NC3_INFO* ncp, const NC_var *varp, +#line 855 + const size_t *start, size_t nelems, const schar *value) +#line 855 +{ +#line 855 + off_t offset = NC_varoffset(ncp, varp, start); +#line 855 + size_t remaining = varp->xsz * nelems; +#line 855 + int status = NC_NOERR; +#line 855 + void *xp; +#line 855 + void *fillp=NULL; +#line 855 + +#line 855 + if(nelems == 0) +#line 855 + return NC_NOERR; +#line 855 + +#line 855 + assert(value != NULL); +#line 855 + +#line 855 +#ifdef ERANGE_FILL +#line 855 + fillp = malloc(varp->xsz); +#line 855 + status = NC3_inq_var_fill(varp, fillp); +#line 855 +#endif +#line 855 + +#line 855 + for(;;) +#line 855 + { +#line 855 + size_t extent = MIN(remaining, ncp->chunk); +#line 855 + size_t nput = ncx_howmany(varp->type, extent); +#line 855 + +#line 855 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 855 + RGN_WRITE, &xp); +#line 855 + if(lstatus != NC_NOERR) +#line 855 + return lstatus; +#line 855 + +#line 855 + lstatus = ncx_putn_ulonglong_schar(&xp, nput, value ,fillp); +#line 855 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 855 + { +#line 855 + /* not fatal to the loop */ +#line 855 + status = lstatus; +#line 855 + } +#line 855 + +#line 855 + (void) ncio_rel(ncp->nciop, offset, +#line 855 + RGN_MODIFIED); +#line 855 + +#line 855 + remaining -= extent; +#line 855 + if(remaining == 0) +#line 855 + break; /* normal loop exit */ +#line 855 + offset += (off_t)extent; +#line 855 + value += nput; +#line 855 + +#line 855 + } +#line 855 +#ifdef ERANGE_FILL +#line 855 + free(fillp); +#line 855 +#endif +#line 855 + +#line 855 + return status; +#line 855 +} +#line 855 + +static int +#line 856 +putNCvx_ulonglong_uchar(NC3_INFO* ncp, const NC_var *varp, +#line 856 + const size_t *start, size_t nelems, const uchar *value) +#line 856 +{ +#line 856 + off_t offset = NC_varoffset(ncp, varp, start); +#line 856 + size_t remaining = varp->xsz * nelems; +#line 856 + int status = NC_NOERR; +#line 856 + void *xp; +#line 856 + void *fillp=NULL; +#line 856 + +#line 856 + if(nelems == 0) +#line 856 + return NC_NOERR; +#line 856 + +#line 856 + assert(value != NULL); +#line 856 + +#line 856 +#ifdef ERANGE_FILL +#line 856 + fillp = malloc(varp->xsz); +#line 856 + status = NC3_inq_var_fill(varp, fillp); +#line 856 +#endif +#line 856 + +#line 856 + for(;;) +#line 856 + { +#line 856 + size_t extent = MIN(remaining, ncp->chunk); +#line 856 + size_t nput = ncx_howmany(varp->type, extent); +#line 856 + +#line 856 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 856 + RGN_WRITE, &xp); +#line 856 + if(lstatus != NC_NOERR) +#line 856 + return lstatus; +#line 856 + +#line 856 + lstatus = ncx_putn_ulonglong_uchar(&xp, nput, value ,fillp); +#line 856 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 856 + { +#line 856 + /* not fatal to the loop */ +#line 856 + status = lstatus; +#line 856 + } +#line 856 + +#line 856 + (void) ncio_rel(ncp->nciop, offset, +#line 856 + RGN_MODIFIED); +#line 856 + +#line 856 + remaining -= extent; +#line 856 + if(remaining == 0) +#line 856 + break; /* normal loop exit */ +#line 856 + offset += (off_t)extent; +#line 856 + value += nput; +#line 856 + +#line 856 + } +#line 856 +#ifdef ERANGE_FILL +#line 856 + free(fillp); +#line 856 +#endif +#line 856 + +#line 856 + return status; +#line 856 +} +#line 856 + +static int +#line 857 +putNCvx_ulonglong_short(NC3_INFO* ncp, const NC_var *varp, +#line 857 + const size_t *start, size_t nelems, const short *value) +#line 857 +{ +#line 857 + off_t offset = NC_varoffset(ncp, varp, start); +#line 857 + size_t remaining = varp->xsz * nelems; +#line 857 + int status = NC_NOERR; +#line 857 + void *xp; +#line 857 + void *fillp=NULL; +#line 857 + +#line 857 + if(nelems == 0) +#line 857 + return NC_NOERR; +#line 857 + +#line 857 + assert(value != NULL); +#line 857 + +#line 857 +#ifdef ERANGE_FILL +#line 857 + fillp = malloc(varp->xsz); +#line 857 + status = NC3_inq_var_fill(varp, fillp); +#line 857 +#endif +#line 857 + +#line 857 + for(;;) +#line 857 + { +#line 857 + size_t extent = MIN(remaining, ncp->chunk); +#line 857 + size_t nput = ncx_howmany(varp->type, extent); +#line 857 + +#line 857 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 857 + RGN_WRITE, &xp); +#line 857 + if(lstatus != NC_NOERR) +#line 857 + return lstatus; +#line 857 + +#line 857 + lstatus = ncx_putn_ulonglong_short(&xp, nput, value ,fillp); +#line 857 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 857 + { +#line 857 + /* not fatal to the loop */ +#line 857 + status = lstatus; +#line 857 + } +#line 857 + +#line 857 + (void) ncio_rel(ncp->nciop, offset, +#line 857 + RGN_MODIFIED); +#line 857 + +#line 857 + remaining -= extent; +#line 857 + if(remaining == 0) +#line 857 + break; /* normal loop exit */ +#line 857 + offset += (off_t)extent; +#line 857 + value += nput; +#line 857 + +#line 857 + } +#line 857 +#ifdef ERANGE_FILL +#line 857 + free(fillp); +#line 857 +#endif +#line 857 + +#line 857 + return status; +#line 857 +} +#line 857 + +static int +#line 858 +putNCvx_ulonglong_int(NC3_INFO* ncp, const NC_var *varp, +#line 858 + const size_t *start, size_t nelems, const int *value) +#line 858 +{ +#line 858 + off_t offset = NC_varoffset(ncp, varp, start); +#line 858 + size_t remaining = varp->xsz * nelems; +#line 858 + int status = NC_NOERR; +#line 858 + void *xp; +#line 858 + void *fillp=NULL; +#line 858 + +#line 858 + if(nelems == 0) +#line 858 + return NC_NOERR; +#line 858 + +#line 858 + assert(value != NULL); +#line 858 + +#line 858 +#ifdef ERANGE_FILL +#line 858 + fillp = malloc(varp->xsz); +#line 858 + status = NC3_inq_var_fill(varp, fillp); +#line 858 +#endif +#line 858 + +#line 858 + for(;;) +#line 858 + { +#line 858 + size_t extent = MIN(remaining, ncp->chunk); +#line 858 + size_t nput = ncx_howmany(varp->type, extent); +#line 858 + +#line 858 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 858 + RGN_WRITE, &xp); +#line 858 + if(lstatus != NC_NOERR) +#line 858 + return lstatus; +#line 858 + +#line 858 + lstatus = ncx_putn_ulonglong_int(&xp, nput, value ,fillp); +#line 858 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 858 + { +#line 858 + /* not fatal to the loop */ +#line 858 + status = lstatus; +#line 858 + } +#line 858 + +#line 858 + (void) ncio_rel(ncp->nciop, offset, +#line 858 + RGN_MODIFIED); +#line 858 + +#line 858 + remaining -= extent; +#line 858 + if(remaining == 0) +#line 858 + break; /* normal loop exit */ +#line 858 + offset += (off_t)extent; +#line 858 + value += nput; +#line 858 + +#line 858 + } +#line 858 +#ifdef ERANGE_FILL +#line 858 + free(fillp); +#line 858 +#endif +#line 858 + +#line 858 + return status; +#line 858 +} +#line 858 + +static int +#line 859 +putNCvx_ulonglong_float(NC3_INFO* ncp, const NC_var *varp, +#line 859 + const size_t *start, size_t nelems, const float *value) +#line 859 +{ +#line 859 + off_t offset = NC_varoffset(ncp, varp, start); +#line 859 + size_t remaining = varp->xsz * nelems; +#line 859 + int status = NC_NOERR; +#line 859 + void *xp; +#line 859 + void *fillp=NULL; +#line 859 + +#line 859 + if(nelems == 0) +#line 859 + return NC_NOERR; +#line 859 + +#line 859 + assert(value != NULL); +#line 859 + +#line 859 +#ifdef ERANGE_FILL +#line 859 + fillp = malloc(varp->xsz); +#line 859 + status = NC3_inq_var_fill(varp, fillp); +#line 859 +#endif +#line 859 + +#line 859 + for(;;) +#line 859 + { +#line 859 + size_t extent = MIN(remaining, ncp->chunk); +#line 859 + size_t nput = ncx_howmany(varp->type, extent); +#line 859 + +#line 859 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 859 + RGN_WRITE, &xp); +#line 859 + if(lstatus != NC_NOERR) +#line 859 + return lstatus; +#line 859 + +#line 859 + lstatus = ncx_putn_ulonglong_float(&xp, nput, value ,fillp); +#line 859 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 859 + { +#line 859 + /* not fatal to the loop */ +#line 859 + status = lstatus; +#line 859 + } +#line 859 + +#line 859 + (void) ncio_rel(ncp->nciop, offset, +#line 859 + RGN_MODIFIED); +#line 859 + +#line 859 + remaining -= extent; +#line 859 + if(remaining == 0) +#line 859 + break; /* normal loop exit */ +#line 859 + offset += (off_t)extent; +#line 859 + value += nput; +#line 859 + +#line 859 + } +#line 859 +#ifdef ERANGE_FILL +#line 859 + free(fillp); +#line 859 +#endif +#line 859 + +#line 859 + return status; +#line 859 +} +#line 859 + +static int +#line 860 +putNCvx_ulonglong_double(NC3_INFO* ncp, const NC_var *varp, +#line 860 + const size_t *start, size_t nelems, const double *value) +#line 860 +{ +#line 860 + off_t offset = NC_varoffset(ncp, varp, start); +#line 860 + size_t remaining = varp->xsz * nelems; +#line 860 + int status = NC_NOERR; +#line 860 + void *xp; +#line 860 + void *fillp=NULL; +#line 860 + +#line 860 + if(nelems == 0) +#line 860 + return NC_NOERR; +#line 860 + +#line 860 + assert(value != NULL); +#line 860 + +#line 860 +#ifdef ERANGE_FILL +#line 860 + fillp = malloc(varp->xsz); +#line 860 + status = NC3_inq_var_fill(varp, fillp); +#line 860 +#endif +#line 860 + +#line 860 + for(;;) +#line 860 + { +#line 860 + size_t extent = MIN(remaining, ncp->chunk); +#line 860 + size_t nput = ncx_howmany(varp->type, extent); +#line 860 + +#line 860 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 860 + RGN_WRITE, &xp); +#line 860 + if(lstatus != NC_NOERR) +#line 860 + return lstatus; +#line 860 + +#line 860 + lstatus = ncx_putn_ulonglong_double(&xp, nput, value ,fillp); +#line 860 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 860 + { +#line 860 + /* not fatal to the loop */ +#line 860 + status = lstatus; +#line 860 + } +#line 860 + +#line 860 + (void) ncio_rel(ncp->nciop, offset, +#line 860 + RGN_MODIFIED); +#line 860 + +#line 860 + remaining -= extent; +#line 860 + if(remaining == 0) +#line 860 + break; /* normal loop exit */ +#line 860 + offset += (off_t)extent; +#line 860 + value += nput; +#line 860 + +#line 860 + } +#line 860 +#ifdef ERANGE_FILL +#line 860 + free(fillp); +#line 860 +#endif +#line 860 + +#line 860 + return status; +#line 860 +} +#line 860 + +static int +#line 861 +putNCvx_ulonglong_longlong(NC3_INFO* ncp, const NC_var *varp, +#line 861 + const size_t *start, size_t nelems, const longlong *value) +#line 861 +{ +#line 861 + off_t offset = NC_varoffset(ncp, varp, start); +#line 861 + size_t remaining = varp->xsz * nelems; +#line 861 + int status = NC_NOERR; +#line 861 + void *xp; +#line 861 + void *fillp=NULL; +#line 861 + +#line 861 + if(nelems == 0) +#line 861 + return NC_NOERR; +#line 861 + +#line 861 + assert(value != NULL); +#line 861 + +#line 861 +#ifdef ERANGE_FILL +#line 861 + fillp = malloc(varp->xsz); +#line 861 + status = NC3_inq_var_fill(varp, fillp); +#line 861 +#endif +#line 861 + +#line 861 + for(;;) +#line 861 + { +#line 861 + size_t extent = MIN(remaining, ncp->chunk); +#line 861 + size_t nput = ncx_howmany(varp->type, extent); +#line 861 + +#line 861 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 861 + RGN_WRITE, &xp); +#line 861 + if(lstatus != NC_NOERR) +#line 861 + return lstatus; +#line 861 + +#line 861 + lstatus = ncx_putn_ulonglong_longlong(&xp, nput, value ,fillp); +#line 861 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 861 + { +#line 861 + /* not fatal to the loop */ +#line 861 + status = lstatus; +#line 861 + } +#line 861 + +#line 861 + (void) ncio_rel(ncp->nciop, offset, +#line 861 + RGN_MODIFIED); +#line 861 + +#line 861 + remaining -= extent; +#line 861 + if(remaining == 0) +#line 861 + break; /* normal loop exit */ +#line 861 + offset += (off_t)extent; +#line 861 + value += nput; +#line 861 + +#line 861 + } +#line 861 +#ifdef ERANGE_FILL +#line 861 + free(fillp); +#line 861 +#endif +#line 861 + +#line 861 + return status; +#line 861 +} +#line 861 + +static int +#line 862 +putNCvx_ulonglong_ushort(NC3_INFO* ncp, const NC_var *varp, +#line 862 + const size_t *start, size_t nelems, const ushort *value) +#line 862 +{ +#line 862 + off_t offset = NC_varoffset(ncp, varp, start); +#line 862 + size_t remaining = varp->xsz * nelems; +#line 862 + int status = NC_NOERR; +#line 862 + void *xp; +#line 862 + void *fillp=NULL; +#line 862 + +#line 862 + if(nelems == 0) +#line 862 + return NC_NOERR; +#line 862 + +#line 862 + assert(value != NULL); +#line 862 + +#line 862 +#ifdef ERANGE_FILL +#line 862 + fillp = malloc(varp->xsz); +#line 862 + status = NC3_inq_var_fill(varp, fillp); +#line 862 +#endif +#line 862 + +#line 862 + for(;;) +#line 862 + { +#line 862 + size_t extent = MIN(remaining, ncp->chunk); +#line 862 + size_t nput = ncx_howmany(varp->type, extent); +#line 862 + +#line 862 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 862 + RGN_WRITE, &xp); +#line 862 + if(lstatus != NC_NOERR) +#line 862 + return lstatus; +#line 862 + +#line 862 + lstatus = ncx_putn_ulonglong_ushort(&xp, nput, value ,fillp); +#line 862 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 862 + { +#line 862 + /* not fatal to the loop */ +#line 862 + status = lstatus; +#line 862 + } +#line 862 + +#line 862 + (void) ncio_rel(ncp->nciop, offset, +#line 862 + RGN_MODIFIED); +#line 862 + +#line 862 + remaining -= extent; +#line 862 + if(remaining == 0) +#line 862 + break; /* normal loop exit */ +#line 862 + offset += (off_t)extent; +#line 862 + value += nput; +#line 862 + +#line 862 + } +#line 862 +#ifdef ERANGE_FILL +#line 862 + free(fillp); +#line 862 +#endif +#line 862 + +#line 862 + return status; +#line 862 +} +#line 862 + +static int +#line 863 +putNCvx_ulonglong_uint(NC3_INFO* ncp, const NC_var *varp, +#line 863 + const size_t *start, size_t nelems, const uint *value) +#line 863 +{ +#line 863 + off_t offset = NC_varoffset(ncp, varp, start); +#line 863 + size_t remaining = varp->xsz * nelems; +#line 863 + int status = NC_NOERR; +#line 863 + void *xp; +#line 863 + void *fillp=NULL; +#line 863 + +#line 863 + if(nelems == 0) +#line 863 + return NC_NOERR; +#line 863 + +#line 863 + assert(value != NULL); +#line 863 + +#line 863 +#ifdef ERANGE_FILL +#line 863 + fillp = malloc(varp->xsz); +#line 863 + status = NC3_inq_var_fill(varp, fillp); +#line 863 +#endif +#line 863 + +#line 863 + for(;;) +#line 863 + { +#line 863 + size_t extent = MIN(remaining, ncp->chunk); +#line 863 + size_t nput = ncx_howmany(varp->type, extent); +#line 863 + +#line 863 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 863 + RGN_WRITE, &xp); +#line 863 + if(lstatus != NC_NOERR) +#line 863 + return lstatus; +#line 863 + +#line 863 + lstatus = ncx_putn_ulonglong_uint(&xp, nput, value ,fillp); +#line 863 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 863 + { +#line 863 + /* not fatal to the loop */ +#line 863 + status = lstatus; +#line 863 + } +#line 863 + +#line 863 + (void) ncio_rel(ncp->nciop, offset, +#line 863 + RGN_MODIFIED); +#line 863 + +#line 863 + remaining -= extent; +#line 863 + if(remaining == 0) +#line 863 + break; /* normal loop exit */ +#line 863 + offset += (off_t)extent; +#line 863 + value += nput; +#line 863 + +#line 863 + } +#line 863 +#ifdef ERANGE_FILL +#line 863 + free(fillp); +#line 863 +#endif +#line 863 + +#line 863 + return status; +#line 863 +} +#line 863 + +static int +#line 864 +putNCvx_ulonglong_ulonglong(NC3_INFO* ncp, const NC_var *varp, +#line 864 + const size_t *start, size_t nelems, const ulonglong *value) +#line 864 +{ +#line 864 + off_t offset = NC_varoffset(ncp, varp, start); +#line 864 + size_t remaining = varp->xsz * nelems; +#line 864 + int status = NC_NOERR; +#line 864 + void *xp; +#line 864 + void *fillp=NULL; +#line 864 + +#line 864 + if(nelems == 0) +#line 864 + return NC_NOERR; +#line 864 + +#line 864 + assert(value != NULL); +#line 864 + +#line 864 +#ifdef ERANGE_FILL +#line 864 + fillp = malloc(varp->xsz); +#line 864 + status = NC3_inq_var_fill(varp, fillp); +#line 864 +#endif +#line 864 + +#line 864 + for(;;) +#line 864 + { +#line 864 + size_t extent = MIN(remaining, ncp->chunk); +#line 864 + size_t nput = ncx_howmany(varp->type, extent); +#line 864 + +#line 864 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 864 + RGN_WRITE, &xp); +#line 864 + if(lstatus != NC_NOERR) +#line 864 + return lstatus; +#line 864 + +#line 864 + lstatus = ncx_putn_ulonglong_ulonglong(&xp, nput, value ,fillp); +#line 864 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 864 + { +#line 864 + /* not fatal to the loop */ +#line 864 + status = lstatus; +#line 864 + } +#line 864 + +#line 864 + (void) ncio_rel(ncp->nciop, offset, +#line 864 + RGN_MODIFIED); +#line 864 + +#line 864 + remaining -= extent; +#line 864 + if(remaining == 0) +#line 864 + break; /* normal loop exit */ +#line 864 + offset += (off_t)extent; +#line 864 + value += nput; +#line 864 + +#line 864 + } +#line 864 +#ifdef ERANGE_FILL +#line 864 + free(fillp); +#line 864 +#endif +#line 864 + +#line 864 + return status; +#line 864 +} +#line 864 + + +#line 911 + +static int +#line 912 +getNCvx_char_char(const NC3_INFO* ncp, const NC_var *varp, +#line 912 + const size_t *start, size_t nelems, char *value) +#line 912 +{ +#line 912 + off_t offset = NC_varoffset(ncp, varp, start); +#line 912 + size_t remaining = varp->xsz * nelems; +#line 912 + int status = NC_NOERR; +#line 912 + const void *xp; +#line 912 + +#line 912 + if(nelems == 0) +#line 912 + return NC_NOERR; +#line 912 + +#line 912 + assert(value != NULL); +#line 912 + +#line 912 + for(;;) +#line 912 + { +#line 912 + size_t extent = MIN(remaining, ncp->chunk); +#line 912 + size_t nget = ncx_howmany(varp->type, extent); +#line 912 + +#line 912 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 912 + 0, (void **)&xp); /* cast away const */ +#line 912 + if(lstatus != NC_NOERR) +#line 912 + return lstatus; +#line 912 + +#line 912 + lstatus = ncx_getn_char_char(&xp, nget, value); +#line 912 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 912 + status = lstatus; +#line 912 + +#line 912 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 912 + +#line 912 + remaining -= extent; +#line 912 + if(remaining == 0) +#line 912 + break; /* normal loop exit */ +#line 912 + offset += (off_t)extent; +#line 912 + value += nget; +#line 912 + } +#line 912 + +#line 912 + return status; +#line 912 +} +#line 912 + + +static int +#line 914 +getNCvx_schar_schar(const NC3_INFO* ncp, const NC_var *varp, +#line 914 + const size_t *start, size_t nelems, schar *value) +#line 914 +{ +#line 914 + off_t offset = NC_varoffset(ncp, varp, start); +#line 914 + size_t remaining = varp->xsz * nelems; +#line 914 + int status = NC_NOERR; +#line 914 + const void *xp; +#line 914 + +#line 914 + if(nelems == 0) +#line 914 + return NC_NOERR; +#line 914 + +#line 914 + assert(value != NULL); +#line 914 + +#line 914 + for(;;) +#line 914 + { +#line 914 + size_t extent = MIN(remaining, ncp->chunk); +#line 914 + size_t nget = ncx_howmany(varp->type, extent); +#line 914 + +#line 914 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 914 + 0, (void **)&xp); /* cast away const */ +#line 914 + if(lstatus != NC_NOERR) +#line 914 + return lstatus; +#line 914 + +#line 914 + lstatus = ncx_getn_schar_schar(&xp, nget, value); +#line 914 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 914 + status = lstatus; +#line 914 + +#line 914 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 914 + +#line 914 + remaining -= extent; +#line 914 + if(remaining == 0) +#line 914 + break; /* normal loop exit */ +#line 914 + offset += (off_t)extent; +#line 914 + value += nget; +#line 914 + } +#line 914 + +#line 914 + return status; +#line 914 +} +#line 914 + +static int +#line 915 +getNCvx_schar_short(const NC3_INFO* ncp, const NC_var *varp, +#line 915 + const size_t *start, size_t nelems, short *value) +#line 915 +{ +#line 915 + off_t offset = NC_varoffset(ncp, varp, start); +#line 915 + size_t remaining = varp->xsz * nelems; +#line 915 + int status = NC_NOERR; +#line 915 + const void *xp; +#line 915 + +#line 915 + if(nelems == 0) +#line 915 + return NC_NOERR; +#line 915 + +#line 915 + assert(value != NULL); +#line 915 + +#line 915 + for(;;) +#line 915 + { +#line 915 + size_t extent = MIN(remaining, ncp->chunk); +#line 915 + size_t nget = ncx_howmany(varp->type, extent); +#line 915 + +#line 915 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 915 + 0, (void **)&xp); /* cast away const */ +#line 915 + if(lstatus != NC_NOERR) +#line 915 + return lstatus; +#line 915 + +#line 915 + lstatus = ncx_getn_schar_short(&xp, nget, value); +#line 915 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 915 + status = lstatus; +#line 915 + +#line 915 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 915 + +#line 915 + remaining -= extent; +#line 915 + if(remaining == 0) +#line 915 + break; /* normal loop exit */ +#line 915 + offset += (off_t)extent; +#line 915 + value += nget; +#line 915 + } +#line 915 + +#line 915 + return status; +#line 915 +} +#line 915 + +static int +#line 916 +getNCvx_schar_int(const NC3_INFO* ncp, const NC_var *varp, +#line 916 + const size_t *start, size_t nelems, int *value) +#line 916 +{ +#line 916 + off_t offset = NC_varoffset(ncp, varp, start); +#line 916 + size_t remaining = varp->xsz * nelems; +#line 916 + int status = NC_NOERR; +#line 916 + const void *xp; +#line 916 + +#line 916 + if(nelems == 0) +#line 916 + return NC_NOERR; +#line 916 + +#line 916 + assert(value != NULL); +#line 916 + +#line 916 + for(;;) +#line 916 + { +#line 916 + size_t extent = MIN(remaining, ncp->chunk); +#line 916 + size_t nget = ncx_howmany(varp->type, extent); +#line 916 + +#line 916 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 916 + 0, (void **)&xp); /* cast away const */ +#line 916 + if(lstatus != NC_NOERR) +#line 916 + return lstatus; +#line 916 + +#line 916 + lstatus = ncx_getn_schar_int(&xp, nget, value); +#line 916 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 916 + status = lstatus; +#line 916 + +#line 916 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 916 + +#line 916 + remaining -= extent; +#line 916 + if(remaining == 0) +#line 916 + break; /* normal loop exit */ +#line 916 + offset += (off_t)extent; +#line 916 + value += nget; +#line 916 + } +#line 916 + +#line 916 + return status; +#line 916 +} +#line 916 + +static int +#line 917 +getNCvx_schar_float(const NC3_INFO* ncp, const NC_var *varp, +#line 917 + const size_t *start, size_t nelems, float *value) +#line 917 +{ +#line 917 + off_t offset = NC_varoffset(ncp, varp, start); +#line 917 + size_t remaining = varp->xsz * nelems; +#line 917 + int status = NC_NOERR; +#line 917 + const void *xp; +#line 917 + +#line 917 + if(nelems == 0) +#line 917 + return NC_NOERR; +#line 917 + +#line 917 + assert(value != NULL); +#line 917 + +#line 917 + for(;;) +#line 917 + { +#line 917 + size_t extent = MIN(remaining, ncp->chunk); +#line 917 + size_t nget = ncx_howmany(varp->type, extent); +#line 917 + +#line 917 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 917 + 0, (void **)&xp); /* cast away const */ +#line 917 + if(lstatus != NC_NOERR) +#line 917 + return lstatus; +#line 917 + +#line 917 + lstatus = ncx_getn_schar_float(&xp, nget, value); +#line 917 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 917 + status = lstatus; +#line 917 + +#line 917 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 917 + +#line 917 + remaining -= extent; +#line 917 + if(remaining == 0) +#line 917 + break; /* normal loop exit */ +#line 917 + offset += (off_t)extent; +#line 917 + value += nget; +#line 917 + } +#line 917 + +#line 917 + return status; +#line 917 +} +#line 917 + +static int +#line 918 +getNCvx_schar_double(const NC3_INFO* ncp, const NC_var *varp, +#line 918 + const size_t *start, size_t nelems, double *value) +#line 918 +{ +#line 918 + off_t offset = NC_varoffset(ncp, varp, start); +#line 918 + size_t remaining = varp->xsz * nelems; +#line 918 + int status = NC_NOERR; +#line 918 + const void *xp; +#line 918 + +#line 918 + if(nelems == 0) +#line 918 + return NC_NOERR; +#line 918 + +#line 918 + assert(value != NULL); +#line 918 + +#line 918 + for(;;) +#line 918 + { +#line 918 + size_t extent = MIN(remaining, ncp->chunk); +#line 918 + size_t nget = ncx_howmany(varp->type, extent); +#line 918 + +#line 918 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 918 + 0, (void **)&xp); /* cast away const */ +#line 918 + if(lstatus != NC_NOERR) +#line 918 + return lstatus; +#line 918 + +#line 918 + lstatus = ncx_getn_schar_double(&xp, nget, value); +#line 918 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 918 + status = lstatus; +#line 918 + +#line 918 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 918 + +#line 918 + remaining -= extent; +#line 918 + if(remaining == 0) +#line 918 + break; /* normal loop exit */ +#line 918 + offset += (off_t)extent; +#line 918 + value += nget; +#line 918 + } +#line 918 + +#line 918 + return status; +#line 918 +} +#line 918 + +static int +#line 919 +getNCvx_schar_longlong(const NC3_INFO* ncp, const NC_var *varp, +#line 919 + const size_t *start, size_t nelems, longlong *value) +#line 919 +{ +#line 919 + off_t offset = NC_varoffset(ncp, varp, start); +#line 919 + size_t remaining = varp->xsz * nelems; +#line 919 + int status = NC_NOERR; +#line 919 + const void *xp; +#line 919 + +#line 919 + if(nelems == 0) +#line 919 + return NC_NOERR; +#line 919 + +#line 919 + assert(value != NULL); +#line 919 + +#line 919 + for(;;) +#line 919 + { +#line 919 + size_t extent = MIN(remaining, ncp->chunk); +#line 919 + size_t nget = ncx_howmany(varp->type, extent); +#line 919 + +#line 919 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 919 + 0, (void **)&xp); /* cast away const */ +#line 919 + if(lstatus != NC_NOERR) +#line 919 + return lstatus; +#line 919 + +#line 919 + lstatus = ncx_getn_schar_longlong(&xp, nget, value); +#line 919 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 919 + status = lstatus; +#line 919 + +#line 919 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 919 + +#line 919 + remaining -= extent; +#line 919 + if(remaining == 0) +#line 919 + break; /* normal loop exit */ +#line 919 + offset += (off_t)extent; +#line 919 + value += nget; +#line 919 + } +#line 919 + +#line 919 + return status; +#line 919 +} +#line 919 + +static int +#line 920 +getNCvx_schar_uint(const NC3_INFO* ncp, const NC_var *varp, +#line 920 + const size_t *start, size_t nelems, uint *value) +#line 920 +{ +#line 920 + off_t offset = NC_varoffset(ncp, varp, start); +#line 920 + size_t remaining = varp->xsz * nelems; +#line 920 + int status = NC_NOERR; +#line 920 + const void *xp; +#line 920 + +#line 920 + if(nelems == 0) +#line 920 + return NC_NOERR; +#line 920 + +#line 920 + assert(value != NULL); +#line 920 + +#line 920 + for(;;) +#line 920 + { +#line 920 + size_t extent = MIN(remaining, ncp->chunk); +#line 920 + size_t nget = ncx_howmany(varp->type, extent); +#line 920 + +#line 920 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 920 + 0, (void **)&xp); /* cast away const */ +#line 920 + if(lstatus != NC_NOERR) +#line 920 + return lstatus; +#line 920 + +#line 920 + lstatus = ncx_getn_schar_uint(&xp, nget, value); +#line 920 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 920 + status = lstatus; +#line 920 + +#line 920 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 920 + +#line 920 + remaining -= extent; +#line 920 + if(remaining == 0) +#line 920 + break; /* normal loop exit */ +#line 920 + offset += (off_t)extent; +#line 920 + value += nget; +#line 920 + } +#line 920 + +#line 920 + return status; +#line 920 +} +#line 920 + +static int +#line 921 +getNCvx_schar_ulonglong(const NC3_INFO* ncp, const NC_var *varp, +#line 921 + const size_t *start, size_t nelems, ulonglong *value) +#line 921 +{ +#line 921 + off_t offset = NC_varoffset(ncp, varp, start); +#line 921 + size_t remaining = varp->xsz * nelems; +#line 921 + int status = NC_NOERR; +#line 921 + const void *xp; +#line 921 + +#line 921 + if(nelems == 0) +#line 921 + return NC_NOERR; +#line 921 + +#line 921 + assert(value != NULL); +#line 921 + +#line 921 + for(;;) +#line 921 + { +#line 921 + size_t extent = MIN(remaining, ncp->chunk); +#line 921 + size_t nget = ncx_howmany(varp->type, extent); +#line 921 + +#line 921 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 921 + 0, (void **)&xp); /* cast away const */ +#line 921 + if(lstatus != NC_NOERR) +#line 921 + return lstatus; +#line 921 + +#line 921 + lstatus = ncx_getn_schar_ulonglong(&xp, nget, value); +#line 921 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 921 + status = lstatus; +#line 921 + +#line 921 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 921 + +#line 921 + remaining -= extent; +#line 921 + if(remaining == 0) +#line 921 + break; /* normal loop exit */ +#line 921 + offset += (off_t)extent; +#line 921 + value += nget; +#line 921 + } +#line 921 + +#line 921 + return status; +#line 921 +} +#line 921 + +static int +#line 922 +getNCvx_schar_uchar(const NC3_INFO* ncp, const NC_var *varp, +#line 922 + const size_t *start, size_t nelems, uchar *value) +#line 922 +{ +#line 922 + off_t offset = NC_varoffset(ncp, varp, start); +#line 922 + size_t remaining = varp->xsz * nelems; +#line 922 + int status = NC_NOERR; +#line 922 + const void *xp; +#line 922 + +#line 922 + if(nelems == 0) +#line 922 + return NC_NOERR; +#line 922 + +#line 922 + assert(value != NULL); +#line 922 + +#line 922 + for(;;) +#line 922 + { +#line 922 + size_t extent = MIN(remaining, ncp->chunk); +#line 922 + size_t nget = ncx_howmany(varp->type, extent); +#line 922 + +#line 922 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 922 + 0, (void **)&xp); /* cast away const */ +#line 922 + if(lstatus != NC_NOERR) +#line 922 + return lstatus; +#line 922 + +#line 922 + lstatus = ncx_getn_schar_uchar(&xp, nget, value); +#line 922 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 922 + status = lstatus; +#line 922 + +#line 922 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 922 + +#line 922 + remaining -= extent; +#line 922 + if(remaining == 0) +#line 922 + break; /* normal loop exit */ +#line 922 + offset += (off_t)extent; +#line 922 + value += nget; +#line 922 + } +#line 922 + +#line 922 + return status; +#line 922 +} +#line 922 + +static int +#line 923 +getNCvx_schar_ushort(const NC3_INFO* ncp, const NC_var *varp, +#line 923 + const size_t *start, size_t nelems, ushort *value) +#line 923 +{ +#line 923 + off_t offset = NC_varoffset(ncp, varp, start); +#line 923 + size_t remaining = varp->xsz * nelems; +#line 923 + int status = NC_NOERR; +#line 923 + const void *xp; +#line 923 + +#line 923 + if(nelems == 0) +#line 923 + return NC_NOERR; +#line 923 + +#line 923 + assert(value != NULL); +#line 923 + +#line 923 + for(;;) +#line 923 + { +#line 923 + size_t extent = MIN(remaining, ncp->chunk); +#line 923 + size_t nget = ncx_howmany(varp->type, extent); +#line 923 + +#line 923 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 923 + 0, (void **)&xp); /* cast away const */ +#line 923 + if(lstatus != NC_NOERR) +#line 923 + return lstatus; +#line 923 + +#line 923 + lstatus = ncx_getn_schar_ushort(&xp, nget, value); +#line 923 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 923 + status = lstatus; +#line 923 + +#line 923 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 923 + +#line 923 + remaining -= extent; +#line 923 + if(remaining == 0) +#line 923 + break; /* normal loop exit */ +#line 923 + offset += (off_t)extent; +#line 923 + value += nget; +#line 923 + } +#line 923 + +#line 923 + return status; +#line 923 +} +#line 923 + + +static int +#line 925 +getNCvx_short_schar(const NC3_INFO* ncp, const NC_var *varp, +#line 925 + const size_t *start, size_t nelems, schar *value) +#line 925 +{ +#line 925 + off_t offset = NC_varoffset(ncp, varp, start); +#line 925 + size_t remaining = varp->xsz * nelems; +#line 925 + int status = NC_NOERR; +#line 925 + const void *xp; +#line 925 + +#line 925 + if(nelems == 0) +#line 925 + return NC_NOERR; +#line 925 + +#line 925 + assert(value != NULL); +#line 925 + +#line 925 + for(;;) +#line 925 + { +#line 925 + size_t extent = MIN(remaining, ncp->chunk); +#line 925 + size_t nget = ncx_howmany(varp->type, extent); +#line 925 + +#line 925 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 925 + 0, (void **)&xp); /* cast away const */ +#line 925 + if(lstatus != NC_NOERR) +#line 925 + return lstatus; +#line 925 + +#line 925 + lstatus = ncx_getn_short_schar(&xp, nget, value); +#line 925 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 925 + status = lstatus; +#line 925 + +#line 925 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 925 + +#line 925 + remaining -= extent; +#line 925 + if(remaining == 0) +#line 925 + break; /* normal loop exit */ +#line 925 + offset += (off_t)extent; +#line 925 + value += nget; +#line 925 + } +#line 925 + +#line 925 + return status; +#line 925 +} +#line 925 + +static int +#line 926 +getNCvx_short_uchar(const NC3_INFO* ncp, const NC_var *varp, +#line 926 + const size_t *start, size_t nelems, uchar *value) +#line 926 +{ +#line 926 + off_t offset = NC_varoffset(ncp, varp, start); +#line 926 + size_t remaining = varp->xsz * nelems; +#line 926 + int status = NC_NOERR; +#line 926 + const void *xp; +#line 926 + +#line 926 + if(nelems == 0) +#line 926 + return NC_NOERR; +#line 926 + +#line 926 + assert(value != NULL); +#line 926 + +#line 926 + for(;;) +#line 926 + { +#line 926 + size_t extent = MIN(remaining, ncp->chunk); +#line 926 + size_t nget = ncx_howmany(varp->type, extent); +#line 926 + +#line 926 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 926 + 0, (void **)&xp); /* cast away const */ +#line 926 + if(lstatus != NC_NOERR) +#line 926 + return lstatus; +#line 926 + +#line 926 + lstatus = ncx_getn_short_uchar(&xp, nget, value); +#line 926 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 926 + status = lstatus; +#line 926 + +#line 926 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 926 + +#line 926 + remaining -= extent; +#line 926 + if(remaining == 0) +#line 926 + break; /* normal loop exit */ +#line 926 + offset += (off_t)extent; +#line 926 + value += nget; +#line 926 + } +#line 926 + +#line 926 + return status; +#line 926 +} +#line 926 + +static int +#line 927 +getNCvx_short_short(const NC3_INFO* ncp, const NC_var *varp, +#line 927 + const size_t *start, size_t nelems, short *value) +#line 927 +{ +#line 927 + off_t offset = NC_varoffset(ncp, varp, start); +#line 927 + size_t remaining = varp->xsz * nelems; +#line 927 + int status = NC_NOERR; +#line 927 + const void *xp; +#line 927 + +#line 927 + if(nelems == 0) +#line 927 + return NC_NOERR; +#line 927 + +#line 927 + assert(value != NULL); +#line 927 + +#line 927 + for(;;) +#line 927 + { +#line 927 + size_t extent = MIN(remaining, ncp->chunk); +#line 927 + size_t nget = ncx_howmany(varp->type, extent); +#line 927 + +#line 927 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 927 + 0, (void **)&xp); /* cast away const */ +#line 927 + if(lstatus != NC_NOERR) +#line 927 + return lstatus; +#line 927 + +#line 927 + lstatus = ncx_getn_short_short(&xp, nget, value); +#line 927 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 927 + status = lstatus; +#line 927 + +#line 927 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 927 + +#line 927 + remaining -= extent; +#line 927 + if(remaining == 0) +#line 927 + break; /* normal loop exit */ +#line 927 + offset += (off_t)extent; +#line 927 + value += nget; +#line 927 + } +#line 927 + +#line 927 + return status; +#line 927 +} +#line 927 + +static int +#line 928 +getNCvx_short_int(const NC3_INFO* ncp, const NC_var *varp, +#line 928 + const size_t *start, size_t nelems, int *value) +#line 928 +{ +#line 928 + off_t offset = NC_varoffset(ncp, varp, start); +#line 928 + size_t remaining = varp->xsz * nelems; +#line 928 + int status = NC_NOERR; +#line 928 + const void *xp; +#line 928 + +#line 928 + if(nelems == 0) +#line 928 + return NC_NOERR; +#line 928 + +#line 928 + assert(value != NULL); +#line 928 + +#line 928 + for(;;) +#line 928 + { +#line 928 + size_t extent = MIN(remaining, ncp->chunk); +#line 928 + size_t nget = ncx_howmany(varp->type, extent); +#line 928 + +#line 928 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 928 + 0, (void **)&xp); /* cast away const */ +#line 928 + if(lstatus != NC_NOERR) +#line 928 + return lstatus; +#line 928 + +#line 928 + lstatus = ncx_getn_short_int(&xp, nget, value); +#line 928 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 928 + status = lstatus; +#line 928 + +#line 928 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 928 + +#line 928 + remaining -= extent; +#line 928 + if(remaining == 0) +#line 928 + break; /* normal loop exit */ +#line 928 + offset += (off_t)extent; +#line 928 + value += nget; +#line 928 + } +#line 928 + +#line 928 + return status; +#line 928 +} +#line 928 + +static int +#line 929 +getNCvx_short_float(const NC3_INFO* ncp, const NC_var *varp, +#line 929 + const size_t *start, size_t nelems, float *value) +#line 929 +{ +#line 929 + off_t offset = NC_varoffset(ncp, varp, start); +#line 929 + size_t remaining = varp->xsz * nelems; +#line 929 + int status = NC_NOERR; +#line 929 + const void *xp; +#line 929 + +#line 929 + if(nelems == 0) +#line 929 + return NC_NOERR; +#line 929 + +#line 929 + assert(value != NULL); +#line 929 + +#line 929 + for(;;) +#line 929 + { +#line 929 + size_t extent = MIN(remaining, ncp->chunk); +#line 929 + size_t nget = ncx_howmany(varp->type, extent); +#line 929 + +#line 929 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 929 + 0, (void **)&xp); /* cast away const */ +#line 929 + if(lstatus != NC_NOERR) +#line 929 + return lstatus; +#line 929 + +#line 929 + lstatus = ncx_getn_short_float(&xp, nget, value); +#line 929 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 929 + status = lstatus; +#line 929 + +#line 929 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 929 + +#line 929 + remaining -= extent; +#line 929 + if(remaining == 0) +#line 929 + break; /* normal loop exit */ +#line 929 + offset += (off_t)extent; +#line 929 + value += nget; +#line 929 + } +#line 929 + +#line 929 + return status; +#line 929 +} +#line 929 + +static int +#line 930 +getNCvx_short_double(const NC3_INFO* ncp, const NC_var *varp, +#line 930 + const size_t *start, size_t nelems, double *value) +#line 930 +{ +#line 930 + off_t offset = NC_varoffset(ncp, varp, start); +#line 930 + size_t remaining = varp->xsz * nelems; +#line 930 + int status = NC_NOERR; +#line 930 + const void *xp; +#line 930 + +#line 930 + if(nelems == 0) +#line 930 + return NC_NOERR; +#line 930 + +#line 930 + assert(value != NULL); +#line 930 + +#line 930 + for(;;) +#line 930 + { +#line 930 + size_t extent = MIN(remaining, ncp->chunk); +#line 930 + size_t nget = ncx_howmany(varp->type, extent); +#line 930 + +#line 930 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 930 + 0, (void **)&xp); /* cast away const */ +#line 930 + if(lstatus != NC_NOERR) +#line 930 + return lstatus; +#line 930 + +#line 930 + lstatus = ncx_getn_short_double(&xp, nget, value); +#line 930 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 930 + status = lstatus; +#line 930 + +#line 930 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 930 + +#line 930 + remaining -= extent; +#line 930 + if(remaining == 0) +#line 930 + break; /* normal loop exit */ +#line 930 + offset += (off_t)extent; +#line 930 + value += nget; +#line 930 + } +#line 930 + +#line 930 + return status; +#line 930 +} +#line 930 + +static int +#line 931 +getNCvx_short_longlong(const NC3_INFO* ncp, const NC_var *varp, +#line 931 + const size_t *start, size_t nelems, longlong *value) +#line 931 +{ +#line 931 + off_t offset = NC_varoffset(ncp, varp, start); +#line 931 + size_t remaining = varp->xsz * nelems; +#line 931 + int status = NC_NOERR; +#line 931 + const void *xp; +#line 931 + +#line 931 + if(nelems == 0) +#line 931 + return NC_NOERR; +#line 931 + +#line 931 + assert(value != NULL); +#line 931 + +#line 931 + for(;;) +#line 931 + { +#line 931 + size_t extent = MIN(remaining, ncp->chunk); +#line 931 + size_t nget = ncx_howmany(varp->type, extent); +#line 931 + +#line 931 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 931 + 0, (void **)&xp); /* cast away const */ +#line 931 + if(lstatus != NC_NOERR) +#line 931 + return lstatus; +#line 931 + +#line 931 + lstatus = ncx_getn_short_longlong(&xp, nget, value); +#line 931 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 931 + status = lstatus; +#line 931 + +#line 931 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 931 + +#line 931 + remaining -= extent; +#line 931 + if(remaining == 0) +#line 931 + break; /* normal loop exit */ +#line 931 + offset += (off_t)extent; +#line 931 + value += nget; +#line 931 + } +#line 931 + +#line 931 + return status; +#line 931 +} +#line 931 + +static int +#line 932 +getNCvx_short_uint(const NC3_INFO* ncp, const NC_var *varp, +#line 932 + const size_t *start, size_t nelems, uint *value) +#line 932 +{ +#line 932 + off_t offset = NC_varoffset(ncp, varp, start); +#line 932 + size_t remaining = varp->xsz * nelems; +#line 932 + int status = NC_NOERR; +#line 932 + const void *xp; +#line 932 + +#line 932 + if(nelems == 0) +#line 932 + return NC_NOERR; +#line 932 + +#line 932 + assert(value != NULL); +#line 932 + +#line 932 + for(;;) +#line 932 + { +#line 932 + size_t extent = MIN(remaining, ncp->chunk); +#line 932 + size_t nget = ncx_howmany(varp->type, extent); +#line 932 + +#line 932 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 932 + 0, (void **)&xp); /* cast away const */ +#line 932 + if(lstatus != NC_NOERR) +#line 932 + return lstatus; +#line 932 + +#line 932 + lstatus = ncx_getn_short_uint(&xp, nget, value); +#line 932 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 932 + status = lstatus; +#line 932 + +#line 932 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 932 + +#line 932 + remaining -= extent; +#line 932 + if(remaining == 0) +#line 932 + break; /* normal loop exit */ +#line 932 + offset += (off_t)extent; +#line 932 + value += nget; +#line 932 + } +#line 932 + +#line 932 + return status; +#line 932 +} +#line 932 + +static int +#line 933 +getNCvx_short_ulonglong(const NC3_INFO* ncp, const NC_var *varp, +#line 933 + const size_t *start, size_t nelems, ulonglong *value) +#line 933 +{ +#line 933 + off_t offset = NC_varoffset(ncp, varp, start); +#line 933 + size_t remaining = varp->xsz * nelems; +#line 933 + int status = NC_NOERR; +#line 933 + const void *xp; +#line 933 + +#line 933 + if(nelems == 0) +#line 933 + return NC_NOERR; +#line 933 + +#line 933 + assert(value != NULL); +#line 933 + +#line 933 + for(;;) +#line 933 + { +#line 933 + size_t extent = MIN(remaining, ncp->chunk); +#line 933 + size_t nget = ncx_howmany(varp->type, extent); +#line 933 + +#line 933 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 933 + 0, (void **)&xp); /* cast away const */ +#line 933 + if(lstatus != NC_NOERR) +#line 933 + return lstatus; +#line 933 + +#line 933 + lstatus = ncx_getn_short_ulonglong(&xp, nget, value); +#line 933 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 933 + status = lstatus; +#line 933 + +#line 933 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 933 + +#line 933 + remaining -= extent; +#line 933 + if(remaining == 0) +#line 933 + break; /* normal loop exit */ +#line 933 + offset += (off_t)extent; +#line 933 + value += nget; +#line 933 + } +#line 933 + +#line 933 + return status; +#line 933 +} +#line 933 + +static int +#line 934 +getNCvx_short_ushort(const NC3_INFO* ncp, const NC_var *varp, +#line 934 + const size_t *start, size_t nelems, ushort *value) +#line 934 +{ +#line 934 + off_t offset = NC_varoffset(ncp, varp, start); +#line 934 + size_t remaining = varp->xsz * nelems; +#line 934 + int status = NC_NOERR; +#line 934 + const void *xp; +#line 934 + +#line 934 + if(nelems == 0) +#line 934 + return NC_NOERR; +#line 934 + +#line 934 + assert(value != NULL); +#line 934 + +#line 934 + for(;;) +#line 934 + { +#line 934 + size_t extent = MIN(remaining, ncp->chunk); +#line 934 + size_t nget = ncx_howmany(varp->type, extent); +#line 934 + +#line 934 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 934 + 0, (void **)&xp); /* cast away const */ +#line 934 + if(lstatus != NC_NOERR) +#line 934 + return lstatus; +#line 934 + +#line 934 + lstatus = ncx_getn_short_ushort(&xp, nget, value); +#line 934 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 934 + status = lstatus; +#line 934 + +#line 934 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 934 + +#line 934 + remaining -= extent; +#line 934 + if(remaining == 0) +#line 934 + break; /* normal loop exit */ +#line 934 + offset += (off_t)extent; +#line 934 + value += nget; +#line 934 + } +#line 934 + +#line 934 + return status; +#line 934 +} +#line 934 + + +static int +#line 936 +getNCvx_int_schar(const NC3_INFO* ncp, const NC_var *varp, +#line 936 + const size_t *start, size_t nelems, schar *value) +#line 936 +{ +#line 936 + off_t offset = NC_varoffset(ncp, varp, start); +#line 936 + size_t remaining = varp->xsz * nelems; +#line 936 + int status = NC_NOERR; +#line 936 + const void *xp; +#line 936 + +#line 936 + if(nelems == 0) +#line 936 + return NC_NOERR; +#line 936 + +#line 936 + assert(value != NULL); +#line 936 + +#line 936 + for(;;) +#line 936 + { +#line 936 + size_t extent = MIN(remaining, ncp->chunk); +#line 936 + size_t nget = ncx_howmany(varp->type, extent); +#line 936 + +#line 936 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 936 + 0, (void **)&xp); /* cast away const */ +#line 936 + if(lstatus != NC_NOERR) +#line 936 + return lstatus; +#line 936 + +#line 936 + lstatus = ncx_getn_int_schar(&xp, nget, value); +#line 936 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 936 + status = lstatus; +#line 936 + +#line 936 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 936 + +#line 936 + remaining -= extent; +#line 936 + if(remaining == 0) +#line 936 + break; /* normal loop exit */ +#line 936 + offset += (off_t)extent; +#line 936 + value += nget; +#line 936 + } +#line 936 + +#line 936 + return status; +#line 936 +} +#line 936 + +static int +#line 937 +getNCvx_int_uchar(const NC3_INFO* ncp, const NC_var *varp, +#line 937 + const size_t *start, size_t nelems, uchar *value) +#line 937 +{ +#line 937 + off_t offset = NC_varoffset(ncp, varp, start); +#line 937 + size_t remaining = varp->xsz * nelems; +#line 937 + int status = NC_NOERR; +#line 937 + const void *xp; +#line 937 + +#line 937 + if(nelems == 0) +#line 937 + return NC_NOERR; +#line 937 + +#line 937 + assert(value != NULL); +#line 937 + +#line 937 + for(;;) +#line 937 + { +#line 937 + size_t extent = MIN(remaining, ncp->chunk); +#line 937 + size_t nget = ncx_howmany(varp->type, extent); +#line 937 + +#line 937 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 937 + 0, (void **)&xp); /* cast away const */ +#line 937 + if(lstatus != NC_NOERR) +#line 937 + return lstatus; +#line 937 + +#line 937 + lstatus = ncx_getn_int_uchar(&xp, nget, value); +#line 937 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 937 + status = lstatus; +#line 937 + +#line 937 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 937 + +#line 937 + remaining -= extent; +#line 937 + if(remaining == 0) +#line 937 + break; /* normal loop exit */ +#line 937 + offset += (off_t)extent; +#line 937 + value += nget; +#line 937 + } +#line 937 + +#line 937 + return status; +#line 937 +} +#line 937 + +static int +#line 938 +getNCvx_int_short(const NC3_INFO* ncp, const NC_var *varp, +#line 938 + const size_t *start, size_t nelems, short *value) +#line 938 +{ +#line 938 + off_t offset = NC_varoffset(ncp, varp, start); +#line 938 + size_t remaining = varp->xsz * nelems; +#line 938 + int status = NC_NOERR; +#line 938 + const void *xp; +#line 938 + +#line 938 + if(nelems == 0) +#line 938 + return NC_NOERR; +#line 938 + +#line 938 + assert(value != NULL); +#line 938 + +#line 938 + for(;;) +#line 938 + { +#line 938 + size_t extent = MIN(remaining, ncp->chunk); +#line 938 + size_t nget = ncx_howmany(varp->type, extent); +#line 938 + +#line 938 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 938 + 0, (void **)&xp); /* cast away const */ +#line 938 + if(lstatus != NC_NOERR) +#line 938 + return lstatus; +#line 938 + +#line 938 + lstatus = ncx_getn_int_short(&xp, nget, value); +#line 938 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 938 + status = lstatus; +#line 938 + +#line 938 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 938 + +#line 938 + remaining -= extent; +#line 938 + if(remaining == 0) +#line 938 + break; /* normal loop exit */ +#line 938 + offset += (off_t)extent; +#line 938 + value += nget; +#line 938 + } +#line 938 + +#line 938 + return status; +#line 938 +} +#line 938 + +static int +#line 939 +getNCvx_int_int(const NC3_INFO* ncp, const NC_var *varp, +#line 939 + const size_t *start, size_t nelems, int *value) +#line 939 +{ +#line 939 + off_t offset = NC_varoffset(ncp, varp, start); +#line 939 + size_t remaining = varp->xsz * nelems; +#line 939 + int status = NC_NOERR; +#line 939 + const void *xp; +#line 939 + +#line 939 + if(nelems == 0) +#line 939 + return NC_NOERR; +#line 939 + +#line 939 + assert(value != NULL); +#line 939 + +#line 939 + for(;;) +#line 939 + { +#line 939 + size_t extent = MIN(remaining, ncp->chunk); +#line 939 + size_t nget = ncx_howmany(varp->type, extent); +#line 939 + +#line 939 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 939 + 0, (void **)&xp); /* cast away const */ +#line 939 + if(lstatus != NC_NOERR) +#line 939 + return lstatus; +#line 939 + +#line 939 + lstatus = ncx_getn_int_int(&xp, nget, value); +#line 939 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 939 + status = lstatus; +#line 939 + +#line 939 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 939 + +#line 939 + remaining -= extent; +#line 939 + if(remaining == 0) +#line 939 + break; /* normal loop exit */ +#line 939 + offset += (off_t)extent; +#line 939 + value += nget; +#line 939 + } +#line 939 + +#line 939 + return status; +#line 939 +} +#line 939 + +static int +#line 940 +getNCvx_int_float(const NC3_INFO* ncp, const NC_var *varp, +#line 940 + const size_t *start, size_t nelems, float *value) +#line 940 +{ +#line 940 + off_t offset = NC_varoffset(ncp, varp, start); +#line 940 + size_t remaining = varp->xsz * nelems; +#line 940 + int status = NC_NOERR; +#line 940 + const void *xp; +#line 940 + +#line 940 + if(nelems == 0) +#line 940 + return NC_NOERR; +#line 940 + +#line 940 + assert(value != NULL); +#line 940 + +#line 940 + for(;;) +#line 940 + { +#line 940 + size_t extent = MIN(remaining, ncp->chunk); +#line 940 + size_t nget = ncx_howmany(varp->type, extent); +#line 940 + +#line 940 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 940 + 0, (void **)&xp); /* cast away const */ +#line 940 + if(lstatus != NC_NOERR) +#line 940 + return lstatus; +#line 940 + +#line 940 + lstatus = ncx_getn_int_float(&xp, nget, value); +#line 940 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 940 + status = lstatus; +#line 940 + +#line 940 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 940 + +#line 940 + remaining -= extent; +#line 940 + if(remaining == 0) +#line 940 + break; /* normal loop exit */ +#line 940 + offset += (off_t)extent; +#line 940 + value += nget; +#line 940 + } +#line 940 + +#line 940 + return status; +#line 940 +} +#line 940 + +static int +#line 941 +getNCvx_int_double(const NC3_INFO* ncp, const NC_var *varp, +#line 941 + const size_t *start, size_t nelems, double *value) +#line 941 +{ +#line 941 + off_t offset = NC_varoffset(ncp, varp, start); +#line 941 + size_t remaining = varp->xsz * nelems; +#line 941 + int status = NC_NOERR; +#line 941 + const void *xp; +#line 941 + +#line 941 + if(nelems == 0) +#line 941 + return NC_NOERR; +#line 941 + +#line 941 + assert(value != NULL); +#line 941 + +#line 941 + for(;;) +#line 941 + { +#line 941 + size_t extent = MIN(remaining, ncp->chunk); +#line 941 + size_t nget = ncx_howmany(varp->type, extent); +#line 941 + +#line 941 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 941 + 0, (void **)&xp); /* cast away const */ +#line 941 + if(lstatus != NC_NOERR) +#line 941 + return lstatus; +#line 941 + +#line 941 + lstatus = ncx_getn_int_double(&xp, nget, value); +#line 941 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 941 + status = lstatus; +#line 941 + +#line 941 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 941 + +#line 941 + remaining -= extent; +#line 941 + if(remaining == 0) +#line 941 + break; /* normal loop exit */ +#line 941 + offset += (off_t)extent; +#line 941 + value += nget; +#line 941 + } +#line 941 + +#line 941 + return status; +#line 941 +} +#line 941 + +static int +#line 942 +getNCvx_int_longlong(const NC3_INFO* ncp, const NC_var *varp, +#line 942 + const size_t *start, size_t nelems, longlong *value) +#line 942 +{ +#line 942 + off_t offset = NC_varoffset(ncp, varp, start); +#line 942 + size_t remaining = varp->xsz * nelems; +#line 942 + int status = NC_NOERR; +#line 942 + const void *xp; +#line 942 + +#line 942 + if(nelems == 0) +#line 942 + return NC_NOERR; +#line 942 + +#line 942 + assert(value != NULL); +#line 942 + +#line 942 + for(;;) +#line 942 + { +#line 942 + size_t extent = MIN(remaining, ncp->chunk); +#line 942 + size_t nget = ncx_howmany(varp->type, extent); +#line 942 + +#line 942 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 942 + 0, (void **)&xp); /* cast away const */ +#line 942 + if(lstatus != NC_NOERR) +#line 942 + return lstatus; +#line 942 + +#line 942 + lstatus = ncx_getn_int_longlong(&xp, nget, value); +#line 942 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 942 + status = lstatus; +#line 942 + +#line 942 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 942 + +#line 942 + remaining -= extent; +#line 942 + if(remaining == 0) +#line 942 + break; /* normal loop exit */ +#line 942 + offset += (off_t)extent; +#line 942 + value += nget; +#line 942 + } +#line 942 + +#line 942 + return status; +#line 942 +} +#line 942 + +static int +#line 943 +getNCvx_int_uint(const NC3_INFO* ncp, const NC_var *varp, +#line 943 + const size_t *start, size_t nelems, uint *value) +#line 943 +{ +#line 943 + off_t offset = NC_varoffset(ncp, varp, start); +#line 943 + size_t remaining = varp->xsz * nelems; +#line 943 + int status = NC_NOERR; +#line 943 + const void *xp; +#line 943 + +#line 943 + if(nelems == 0) +#line 943 + return NC_NOERR; +#line 943 + +#line 943 + assert(value != NULL); +#line 943 + +#line 943 + for(;;) +#line 943 + { +#line 943 + size_t extent = MIN(remaining, ncp->chunk); +#line 943 + size_t nget = ncx_howmany(varp->type, extent); +#line 943 + +#line 943 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 943 + 0, (void **)&xp); /* cast away const */ +#line 943 + if(lstatus != NC_NOERR) +#line 943 + return lstatus; +#line 943 + +#line 943 + lstatus = ncx_getn_int_uint(&xp, nget, value); +#line 943 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 943 + status = lstatus; +#line 943 + +#line 943 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 943 + +#line 943 + remaining -= extent; +#line 943 + if(remaining == 0) +#line 943 + break; /* normal loop exit */ +#line 943 + offset += (off_t)extent; +#line 943 + value += nget; +#line 943 + } +#line 943 + +#line 943 + return status; +#line 943 +} +#line 943 + +static int +#line 944 +getNCvx_int_ulonglong(const NC3_INFO* ncp, const NC_var *varp, +#line 944 + const size_t *start, size_t nelems, ulonglong *value) +#line 944 +{ +#line 944 + off_t offset = NC_varoffset(ncp, varp, start); +#line 944 + size_t remaining = varp->xsz * nelems; +#line 944 + int status = NC_NOERR; +#line 944 + const void *xp; +#line 944 + +#line 944 + if(nelems == 0) +#line 944 + return NC_NOERR; +#line 944 + +#line 944 + assert(value != NULL); +#line 944 + +#line 944 + for(;;) +#line 944 + { +#line 944 + size_t extent = MIN(remaining, ncp->chunk); +#line 944 + size_t nget = ncx_howmany(varp->type, extent); +#line 944 + +#line 944 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 944 + 0, (void **)&xp); /* cast away const */ +#line 944 + if(lstatus != NC_NOERR) +#line 944 + return lstatus; +#line 944 + +#line 944 + lstatus = ncx_getn_int_ulonglong(&xp, nget, value); +#line 944 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 944 + status = lstatus; +#line 944 + +#line 944 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 944 + +#line 944 + remaining -= extent; +#line 944 + if(remaining == 0) +#line 944 + break; /* normal loop exit */ +#line 944 + offset += (off_t)extent; +#line 944 + value += nget; +#line 944 + } +#line 944 + +#line 944 + return status; +#line 944 +} +#line 944 + +static int +#line 945 +getNCvx_int_ushort(const NC3_INFO* ncp, const NC_var *varp, +#line 945 + const size_t *start, size_t nelems, ushort *value) +#line 945 +{ +#line 945 + off_t offset = NC_varoffset(ncp, varp, start); +#line 945 + size_t remaining = varp->xsz * nelems; +#line 945 + int status = NC_NOERR; +#line 945 + const void *xp; +#line 945 + +#line 945 + if(nelems == 0) +#line 945 + return NC_NOERR; +#line 945 + +#line 945 + assert(value != NULL); +#line 945 + +#line 945 + for(;;) +#line 945 + { +#line 945 + size_t extent = MIN(remaining, ncp->chunk); +#line 945 + size_t nget = ncx_howmany(varp->type, extent); +#line 945 + +#line 945 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 945 + 0, (void **)&xp); /* cast away const */ +#line 945 + if(lstatus != NC_NOERR) +#line 945 + return lstatus; +#line 945 + +#line 945 + lstatus = ncx_getn_int_ushort(&xp, nget, value); +#line 945 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 945 + status = lstatus; +#line 945 + +#line 945 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 945 + +#line 945 + remaining -= extent; +#line 945 + if(remaining == 0) +#line 945 + break; /* normal loop exit */ +#line 945 + offset += (off_t)extent; +#line 945 + value += nget; +#line 945 + } +#line 945 + +#line 945 + return status; +#line 945 +} +#line 945 + + +static int +#line 947 +getNCvx_float_schar(const NC3_INFO* ncp, const NC_var *varp, +#line 947 + const size_t *start, size_t nelems, schar *value) +#line 947 +{ +#line 947 + off_t offset = NC_varoffset(ncp, varp, start); +#line 947 + size_t remaining = varp->xsz * nelems; +#line 947 + int status = NC_NOERR; +#line 947 + const void *xp; +#line 947 + +#line 947 + if(nelems == 0) +#line 947 + return NC_NOERR; +#line 947 + +#line 947 + assert(value != NULL); +#line 947 + +#line 947 + for(;;) +#line 947 + { +#line 947 + size_t extent = MIN(remaining, ncp->chunk); +#line 947 + size_t nget = ncx_howmany(varp->type, extent); +#line 947 + +#line 947 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 947 + 0, (void **)&xp); /* cast away const */ +#line 947 + if(lstatus != NC_NOERR) +#line 947 + return lstatus; +#line 947 + +#line 947 + lstatus = ncx_getn_float_schar(&xp, nget, value); +#line 947 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 947 + status = lstatus; +#line 947 + +#line 947 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 947 + +#line 947 + remaining -= extent; +#line 947 + if(remaining == 0) +#line 947 + break; /* normal loop exit */ +#line 947 + offset += (off_t)extent; +#line 947 + value += nget; +#line 947 + } +#line 947 + +#line 947 + return status; +#line 947 +} +#line 947 + +static int +#line 948 +getNCvx_float_uchar(const NC3_INFO* ncp, const NC_var *varp, +#line 948 + const size_t *start, size_t nelems, uchar *value) +#line 948 +{ +#line 948 + off_t offset = NC_varoffset(ncp, varp, start); +#line 948 + size_t remaining = varp->xsz * nelems; +#line 948 + int status = NC_NOERR; +#line 948 + const void *xp; +#line 948 + +#line 948 + if(nelems == 0) +#line 948 + return NC_NOERR; +#line 948 + +#line 948 + assert(value != NULL); +#line 948 + +#line 948 + for(;;) +#line 948 + { +#line 948 + size_t extent = MIN(remaining, ncp->chunk); +#line 948 + size_t nget = ncx_howmany(varp->type, extent); +#line 948 + +#line 948 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 948 + 0, (void **)&xp); /* cast away const */ +#line 948 + if(lstatus != NC_NOERR) +#line 948 + return lstatus; +#line 948 + +#line 948 + lstatus = ncx_getn_float_uchar(&xp, nget, value); +#line 948 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 948 + status = lstatus; +#line 948 + +#line 948 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 948 + +#line 948 + remaining -= extent; +#line 948 + if(remaining == 0) +#line 948 + break; /* normal loop exit */ +#line 948 + offset += (off_t)extent; +#line 948 + value += nget; +#line 948 + } +#line 948 + +#line 948 + return status; +#line 948 +} +#line 948 + +static int +#line 949 +getNCvx_float_short(const NC3_INFO* ncp, const NC_var *varp, +#line 949 + const size_t *start, size_t nelems, short *value) +#line 949 +{ +#line 949 + off_t offset = NC_varoffset(ncp, varp, start); +#line 949 + size_t remaining = varp->xsz * nelems; +#line 949 + int status = NC_NOERR; +#line 949 + const void *xp; +#line 949 + +#line 949 + if(nelems == 0) +#line 949 + return NC_NOERR; +#line 949 + +#line 949 + assert(value != NULL); +#line 949 + +#line 949 + for(;;) +#line 949 + { +#line 949 + size_t extent = MIN(remaining, ncp->chunk); +#line 949 + size_t nget = ncx_howmany(varp->type, extent); +#line 949 + +#line 949 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 949 + 0, (void **)&xp); /* cast away const */ +#line 949 + if(lstatus != NC_NOERR) +#line 949 + return lstatus; +#line 949 + +#line 949 + lstatus = ncx_getn_float_short(&xp, nget, value); +#line 949 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 949 + status = lstatus; +#line 949 + +#line 949 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 949 + +#line 949 + remaining -= extent; +#line 949 + if(remaining == 0) +#line 949 + break; /* normal loop exit */ +#line 949 + offset += (off_t)extent; +#line 949 + value += nget; +#line 949 + } +#line 949 + +#line 949 + return status; +#line 949 +} +#line 949 + +static int +#line 950 +getNCvx_float_int(const NC3_INFO* ncp, const NC_var *varp, +#line 950 + const size_t *start, size_t nelems, int *value) +#line 950 +{ +#line 950 + off_t offset = NC_varoffset(ncp, varp, start); +#line 950 + size_t remaining = varp->xsz * nelems; +#line 950 + int status = NC_NOERR; +#line 950 + const void *xp; +#line 950 + +#line 950 + if(nelems == 0) +#line 950 + return NC_NOERR; +#line 950 + +#line 950 + assert(value != NULL); +#line 950 + +#line 950 + for(;;) +#line 950 + { +#line 950 + size_t extent = MIN(remaining, ncp->chunk); +#line 950 + size_t nget = ncx_howmany(varp->type, extent); +#line 950 + +#line 950 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 950 + 0, (void **)&xp); /* cast away const */ +#line 950 + if(lstatus != NC_NOERR) +#line 950 + return lstatus; +#line 950 + +#line 950 + lstatus = ncx_getn_float_int(&xp, nget, value); +#line 950 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 950 + status = lstatus; +#line 950 + +#line 950 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 950 + +#line 950 + remaining -= extent; +#line 950 + if(remaining == 0) +#line 950 + break; /* normal loop exit */ +#line 950 + offset += (off_t)extent; +#line 950 + value += nget; +#line 950 + } +#line 950 + +#line 950 + return status; +#line 950 +} +#line 950 + +static int +#line 951 +getNCvx_float_float(const NC3_INFO* ncp, const NC_var *varp, +#line 951 + const size_t *start, size_t nelems, float *value) +#line 951 +{ +#line 951 + off_t offset = NC_varoffset(ncp, varp, start); +#line 951 + size_t remaining = varp->xsz * nelems; +#line 951 + int status = NC_NOERR; +#line 951 + const void *xp; +#line 951 + +#line 951 + if(nelems == 0) +#line 951 + return NC_NOERR; +#line 951 + +#line 951 + assert(value != NULL); +#line 951 + +#line 951 + for(;;) +#line 951 + { +#line 951 + size_t extent = MIN(remaining, ncp->chunk); +#line 951 + size_t nget = ncx_howmany(varp->type, extent); +#line 951 + +#line 951 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 951 + 0, (void **)&xp); /* cast away const */ +#line 951 + if(lstatus != NC_NOERR) +#line 951 + return lstatus; +#line 951 + +#line 951 + lstatus = ncx_getn_float_float(&xp, nget, value); +#line 951 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 951 + status = lstatus; +#line 951 + +#line 951 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 951 + +#line 951 + remaining -= extent; +#line 951 + if(remaining == 0) +#line 951 + break; /* normal loop exit */ +#line 951 + offset += (off_t)extent; +#line 951 + value += nget; +#line 951 + } +#line 951 + +#line 951 + return status; +#line 951 +} +#line 951 + +static int +#line 952 +getNCvx_float_double(const NC3_INFO* ncp, const NC_var *varp, +#line 952 + const size_t *start, size_t nelems, double *value) +#line 952 +{ +#line 952 + off_t offset = NC_varoffset(ncp, varp, start); +#line 952 + size_t remaining = varp->xsz * nelems; +#line 952 + int status = NC_NOERR; +#line 952 + const void *xp; +#line 952 + +#line 952 + if(nelems == 0) +#line 952 + return NC_NOERR; +#line 952 + +#line 952 + assert(value != NULL); +#line 952 + +#line 952 + for(;;) +#line 952 + { +#line 952 + size_t extent = MIN(remaining, ncp->chunk); +#line 952 + size_t nget = ncx_howmany(varp->type, extent); +#line 952 + +#line 952 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 952 + 0, (void **)&xp); /* cast away const */ +#line 952 + if(lstatus != NC_NOERR) +#line 952 + return lstatus; +#line 952 + +#line 952 + lstatus = ncx_getn_float_double(&xp, nget, value); +#line 952 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 952 + status = lstatus; +#line 952 + +#line 952 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 952 + +#line 952 + remaining -= extent; +#line 952 + if(remaining == 0) +#line 952 + break; /* normal loop exit */ +#line 952 + offset += (off_t)extent; +#line 952 + value += nget; +#line 952 + } +#line 952 + +#line 952 + return status; +#line 952 +} +#line 952 + +static int +#line 953 +getNCvx_float_longlong(const NC3_INFO* ncp, const NC_var *varp, +#line 953 + const size_t *start, size_t nelems, longlong *value) +#line 953 +{ +#line 953 + off_t offset = NC_varoffset(ncp, varp, start); +#line 953 + size_t remaining = varp->xsz * nelems; +#line 953 + int status = NC_NOERR; +#line 953 + const void *xp; +#line 953 + +#line 953 + if(nelems == 0) +#line 953 + return NC_NOERR; +#line 953 + +#line 953 + assert(value != NULL); +#line 953 + +#line 953 + for(;;) +#line 953 + { +#line 953 + size_t extent = MIN(remaining, ncp->chunk); +#line 953 + size_t nget = ncx_howmany(varp->type, extent); +#line 953 + +#line 953 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 953 + 0, (void **)&xp); /* cast away const */ +#line 953 + if(lstatus != NC_NOERR) +#line 953 + return lstatus; +#line 953 + +#line 953 + lstatus = ncx_getn_float_longlong(&xp, nget, value); +#line 953 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 953 + status = lstatus; +#line 953 + +#line 953 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 953 + +#line 953 + remaining -= extent; +#line 953 + if(remaining == 0) +#line 953 + break; /* normal loop exit */ +#line 953 + offset += (off_t)extent; +#line 953 + value += nget; +#line 953 + } +#line 953 + +#line 953 + return status; +#line 953 +} +#line 953 + +static int +#line 954 +getNCvx_float_uint(const NC3_INFO* ncp, const NC_var *varp, +#line 954 + const size_t *start, size_t nelems, uint *value) +#line 954 +{ +#line 954 + off_t offset = NC_varoffset(ncp, varp, start); +#line 954 + size_t remaining = varp->xsz * nelems; +#line 954 + int status = NC_NOERR; +#line 954 + const void *xp; +#line 954 + +#line 954 + if(nelems == 0) +#line 954 + return NC_NOERR; +#line 954 + +#line 954 + assert(value != NULL); +#line 954 + +#line 954 + for(;;) +#line 954 + { +#line 954 + size_t extent = MIN(remaining, ncp->chunk); +#line 954 + size_t nget = ncx_howmany(varp->type, extent); +#line 954 + +#line 954 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 954 + 0, (void **)&xp); /* cast away const */ +#line 954 + if(lstatus != NC_NOERR) +#line 954 + return lstatus; +#line 954 + +#line 954 + lstatus = ncx_getn_float_uint(&xp, nget, value); +#line 954 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 954 + status = lstatus; +#line 954 + +#line 954 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 954 + +#line 954 + remaining -= extent; +#line 954 + if(remaining == 0) +#line 954 + break; /* normal loop exit */ +#line 954 + offset += (off_t)extent; +#line 954 + value += nget; +#line 954 + } +#line 954 + +#line 954 + return status; +#line 954 +} +#line 954 + +static int +#line 955 +getNCvx_float_ulonglong(const NC3_INFO* ncp, const NC_var *varp, +#line 955 + const size_t *start, size_t nelems, ulonglong *value) +#line 955 +{ +#line 955 + off_t offset = NC_varoffset(ncp, varp, start); +#line 955 + size_t remaining = varp->xsz * nelems; +#line 955 + int status = NC_NOERR; +#line 955 + const void *xp; +#line 955 + +#line 955 + if(nelems == 0) +#line 955 + return NC_NOERR; +#line 955 + +#line 955 + assert(value != NULL); +#line 955 + +#line 955 + for(;;) +#line 955 + { +#line 955 + size_t extent = MIN(remaining, ncp->chunk); +#line 955 + size_t nget = ncx_howmany(varp->type, extent); +#line 955 + +#line 955 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 955 + 0, (void **)&xp); /* cast away const */ +#line 955 + if(lstatus != NC_NOERR) +#line 955 + return lstatus; +#line 955 + +#line 955 + lstatus = ncx_getn_float_ulonglong(&xp, nget, value); +#line 955 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 955 + status = lstatus; +#line 955 + +#line 955 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 955 + +#line 955 + remaining -= extent; +#line 955 + if(remaining == 0) +#line 955 + break; /* normal loop exit */ +#line 955 + offset += (off_t)extent; +#line 955 + value += nget; +#line 955 + } +#line 955 + +#line 955 + return status; +#line 955 +} +#line 955 + +static int +#line 956 +getNCvx_float_ushort(const NC3_INFO* ncp, const NC_var *varp, +#line 956 + const size_t *start, size_t nelems, ushort *value) +#line 956 +{ +#line 956 + off_t offset = NC_varoffset(ncp, varp, start); +#line 956 + size_t remaining = varp->xsz * nelems; +#line 956 + int status = NC_NOERR; +#line 956 + const void *xp; +#line 956 + +#line 956 + if(nelems == 0) +#line 956 + return NC_NOERR; +#line 956 + +#line 956 + assert(value != NULL); +#line 956 + +#line 956 + for(;;) +#line 956 + { +#line 956 + size_t extent = MIN(remaining, ncp->chunk); +#line 956 + size_t nget = ncx_howmany(varp->type, extent); +#line 956 + +#line 956 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 956 + 0, (void **)&xp); /* cast away const */ +#line 956 + if(lstatus != NC_NOERR) +#line 956 + return lstatus; +#line 956 + +#line 956 + lstatus = ncx_getn_float_ushort(&xp, nget, value); +#line 956 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 956 + status = lstatus; +#line 956 + +#line 956 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 956 + +#line 956 + remaining -= extent; +#line 956 + if(remaining == 0) +#line 956 + break; /* normal loop exit */ +#line 956 + offset += (off_t)extent; +#line 956 + value += nget; +#line 956 + } +#line 956 + +#line 956 + return status; +#line 956 +} +#line 956 + + +static int +#line 958 +getNCvx_double_schar(const NC3_INFO* ncp, const NC_var *varp, +#line 958 + const size_t *start, size_t nelems, schar *value) +#line 958 +{ +#line 958 + off_t offset = NC_varoffset(ncp, varp, start); +#line 958 + size_t remaining = varp->xsz * nelems; +#line 958 + int status = NC_NOERR; +#line 958 + const void *xp; +#line 958 + +#line 958 + if(nelems == 0) +#line 958 + return NC_NOERR; +#line 958 + +#line 958 + assert(value != NULL); +#line 958 + +#line 958 + for(;;) +#line 958 + { +#line 958 + size_t extent = MIN(remaining, ncp->chunk); +#line 958 + size_t nget = ncx_howmany(varp->type, extent); +#line 958 + +#line 958 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 958 + 0, (void **)&xp); /* cast away const */ +#line 958 + if(lstatus != NC_NOERR) +#line 958 + return lstatus; +#line 958 + +#line 958 + lstatus = ncx_getn_double_schar(&xp, nget, value); +#line 958 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 958 + status = lstatus; +#line 958 + +#line 958 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 958 + +#line 958 + remaining -= extent; +#line 958 + if(remaining == 0) +#line 958 + break; /* normal loop exit */ +#line 958 + offset += (off_t)extent; +#line 958 + value += nget; +#line 958 + } +#line 958 + +#line 958 + return status; +#line 958 +} +#line 958 + +static int +#line 959 +getNCvx_double_uchar(const NC3_INFO* ncp, const NC_var *varp, +#line 959 + const size_t *start, size_t nelems, uchar *value) +#line 959 +{ +#line 959 + off_t offset = NC_varoffset(ncp, varp, start); +#line 959 + size_t remaining = varp->xsz * nelems; +#line 959 + int status = NC_NOERR; +#line 959 + const void *xp; +#line 959 + +#line 959 + if(nelems == 0) +#line 959 + return NC_NOERR; +#line 959 + +#line 959 + assert(value != NULL); +#line 959 + +#line 959 + for(;;) +#line 959 + { +#line 959 + size_t extent = MIN(remaining, ncp->chunk); +#line 959 + size_t nget = ncx_howmany(varp->type, extent); +#line 959 + +#line 959 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 959 + 0, (void **)&xp); /* cast away const */ +#line 959 + if(lstatus != NC_NOERR) +#line 959 + return lstatus; +#line 959 + +#line 959 + lstatus = ncx_getn_double_uchar(&xp, nget, value); +#line 959 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 959 + status = lstatus; +#line 959 + +#line 959 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 959 + +#line 959 + remaining -= extent; +#line 959 + if(remaining == 0) +#line 959 + break; /* normal loop exit */ +#line 959 + offset += (off_t)extent; +#line 959 + value += nget; +#line 959 + } +#line 959 + +#line 959 + return status; +#line 959 +} +#line 959 + +static int +#line 960 +getNCvx_double_short(const NC3_INFO* ncp, const NC_var *varp, +#line 960 + const size_t *start, size_t nelems, short *value) +#line 960 +{ +#line 960 + off_t offset = NC_varoffset(ncp, varp, start); +#line 960 + size_t remaining = varp->xsz * nelems; +#line 960 + int status = NC_NOERR; +#line 960 + const void *xp; +#line 960 + +#line 960 + if(nelems == 0) +#line 960 + return NC_NOERR; +#line 960 + +#line 960 + assert(value != NULL); +#line 960 + +#line 960 + for(;;) +#line 960 + { +#line 960 + size_t extent = MIN(remaining, ncp->chunk); +#line 960 + size_t nget = ncx_howmany(varp->type, extent); +#line 960 + +#line 960 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 960 + 0, (void **)&xp); /* cast away const */ +#line 960 + if(lstatus != NC_NOERR) +#line 960 + return lstatus; +#line 960 + +#line 960 + lstatus = ncx_getn_double_short(&xp, nget, value); +#line 960 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 960 + status = lstatus; +#line 960 + +#line 960 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 960 + +#line 960 + remaining -= extent; +#line 960 + if(remaining == 0) +#line 960 + break; /* normal loop exit */ +#line 960 + offset += (off_t)extent; +#line 960 + value += nget; +#line 960 + } +#line 960 + +#line 960 + return status; +#line 960 +} +#line 960 + +static int +#line 961 +getNCvx_double_int(const NC3_INFO* ncp, const NC_var *varp, +#line 961 + const size_t *start, size_t nelems, int *value) +#line 961 +{ +#line 961 + off_t offset = NC_varoffset(ncp, varp, start); +#line 961 + size_t remaining = varp->xsz * nelems; +#line 961 + int status = NC_NOERR; +#line 961 + const void *xp; +#line 961 + +#line 961 + if(nelems == 0) +#line 961 + return NC_NOERR; +#line 961 + +#line 961 + assert(value != NULL); +#line 961 + +#line 961 + for(;;) +#line 961 + { +#line 961 + size_t extent = MIN(remaining, ncp->chunk); +#line 961 + size_t nget = ncx_howmany(varp->type, extent); +#line 961 + +#line 961 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 961 + 0, (void **)&xp); /* cast away const */ +#line 961 + if(lstatus != NC_NOERR) +#line 961 + return lstatus; +#line 961 + +#line 961 + lstatus = ncx_getn_double_int(&xp, nget, value); +#line 961 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 961 + status = lstatus; +#line 961 + +#line 961 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 961 + +#line 961 + remaining -= extent; +#line 961 + if(remaining == 0) +#line 961 + break; /* normal loop exit */ +#line 961 + offset += (off_t)extent; +#line 961 + value += nget; +#line 961 + } +#line 961 + +#line 961 + return status; +#line 961 +} +#line 961 + +static int +#line 962 +getNCvx_double_float(const NC3_INFO* ncp, const NC_var *varp, +#line 962 + const size_t *start, size_t nelems, float *value) +#line 962 +{ +#line 962 + off_t offset = NC_varoffset(ncp, varp, start); +#line 962 + size_t remaining = varp->xsz * nelems; +#line 962 + int status = NC_NOERR; +#line 962 + const void *xp; +#line 962 + +#line 962 + if(nelems == 0) +#line 962 + return NC_NOERR; +#line 962 + +#line 962 + assert(value != NULL); +#line 962 + +#line 962 + for(;;) +#line 962 + { +#line 962 + size_t extent = MIN(remaining, ncp->chunk); +#line 962 + size_t nget = ncx_howmany(varp->type, extent); +#line 962 + +#line 962 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 962 + 0, (void **)&xp); /* cast away const */ +#line 962 + if(lstatus != NC_NOERR) +#line 962 + return lstatus; +#line 962 + +#line 962 + lstatus = ncx_getn_double_float(&xp, nget, value); +#line 962 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 962 + status = lstatus; +#line 962 + +#line 962 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 962 + +#line 962 + remaining -= extent; +#line 962 + if(remaining == 0) +#line 962 + break; /* normal loop exit */ +#line 962 + offset += (off_t)extent; +#line 962 + value += nget; +#line 962 + } +#line 962 + +#line 962 + return status; +#line 962 +} +#line 962 + +static int +#line 963 +getNCvx_double_double(const NC3_INFO* ncp, const NC_var *varp, +#line 963 + const size_t *start, size_t nelems, double *value) +#line 963 +{ +#line 963 + off_t offset = NC_varoffset(ncp, varp, start); +#line 963 + size_t remaining = varp->xsz * nelems; +#line 963 + int status = NC_NOERR; +#line 963 + const void *xp; +#line 963 + +#line 963 + if(nelems == 0) +#line 963 + return NC_NOERR; +#line 963 + +#line 963 + assert(value != NULL); +#line 963 + +#line 963 + for(;;) +#line 963 + { +#line 963 + size_t extent = MIN(remaining, ncp->chunk); +#line 963 + size_t nget = ncx_howmany(varp->type, extent); +#line 963 + +#line 963 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 963 + 0, (void **)&xp); /* cast away const */ +#line 963 + if(lstatus != NC_NOERR) +#line 963 + return lstatus; +#line 963 + +#line 963 + lstatus = ncx_getn_double_double(&xp, nget, value); +#line 963 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 963 + status = lstatus; +#line 963 + +#line 963 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 963 + +#line 963 + remaining -= extent; +#line 963 + if(remaining == 0) +#line 963 + break; /* normal loop exit */ +#line 963 + offset += (off_t)extent; +#line 963 + value += nget; +#line 963 + } +#line 963 + +#line 963 + return status; +#line 963 +} +#line 963 + +static int +#line 964 +getNCvx_double_longlong(const NC3_INFO* ncp, const NC_var *varp, +#line 964 + const size_t *start, size_t nelems, longlong *value) +#line 964 +{ +#line 964 + off_t offset = NC_varoffset(ncp, varp, start); +#line 964 + size_t remaining = varp->xsz * nelems; +#line 964 + int status = NC_NOERR; +#line 964 + const void *xp; +#line 964 + +#line 964 + if(nelems == 0) +#line 964 + return NC_NOERR; +#line 964 + +#line 964 + assert(value != NULL); +#line 964 + +#line 964 + for(;;) +#line 964 + { +#line 964 + size_t extent = MIN(remaining, ncp->chunk); +#line 964 + size_t nget = ncx_howmany(varp->type, extent); +#line 964 + +#line 964 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 964 + 0, (void **)&xp); /* cast away const */ +#line 964 + if(lstatus != NC_NOERR) +#line 964 + return lstatus; +#line 964 + +#line 964 + lstatus = ncx_getn_double_longlong(&xp, nget, value); +#line 964 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 964 + status = lstatus; +#line 964 + +#line 964 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 964 + +#line 964 + remaining -= extent; +#line 964 + if(remaining == 0) +#line 964 + break; /* normal loop exit */ +#line 964 + offset += (off_t)extent; +#line 964 + value += nget; +#line 964 + } +#line 964 + +#line 964 + return status; +#line 964 +} +#line 964 + +static int +#line 965 +getNCvx_double_uint(const NC3_INFO* ncp, const NC_var *varp, +#line 965 + const size_t *start, size_t nelems, uint *value) +#line 965 +{ +#line 965 + off_t offset = NC_varoffset(ncp, varp, start); +#line 965 + size_t remaining = varp->xsz * nelems; +#line 965 + int status = NC_NOERR; +#line 965 + const void *xp; +#line 965 + +#line 965 + if(nelems == 0) +#line 965 + return NC_NOERR; +#line 965 + +#line 965 + assert(value != NULL); +#line 965 + +#line 965 + for(;;) +#line 965 + { +#line 965 + size_t extent = MIN(remaining, ncp->chunk); +#line 965 + size_t nget = ncx_howmany(varp->type, extent); +#line 965 + +#line 965 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 965 + 0, (void **)&xp); /* cast away const */ +#line 965 + if(lstatus != NC_NOERR) +#line 965 + return lstatus; +#line 965 + +#line 965 + lstatus = ncx_getn_double_uint(&xp, nget, value); +#line 965 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 965 + status = lstatus; +#line 965 + +#line 965 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 965 + +#line 965 + remaining -= extent; +#line 965 + if(remaining == 0) +#line 965 + break; /* normal loop exit */ +#line 965 + offset += (off_t)extent; +#line 965 + value += nget; +#line 965 + } +#line 965 + +#line 965 + return status; +#line 965 +} +#line 965 + +static int +#line 966 +getNCvx_double_ulonglong(const NC3_INFO* ncp, const NC_var *varp, +#line 966 + const size_t *start, size_t nelems, ulonglong *value) +#line 966 +{ +#line 966 + off_t offset = NC_varoffset(ncp, varp, start); +#line 966 + size_t remaining = varp->xsz * nelems; +#line 966 + int status = NC_NOERR; +#line 966 + const void *xp; +#line 966 + +#line 966 + if(nelems == 0) +#line 966 + return NC_NOERR; +#line 966 + +#line 966 + assert(value != NULL); +#line 966 + +#line 966 + for(;;) +#line 966 + { +#line 966 + size_t extent = MIN(remaining, ncp->chunk); +#line 966 + size_t nget = ncx_howmany(varp->type, extent); +#line 966 + +#line 966 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 966 + 0, (void **)&xp); /* cast away const */ +#line 966 + if(lstatus != NC_NOERR) +#line 966 + return lstatus; +#line 966 + +#line 966 + lstatus = ncx_getn_double_ulonglong(&xp, nget, value); +#line 966 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 966 + status = lstatus; +#line 966 + +#line 966 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 966 + +#line 966 + remaining -= extent; +#line 966 + if(remaining == 0) +#line 966 + break; /* normal loop exit */ +#line 966 + offset += (off_t)extent; +#line 966 + value += nget; +#line 966 + } +#line 966 + +#line 966 + return status; +#line 966 +} +#line 966 + +static int +#line 967 +getNCvx_double_ushort(const NC3_INFO* ncp, const NC_var *varp, +#line 967 + const size_t *start, size_t nelems, ushort *value) +#line 967 +{ +#line 967 + off_t offset = NC_varoffset(ncp, varp, start); +#line 967 + size_t remaining = varp->xsz * nelems; +#line 967 + int status = NC_NOERR; +#line 967 + const void *xp; +#line 967 + +#line 967 + if(nelems == 0) +#line 967 + return NC_NOERR; +#line 967 + +#line 967 + assert(value != NULL); +#line 967 + +#line 967 + for(;;) +#line 967 + { +#line 967 + size_t extent = MIN(remaining, ncp->chunk); +#line 967 + size_t nget = ncx_howmany(varp->type, extent); +#line 967 + +#line 967 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 967 + 0, (void **)&xp); /* cast away const */ +#line 967 + if(lstatus != NC_NOERR) +#line 967 + return lstatus; +#line 967 + +#line 967 + lstatus = ncx_getn_double_ushort(&xp, nget, value); +#line 967 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 967 + status = lstatus; +#line 967 + +#line 967 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 967 + +#line 967 + remaining -= extent; +#line 967 + if(remaining == 0) +#line 967 + break; /* normal loop exit */ +#line 967 + offset += (off_t)extent; +#line 967 + value += nget; +#line 967 + } +#line 967 + +#line 967 + return status; +#line 967 +} +#line 967 + + +static int +#line 969 +getNCvx_uchar_schar(const NC3_INFO* ncp, const NC_var *varp, +#line 969 + const size_t *start, size_t nelems, schar *value) +#line 969 +{ +#line 969 + off_t offset = NC_varoffset(ncp, varp, start); +#line 969 + size_t remaining = varp->xsz * nelems; +#line 969 + int status = NC_NOERR; +#line 969 + const void *xp; +#line 969 + +#line 969 + if(nelems == 0) +#line 969 + return NC_NOERR; +#line 969 + +#line 969 + assert(value != NULL); +#line 969 + +#line 969 + for(;;) +#line 969 + { +#line 969 + size_t extent = MIN(remaining, ncp->chunk); +#line 969 + size_t nget = ncx_howmany(varp->type, extent); +#line 969 + +#line 969 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 969 + 0, (void **)&xp); /* cast away const */ +#line 969 + if(lstatus != NC_NOERR) +#line 969 + return lstatus; +#line 969 + +#line 969 + lstatus = ncx_getn_uchar_schar(&xp, nget, value); +#line 969 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 969 + status = lstatus; +#line 969 + +#line 969 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 969 + +#line 969 + remaining -= extent; +#line 969 + if(remaining == 0) +#line 969 + break; /* normal loop exit */ +#line 969 + offset += (off_t)extent; +#line 969 + value += nget; +#line 969 + } +#line 969 + +#line 969 + return status; +#line 969 +} +#line 969 + +static int +#line 970 +getNCvx_uchar_uchar(const NC3_INFO* ncp, const NC_var *varp, +#line 970 + const size_t *start, size_t nelems, uchar *value) +#line 970 +{ +#line 970 + off_t offset = NC_varoffset(ncp, varp, start); +#line 970 + size_t remaining = varp->xsz * nelems; +#line 970 + int status = NC_NOERR; +#line 970 + const void *xp; +#line 970 + +#line 970 + if(nelems == 0) +#line 970 + return NC_NOERR; +#line 970 + +#line 970 + assert(value != NULL); +#line 970 + +#line 970 + for(;;) +#line 970 + { +#line 970 + size_t extent = MIN(remaining, ncp->chunk); +#line 970 + size_t nget = ncx_howmany(varp->type, extent); +#line 970 + +#line 970 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 970 + 0, (void **)&xp); /* cast away const */ +#line 970 + if(lstatus != NC_NOERR) +#line 970 + return lstatus; +#line 970 + +#line 970 + lstatus = ncx_getn_uchar_uchar(&xp, nget, value); +#line 970 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 970 + status = lstatus; +#line 970 + +#line 970 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 970 + +#line 970 + remaining -= extent; +#line 970 + if(remaining == 0) +#line 970 + break; /* normal loop exit */ +#line 970 + offset += (off_t)extent; +#line 970 + value += nget; +#line 970 + } +#line 970 + +#line 970 + return status; +#line 970 +} +#line 970 + +static int +#line 971 +getNCvx_uchar_short(const NC3_INFO* ncp, const NC_var *varp, +#line 971 + const size_t *start, size_t nelems, short *value) +#line 971 +{ +#line 971 + off_t offset = NC_varoffset(ncp, varp, start); +#line 971 + size_t remaining = varp->xsz * nelems; +#line 971 + int status = NC_NOERR; +#line 971 + const void *xp; +#line 971 + +#line 971 + if(nelems == 0) +#line 971 + return NC_NOERR; +#line 971 + +#line 971 + assert(value != NULL); +#line 971 + +#line 971 + for(;;) +#line 971 + { +#line 971 + size_t extent = MIN(remaining, ncp->chunk); +#line 971 + size_t nget = ncx_howmany(varp->type, extent); +#line 971 + +#line 971 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 971 + 0, (void **)&xp); /* cast away const */ +#line 971 + if(lstatus != NC_NOERR) +#line 971 + return lstatus; +#line 971 + +#line 971 + lstatus = ncx_getn_uchar_short(&xp, nget, value); +#line 971 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 971 + status = lstatus; +#line 971 + +#line 971 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 971 + +#line 971 + remaining -= extent; +#line 971 + if(remaining == 0) +#line 971 + break; /* normal loop exit */ +#line 971 + offset += (off_t)extent; +#line 971 + value += nget; +#line 971 + } +#line 971 + +#line 971 + return status; +#line 971 +} +#line 971 + +static int +#line 972 +getNCvx_uchar_int(const NC3_INFO* ncp, const NC_var *varp, +#line 972 + const size_t *start, size_t nelems, int *value) +#line 972 +{ +#line 972 + off_t offset = NC_varoffset(ncp, varp, start); +#line 972 + size_t remaining = varp->xsz * nelems; +#line 972 + int status = NC_NOERR; +#line 972 + const void *xp; +#line 972 + +#line 972 + if(nelems == 0) +#line 972 + return NC_NOERR; +#line 972 + +#line 972 + assert(value != NULL); +#line 972 + +#line 972 + for(;;) +#line 972 + { +#line 972 + size_t extent = MIN(remaining, ncp->chunk); +#line 972 + size_t nget = ncx_howmany(varp->type, extent); +#line 972 + +#line 972 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 972 + 0, (void **)&xp); /* cast away const */ +#line 972 + if(lstatus != NC_NOERR) +#line 972 + return lstatus; +#line 972 + +#line 972 + lstatus = ncx_getn_uchar_int(&xp, nget, value); +#line 972 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 972 + status = lstatus; +#line 972 + +#line 972 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 972 + +#line 972 + remaining -= extent; +#line 972 + if(remaining == 0) +#line 972 + break; /* normal loop exit */ +#line 972 + offset += (off_t)extent; +#line 972 + value += nget; +#line 972 + } +#line 972 + +#line 972 + return status; +#line 972 +} +#line 972 + +static int +#line 973 +getNCvx_uchar_float(const NC3_INFO* ncp, const NC_var *varp, +#line 973 + const size_t *start, size_t nelems, float *value) +#line 973 +{ +#line 973 + off_t offset = NC_varoffset(ncp, varp, start); +#line 973 + size_t remaining = varp->xsz * nelems; +#line 973 + int status = NC_NOERR; +#line 973 + const void *xp; +#line 973 + +#line 973 + if(nelems == 0) +#line 973 + return NC_NOERR; +#line 973 + +#line 973 + assert(value != NULL); +#line 973 + +#line 973 + for(;;) +#line 973 + { +#line 973 + size_t extent = MIN(remaining, ncp->chunk); +#line 973 + size_t nget = ncx_howmany(varp->type, extent); +#line 973 + +#line 973 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 973 + 0, (void **)&xp); /* cast away const */ +#line 973 + if(lstatus != NC_NOERR) +#line 973 + return lstatus; +#line 973 + +#line 973 + lstatus = ncx_getn_uchar_float(&xp, nget, value); +#line 973 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 973 + status = lstatus; +#line 973 + +#line 973 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 973 + +#line 973 + remaining -= extent; +#line 973 + if(remaining == 0) +#line 973 + break; /* normal loop exit */ +#line 973 + offset += (off_t)extent; +#line 973 + value += nget; +#line 973 + } +#line 973 + +#line 973 + return status; +#line 973 +} +#line 973 + +static int +#line 974 +getNCvx_uchar_double(const NC3_INFO* ncp, const NC_var *varp, +#line 974 + const size_t *start, size_t nelems, double *value) +#line 974 +{ +#line 974 + off_t offset = NC_varoffset(ncp, varp, start); +#line 974 + size_t remaining = varp->xsz * nelems; +#line 974 + int status = NC_NOERR; +#line 974 + const void *xp; +#line 974 + +#line 974 + if(nelems == 0) +#line 974 + return NC_NOERR; +#line 974 + +#line 974 + assert(value != NULL); +#line 974 + +#line 974 + for(;;) +#line 974 + { +#line 974 + size_t extent = MIN(remaining, ncp->chunk); +#line 974 + size_t nget = ncx_howmany(varp->type, extent); +#line 974 + +#line 974 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 974 + 0, (void **)&xp); /* cast away const */ +#line 974 + if(lstatus != NC_NOERR) +#line 974 + return lstatus; +#line 974 + +#line 974 + lstatus = ncx_getn_uchar_double(&xp, nget, value); +#line 974 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 974 + status = lstatus; +#line 974 + +#line 974 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 974 + +#line 974 + remaining -= extent; +#line 974 + if(remaining == 0) +#line 974 + break; /* normal loop exit */ +#line 974 + offset += (off_t)extent; +#line 974 + value += nget; +#line 974 + } +#line 974 + +#line 974 + return status; +#line 974 +} +#line 974 + +static int +#line 975 +getNCvx_uchar_longlong(const NC3_INFO* ncp, const NC_var *varp, +#line 975 + const size_t *start, size_t nelems, longlong *value) +#line 975 +{ +#line 975 + off_t offset = NC_varoffset(ncp, varp, start); +#line 975 + size_t remaining = varp->xsz * nelems; +#line 975 + int status = NC_NOERR; +#line 975 + const void *xp; +#line 975 + +#line 975 + if(nelems == 0) +#line 975 + return NC_NOERR; +#line 975 + +#line 975 + assert(value != NULL); +#line 975 + +#line 975 + for(;;) +#line 975 + { +#line 975 + size_t extent = MIN(remaining, ncp->chunk); +#line 975 + size_t nget = ncx_howmany(varp->type, extent); +#line 975 + +#line 975 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 975 + 0, (void **)&xp); /* cast away const */ +#line 975 + if(lstatus != NC_NOERR) +#line 975 + return lstatus; +#line 975 + +#line 975 + lstatus = ncx_getn_uchar_longlong(&xp, nget, value); +#line 975 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 975 + status = lstatus; +#line 975 + +#line 975 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 975 + +#line 975 + remaining -= extent; +#line 975 + if(remaining == 0) +#line 975 + break; /* normal loop exit */ +#line 975 + offset += (off_t)extent; +#line 975 + value += nget; +#line 975 + } +#line 975 + +#line 975 + return status; +#line 975 +} +#line 975 + +static int +#line 976 +getNCvx_uchar_uint(const NC3_INFO* ncp, const NC_var *varp, +#line 976 + const size_t *start, size_t nelems, uint *value) +#line 976 +{ +#line 976 + off_t offset = NC_varoffset(ncp, varp, start); +#line 976 + size_t remaining = varp->xsz * nelems; +#line 976 + int status = NC_NOERR; +#line 976 + const void *xp; +#line 976 + +#line 976 + if(nelems == 0) +#line 976 + return NC_NOERR; +#line 976 + +#line 976 + assert(value != NULL); +#line 976 + +#line 976 + for(;;) +#line 976 + { +#line 976 + size_t extent = MIN(remaining, ncp->chunk); +#line 976 + size_t nget = ncx_howmany(varp->type, extent); +#line 976 + +#line 976 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 976 + 0, (void **)&xp); /* cast away const */ +#line 976 + if(lstatus != NC_NOERR) +#line 976 + return lstatus; +#line 976 + +#line 976 + lstatus = ncx_getn_uchar_uint(&xp, nget, value); +#line 976 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 976 + status = lstatus; +#line 976 + +#line 976 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 976 + +#line 976 + remaining -= extent; +#line 976 + if(remaining == 0) +#line 976 + break; /* normal loop exit */ +#line 976 + offset += (off_t)extent; +#line 976 + value += nget; +#line 976 + } +#line 976 + +#line 976 + return status; +#line 976 +} +#line 976 + +static int +#line 977 +getNCvx_uchar_ulonglong(const NC3_INFO* ncp, const NC_var *varp, +#line 977 + const size_t *start, size_t nelems, ulonglong *value) +#line 977 +{ +#line 977 + off_t offset = NC_varoffset(ncp, varp, start); +#line 977 + size_t remaining = varp->xsz * nelems; +#line 977 + int status = NC_NOERR; +#line 977 + const void *xp; +#line 977 + +#line 977 + if(nelems == 0) +#line 977 + return NC_NOERR; +#line 977 + +#line 977 + assert(value != NULL); +#line 977 + +#line 977 + for(;;) +#line 977 + { +#line 977 + size_t extent = MIN(remaining, ncp->chunk); +#line 977 + size_t nget = ncx_howmany(varp->type, extent); +#line 977 + +#line 977 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 977 + 0, (void **)&xp); /* cast away const */ +#line 977 + if(lstatus != NC_NOERR) +#line 977 + return lstatus; +#line 977 + +#line 977 + lstatus = ncx_getn_uchar_ulonglong(&xp, nget, value); +#line 977 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 977 + status = lstatus; +#line 977 + +#line 977 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 977 + +#line 977 + remaining -= extent; +#line 977 + if(remaining == 0) +#line 977 + break; /* normal loop exit */ +#line 977 + offset += (off_t)extent; +#line 977 + value += nget; +#line 977 + } +#line 977 + +#line 977 + return status; +#line 977 +} +#line 977 + +static int +#line 978 +getNCvx_uchar_ushort(const NC3_INFO* ncp, const NC_var *varp, +#line 978 + const size_t *start, size_t nelems, ushort *value) +#line 978 +{ +#line 978 + off_t offset = NC_varoffset(ncp, varp, start); +#line 978 + size_t remaining = varp->xsz * nelems; +#line 978 + int status = NC_NOERR; +#line 978 + const void *xp; +#line 978 + +#line 978 + if(nelems == 0) +#line 978 + return NC_NOERR; +#line 978 + +#line 978 + assert(value != NULL); +#line 978 + +#line 978 + for(;;) +#line 978 + { +#line 978 + size_t extent = MIN(remaining, ncp->chunk); +#line 978 + size_t nget = ncx_howmany(varp->type, extent); +#line 978 + +#line 978 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 978 + 0, (void **)&xp); /* cast away const */ +#line 978 + if(lstatus != NC_NOERR) +#line 978 + return lstatus; +#line 978 + +#line 978 + lstatus = ncx_getn_uchar_ushort(&xp, nget, value); +#line 978 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 978 + status = lstatus; +#line 978 + +#line 978 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 978 + +#line 978 + remaining -= extent; +#line 978 + if(remaining == 0) +#line 978 + break; /* normal loop exit */ +#line 978 + offset += (off_t)extent; +#line 978 + value += nget; +#line 978 + } +#line 978 + +#line 978 + return status; +#line 978 +} +#line 978 + + +static int +#line 980 +getNCvx_ushort_schar(const NC3_INFO* ncp, const NC_var *varp, +#line 980 + const size_t *start, size_t nelems, schar *value) +#line 980 +{ +#line 980 + off_t offset = NC_varoffset(ncp, varp, start); +#line 980 + size_t remaining = varp->xsz * nelems; +#line 980 + int status = NC_NOERR; +#line 980 + const void *xp; +#line 980 + +#line 980 + if(nelems == 0) +#line 980 + return NC_NOERR; +#line 980 + +#line 980 + assert(value != NULL); +#line 980 + +#line 980 + for(;;) +#line 980 + { +#line 980 + size_t extent = MIN(remaining, ncp->chunk); +#line 980 + size_t nget = ncx_howmany(varp->type, extent); +#line 980 + +#line 980 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 980 + 0, (void **)&xp); /* cast away const */ +#line 980 + if(lstatus != NC_NOERR) +#line 980 + return lstatus; +#line 980 + +#line 980 + lstatus = ncx_getn_ushort_schar(&xp, nget, value); +#line 980 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 980 + status = lstatus; +#line 980 + +#line 980 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 980 + +#line 980 + remaining -= extent; +#line 980 + if(remaining == 0) +#line 980 + break; /* normal loop exit */ +#line 980 + offset += (off_t)extent; +#line 980 + value += nget; +#line 980 + } +#line 980 + +#line 980 + return status; +#line 980 +} +#line 980 + +static int +#line 981 +getNCvx_ushort_uchar(const NC3_INFO* ncp, const NC_var *varp, +#line 981 + const size_t *start, size_t nelems, uchar *value) +#line 981 +{ +#line 981 + off_t offset = NC_varoffset(ncp, varp, start); +#line 981 + size_t remaining = varp->xsz * nelems; +#line 981 + int status = NC_NOERR; +#line 981 + const void *xp; +#line 981 + +#line 981 + if(nelems == 0) +#line 981 + return NC_NOERR; +#line 981 + +#line 981 + assert(value != NULL); +#line 981 + +#line 981 + for(;;) +#line 981 + { +#line 981 + size_t extent = MIN(remaining, ncp->chunk); +#line 981 + size_t nget = ncx_howmany(varp->type, extent); +#line 981 + +#line 981 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 981 + 0, (void **)&xp); /* cast away const */ +#line 981 + if(lstatus != NC_NOERR) +#line 981 + return lstatus; +#line 981 + +#line 981 + lstatus = ncx_getn_ushort_uchar(&xp, nget, value); +#line 981 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 981 + status = lstatus; +#line 981 + +#line 981 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 981 + +#line 981 + remaining -= extent; +#line 981 + if(remaining == 0) +#line 981 + break; /* normal loop exit */ +#line 981 + offset += (off_t)extent; +#line 981 + value += nget; +#line 981 + } +#line 981 + +#line 981 + return status; +#line 981 +} +#line 981 + +static int +#line 982 +getNCvx_ushort_short(const NC3_INFO* ncp, const NC_var *varp, +#line 982 + const size_t *start, size_t nelems, short *value) +#line 982 +{ +#line 982 + off_t offset = NC_varoffset(ncp, varp, start); +#line 982 + size_t remaining = varp->xsz * nelems; +#line 982 + int status = NC_NOERR; +#line 982 + const void *xp; +#line 982 + +#line 982 + if(nelems == 0) +#line 982 + return NC_NOERR; +#line 982 + +#line 982 + assert(value != NULL); +#line 982 + +#line 982 + for(;;) +#line 982 + { +#line 982 + size_t extent = MIN(remaining, ncp->chunk); +#line 982 + size_t nget = ncx_howmany(varp->type, extent); +#line 982 + +#line 982 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 982 + 0, (void **)&xp); /* cast away const */ +#line 982 + if(lstatus != NC_NOERR) +#line 982 + return lstatus; +#line 982 + +#line 982 + lstatus = ncx_getn_ushort_short(&xp, nget, value); +#line 982 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 982 + status = lstatus; +#line 982 + +#line 982 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 982 + +#line 982 + remaining -= extent; +#line 982 + if(remaining == 0) +#line 982 + break; /* normal loop exit */ +#line 982 + offset += (off_t)extent; +#line 982 + value += nget; +#line 982 + } +#line 982 + +#line 982 + return status; +#line 982 +} +#line 982 + +static int +#line 983 +getNCvx_ushort_int(const NC3_INFO* ncp, const NC_var *varp, +#line 983 + const size_t *start, size_t nelems, int *value) +#line 983 +{ +#line 983 + off_t offset = NC_varoffset(ncp, varp, start); +#line 983 + size_t remaining = varp->xsz * nelems; +#line 983 + int status = NC_NOERR; +#line 983 + const void *xp; +#line 983 + +#line 983 + if(nelems == 0) +#line 983 + return NC_NOERR; +#line 983 + +#line 983 + assert(value != NULL); +#line 983 + +#line 983 + for(;;) +#line 983 + { +#line 983 + size_t extent = MIN(remaining, ncp->chunk); +#line 983 + size_t nget = ncx_howmany(varp->type, extent); +#line 983 + +#line 983 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 983 + 0, (void **)&xp); /* cast away const */ +#line 983 + if(lstatus != NC_NOERR) +#line 983 + return lstatus; +#line 983 + +#line 983 + lstatus = ncx_getn_ushort_int(&xp, nget, value); +#line 983 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 983 + status = lstatus; +#line 983 + +#line 983 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 983 + +#line 983 + remaining -= extent; +#line 983 + if(remaining == 0) +#line 983 + break; /* normal loop exit */ +#line 983 + offset += (off_t)extent; +#line 983 + value += nget; +#line 983 + } +#line 983 + +#line 983 + return status; +#line 983 +} +#line 983 + +static int +#line 984 +getNCvx_ushort_float(const NC3_INFO* ncp, const NC_var *varp, +#line 984 + const size_t *start, size_t nelems, float *value) +#line 984 +{ +#line 984 + off_t offset = NC_varoffset(ncp, varp, start); +#line 984 + size_t remaining = varp->xsz * nelems; +#line 984 + int status = NC_NOERR; +#line 984 + const void *xp; +#line 984 + +#line 984 + if(nelems == 0) +#line 984 + return NC_NOERR; +#line 984 + +#line 984 + assert(value != NULL); +#line 984 + +#line 984 + for(;;) +#line 984 + { +#line 984 + size_t extent = MIN(remaining, ncp->chunk); +#line 984 + size_t nget = ncx_howmany(varp->type, extent); +#line 984 + +#line 984 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 984 + 0, (void **)&xp); /* cast away const */ +#line 984 + if(lstatus != NC_NOERR) +#line 984 + return lstatus; +#line 984 + +#line 984 + lstatus = ncx_getn_ushort_float(&xp, nget, value); +#line 984 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 984 + status = lstatus; +#line 984 + +#line 984 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 984 + +#line 984 + remaining -= extent; +#line 984 + if(remaining == 0) +#line 984 + break; /* normal loop exit */ +#line 984 + offset += (off_t)extent; +#line 984 + value += nget; +#line 984 + } +#line 984 + +#line 984 + return status; +#line 984 +} +#line 984 + +static int +#line 985 +getNCvx_ushort_double(const NC3_INFO* ncp, const NC_var *varp, +#line 985 + const size_t *start, size_t nelems, double *value) +#line 985 +{ +#line 985 + off_t offset = NC_varoffset(ncp, varp, start); +#line 985 + size_t remaining = varp->xsz * nelems; +#line 985 + int status = NC_NOERR; +#line 985 + const void *xp; +#line 985 + +#line 985 + if(nelems == 0) +#line 985 + return NC_NOERR; +#line 985 + +#line 985 + assert(value != NULL); +#line 985 + +#line 985 + for(;;) +#line 985 + { +#line 985 + size_t extent = MIN(remaining, ncp->chunk); +#line 985 + size_t nget = ncx_howmany(varp->type, extent); +#line 985 + +#line 985 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 985 + 0, (void **)&xp); /* cast away const */ +#line 985 + if(lstatus != NC_NOERR) +#line 985 + return lstatus; +#line 985 + +#line 985 + lstatus = ncx_getn_ushort_double(&xp, nget, value); +#line 985 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 985 + status = lstatus; +#line 985 + +#line 985 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 985 + +#line 985 + remaining -= extent; +#line 985 + if(remaining == 0) +#line 985 + break; /* normal loop exit */ +#line 985 + offset += (off_t)extent; +#line 985 + value += nget; +#line 985 + } +#line 985 + +#line 985 + return status; +#line 985 +} +#line 985 + +static int +#line 986 +getNCvx_ushort_longlong(const NC3_INFO* ncp, const NC_var *varp, +#line 986 + const size_t *start, size_t nelems, longlong *value) +#line 986 +{ +#line 986 + off_t offset = NC_varoffset(ncp, varp, start); +#line 986 + size_t remaining = varp->xsz * nelems; +#line 986 + int status = NC_NOERR; +#line 986 + const void *xp; +#line 986 + +#line 986 + if(nelems == 0) +#line 986 + return NC_NOERR; +#line 986 + +#line 986 + assert(value != NULL); +#line 986 + +#line 986 + for(;;) +#line 986 + { +#line 986 + size_t extent = MIN(remaining, ncp->chunk); +#line 986 + size_t nget = ncx_howmany(varp->type, extent); +#line 986 + +#line 986 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 986 + 0, (void **)&xp); /* cast away const */ +#line 986 + if(lstatus != NC_NOERR) +#line 986 + return lstatus; +#line 986 + +#line 986 + lstatus = ncx_getn_ushort_longlong(&xp, nget, value); +#line 986 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 986 + status = lstatus; +#line 986 + +#line 986 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 986 + +#line 986 + remaining -= extent; +#line 986 + if(remaining == 0) +#line 986 + break; /* normal loop exit */ +#line 986 + offset += (off_t)extent; +#line 986 + value += nget; +#line 986 + } +#line 986 + +#line 986 + return status; +#line 986 +} +#line 986 + +static int +#line 987 +getNCvx_ushort_uint(const NC3_INFO* ncp, const NC_var *varp, +#line 987 + const size_t *start, size_t nelems, uint *value) +#line 987 +{ +#line 987 + off_t offset = NC_varoffset(ncp, varp, start); +#line 987 + size_t remaining = varp->xsz * nelems; +#line 987 + int status = NC_NOERR; +#line 987 + const void *xp; +#line 987 + +#line 987 + if(nelems == 0) +#line 987 + return NC_NOERR; +#line 987 + +#line 987 + assert(value != NULL); +#line 987 + +#line 987 + for(;;) +#line 987 + { +#line 987 + size_t extent = MIN(remaining, ncp->chunk); +#line 987 + size_t nget = ncx_howmany(varp->type, extent); +#line 987 + +#line 987 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 987 + 0, (void **)&xp); /* cast away const */ +#line 987 + if(lstatus != NC_NOERR) +#line 987 + return lstatus; +#line 987 + +#line 987 + lstatus = ncx_getn_ushort_uint(&xp, nget, value); +#line 987 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 987 + status = lstatus; +#line 987 + +#line 987 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 987 + +#line 987 + remaining -= extent; +#line 987 + if(remaining == 0) +#line 987 + break; /* normal loop exit */ +#line 987 + offset += (off_t)extent; +#line 987 + value += nget; +#line 987 + } +#line 987 + +#line 987 + return status; +#line 987 +} +#line 987 + +static int +#line 988 +getNCvx_ushort_ulonglong(const NC3_INFO* ncp, const NC_var *varp, +#line 988 + const size_t *start, size_t nelems, ulonglong *value) +#line 988 +{ +#line 988 + off_t offset = NC_varoffset(ncp, varp, start); +#line 988 + size_t remaining = varp->xsz * nelems; +#line 988 + int status = NC_NOERR; +#line 988 + const void *xp; +#line 988 + +#line 988 + if(nelems == 0) +#line 988 + return NC_NOERR; +#line 988 + +#line 988 + assert(value != NULL); +#line 988 + +#line 988 + for(;;) +#line 988 + { +#line 988 + size_t extent = MIN(remaining, ncp->chunk); +#line 988 + size_t nget = ncx_howmany(varp->type, extent); +#line 988 + +#line 988 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 988 + 0, (void **)&xp); /* cast away const */ +#line 988 + if(lstatus != NC_NOERR) +#line 988 + return lstatus; +#line 988 + +#line 988 + lstatus = ncx_getn_ushort_ulonglong(&xp, nget, value); +#line 988 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 988 + status = lstatus; +#line 988 + +#line 988 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 988 + +#line 988 + remaining -= extent; +#line 988 + if(remaining == 0) +#line 988 + break; /* normal loop exit */ +#line 988 + offset += (off_t)extent; +#line 988 + value += nget; +#line 988 + } +#line 988 + +#line 988 + return status; +#line 988 +} +#line 988 + +static int +#line 989 +getNCvx_ushort_ushort(const NC3_INFO* ncp, const NC_var *varp, +#line 989 + const size_t *start, size_t nelems, ushort *value) +#line 989 +{ +#line 989 + off_t offset = NC_varoffset(ncp, varp, start); +#line 989 + size_t remaining = varp->xsz * nelems; +#line 989 + int status = NC_NOERR; +#line 989 + const void *xp; +#line 989 + +#line 989 + if(nelems == 0) +#line 989 + return NC_NOERR; +#line 989 + +#line 989 + assert(value != NULL); +#line 989 + +#line 989 + for(;;) +#line 989 + { +#line 989 + size_t extent = MIN(remaining, ncp->chunk); +#line 989 + size_t nget = ncx_howmany(varp->type, extent); +#line 989 + +#line 989 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 989 + 0, (void **)&xp); /* cast away const */ +#line 989 + if(lstatus != NC_NOERR) +#line 989 + return lstatus; +#line 989 + +#line 989 + lstatus = ncx_getn_ushort_ushort(&xp, nget, value); +#line 989 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 989 + status = lstatus; +#line 989 + +#line 989 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 989 + +#line 989 + remaining -= extent; +#line 989 + if(remaining == 0) +#line 989 + break; /* normal loop exit */ +#line 989 + offset += (off_t)extent; +#line 989 + value += nget; +#line 989 + } +#line 989 + +#line 989 + return status; +#line 989 +} +#line 989 + + +static int +#line 991 +getNCvx_uint_schar(const NC3_INFO* ncp, const NC_var *varp, +#line 991 + const size_t *start, size_t nelems, schar *value) +#line 991 +{ +#line 991 + off_t offset = NC_varoffset(ncp, varp, start); +#line 991 + size_t remaining = varp->xsz * nelems; +#line 991 + int status = NC_NOERR; +#line 991 + const void *xp; +#line 991 + +#line 991 + if(nelems == 0) +#line 991 + return NC_NOERR; +#line 991 + +#line 991 + assert(value != NULL); +#line 991 + +#line 991 + for(;;) +#line 991 + { +#line 991 + size_t extent = MIN(remaining, ncp->chunk); +#line 991 + size_t nget = ncx_howmany(varp->type, extent); +#line 991 + +#line 991 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 991 + 0, (void **)&xp); /* cast away const */ +#line 991 + if(lstatus != NC_NOERR) +#line 991 + return lstatus; +#line 991 + +#line 991 + lstatus = ncx_getn_uint_schar(&xp, nget, value); +#line 991 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 991 + status = lstatus; +#line 991 + +#line 991 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 991 + +#line 991 + remaining -= extent; +#line 991 + if(remaining == 0) +#line 991 + break; /* normal loop exit */ +#line 991 + offset += (off_t)extent; +#line 991 + value += nget; +#line 991 + } +#line 991 + +#line 991 + return status; +#line 991 +} +#line 991 + +static int +#line 992 +getNCvx_uint_uchar(const NC3_INFO* ncp, const NC_var *varp, +#line 992 + const size_t *start, size_t nelems, uchar *value) +#line 992 +{ +#line 992 + off_t offset = NC_varoffset(ncp, varp, start); +#line 992 + size_t remaining = varp->xsz * nelems; +#line 992 + int status = NC_NOERR; +#line 992 + const void *xp; +#line 992 + +#line 992 + if(nelems == 0) +#line 992 + return NC_NOERR; +#line 992 + +#line 992 + assert(value != NULL); +#line 992 + +#line 992 + for(;;) +#line 992 + { +#line 992 + size_t extent = MIN(remaining, ncp->chunk); +#line 992 + size_t nget = ncx_howmany(varp->type, extent); +#line 992 + +#line 992 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 992 + 0, (void **)&xp); /* cast away const */ +#line 992 + if(lstatus != NC_NOERR) +#line 992 + return lstatus; +#line 992 + +#line 992 + lstatus = ncx_getn_uint_uchar(&xp, nget, value); +#line 992 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 992 + status = lstatus; +#line 992 + +#line 992 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 992 + +#line 992 + remaining -= extent; +#line 992 + if(remaining == 0) +#line 992 + break; /* normal loop exit */ +#line 992 + offset += (off_t)extent; +#line 992 + value += nget; +#line 992 + } +#line 992 + +#line 992 + return status; +#line 992 +} +#line 992 + +static int +#line 993 +getNCvx_uint_short(const NC3_INFO* ncp, const NC_var *varp, +#line 993 + const size_t *start, size_t nelems, short *value) +#line 993 +{ +#line 993 + off_t offset = NC_varoffset(ncp, varp, start); +#line 993 + size_t remaining = varp->xsz * nelems; +#line 993 + int status = NC_NOERR; +#line 993 + const void *xp; +#line 993 + +#line 993 + if(nelems == 0) +#line 993 + return NC_NOERR; +#line 993 + +#line 993 + assert(value != NULL); +#line 993 + +#line 993 + for(;;) +#line 993 + { +#line 993 + size_t extent = MIN(remaining, ncp->chunk); +#line 993 + size_t nget = ncx_howmany(varp->type, extent); +#line 993 + +#line 993 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 993 + 0, (void **)&xp); /* cast away const */ +#line 993 + if(lstatus != NC_NOERR) +#line 993 + return lstatus; +#line 993 + +#line 993 + lstatus = ncx_getn_uint_short(&xp, nget, value); +#line 993 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 993 + status = lstatus; +#line 993 + +#line 993 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 993 + +#line 993 + remaining -= extent; +#line 993 + if(remaining == 0) +#line 993 + break; /* normal loop exit */ +#line 993 + offset += (off_t)extent; +#line 993 + value += nget; +#line 993 + } +#line 993 + +#line 993 + return status; +#line 993 +} +#line 993 + +static int +#line 994 +getNCvx_uint_int(const NC3_INFO* ncp, const NC_var *varp, +#line 994 + const size_t *start, size_t nelems, int *value) +#line 994 +{ +#line 994 + off_t offset = NC_varoffset(ncp, varp, start); +#line 994 + size_t remaining = varp->xsz * nelems; +#line 994 + int status = NC_NOERR; +#line 994 + const void *xp; +#line 994 + +#line 994 + if(nelems == 0) +#line 994 + return NC_NOERR; +#line 994 + +#line 994 + assert(value != NULL); +#line 994 + +#line 994 + for(;;) +#line 994 + { +#line 994 + size_t extent = MIN(remaining, ncp->chunk); +#line 994 + size_t nget = ncx_howmany(varp->type, extent); +#line 994 + +#line 994 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 994 + 0, (void **)&xp); /* cast away const */ +#line 994 + if(lstatus != NC_NOERR) +#line 994 + return lstatus; +#line 994 + +#line 994 + lstatus = ncx_getn_uint_int(&xp, nget, value); +#line 994 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 994 + status = lstatus; +#line 994 + +#line 994 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 994 + +#line 994 + remaining -= extent; +#line 994 + if(remaining == 0) +#line 994 + break; /* normal loop exit */ +#line 994 + offset += (off_t)extent; +#line 994 + value += nget; +#line 994 + } +#line 994 + +#line 994 + return status; +#line 994 +} +#line 994 + +static int +#line 995 +getNCvx_uint_float(const NC3_INFO* ncp, const NC_var *varp, +#line 995 + const size_t *start, size_t nelems, float *value) +#line 995 +{ +#line 995 + off_t offset = NC_varoffset(ncp, varp, start); +#line 995 + size_t remaining = varp->xsz * nelems; +#line 995 + int status = NC_NOERR; +#line 995 + const void *xp; +#line 995 + +#line 995 + if(nelems == 0) +#line 995 + return NC_NOERR; +#line 995 + +#line 995 + assert(value != NULL); +#line 995 + +#line 995 + for(;;) +#line 995 + { +#line 995 + size_t extent = MIN(remaining, ncp->chunk); +#line 995 + size_t nget = ncx_howmany(varp->type, extent); +#line 995 + +#line 995 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 995 + 0, (void **)&xp); /* cast away const */ +#line 995 + if(lstatus != NC_NOERR) +#line 995 + return lstatus; +#line 995 + +#line 995 + lstatus = ncx_getn_uint_float(&xp, nget, value); +#line 995 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 995 + status = lstatus; +#line 995 + +#line 995 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 995 + +#line 995 + remaining -= extent; +#line 995 + if(remaining == 0) +#line 995 + break; /* normal loop exit */ +#line 995 + offset += (off_t)extent; +#line 995 + value += nget; +#line 995 + } +#line 995 + +#line 995 + return status; +#line 995 +} +#line 995 + +static int +#line 996 +getNCvx_uint_double(const NC3_INFO* ncp, const NC_var *varp, +#line 996 + const size_t *start, size_t nelems, double *value) +#line 996 +{ +#line 996 + off_t offset = NC_varoffset(ncp, varp, start); +#line 996 + size_t remaining = varp->xsz * nelems; +#line 996 + int status = NC_NOERR; +#line 996 + const void *xp; +#line 996 + +#line 996 + if(nelems == 0) +#line 996 + return NC_NOERR; +#line 996 + +#line 996 + assert(value != NULL); +#line 996 + +#line 996 + for(;;) +#line 996 + { +#line 996 + size_t extent = MIN(remaining, ncp->chunk); +#line 996 + size_t nget = ncx_howmany(varp->type, extent); +#line 996 + +#line 996 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 996 + 0, (void **)&xp); /* cast away const */ +#line 996 + if(lstatus != NC_NOERR) +#line 996 + return lstatus; +#line 996 + +#line 996 + lstatus = ncx_getn_uint_double(&xp, nget, value); +#line 996 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 996 + status = lstatus; +#line 996 + +#line 996 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 996 + +#line 996 + remaining -= extent; +#line 996 + if(remaining == 0) +#line 996 + break; /* normal loop exit */ +#line 996 + offset += (off_t)extent; +#line 996 + value += nget; +#line 996 + } +#line 996 + +#line 996 + return status; +#line 996 +} +#line 996 + +static int +#line 997 +getNCvx_uint_longlong(const NC3_INFO* ncp, const NC_var *varp, +#line 997 + const size_t *start, size_t nelems, longlong *value) +#line 997 +{ +#line 997 + off_t offset = NC_varoffset(ncp, varp, start); +#line 997 + size_t remaining = varp->xsz * nelems; +#line 997 + int status = NC_NOERR; +#line 997 + const void *xp; +#line 997 + +#line 997 + if(nelems == 0) +#line 997 + return NC_NOERR; +#line 997 + +#line 997 + assert(value != NULL); +#line 997 + +#line 997 + for(;;) +#line 997 + { +#line 997 + size_t extent = MIN(remaining, ncp->chunk); +#line 997 + size_t nget = ncx_howmany(varp->type, extent); +#line 997 + +#line 997 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 997 + 0, (void **)&xp); /* cast away const */ +#line 997 + if(lstatus != NC_NOERR) +#line 997 + return lstatus; +#line 997 + +#line 997 + lstatus = ncx_getn_uint_longlong(&xp, nget, value); +#line 997 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 997 + status = lstatus; +#line 997 + +#line 997 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 997 + +#line 997 + remaining -= extent; +#line 997 + if(remaining == 0) +#line 997 + break; /* normal loop exit */ +#line 997 + offset += (off_t)extent; +#line 997 + value += nget; +#line 997 + } +#line 997 + +#line 997 + return status; +#line 997 +} +#line 997 + +static int +#line 998 +getNCvx_uint_uint(const NC3_INFO* ncp, const NC_var *varp, +#line 998 + const size_t *start, size_t nelems, uint *value) +#line 998 +{ +#line 998 + off_t offset = NC_varoffset(ncp, varp, start); +#line 998 + size_t remaining = varp->xsz * nelems; +#line 998 + int status = NC_NOERR; +#line 998 + const void *xp; +#line 998 + +#line 998 + if(nelems == 0) +#line 998 + return NC_NOERR; +#line 998 + +#line 998 + assert(value != NULL); +#line 998 + +#line 998 + for(;;) +#line 998 + { +#line 998 + size_t extent = MIN(remaining, ncp->chunk); +#line 998 + size_t nget = ncx_howmany(varp->type, extent); +#line 998 + +#line 998 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 998 + 0, (void **)&xp); /* cast away const */ +#line 998 + if(lstatus != NC_NOERR) +#line 998 + return lstatus; +#line 998 + +#line 998 + lstatus = ncx_getn_uint_uint(&xp, nget, value); +#line 998 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 998 + status = lstatus; +#line 998 + +#line 998 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 998 + +#line 998 + remaining -= extent; +#line 998 + if(remaining == 0) +#line 998 + break; /* normal loop exit */ +#line 998 + offset += (off_t)extent; +#line 998 + value += nget; +#line 998 + } +#line 998 + +#line 998 + return status; +#line 998 +} +#line 998 + +static int +#line 999 +getNCvx_uint_ulonglong(const NC3_INFO* ncp, const NC_var *varp, +#line 999 + const size_t *start, size_t nelems, ulonglong *value) +#line 999 +{ +#line 999 + off_t offset = NC_varoffset(ncp, varp, start); +#line 999 + size_t remaining = varp->xsz * nelems; +#line 999 + int status = NC_NOERR; +#line 999 + const void *xp; +#line 999 + +#line 999 + if(nelems == 0) +#line 999 + return NC_NOERR; +#line 999 + +#line 999 + assert(value != NULL); +#line 999 + +#line 999 + for(;;) +#line 999 + { +#line 999 + size_t extent = MIN(remaining, ncp->chunk); +#line 999 + size_t nget = ncx_howmany(varp->type, extent); +#line 999 + +#line 999 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 999 + 0, (void **)&xp); /* cast away const */ +#line 999 + if(lstatus != NC_NOERR) +#line 999 + return lstatus; +#line 999 + +#line 999 + lstatus = ncx_getn_uint_ulonglong(&xp, nget, value); +#line 999 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 999 + status = lstatus; +#line 999 + +#line 999 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 999 + +#line 999 + remaining -= extent; +#line 999 + if(remaining == 0) +#line 999 + break; /* normal loop exit */ +#line 999 + offset += (off_t)extent; +#line 999 + value += nget; +#line 999 + } +#line 999 + +#line 999 + return status; +#line 999 +} +#line 999 + +static int +#line 1000 +getNCvx_uint_ushort(const NC3_INFO* ncp, const NC_var *varp, +#line 1000 + const size_t *start, size_t nelems, ushort *value) +#line 1000 +{ +#line 1000 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1000 + size_t remaining = varp->xsz * nelems; +#line 1000 + int status = NC_NOERR; +#line 1000 + const void *xp; +#line 1000 + +#line 1000 + if(nelems == 0) +#line 1000 + return NC_NOERR; +#line 1000 + +#line 1000 + assert(value != NULL); +#line 1000 + +#line 1000 + for(;;) +#line 1000 + { +#line 1000 + size_t extent = MIN(remaining, ncp->chunk); +#line 1000 + size_t nget = ncx_howmany(varp->type, extent); +#line 1000 + +#line 1000 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1000 + 0, (void **)&xp); /* cast away const */ +#line 1000 + if(lstatus != NC_NOERR) +#line 1000 + return lstatus; +#line 1000 + +#line 1000 + lstatus = ncx_getn_uint_ushort(&xp, nget, value); +#line 1000 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1000 + status = lstatus; +#line 1000 + +#line 1000 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1000 + +#line 1000 + remaining -= extent; +#line 1000 + if(remaining == 0) +#line 1000 + break; /* normal loop exit */ +#line 1000 + offset += (off_t)extent; +#line 1000 + value += nget; +#line 1000 + } +#line 1000 + +#line 1000 + return status; +#line 1000 +} +#line 1000 + + +static int +#line 1002 +getNCvx_longlong_schar(const NC3_INFO* ncp, const NC_var *varp, +#line 1002 + const size_t *start, size_t nelems, schar *value) +#line 1002 +{ +#line 1002 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1002 + size_t remaining = varp->xsz * nelems; +#line 1002 + int status = NC_NOERR; +#line 1002 + const void *xp; +#line 1002 + +#line 1002 + if(nelems == 0) +#line 1002 + return NC_NOERR; +#line 1002 + +#line 1002 + assert(value != NULL); +#line 1002 + +#line 1002 + for(;;) +#line 1002 + { +#line 1002 + size_t extent = MIN(remaining, ncp->chunk); +#line 1002 + size_t nget = ncx_howmany(varp->type, extent); +#line 1002 + +#line 1002 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1002 + 0, (void **)&xp); /* cast away const */ +#line 1002 + if(lstatus != NC_NOERR) +#line 1002 + return lstatus; +#line 1002 + +#line 1002 + lstatus = ncx_getn_longlong_schar(&xp, nget, value); +#line 1002 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1002 + status = lstatus; +#line 1002 + +#line 1002 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1002 + +#line 1002 + remaining -= extent; +#line 1002 + if(remaining == 0) +#line 1002 + break; /* normal loop exit */ +#line 1002 + offset += (off_t)extent; +#line 1002 + value += nget; +#line 1002 + } +#line 1002 + +#line 1002 + return status; +#line 1002 +} +#line 1002 + +static int +#line 1003 +getNCvx_longlong_uchar(const NC3_INFO* ncp, const NC_var *varp, +#line 1003 + const size_t *start, size_t nelems, uchar *value) +#line 1003 +{ +#line 1003 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1003 + size_t remaining = varp->xsz * nelems; +#line 1003 + int status = NC_NOERR; +#line 1003 + const void *xp; +#line 1003 + +#line 1003 + if(nelems == 0) +#line 1003 + return NC_NOERR; +#line 1003 + +#line 1003 + assert(value != NULL); +#line 1003 + +#line 1003 + for(;;) +#line 1003 + { +#line 1003 + size_t extent = MIN(remaining, ncp->chunk); +#line 1003 + size_t nget = ncx_howmany(varp->type, extent); +#line 1003 + +#line 1003 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1003 + 0, (void **)&xp); /* cast away const */ +#line 1003 + if(lstatus != NC_NOERR) +#line 1003 + return lstatus; +#line 1003 + +#line 1003 + lstatus = ncx_getn_longlong_uchar(&xp, nget, value); +#line 1003 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1003 + status = lstatus; +#line 1003 + +#line 1003 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1003 + +#line 1003 + remaining -= extent; +#line 1003 + if(remaining == 0) +#line 1003 + break; /* normal loop exit */ +#line 1003 + offset += (off_t)extent; +#line 1003 + value += nget; +#line 1003 + } +#line 1003 + +#line 1003 + return status; +#line 1003 +} +#line 1003 + +static int +#line 1004 +getNCvx_longlong_short(const NC3_INFO* ncp, const NC_var *varp, +#line 1004 + const size_t *start, size_t nelems, short *value) +#line 1004 +{ +#line 1004 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1004 + size_t remaining = varp->xsz * nelems; +#line 1004 + int status = NC_NOERR; +#line 1004 + const void *xp; +#line 1004 + +#line 1004 + if(nelems == 0) +#line 1004 + return NC_NOERR; +#line 1004 + +#line 1004 + assert(value != NULL); +#line 1004 + +#line 1004 + for(;;) +#line 1004 + { +#line 1004 + size_t extent = MIN(remaining, ncp->chunk); +#line 1004 + size_t nget = ncx_howmany(varp->type, extent); +#line 1004 + +#line 1004 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1004 + 0, (void **)&xp); /* cast away const */ +#line 1004 + if(lstatus != NC_NOERR) +#line 1004 + return lstatus; +#line 1004 + +#line 1004 + lstatus = ncx_getn_longlong_short(&xp, nget, value); +#line 1004 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1004 + status = lstatus; +#line 1004 + +#line 1004 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1004 + +#line 1004 + remaining -= extent; +#line 1004 + if(remaining == 0) +#line 1004 + break; /* normal loop exit */ +#line 1004 + offset += (off_t)extent; +#line 1004 + value += nget; +#line 1004 + } +#line 1004 + +#line 1004 + return status; +#line 1004 +} +#line 1004 + +static int +#line 1005 +getNCvx_longlong_int(const NC3_INFO* ncp, const NC_var *varp, +#line 1005 + const size_t *start, size_t nelems, int *value) +#line 1005 +{ +#line 1005 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1005 + size_t remaining = varp->xsz * nelems; +#line 1005 + int status = NC_NOERR; +#line 1005 + const void *xp; +#line 1005 + +#line 1005 + if(nelems == 0) +#line 1005 + return NC_NOERR; +#line 1005 + +#line 1005 + assert(value != NULL); +#line 1005 + +#line 1005 + for(;;) +#line 1005 + { +#line 1005 + size_t extent = MIN(remaining, ncp->chunk); +#line 1005 + size_t nget = ncx_howmany(varp->type, extent); +#line 1005 + +#line 1005 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1005 + 0, (void **)&xp); /* cast away const */ +#line 1005 + if(lstatus != NC_NOERR) +#line 1005 + return lstatus; +#line 1005 + +#line 1005 + lstatus = ncx_getn_longlong_int(&xp, nget, value); +#line 1005 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1005 + status = lstatus; +#line 1005 + +#line 1005 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1005 + +#line 1005 + remaining -= extent; +#line 1005 + if(remaining == 0) +#line 1005 + break; /* normal loop exit */ +#line 1005 + offset += (off_t)extent; +#line 1005 + value += nget; +#line 1005 + } +#line 1005 + +#line 1005 + return status; +#line 1005 +} +#line 1005 + +static int +#line 1006 +getNCvx_longlong_float(const NC3_INFO* ncp, const NC_var *varp, +#line 1006 + const size_t *start, size_t nelems, float *value) +#line 1006 +{ +#line 1006 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1006 + size_t remaining = varp->xsz * nelems; +#line 1006 + int status = NC_NOERR; +#line 1006 + const void *xp; +#line 1006 + +#line 1006 + if(nelems == 0) +#line 1006 + return NC_NOERR; +#line 1006 + +#line 1006 + assert(value != NULL); +#line 1006 + +#line 1006 + for(;;) +#line 1006 + { +#line 1006 + size_t extent = MIN(remaining, ncp->chunk); +#line 1006 + size_t nget = ncx_howmany(varp->type, extent); +#line 1006 + +#line 1006 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1006 + 0, (void **)&xp); /* cast away const */ +#line 1006 + if(lstatus != NC_NOERR) +#line 1006 + return lstatus; +#line 1006 + +#line 1006 + lstatus = ncx_getn_longlong_float(&xp, nget, value); +#line 1006 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1006 + status = lstatus; +#line 1006 + +#line 1006 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1006 + +#line 1006 + remaining -= extent; +#line 1006 + if(remaining == 0) +#line 1006 + break; /* normal loop exit */ +#line 1006 + offset += (off_t)extent; +#line 1006 + value += nget; +#line 1006 + } +#line 1006 + +#line 1006 + return status; +#line 1006 +} +#line 1006 + +static int +#line 1007 +getNCvx_longlong_double(const NC3_INFO* ncp, const NC_var *varp, +#line 1007 + const size_t *start, size_t nelems, double *value) +#line 1007 +{ +#line 1007 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1007 + size_t remaining = varp->xsz * nelems; +#line 1007 + int status = NC_NOERR; +#line 1007 + const void *xp; +#line 1007 + +#line 1007 + if(nelems == 0) +#line 1007 + return NC_NOERR; +#line 1007 + +#line 1007 + assert(value != NULL); +#line 1007 + +#line 1007 + for(;;) +#line 1007 + { +#line 1007 + size_t extent = MIN(remaining, ncp->chunk); +#line 1007 + size_t nget = ncx_howmany(varp->type, extent); +#line 1007 + +#line 1007 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1007 + 0, (void **)&xp); /* cast away const */ +#line 1007 + if(lstatus != NC_NOERR) +#line 1007 + return lstatus; +#line 1007 + +#line 1007 + lstatus = ncx_getn_longlong_double(&xp, nget, value); +#line 1007 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1007 + status = lstatus; +#line 1007 + +#line 1007 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1007 + +#line 1007 + remaining -= extent; +#line 1007 + if(remaining == 0) +#line 1007 + break; /* normal loop exit */ +#line 1007 + offset += (off_t)extent; +#line 1007 + value += nget; +#line 1007 + } +#line 1007 + +#line 1007 + return status; +#line 1007 +} +#line 1007 + +static int +#line 1008 +getNCvx_longlong_longlong(const NC3_INFO* ncp, const NC_var *varp, +#line 1008 + const size_t *start, size_t nelems, longlong *value) +#line 1008 +{ +#line 1008 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1008 + size_t remaining = varp->xsz * nelems; +#line 1008 + int status = NC_NOERR; +#line 1008 + const void *xp; +#line 1008 + +#line 1008 + if(nelems == 0) +#line 1008 + return NC_NOERR; +#line 1008 + +#line 1008 + assert(value != NULL); +#line 1008 + +#line 1008 + for(;;) +#line 1008 + { +#line 1008 + size_t extent = MIN(remaining, ncp->chunk); +#line 1008 + size_t nget = ncx_howmany(varp->type, extent); +#line 1008 + +#line 1008 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1008 + 0, (void **)&xp); /* cast away const */ +#line 1008 + if(lstatus != NC_NOERR) +#line 1008 + return lstatus; +#line 1008 + +#line 1008 + lstatus = ncx_getn_longlong_longlong(&xp, nget, value); +#line 1008 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1008 + status = lstatus; +#line 1008 + +#line 1008 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1008 + +#line 1008 + remaining -= extent; +#line 1008 + if(remaining == 0) +#line 1008 + break; /* normal loop exit */ +#line 1008 + offset += (off_t)extent; +#line 1008 + value += nget; +#line 1008 + } +#line 1008 + +#line 1008 + return status; +#line 1008 +} +#line 1008 + +static int +#line 1009 +getNCvx_longlong_uint(const NC3_INFO* ncp, const NC_var *varp, +#line 1009 + const size_t *start, size_t nelems, uint *value) +#line 1009 +{ +#line 1009 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1009 + size_t remaining = varp->xsz * nelems; +#line 1009 + int status = NC_NOERR; +#line 1009 + const void *xp; +#line 1009 + +#line 1009 + if(nelems == 0) +#line 1009 + return NC_NOERR; +#line 1009 + +#line 1009 + assert(value != NULL); +#line 1009 + +#line 1009 + for(;;) +#line 1009 + { +#line 1009 + size_t extent = MIN(remaining, ncp->chunk); +#line 1009 + size_t nget = ncx_howmany(varp->type, extent); +#line 1009 + +#line 1009 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1009 + 0, (void **)&xp); /* cast away const */ +#line 1009 + if(lstatus != NC_NOERR) +#line 1009 + return lstatus; +#line 1009 + +#line 1009 + lstatus = ncx_getn_longlong_uint(&xp, nget, value); +#line 1009 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1009 + status = lstatus; +#line 1009 + +#line 1009 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1009 + +#line 1009 + remaining -= extent; +#line 1009 + if(remaining == 0) +#line 1009 + break; /* normal loop exit */ +#line 1009 + offset += (off_t)extent; +#line 1009 + value += nget; +#line 1009 + } +#line 1009 + +#line 1009 + return status; +#line 1009 +} +#line 1009 + +static int +#line 1010 +getNCvx_longlong_ulonglong(const NC3_INFO* ncp, const NC_var *varp, +#line 1010 + const size_t *start, size_t nelems, ulonglong *value) +#line 1010 +{ +#line 1010 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1010 + size_t remaining = varp->xsz * nelems; +#line 1010 + int status = NC_NOERR; +#line 1010 + const void *xp; +#line 1010 + +#line 1010 + if(nelems == 0) +#line 1010 + return NC_NOERR; +#line 1010 + +#line 1010 + assert(value != NULL); +#line 1010 + +#line 1010 + for(;;) +#line 1010 + { +#line 1010 + size_t extent = MIN(remaining, ncp->chunk); +#line 1010 + size_t nget = ncx_howmany(varp->type, extent); +#line 1010 + +#line 1010 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1010 + 0, (void **)&xp); /* cast away const */ +#line 1010 + if(lstatus != NC_NOERR) +#line 1010 + return lstatus; +#line 1010 + +#line 1010 + lstatus = ncx_getn_longlong_ulonglong(&xp, nget, value); +#line 1010 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1010 + status = lstatus; +#line 1010 + +#line 1010 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1010 + +#line 1010 + remaining -= extent; +#line 1010 + if(remaining == 0) +#line 1010 + break; /* normal loop exit */ +#line 1010 + offset += (off_t)extent; +#line 1010 + value += nget; +#line 1010 + } +#line 1010 + +#line 1010 + return status; +#line 1010 +} +#line 1010 + +static int +#line 1011 +getNCvx_longlong_ushort(const NC3_INFO* ncp, const NC_var *varp, +#line 1011 + const size_t *start, size_t nelems, ushort *value) +#line 1011 +{ +#line 1011 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1011 + size_t remaining = varp->xsz * nelems; +#line 1011 + int status = NC_NOERR; +#line 1011 + const void *xp; +#line 1011 + +#line 1011 + if(nelems == 0) +#line 1011 + return NC_NOERR; +#line 1011 + +#line 1011 + assert(value != NULL); +#line 1011 + +#line 1011 + for(;;) +#line 1011 + { +#line 1011 + size_t extent = MIN(remaining, ncp->chunk); +#line 1011 + size_t nget = ncx_howmany(varp->type, extent); +#line 1011 + +#line 1011 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1011 + 0, (void **)&xp); /* cast away const */ +#line 1011 + if(lstatus != NC_NOERR) +#line 1011 + return lstatus; +#line 1011 + +#line 1011 + lstatus = ncx_getn_longlong_ushort(&xp, nget, value); +#line 1011 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1011 + status = lstatus; +#line 1011 + +#line 1011 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1011 + +#line 1011 + remaining -= extent; +#line 1011 + if(remaining == 0) +#line 1011 + break; /* normal loop exit */ +#line 1011 + offset += (off_t)extent; +#line 1011 + value += nget; +#line 1011 + } +#line 1011 + +#line 1011 + return status; +#line 1011 +} +#line 1011 + + +static int +#line 1013 +getNCvx_ulonglong_schar(const NC3_INFO* ncp, const NC_var *varp, +#line 1013 + const size_t *start, size_t nelems, schar *value) +#line 1013 +{ +#line 1013 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1013 + size_t remaining = varp->xsz * nelems; +#line 1013 + int status = NC_NOERR; +#line 1013 + const void *xp; +#line 1013 + +#line 1013 + if(nelems == 0) +#line 1013 + return NC_NOERR; +#line 1013 + +#line 1013 + assert(value != NULL); +#line 1013 + +#line 1013 + for(;;) +#line 1013 + { +#line 1013 + size_t extent = MIN(remaining, ncp->chunk); +#line 1013 + size_t nget = ncx_howmany(varp->type, extent); +#line 1013 + +#line 1013 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1013 + 0, (void **)&xp); /* cast away const */ +#line 1013 + if(lstatus != NC_NOERR) +#line 1013 + return lstatus; +#line 1013 + +#line 1013 + lstatus = ncx_getn_ulonglong_schar(&xp, nget, value); +#line 1013 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1013 + status = lstatus; +#line 1013 + +#line 1013 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1013 + +#line 1013 + remaining -= extent; +#line 1013 + if(remaining == 0) +#line 1013 + break; /* normal loop exit */ +#line 1013 + offset += (off_t)extent; +#line 1013 + value += nget; +#line 1013 + } +#line 1013 + +#line 1013 + return status; +#line 1013 +} +#line 1013 + +static int +#line 1014 +getNCvx_ulonglong_uchar(const NC3_INFO* ncp, const NC_var *varp, +#line 1014 + const size_t *start, size_t nelems, uchar *value) +#line 1014 +{ +#line 1014 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1014 + size_t remaining = varp->xsz * nelems; +#line 1014 + int status = NC_NOERR; +#line 1014 + const void *xp; +#line 1014 + +#line 1014 + if(nelems == 0) +#line 1014 + return NC_NOERR; +#line 1014 + +#line 1014 + assert(value != NULL); +#line 1014 + +#line 1014 + for(;;) +#line 1014 + { +#line 1014 + size_t extent = MIN(remaining, ncp->chunk); +#line 1014 + size_t nget = ncx_howmany(varp->type, extent); +#line 1014 + +#line 1014 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1014 + 0, (void **)&xp); /* cast away const */ +#line 1014 + if(lstatus != NC_NOERR) +#line 1014 + return lstatus; +#line 1014 + +#line 1014 + lstatus = ncx_getn_ulonglong_uchar(&xp, nget, value); +#line 1014 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1014 + status = lstatus; +#line 1014 + +#line 1014 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1014 + +#line 1014 + remaining -= extent; +#line 1014 + if(remaining == 0) +#line 1014 + break; /* normal loop exit */ +#line 1014 + offset += (off_t)extent; +#line 1014 + value += nget; +#line 1014 + } +#line 1014 + +#line 1014 + return status; +#line 1014 +} +#line 1014 + +static int +#line 1015 +getNCvx_ulonglong_short(const NC3_INFO* ncp, const NC_var *varp, +#line 1015 + const size_t *start, size_t nelems, short *value) +#line 1015 +{ +#line 1015 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1015 + size_t remaining = varp->xsz * nelems; +#line 1015 + int status = NC_NOERR; +#line 1015 + const void *xp; +#line 1015 + +#line 1015 + if(nelems == 0) +#line 1015 + return NC_NOERR; +#line 1015 + +#line 1015 + assert(value != NULL); +#line 1015 + +#line 1015 + for(;;) +#line 1015 + { +#line 1015 + size_t extent = MIN(remaining, ncp->chunk); +#line 1015 + size_t nget = ncx_howmany(varp->type, extent); +#line 1015 + +#line 1015 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1015 + 0, (void **)&xp); /* cast away const */ +#line 1015 + if(lstatus != NC_NOERR) +#line 1015 + return lstatus; +#line 1015 + +#line 1015 + lstatus = ncx_getn_ulonglong_short(&xp, nget, value); +#line 1015 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1015 + status = lstatus; +#line 1015 + +#line 1015 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1015 + +#line 1015 + remaining -= extent; +#line 1015 + if(remaining == 0) +#line 1015 + break; /* normal loop exit */ +#line 1015 + offset += (off_t)extent; +#line 1015 + value += nget; +#line 1015 + } +#line 1015 + +#line 1015 + return status; +#line 1015 +} +#line 1015 + +static int +#line 1016 +getNCvx_ulonglong_int(const NC3_INFO* ncp, const NC_var *varp, +#line 1016 + const size_t *start, size_t nelems, int *value) +#line 1016 +{ +#line 1016 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1016 + size_t remaining = varp->xsz * nelems; +#line 1016 + int status = NC_NOERR; +#line 1016 + const void *xp; +#line 1016 + +#line 1016 + if(nelems == 0) +#line 1016 + return NC_NOERR; +#line 1016 + +#line 1016 + assert(value != NULL); +#line 1016 + +#line 1016 + for(;;) +#line 1016 + { +#line 1016 + size_t extent = MIN(remaining, ncp->chunk); +#line 1016 + size_t nget = ncx_howmany(varp->type, extent); +#line 1016 + +#line 1016 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1016 + 0, (void **)&xp); /* cast away const */ +#line 1016 + if(lstatus != NC_NOERR) +#line 1016 + return lstatus; +#line 1016 + +#line 1016 + lstatus = ncx_getn_ulonglong_int(&xp, nget, value); +#line 1016 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1016 + status = lstatus; +#line 1016 + +#line 1016 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1016 + +#line 1016 + remaining -= extent; +#line 1016 + if(remaining == 0) +#line 1016 + break; /* normal loop exit */ +#line 1016 + offset += (off_t)extent; +#line 1016 + value += nget; +#line 1016 + } +#line 1016 + +#line 1016 + return status; +#line 1016 +} +#line 1016 + +static int +#line 1017 +getNCvx_ulonglong_float(const NC3_INFO* ncp, const NC_var *varp, +#line 1017 + const size_t *start, size_t nelems, float *value) +#line 1017 +{ +#line 1017 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1017 + size_t remaining = varp->xsz * nelems; +#line 1017 + int status = NC_NOERR; +#line 1017 + const void *xp; +#line 1017 + +#line 1017 + if(nelems == 0) +#line 1017 + return NC_NOERR; +#line 1017 + +#line 1017 + assert(value != NULL); +#line 1017 + +#line 1017 + for(;;) +#line 1017 + { +#line 1017 + size_t extent = MIN(remaining, ncp->chunk); +#line 1017 + size_t nget = ncx_howmany(varp->type, extent); +#line 1017 + +#line 1017 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1017 + 0, (void **)&xp); /* cast away const */ +#line 1017 + if(lstatus != NC_NOERR) +#line 1017 + return lstatus; +#line 1017 + +#line 1017 + lstatus = ncx_getn_ulonglong_float(&xp, nget, value); +#line 1017 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1017 + status = lstatus; +#line 1017 + +#line 1017 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1017 + +#line 1017 + remaining -= extent; +#line 1017 + if(remaining == 0) +#line 1017 + break; /* normal loop exit */ +#line 1017 + offset += (off_t)extent; +#line 1017 + value += nget; +#line 1017 + } +#line 1017 + +#line 1017 + return status; +#line 1017 +} +#line 1017 + +static int +#line 1018 +getNCvx_ulonglong_double(const NC3_INFO* ncp, const NC_var *varp, +#line 1018 + const size_t *start, size_t nelems, double *value) +#line 1018 +{ +#line 1018 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1018 + size_t remaining = varp->xsz * nelems; +#line 1018 + int status = NC_NOERR; +#line 1018 + const void *xp; +#line 1018 + +#line 1018 + if(nelems == 0) +#line 1018 + return NC_NOERR; +#line 1018 + +#line 1018 + assert(value != NULL); +#line 1018 + +#line 1018 + for(;;) +#line 1018 + { +#line 1018 + size_t extent = MIN(remaining, ncp->chunk); +#line 1018 + size_t nget = ncx_howmany(varp->type, extent); +#line 1018 + +#line 1018 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1018 + 0, (void **)&xp); /* cast away const */ +#line 1018 + if(lstatus != NC_NOERR) +#line 1018 + return lstatus; +#line 1018 + +#line 1018 + lstatus = ncx_getn_ulonglong_double(&xp, nget, value); +#line 1018 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1018 + status = lstatus; +#line 1018 + +#line 1018 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1018 + +#line 1018 + remaining -= extent; +#line 1018 + if(remaining == 0) +#line 1018 + break; /* normal loop exit */ +#line 1018 + offset += (off_t)extent; +#line 1018 + value += nget; +#line 1018 + } +#line 1018 + +#line 1018 + return status; +#line 1018 +} +#line 1018 + +static int +#line 1019 +getNCvx_ulonglong_longlong(const NC3_INFO* ncp, const NC_var *varp, +#line 1019 + const size_t *start, size_t nelems, longlong *value) +#line 1019 +{ +#line 1019 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1019 + size_t remaining = varp->xsz * nelems; +#line 1019 + int status = NC_NOERR; +#line 1019 + const void *xp; +#line 1019 + +#line 1019 + if(nelems == 0) +#line 1019 + return NC_NOERR; +#line 1019 + +#line 1019 + assert(value != NULL); +#line 1019 + +#line 1019 + for(;;) +#line 1019 + { +#line 1019 + size_t extent = MIN(remaining, ncp->chunk); +#line 1019 + size_t nget = ncx_howmany(varp->type, extent); +#line 1019 + +#line 1019 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1019 + 0, (void **)&xp); /* cast away const */ +#line 1019 + if(lstatus != NC_NOERR) +#line 1019 + return lstatus; +#line 1019 + +#line 1019 + lstatus = ncx_getn_ulonglong_longlong(&xp, nget, value); +#line 1019 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1019 + status = lstatus; +#line 1019 + +#line 1019 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1019 + +#line 1019 + remaining -= extent; +#line 1019 + if(remaining == 0) +#line 1019 + break; /* normal loop exit */ +#line 1019 + offset += (off_t)extent; +#line 1019 + value += nget; +#line 1019 + } +#line 1019 + +#line 1019 + return status; +#line 1019 +} +#line 1019 + +static int +#line 1020 +getNCvx_ulonglong_uint(const NC3_INFO* ncp, const NC_var *varp, +#line 1020 + const size_t *start, size_t nelems, uint *value) +#line 1020 +{ +#line 1020 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1020 + size_t remaining = varp->xsz * nelems; +#line 1020 + int status = NC_NOERR; +#line 1020 + const void *xp; +#line 1020 + +#line 1020 + if(nelems == 0) +#line 1020 + return NC_NOERR; +#line 1020 + +#line 1020 + assert(value != NULL); +#line 1020 + +#line 1020 + for(;;) +#line 1020 + { +#line 1020 + size_t extent = MIN(remaining, ncp->chunk); +#line 1020 + size_t nget = ncx_howmany(varp->type, extent); +#line 1020 + +#line 1020 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1020 + 0, (void **)&xp); /* cast away const */ +#line 1020 + if(lstatus != NC_NOERR) +#line 1020 + return lstatus; +#line 1020 + +#line 1020 + lstatus = ncx_getn_ulonglong_uint(&xp, nget, value); +#line 1020 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1020 + status = lstatus; +#line 1020 + +#line 1020 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1020 + +#line 1020 + remaining -= extent; +#line 1020 + if(remaining == 0) +#line 1020 + break; /* normal loop exit */ +#line 1020 + offset += (off_t)extent; +#line 1020 + value += nget; +#line 1020 + } +#line 1020 + +#line 1020 + return status; +#line 1020 +} +#line 1020 + +static int +#line 1021 +getNCvx_ulonglong_ulonglong(const NC3_INFO* ncp, const NC_var *varp, +#line 1021 + const size_t *start, size_t nelems, ulonglong *value) +#line 1021 +{ +#line 1021 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1021 + size_t remaining = varp->xsz * nelems; +#line 1021 + int status = NC_NOERR; +#line 1021 + const void *xp; +#line 1021 + +#line 1021 + if(nelems == 0) +#line 1021 + return NC_NOERR; +#line 1021 + +#line 1021 + assert(value != NULL); +#line 1021 + +#line 1021 + for(;;) +#line 1021 + { +#line 1021 + size_t extent = MIN(remaining, ncp->chunk); +#line 1021 + size_t nget = ncx_howmany(varp->type, extent); +#line 1021 + +#line 1021 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1021 + 0, (void **)&xp); /* cast away const */ +#line 1021 + if(lstatus != NC_NOERR) +#line 1021 + return lstatus; +#line 1021 + +#line 1021 + lstatus = ncx_getn_ulonglong_ulonglong(&xp, nget, value); +#line 1021 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1021 + status = lstatus; +#line 1021 + +#line 1021 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1021 + +#line 1021 + remaining -= extent; +#line 1021 + if(remaining == 0) +#line 1021 + break; /* normal loop exit */ +#line 1021 + offset += (off_t)extent; +#line 1021 + value += nget; +#line 1021 + } +#line 1021 + +#line 1021 + return status; +#line 1021 +} +#line 1021 + +static int +#line 1022 +getNCvx_ulonglong_ushort(const NC3_INFO* ncp, const NC_var *varp, +#line 1022 + const size_t *start, size_t nelems, ushort *value) +#line 1022 +{ +#line 1022 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1022 + size_t remaining = varp->xsz * nelems; +#line 1022 + int status = NC_NOERR; +#line 1022 + const void *xp; +#line 1022 + +#line 1022 + if(nelems == 0) +#line 1022 + return NC_NOERR; +#line 1022 + +#line 1022 + assert(value != NULL); +#line 1022 + +#line 1022 + for(;;) +#line 1022 + { +#line 1022 + size_t extent = MIN(remaining, ncp->chunk); +#line 1022 + size_t nget = ncx_howmany(varp->type, extent); +#line 1022 + +#line 1022 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1022 + 0, (void **)&xp); /* cast away const */ +#line 1022 + if(lstatus != NC_NOERR) +#line 1022 + return lstatus; +#line 1022 + +#line 1022 + lstatus = ncx_getn_ulonglong_ushort(&xp, nget, value); +#line 1022 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1022 + status = lstatus; +#line 1022 + +#line 1022 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1022 + +#line 1022 + remaining -= extent; +#line 1022 + if(remaining == 0) +#line 1022 + break; /* normal loop exit */ +#line 1022 + offset += (off_t)extent; +#line 1022 + value += nget; +#line 1022 + } +#line 1022 + +#line 1022 + return status; +#line 1022 +} +#line 1022 + + +#line 1025 +#ifdef NOTUSED +static int +#line 1026 +getNCvx_schar_uchar(const NC3_INFO* ncp, const NC_var *varp, +#line 1026 + const size_t *start, size_t nelems, uchar *value) +#line 1026 +{ +#line 1026 + off_t offset = NC_varoffset(ncp, varp, start); +#line 1026 + size_t remaining = varp->xsz * nelems; +#line 1026 + int status = NC_NOERR; +#line 1026 + const void *xp; +#line 1026 + +#line 1026 + if(nelems == 0) +#line 1026 + return NC_NOERR; +#line 1026 + +#line 1026 + assert(value != NULL); +#line 1026 + +#line 1026 + for(;;) +#line 1026 + { +#line 1026 + size_t extent = MIN(remaining, ncp->chunk); +#line 1026 + size_t nget = ncx_howmany(varp->type, extent); +#line 1026 + +#line 1026 + int lstatus = ncio_get(ncp->nciop, offset, extent, +#line 1026 + 0, (void **)&xp); /* cast away const */ +#line 1026 + if(lstatus != NC_NOERR) +#line 1026 + return lstatus; +#line 1026 + +#line 1026 + lstatus = ncx_getn_schar_uchar(&xp, nget, value); +#line 1026 + if(lstatus != NC_NOERR && status == NC_NOERR) +#line 1026 + status = lstatus; +#line 1026 + +#line 1026 + (void) ncio_rel(ncp->nciop, offset, 0); +#line 1026 + +#line 1026 + remaining -= extent; +#line 1026 + if(remaining == 0) +#line 1026 + break; /* normal loop exit */ +#line 1026 + offset += (off_t)extent; +#line 1026 + value += nget; +#line 1026 + } +#line 1026 + +#line 1026 + return status; +#line 1026 +} +#line 1026 + +#endif /*NOTUSED*/ + +/* + * For ncvar{put,get}, + * find the largest contiguous block from within 'edges'. + * returns the index to the left of this (which may be -1). + * Compute the number of contiguous elements and return + * that in *iocountp. + * The presence of "record" variables makes this routine + * overly subtle. + */ +static int +NCiocount(const NC3_INFO* const ncp, const NC_var *const varp, + const size_t *const edges, + size_t *const iocountp) +{ + const size_t *edp0 = edges; + const size_t *edp = edges + varp->ndims; + const size_t *shp = varp->shape + varp->ndims; + + if(IS_RECVAR(varp)) + { + if(varp->ndims == 1 && ncp->recsize <= varp->len) + { + /* one dimensional && the only 'record' variable */ + *iocountp = *edges; + return(0); + } + /* else */ + edp0++; + } + + assert(edges != NULL); + + /* find max contiguous */ + while(edp > edp0) + { + shp--; edp--; + if(*edp < *shp ) + { + const size_t *zedp = edp; + while(zedp >= edp0) + { + if(*zedp == 0) + { + *iocountp = 0; + goto done; + } + /* Tip of the hat to segmented architectures */ + if(zedp == edp0) + break; + zedp--; + } + break; + } + assert(*edp == *shp); + } + + /* + * edp, shp reference rightmost index s.t. *(edp +1) == *(shp +1) + * + * Or there is only one dimension. + * If there is only one dimension and it is 'non record' dimension, + * edp is &edges[0] and we will return -1. + * If there is only one dimension and and it is a "record dimension", + * edp is &edges[1] (out of bounds) and we will return 0; + */ + assert(shp >= varp->shape + varp->ndims -1 + || *(edp +1) == *(shp +1)); + + /* now accumulate max count for a single io operation */ + for(*iocountp = 1, edp0 = edp; + edp0 < edges + varp->ndims; + edp0++) + { + *iocountp *= *edp0; + } + +done: + return((int)(edp - edges) - 1); +} + + +/* + * Set the elements of the array 'upp' to + * the sum of the corresponding elements of + * 'stp' and 'edp'. 'end' should be &stp[nelems]. + */ +static void +set_upper(size_t *upp, /* modified on return */ + const size_t *stp, + const size_t *edp, + const size_t *const end) +{ + while(upp < end) { + *upp++ = *stp++ + *edp++; + } +} + + +/* + * The infamous and oft-discussed odometer code. + * + * 'start[]' is the starting coordinate. + * 'upper[]' is the upper bound s.t. start[ii] < upper[ii]. + * 'coord[]' is the register, the current coordinate value. + * For some ii, + * upp == &upper[ii] + * cdp == &coord[ii] + * + * Running this routine increments *cdp. + * + * If after the increment, *cdp is equal to *upp + * (and cdp is not the leftmost dimension), + * *cdp is "zeroed" to the starting value and + * we need to "carry", eg, increment one place to + * the left. + * + * TODO: Some architectures hate recursion? + * Reimplement non-recursively. + */ +static void +odo1(const size_t *const start, const size_t *const upper, + size_t *const coord, /* modified on return */ + const size_t *upp, + size_t *cdp) +{ + assert(coord <= cdp && cdp <= coord + NC_MAX_VAR_DIMS); + assert(upper <= upp && upp <= upper + NC_MAX_VAR_DIMS); + assert(upp - upper == cdp - coord); + + assert(*cdp <= *upp); + + (*cdp)++; + if(cdp != coord && *cdp >= *upp) + { + *cdp = start[cdp - coord]; + odo1(start, upper, coord, upp -1, cdp -1); + } +} +#ifdef _CRAYC +#pragma _CRI noinline odo1 +#endif + + +#line 1188 + +/* Define a macro to allow hash on two type values */ +#define CASE(nc1,nc2) (nc1*256+nc2) + +static int +readNCv(const NC3_INFO* ncp, const NC_var* varp, const size_t* start, + const size_t nelems, void* value, const nc_type memtype) +{ + int status = NC_NOERR; + switch (CASE(varp->type,memtype)) { + + case CASE(NC_CHAR,NC_CHAR): + case CASE(NC_CHAR,NC_UBYTE): + return getNCvx_schar_schar(ncp,varp,start,nelems,(signed char*)value); + break; + case CASE(NC_BYTE,NC_BYTE): + return getNCvx_schar_schar(ncp,varp,start,nelems, (schar*)value); + break; + case CASE(NC_BYTE,NC_UBYTE): + if (fIsSet(ncp->flags,NC_64BIT_DATA)) + return getNCvx_schar_uchar(ncp,varp,start,nelems,(unsigned char*)value); + else + /* for CDF-1 and CDF-2, NC_BYTE is treated the same type as uchar memtype */ + return getNCvx_uchar_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_BYTE,NC_SHORT): + return getNCvx_schar_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_BYTE,NC_INT): + return getNCvx_schar_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_BYTE,NC_FLOAT): + return getNCvx_schar_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_BYTE,NC_DOUBLE): + return getNCvx_schar_double(ncp,varp,start,nelems,(double *)value); + break; + case CASE(NC_BYTE,NC_INT64): + return getNCvx_schar_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_BYTE,NC_UINT): + return getNCvx_schar_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_BYTE,NC_UINT64): + return getNCvx_schar_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_BYTE,NC_USHORT): + return getNCvx_schar_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + case CASE(NC_SHORT,NC_BYTE): + return getNCvx_short_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_SHORT,NC_UBYTE): + return getNCvx_short_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_SHORT,NC_SHORT): + return getNCvx_short_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_SHORT,NC_INT): + return getNCvx_short_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_SHORT,NC_FLOAT): + return getNCvx_short_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_SHORT,NC_DOUBLE): + return getNCvx_short_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_SHORT,NC_INT64): + return getNCvx_short_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_SHORT,NC_UINT): + return getNCvx_short_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_SHORT,NC_UINT64): + return getNCvx_short_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_SHORT,NC_USHORT): + return getNCvx_short_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + + case CASE(NC_INT,NC_BYTE): + return getNCvx_int_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_INT,NC_UBYTE): + return getNCvx_int_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_INT,NC_SHORT): + return getNCvx_int_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_INT,NC_INT): + return getNCvx_int_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_INT,NC_FLOAT): + return getNCvx_int_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_INT,NC_DOUBLE): + return getNCvx_int_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_INT,NC_INT64): + return getNCvx_int_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_INT,NC_UINT): + return getNCvx_int_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_INT,NC_UINT64): + return getNCvx_int_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_INT,NC_USHORT): + return getNCvx_int_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + + case CASE(NC_FLOAT,NC_BYTE): + return getNCvx_float_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_FLOAT,NC_UBYTE): + return getNCvx_float_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_FLOAT,NC_SHORT): + return getNCvx_float_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_FLOAT,NC_INT): + return getNCvx_float_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_FLOAT,NC_FLOAT): + return getNCvx_float_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_FLOAT,NC_DOUBLE): + return getNCvx_float_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_FLOAT,NC_INT64): + return getNCvx_float_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_FLOAT,NC_UINT): + return getNCvx_float_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_FLOAT,NC_UINT64): + return getNCvx_float_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_FLOAT,NC_USHORT): + return getNCvx_float_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + + case CASE(NC_DOUBLE,NC_BYTE): + return getNCvx_double_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_DOUBLE,NC_UBYTE): + return getNCvx_double_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_DOUBLE,NC_SHORT): + return getNCvx_double_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_DOUBLE,NC_INT): + return getNCvx_double_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_DOUBLE,NC_FLOAT): + return getNCvx_double_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_DOUBLE,NC_DOUBLE): + return getNCvx_double_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_DOUBLE,NC_INT64): + return getNCvx_double_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_DOUBLE,NC_UINT): + return getNCvx_double_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_DOUBLE,NC_UINT64): + return getNCvx_double_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_DOUBLE,NC_USHORT): + return getNCvx_double_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + + case CASE(NC_UBYTE,NC_UBYTE): + return getNCvx_uchar_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_UBYTE,NC_BYTE): + return getNCvx_uchar_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_UBYTE,NC_SHORT): + return getNCvx_uchar_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_UBYTE,NC_INT): + return getNCvx_uchar_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_UBYTE,NC_FLOAT): + return getNCvx_uchar_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_UBYTE,NC_DOUBLE): + return getNCvx_uchar_double(ncp,varp,start,nelems,(double *)value); + break; + case CASE(NC_UBYTE,NC_INT64): + return getNCvx_uchar_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_UBYTE,NC_UINT): + return getNCvx_uchar_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_UBYTE,NC_UINT64): + return getNCvx_uchar_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_UBYTE,NC_USHORT): + return getNCvx_uchar_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + + case CASE(NC_USHORT,NC_BYTE): + return getNCvx_ushort_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_USHORT,NC_UBYTE): + return getNCvx_ushort_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_USHORT,NC_SHORT): + return getNCvx_ushort_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_USHORT,NC_INT): + return getNCvx_ushort_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_USHORT,NC_FLOAT): + return getNCvx_ushort_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_USHORT,NC_DOUBLE): + return getNCvx_ushort_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_USHORT,NC_INT64): + return getNCvx_ushort_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_USHORT,NC_UINT): + return getNCvx_ushort_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_USHORT,NC_UINT64): + return getNCvx_ushort_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_USHORT,NC_USHORT): + return getNCvx_ushort_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + + case CASE(NC_UINT,NC_BYTE): + return getNCvx_uint_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_UINT,NC_UBYTE): + return getNCvx_uint_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_UINT,NC_SHORT): + return getNCvx_uint_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_UINT,NC_INT): + return getNCvx_uint_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_UINT,NC_FLOAT): + return getNCvx_uint_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_UINT,NC_DOUBLE): + return getNCvx_uint_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_UINT,NC_INT64): + return getNCvx_uint_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_UINT,NC_UINT): + return getNCvx_uint_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_UINT,NC_UINT64): + return getNCvx_uint_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_UINT,NC_USHORT): + return getNCvx_uint_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + + case CASE(NC_INT64,NC_BYTE): + return getNCvx_longlong_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_INT64,NC_UBYTE): + return getNCvx_longlong_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_INT64,NC_SHORT): + return getNCvx_longlong_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_INT64,NC_INT): + return getNCvx_longlong_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_INT64,NC_FLOAT): + return getNCvx_longlong_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_INT64,NC_DOUBLE): + return getNCvx_longlong_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_INT64,NC_INT64): + return getNCvx_longlong_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_INT64,NC_UINT): + return getNCvx_longlong_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_INT64,NC_UINT64): + return getNCvx_longlong_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_INT64,NC_USHORT): + return getNCvx_longlong_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + + case CASE(NC_UINT64,NC_BYTE): + return getNCvx_ulonglong_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_UINT64,NC_UBYTE): + return getNCvx_ulonglong_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_UINT64,NC_SHORT): + return getNCvx_ulonglong_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_UINT64,NC_INT): + return getNCvx_ulonglong_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_UINT64,NC_FLOAT): + return getNCvx_ulonglong_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_UINT64,NC_DOUBLE): + return getNCvx_ulonglong_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_UINT64,NC_INT64): + return getNCvx_ulonglong_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_UINT64,NC_UINT): + return getNCvx_ulonglong_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_UINT64,NC_UINT64): + return getNCvx_ulonglong_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_UINT64,NC_USHORT): + return getNCvx_ulonglong_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + + default: + return NC_EBADTYPE; + break; + } + return status; +} + + +static int +writeNCv(NC3_INFO* ncp, const NC_var* varp, const size_t* start, + const size_t nelems, const void* value, const nc_type memtype) +{ + int status = NC_NOERR; + switch (CASE(varp->type,memtype)) { + + case CASE(NC_CHAR,NC_CHAR): + case CASE(NC_CHAR,NC_UBYTE): + return putNCvx_char_char(ncp,varp,start,nelems,(char*)value); + break; + case CASE(NC_BYTE,NC_BYTE): + return putNCvx_schar_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_BYTE,NC_UBYTE): + if (fIsSet(ncp->flags,NC_64BIT_DATA)) + return putNCvx_schar_uchar(ncp,varp,start,nelems,(unsigned char*)value); + else + /* for CDF-1 and CDF-2, NC_BYTE is treated the same type as uchar memtype */ + return putNCvx_uchar_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_BYTE,NC_SHORT): + return putNCvx_schar_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_BYTE,NC_INT): + return putNCvx_schar_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_BYTE,NC_FLOAT): + return putNCvx_schar_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_BYTE,NC_DOUBLE): + return putNCvx_schar_double(ncp,varp,start,nelems,(double *)value); + break; + case CASE(NC_BYTE,NC_INT64): + return putNCvx_schar_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_BYTE,NC_UINT): + return putNCvx_schar_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_BYTE,NC_UINT64): + return putNCvx_schar_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_BYTE,NC_USHORT): + return putNCvx_schar_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + case CASE(NC_SHORT,NC_BYTE): + return putNCvx_short_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_SHORT,NC_UBYTE): + return putNCvx_short_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_SHORT,NC_SHORT): + return putNCvx_short_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_SHORT,NC_INT): + return putNCvx_short_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_SHORT,NC_FLOAT): + return putNCvx_short_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_SHORT,NC_DOUBLE): + return putNCvx_short_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_SHORT,NC_INT64): + return putNCvx_short_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_SHORT,NC_UINT): + return putNCvx_short_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_SHORT,NC_UINT64): + return putNCvx_short_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_SHORT,NC_USHORT): + return putNCvx_short_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + case CASE(NC_INT,NC_BYTE): + return putNCvx_int_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_INT,NC_UBYTE): + return putNCvx_int_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_INT,NC_SHORT): + return putNCvx_int_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_INT,NC_INT): + return putNCvx_int_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_INT,NC_FLOAT): + return putNCvx_int_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_INT,NC_DOUBLE): + return putNCvx_int_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_INT,NC_INT64): + return putNCvx_int_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_INT,NC_UINT): + return putNCvx_int_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_INT,NC_UINT64): + return putNCvx_int_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_INT,NC_USHORT): + return putNCvx_int_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + case CASE(NC_FLOAT,NC_BYTE): + return putNCvx_float_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_FLOAT,NC_UBYTE): + return putNCvx_float_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_FLOAT,NC_SHORT): + return putNCvx_float_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_FLOAT,NC_INT): + return putNCvx_float_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_FLOAT,NC_FLOAT): + return putNCvx_float_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_FLOAT,NC_DOUBLE): + return putNCvx_float_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_FLOAT,NC_INT64): + return putNCvx_float_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_FLOAT,NC_UINT): + return putNCvx_float_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_FLOAT,NC_UINT64): + return putNCvx_float_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_FLOAT,NC_USHORT): + return putNCvx_float_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + case CASE(NC_DOUBLE,NC_BYTE): + return putNCvx_double_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_DOUBLE,NC_UBYTE): + return putNCvx_double_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_DOUBLE,NC_SHORT): + return putNCvx_double_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_DOUBLE,NC_INT): + return putNCvx_double_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_DOUBLE,NC_FLOAT): + return putNCvx_double_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_DOUBLE,NC_DOUBLE): + return putNCvx_double_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_DOUBLE,NC_INT64): + return putNCvx_double_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_DOUBLE,NC_UINT): + return putNCvx_double_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_DOUBLE,NC_UINT64): + return putNCvx_double_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_DOUBLE,NC_USHORT): + return putNCvx_double_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + case CASE(NC_UBYTE,NC_UBYTE): + return putNCvx_uchar_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_UBYTE,NC_BYTE): + return putNCvx_uchar_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_UBYTE,NC_SHORT): + return putNCvx_uchar_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_UBYTE,NC_INT): + return putNCvx_uchar_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_UBYTE,NC_FLOAT): + return putNCvx_uchar_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_UBYTE,NC_DOUBLE): + return putNCvx_uchar_double(ncp,varp,start,nelems,(double *)value); + break; + case CASE(NC_UBYTE,NC_INT64): + return putNCvx_uchar_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_UBYTE,NC_UINT): + return putNCvx_uchar_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_UBYTE,NC_UINT64): + return putNCvx_uchar_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_UBYTE,NC_USHORT): + return putNCvx_uchar_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + case CASE(NC_USHORT,NC_BYTE): + return putNCvx_ushort_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_USHORT,NC_UBYTE): + return putNCvx_ushort_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_USHORT,NC_SHORT): + return putNCvx_ushort_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_USHORT,NC_INT): + return putNCvx_ushort_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_USHORT,NC_FLOAT): + return putNCvx_ushort_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_USHORT,NC_DOUBLE): + return putNCvx_ushort_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_USHORT,NC_INT64): + return putNCvx_ushort_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_USHORT,NC_UINT): + return putNCvx_ushort_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_USHORT,NC_UINT64): + return putNCvx_ushort_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_USHORT,NC_USHORT): + return putNCvx_ushort_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + case CASE(NC_UINT,NC_BYTE): + return putNCvx_uint_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_UINT,NC_UBYTE): + return putNCvx_uint_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_UINT,NC_SHORT): + return putNCvx_uint_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_UINT,NC_INT): + return putNCvx_uint_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_UINT,NC_FLOAT): + return putNCvx_uint_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_UINT,NC_DOUBLE): + return putNCvx_uint_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_UINT,NC_INT64): + return putNCvx_uint_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_UINT,NC_UINT): + return putNCvx_uint_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_UINT,NC_UINT64): + return putNCvx_uint_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_UINT,NC_USHORT): + return putNCvx_uint_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + case CASE(NC_INT64,NC_BYTE): + return putNCvx_longlong_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_INT64,NC_UBYTE): + return putNCvx_longlong_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_INT64,NC_SHORT): + return putNCvx_longlong_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_INT64,NC_INT): + return putNCvx_longlong_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_INT64,NC_FLOAT): + return putNCvx_longlong_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_INT64,NC_DOUBLE): + return putNCvx_longlong_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_INT64,NC_INT64): + return putNCvx_longlong_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_INT64,NC_UINT): + return putNCvx_longlong_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_INT64,NC_UINT64): + return putNCvx_longlong_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_INT64,NC_USHORT): + return putNCvx_longlong_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + case CASE(NC_UINT64,NC_BYTE): + return putNCvx_ulonglong_schar(ncp,varp,start,nelems,(schar*)value); + break; + case CASE(NC_UINT64,NC_UBYTE): + return putNCvx_ulonglong_uchar(ncp,varp,start,nelems,(unsigned char*)value); + break; + case CASE(NC_UINT64,NC_SHORT): + return putNCvx_ulonglong_short(ncp,varp,start,nelems,(short*)value); + break; + case CASE(NC_UINT64,NC_INT): + return putNCvx_ulonglong_int(ncp,varp,start,nelems,(int*)value); + break; + case CASE(NC_UINT64,NC_FLOAT): + return putNCvx_ulonglong_float(ncp,varp,start,nelems,(float*)value); + break; + case CASE(NC_UINT64,NC_DOUBLE): + return putNCvx_ulonglong_double(ncp,varp,start,nelems,(double*)value); + break; + case CASE(NC_UINT64,NC_INT64): + return putNCvx_ulonglong_longlong(ncp,varp,start,nelems,(long long*)value); + break; + case CASE(NC_UINT64,NC_UINT): + return putNCvx_ulonglong_uint(ncp,varp,start,nelems,(unsigned int*)value); + break; + case CASE(NC_UINT64,NC_UINT64): + return putNCvx_ulonglong_ulonglong(ncp,varp,start,nelems,(unsigned long long*)value); + break; + case CASE(NC_UINT64,NC_USHORT): + return putNCvx_ulonglong_ushort(ncp,varp,start,nelems,(unsigned short*)value); + break; + + default: + return NC_EBADTYPE; + break; + } + return status; +} + +/**************************************************/ + +int +NC3_get_vara(int ncid, int varid, + const size_t *start, const size_t *edges0, + void *value0, + nc_type memtype) +{ + int status = NC_NOERR; + NC* nc; + NC3_INFO* nc3; + NC_var *varp; + int ii; + size_t iocount; + size_t memtypelen; + signed char* value = (signed char*) value0; /* legally allow ptr arithmetic */ + const size_t* edges = edges0; /* so we can modify for special cases */ + size_t modedges[NC_MAX_VAR_DIMS]; + + status = NC_check_id(ncid, &nc); + if(status != NC_NOERR) + return status; + nc3 = NC3_DATA(nc); + + if(NC_indef(nc3)) + return NC_EINDEFINE; + + status = NC_lookupvar(nc3, varid, &varp); + if(status != NC_NOERR) + return status; + + if(memtype == NC_NAT) memtype=varp->type; + + if(memtype == NC_CHAR && varp->type != NC_CHAR) + return NC_ECHAR; + else if(memtype != NC_CHAR && varp->type == NC_CHAR) + return NC_ECHAR; + + /* If edges is NULL, then this was called from nc_get_var() */ + if(edges == NULL && varp->ndims > 0) { + /* If this is a record variable, then we have to + substitute the number of records into dimension 0. */ + if(varp->shape[0] == 0) { + (void)memcpy((void*)modedges,(void*)varp->shape, + sizeof(size_t)*varp->ndims); + modedges[0] = NC_get_numrecs(nc3); + edges = modedges; + } else + edges = varp->shape; + } + + status = NCcoordck(nc3, varp, start); + if(status != NC_NOERR) + return status; + + status = NCedgeck(nc3, varp, start, edges); + if(status != NC_NOERR) + return status; + + /* Get the size of the memtype */ + memtypelen = nctypelen(memtype); + + if(varp->ndims == 0) /* scalar variable */ + { + return( readNCv(nc3, varp, start, 1, (void*)value, memtype) ); + } + + if(IS_RECVAR(varp)) + { + if(*start + *edges > NC_get_numrecs(nc3)) + return NC_EEDGE; + if(varp->ndims == 1 && nc3->recsize <= varp->len) + { + /* one dimensional && the only record variable */ + return( readNCv(nc3, varp, start, *edges, (void*)value, memtype) ); + } + } + + /* + * find max contiguous + * and accumulate max count for a single io operation + */ + ii = NCiocount(nc3, varp, edges, &iocount); + + if(ii == -1) + { + return( readNCv(nc3, varp, start, iocount, (void*)value, memtype) ); + } + + assert(ii >= 0); + + { /* inline */ + ALLOC_ONSTACK(coord, size_t, varp->ndims); + ALLOC_ONSTACK(upper, size_t, varp->ndims); + const size_t index = ii; + + /* copy in starting indices */ + (void) memcpy(coord, start, varp->ndims * sizeof(size_t)); + + /* set up in maximum indices */ + set_upper(upper, start, edges, &upper[varp->ndims]); + + /* ripple counter */ + while(*coord < *upper) + { + const int lstatus = readNCv(nc3, varp, coord, iocount, (void*)value, memtype); + if(lstatus != NC_NOERR) + { + if(lstatus != NC_ERANGE) + { + status = lstatus; + /* fatal for the loop */ + break; + } + /* else NC_ERANGE, not fatal for the loop */ + if(status == NC_NOERR) + status = lstatus; + } + value += (iocount * memtypelen); + odo1(start, upper, coord, &upper[index], &coord[index]); + } + + FREE_ONSTACK(upper); + FREE_ONSTACK(coord); + } /* end inline */ + + return status; +} + +int +NC3_put_vara(int ncid, int varid, + const size_t *start, const size_t *edges0, + const void *value0, + nc_type memtype) +{ + int status = NC_NOERR; + NC *nc; + NC3_INFO* nc3; + NC_var *varp; + int ii; + size_t iocount; + size_t memtypelen; + signed char* value = (signed char*) value0; /* legally allow ptr arithmetic */ + const size_t* edges = edges0; /* so we can modify for special cases */ + size_t modedges[NC_MAX_VAR_DIMS]; + + status = NC_check_id(ncid, &nc); + if(status != NC_NOERR) + return status; + nc3 = NC3_DATA(nc); + + if(NC_readonly(nc3)) + return NC_EPERM; + + if(NC_indef(nc3)) + return NC_EINDEFINE; + + status = NC_lookupvar(nc3, varid, &varp); + if(status != NC_NOERR) + return status; /*invalid varid */ + + + if(memtype == NC_NAT) memtype=varp->type; + + if(memtype == NC_CHAR && varp->type != NC_CHAR) + return NC_ECHAR; + else if(memtype != NC_CHAR && varp->type == NC_CHAR) + return NC_ECHAR; + + /* Get the size of the memtype */ + memtypelen = nctypelen(memtype); + + /* If edges is NULL, then this was called from nc_get_var() */ + if(edges == NULL && varp->ndims > 0) { + /* If this is a record variable, then we have to + substitute the number of records into dimension 0. */ + if(varp->shape[0] == 0) { + (void)memcpy((void*)modedges,(void*)varp->shape, + sizeof(size_t)*varp->ndims); + modedges[0] = NC_get_numrecs(nc3); + edges = modedges; + } else + edges = varp->shape; + } + + status = NCcoordck(nc3, varp, start); + if(status != NC_NOERR) + return status; + status = NCedgeck(nc3, varp, start, edges); + if(status != NC_NOERR) + return status; + + if(varp->ndims == 0) /* scalar variable */ + { + return( writeNCv(nc3, varp, start, 1, (void*)value, memtype) ); + } + + if(IS_RECVAR(varp)) + { + status = NCvnrecs(nc3, *start + *edges); + if(status != NC_NOERR) + return status; + + if(varp->ndims == 1 + && nc3->recsize <= varp->len) + { + /* one dimensional && the only record variable */ + return( writeNCv(nc3, varp, start, *edges, (void*)value, memtype) ); + } + } + + /* + * find max contiguous + * and accumulate max count for a single io operation + */ + ii = NCiocount(nc3, varp, edges, &iocount); + + if(ii == -1) + { + return( writeNCv(nc3, varp, start, iocount, (void*)value, memtype) ); + } + + assert(ii >= 0); + + { /* inline */ + ALLOC_ONSTACK(coord, size_t, varp->ndims); + ALLOC_ONSTACK(upper, size_t, varp->ndims); + const size_t index = ii; + + /* copy in starting indices */ + (void) memcpy(coord, start, varp->ndims * sizeof(size_t)); + + /* set up in maximum indices */ + set_upper(upper, start, edges, &upper[varp->ndims]); + + /* ripple counter */ + while(*coord < *upper) + { + const int lstatus = writeNCv(nc3, varp, coord, iocount, (void*)value, memtype); + if(lstatus != NC_NOERR) + { + if(lstatus != NC_ERANGE) + { + status = lstatus; + /* fatal for the loop */ + break; + } + /* else NC_ERANGE, not fatal for the loop */ + if(status == NC_NOERR) + status = lstatus; + } + value += (iocount * memtypelen); + odo1(start, upper, coord, &upper[index], &coord[index]); + } + + FREE_ONSTACK(upper); + FREE_ONSTACK(coord); + } /* end inline */ + + return status; +} diff --git a/nc_test/test_get.c b/nc_test/test_get.c new file mode 100644 index 0000000000..f9629d470d --- /dev/null +++ b/nc_test/test_get.c @@ -0,0 +1,12203 @@ +/* Do not edit this file. It is produced from the corresponding .m4 source */ +/* + * Copyright (C) 2003, Northwestern University and Argonne National Laboratory + * See COPYRIGHT notice in top-level directory. + */ +/* $Id: test_get.m4 2672 2016-12-03 19:23:53Z wkliao $ */ + + +#include "tests.h" + +#ifdef USE_PNETCDF +#include +#ifndef PNETCDF_VERSION_MAJOR +#error("PNETCDF_VERSION_MAJOR is not defined in pnetcdf.h") +#endif +#ifndef PNETCDF_VERSION_MINOR +#error("PNETCDF_VERSION_MAJOR is not defined in pnetcdf.h") +#endif +#endif + + + + + + + + + + +int +test_nc_get_var1_text(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + text value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_text(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_text(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_text(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) ; + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_text(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_TEXT); + err = nc_get_var1_text(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_TEXT)) { + if (1) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + IF (!equal((double)value[0], expect, var_type[i], NCT_TEXT)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var1_schar(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + schar value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_schar(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_schar(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_schar(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_schar(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_SCHAR); + err = nc_get_var1_schar(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_SCHAR)) { + if ((expect >= schar_min && expect <= schar_max)) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + IF (!equal((double)value[0], expect, var_type[i], NCT_SCHAR)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + +#if defined(USE_PNETCDF) && PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR<7 + else if (cdf_format < NC_FORMAT_CDF5) { +#else + else { +#endif + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var1_uchar(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + uchar value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_uchar(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_uchar(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_uchar(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_uchar(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_UCHAR); + err = nc_get_var1_uchar(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_UCHAR)) { + if ((expect >= uchar_min && expect <= uchar_max)) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + /* in put_vars(), API _put_vara_double() is used to + * write the NC_BYTE variables to files. In this + * case, NC_BYTE variables are treated as signed + * for CDF-1 and 2 formats. Thus, we must skip the + * equal test below for uchar. + */ + if (cdf_format < NC_FORMAT_CDF5 && var_type[i] == NC_BYTE && expect > schar_max) continue; + IF (!equal((double)value[0], expect, var_type[i], NCT_UCHAR)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=8) + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } +#endif + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var1_short(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + short value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_short(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_short(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_short(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_short(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_SHORT); + err = nc_get_var1_short(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_SHORT)) { + if ((expect >= short_min && expect <= short_max)) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + IF (!equal((double)value[0], expect, var_type[i], NCT_SHORT)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var1_int(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + int value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_int(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_int(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_int(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_int(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_INT); + err = nc_get_var1_int(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_INT)) { + if ((expect >= int_min && expect <= int_max)) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + IF (!equal((double)value[0], expect, var_type[i], NCT_INT)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var1_long(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + long value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_long(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_long(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_long(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_long(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_LONG); + err = nc_get_var1_long(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_LONG)) { + if ((expect >= long_min && expect <= long_max)) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + IF (!equal((double)value[0], expect, var_type[i], NCT_LONG)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var1_float(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + float value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_float(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_float(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_float(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_float(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_FLOAT); + err = nc_get_var1_float(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_FLOAT)) { + if ((expect >= float_min && expect <= float_max)) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + IF (!equal((double)value[0], expect, var_type[i], NCT_FLOAT)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var1_double(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + double value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_double(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_double(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_double(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_double(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_DOUBLE); + err = nc_get_var1_double(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_DOUBLE)) { + if ((expect >= double_min && expect <= double_max)) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + IF (!equal((double)value[0], expect, var_type[i], NCT_DOUBLE)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var1_ushort(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + ushort value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_ushort(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_ushort(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_ushort(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_ushort(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_USHORT); + err = nc_get_var1_ushort(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_USHORT)) { + if ((expect >= ushort_min && expect <= ushort_max)) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + IF (!equal((double)value[0], expect, var_type[i], NCT_USHORT)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var1_uint(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + uint value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_uint(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_uint(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_uint(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_uint(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_UINT); + err = nc_get_var1_uint(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_UINT)) { + if ((expect >= uint_min && expect <= uint_max)) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + IF (!equal((double)value[0], expect, var_type[i], NCT_UINT)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var1_longlong(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + longlong value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_longlong(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_longlong(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_longlong(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_longlong(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_LONGLONG); + err = nc_get_var1_longlong(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_LONGLONG)) { + if ((expect >= longlong_min && expect <= longlong_max)) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + IF (!equal((double)value[0], expect, var_type[i], NCT_LONGLONG)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var1_ulonglong(void) +{ + int i, err, ncid, cdf_format; + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect; + ulonglong value[1]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1_ulonglong(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var1_ulonglong(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1_ulonglong(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_get_var1_ulonglong(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + /* when file is created the variable contents are generated by + * hash functions */ + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_ULONGLONG); + err = nc_get_var1_ulonglong(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, expect,var_type[i], NCT_ULONGLONG)) { + if ((expect >= ulonglong_min && expect <= ulonglong_max)) { + IF (err != NC_NOERR) { + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + + IF (!equal((double)value[0], expect, var_type[i], NCT_ULONGLONG)) { + error("expected: %G, got: %G", expect, (double)value[0]); + } + ELSE_NOK + } + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + + + +int +test_nc_get_var_text(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + text value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_text(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_text(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_text(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) ; + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_TEXT); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_TEXT)) { + if (var_type[i] != NC_CHAR) + allInIntRange &= 1; + } else + allInExtRange = 0; + } + err = nc_get_var_text(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (1) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_TEXT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var_uchar(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + uchar value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_uchar(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_uchar(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_uchar(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_UCHAR); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_UCHAR)) { + + allInIntRange &= (expect[j] >= uchar_min && expect[j] <= uchar_max); + } else + allInExtRange = 0; + } + err = nc_get_var_uchar(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=8) + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } +#endif + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UCHAR) && (expect[j] >= uchar_min && expect[j] <= uchar_max)) { + + /* in put_vars(), API _put_vara_double() is used to + * write the NC_BYTE variables to files. In this + * case, NC_BYTE variables are treated as signed + * for CDF-1 and 2 formats. Thus, we must skip the + * equal test below for uchar. + */ + if (cdf_format < NC_FORMAT_CDF5 && var_type[i] == NC_BYTE && expect[j] > schar_max) continue; + IF (!equal((double)value[j],expect[j],var_type[i],NCT_UCHAR)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var_schar(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + schar value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_schar(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_schar(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_schar(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_SCHAR); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_SCHAR)) { + + allInIntRange &= (expect[j] >= schar_min && expect[j] <= schar_max); + } else + allInExtRange = 0; + } + err = nc_get_var_schar(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + +#if defined(USE_PNETCDF) && PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR<7 + else if (cdf_format < NC_FORMAT_CDF5) { +#else + else { +#endif + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SCHAR) && (expect[j] >= schar_min && expect[j] <= schar_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_SCHAR)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var_short(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + short value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_short(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_short(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_short(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_SHORT); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_SHORT)) { + + allInIntRange &= (expect[j] >= short_min && expect[j] <= short_max); + } else + allInExtRange = 0; + } + err = nc_get_var_short(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SHORT) && (expect[j] >= short_min && expect[j] <= short_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_SHORT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var_int(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + int value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_int(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_int(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_int(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_INT); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_INT)) { + + allInIntRange &= (expect[j] >= int_min && expect[j] <= int_max); + } else + allInExtRange = 0; + } + err = nc_get_var_int(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_INT) && (expect[j] >= int_min && expect[j] <= int_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_INT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var_long(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + long value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_long(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_long(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_long(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_LONG); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_LONG)) { + + allInIntRange &= (expect[j] >= long_min && expect[j] <= long_max); + } else + allInExtRange = 0; + } + err = nc_get_var_long(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONG) && (expect[j] >= long_min && expect[j] <= long_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_LONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var_float(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + float value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_float(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_float(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_float(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_FLOAT); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_FLOAT)) { + + allInIntRange &= (expect[j] >= float_min && expect[j] <= float_max); + } else + allInExtRange = 0; + } + err = nc_get_var_float(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_FLOAT) && (expect[j] >= float_min && expect[j] <= float_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_FLOAT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var_double(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + double value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_double(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_double(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_double(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_DOUBLE); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_DOUBLE)) { + + allInIntRange &= (expect[j] >= double_min && expect[j] <= double_max); + } else + allInExtRange = 0; + } + err = nc_get_var_double(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_DOUBLE) && (expect[j] >= double_min && expect[j] <= double_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_DOUBLE)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var_ushort(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + ushort value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_ushort(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_ushort(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_ushort(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_USHORT); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_USHORT)) { + + allInIntRange &= (expect[j] >= ushort_min && expect[j] <= ushort_max); + } else + allInExtRange = 0; + } + err = nc_get_var_ushort(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_USHORT) && (expect[j] >= ushort_min && expect[j] <= ushort_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_USHORT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var_uint(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + uint value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_uint(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_uint(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_uint(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_UINT); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_UINT)) { + + allInIntRange &= (expect[j] >= uint_min && expect[j] <= uint_max); + } else + allInExtRange = 0; + } + err = nc_get_var_uint(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UINT) && (expect[j] >= uint_min && expect[j] <= uint_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_UINT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var_longlong(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + longlong value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_longlong(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_longlong(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_longlong(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_LONGLONG); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_LONGLONG)) { + + allInIntRange &= (expect[j] >= longlong_min && expect[j] <= longlong_max); + } else + allInExtRange = 0; + } + err = nc_get_var_longlong(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONGLONG) && (expect[j] >= longlong_min && expect[j] <= longlong_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_LONGLONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_var_ulonglong(void) +{ + int i, err, ncid, cdf_format; + int allInExtRange; /* all values within range of external data type */ + int allInIntRange; /* all values within range of internal data type */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double expect[MAX_NELS]; + ulonglong value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var_ulonglong(BAD_ID, 0, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_get_var_ulonglong(ncid, BAD_VARID, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var_ulonglong(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + allInExtRange = allInIntRange = 1; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_ULONGLONG); + if (inRange3(cdf_format, expect[j],var_type[i], NCT_ULONGLONG)) { + + allInIntRange &= (expect[j] >= ulonglong_min && expect[j] <= ulonglong_max); + } else + allInExtRange = 0; + } + err = nc_get_var_ulonglong(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_nels[i]; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_ULONGLONG) && (expect[j] >= ulonglong_min && expect[j] <= ulonglong_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_ULONGLONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + + + +int +test_nc_get_vara_text(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + text value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_text(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_text(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_text(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) ; + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_text(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_text(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_text(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_text(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_text(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_TEXT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_TEXT) && + 1) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_TEXT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_TEXT)) { + if (var_type[i] != NC_CHAR) + allInIntRange &= 1; + } else + allInExtRange = 0; + } + err = nc_get_vara_text(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (1) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_TEXT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vara_uchar(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + uchar value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_uchar(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_uchar(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_uchar(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_uchar(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_uchar(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_uchar(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_uchar(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_uchar(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_UCHAR); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_UCHAR) && + (expect[0] >= uchar_min && expect[0] <= uchar_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); +#endif + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_UCHAR); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UCHAR)) { + + allInIntRange &= (expect[j] >= uchar_min && expect[j] <= uchar_max); + } else + allInExtRange = 0; + } + err = nc_get_vara_uchar(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=8) + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } +#endif + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UCHAR) && (expect[j] >= uchar_min && expect[j] <= uchar_max)) { + + /* in put_vars(), API _put_vara_double() is used to + * write the NC_BYTE variables to files. In this + * case, NC_BYTE variables are treated as signed + * for CDF-1 and 2 formats. Thus, we must skip the + * equal test below for uchar. + */ + if (cdf_format < NC_FORMAT_CDF5 && var_type[i] == NC_BYTE && expect[j] > schar_max) continue; + IF (!equal((double)value[j],expect[j],var_type[i],NCT_UCHAR)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vara_schar(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + schar value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_schar(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_schar(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_schar(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_schar(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_schar(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_schar(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_schar(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_schar(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_SCHAR); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_SCHAR) && + (expect[0] >= schar_min && expect[0] <= schar_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_SCHAR); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SCHAR)) { + + allInIntRange &= (expect[j] >= schar_min && expect[j] <= schar_max); + } else + allInExtRange = 0; + } + err = nc_get_vara_schar(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + +#if defined(USE_PNETCDF) && PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR<7 + else if (cdf_format < NC_FORMAT_CDF5) { +#else + else { +#endif + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SCHAR) && (expect[j] >= schar_min && expect[j] <= schar_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_SCHAR)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vara_short(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + short value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_short(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_short(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_short(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_short(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_short(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_short(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_short(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_short(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_SHORT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_SHORT) && + (expect[0] >= short_min && expect[0] <= short_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_SHORT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SHORT)) { + + allInIntRange &= (expect[j] >= short_min && expect[j] <= short_max); + } else + allInExtRange = 0; + } + err = nc_get_vara_short(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SHORT) && (expect[j] >= short_min && expect[j] <= short_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_SHORT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vara_int(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + int value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_int(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_int(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_int(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_int(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_int(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_int(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_int(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_int(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_INT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_INT) && + (expect[0] >= int_min && expect[0] <= int_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_INT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_INT)) { + + allInIntRange &= (expect[j] >= int_min && expect[j] <= int_max); + } else + allInExtRange = 0; + } + err = nc_get_vara_int(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_INT) && (expect[j] >= int_min && expect[j] <= int_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_INT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vara_long(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + long value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_long(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_long(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_long(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_long(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_long(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_long(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_long(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_long(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_LONG); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_LONG) && + (expect[0] >= long_min && expect[0] <= long_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_LONG); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONG)) { + + allInIntRange &= (expect[j] >= long_min && expect[j] <= long_max); + } else + allInExtRange = 0; + } + err = nc_get_vara_long(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONG) && (expect[j] >= long_min && expect[j] <= long_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_LONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vara_float(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + float value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_float(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_float(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_float(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_float(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_float(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_float(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_float(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_float(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_FLOAT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_FLOAT) && + (expect[0] >= float_min && expect[0] <= float_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_FLOAT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_FLOAT)) { + + allInIntRange &= (expect[j] >= float_min && expect[j] <= float_max); + } else + allInExtRange = 0; + } + err = nc_get_vara_float(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_FLOAT) && (expect[j] >= float_min && expect[j] <= float_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_FLOAT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vara_double(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + double value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_double(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_double(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_double(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_double(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_double(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_double(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_double(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_double(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_DOUBLE); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_DOUBLE) && + (expect[0] >= double_min && expect[0] <= double_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_DOUBLE); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_DOUBLE)) { + + allInIntRange &= (expect[j] >= double_min && expect[j] <= double_max); + } else + allInExtRange = 0; + } + err = nc_get_vara_double(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_DOUBLE) && (expect[j] >= double_min && expect[j] <= double_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_DOUBLE)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vara_ushort(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + ushort value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_ushort(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_ushort(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_ushort(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_ushort(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_ushort(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_ushort(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_ushort(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_ushort(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_USHORT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_USHORT) && + (expect[0] >= ushort_min && expect[0] <= ushort_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_USHORT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_USHORT)) { + + allInIntRange &= (expect[j] >= ushort_min && expect[j] <= ushort_max); + } else + allInExtRange = 0; + } + err = nc_get_vara_ushort(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_USHORT) && (expect[j] >= ushort_min && expect[j] <= ushort_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_USHORT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vara_uint(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + uint value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_uint(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_uint(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_uint(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_uint(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_uint(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_uint(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_uint(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_uint(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_UINT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_UINT) && + (expect[0] >= uint_min && expect[0] <= uint_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_UINT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UINT)) { + + allInIntRange &= (expect[j] >= uint_min && expect[j] <= uint_max); + } else + allInExtRange = 0; + } + err = nc_get_vara_uint(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UINT) && (expect[j] >= uint_min && expect[j] <= uint_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_UINT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vara_longlong(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + longlong value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_longlong(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_longlong(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_longlong(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_longlong(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_longlong(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_longlong(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_longlong(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_longlong(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_LONGLONG); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_LONGLONG) && + (expect[0] >= longlong_min && expect[0] <= longlong_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_LONGLONG); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONGLONG)) { + + allInIntRange &= (expect[j] >= longlong_min && expect[j] <= longlong_max); + } else + allInExtRange = 0; + } + err = nc_get_vara_longlong(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONGLONG) && (expect[j] >= longlong_min && expect[j] <= longlong_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_LONGLONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vara_ulonglong(void) +{ + int i, k, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK], mid[MAX_RANK]; + double expect[MAX_NELS]; + ulonglong value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vara_ulonglong(BAD_ID, 0, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vara_ulonglong(ncid, BAD_VARID, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara_ulonglong(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; /* causes NC_EINVALCOORDS */ + err = nc_get_vara_ulonglong(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* causes NC_EEDGE */ + err = nc_get_vara_ulonglong(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[*]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_rank[i] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara_ulonglong(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vara_ulonglong(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + } + + err = nc_get_vara_ulonglong(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_ULONGLONG); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_ULONGLONG) && + (expect[0] >= ulonglong_min && expect[0] <= ulonglong_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + size_t nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + int d; + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_ULONGLONG); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_ULONGLONG)) { + + allInIntRange &= (expect[j] >= ulonglong_min && expect[j] <= ulonglong_max); + } else + allInExtRange = 0; + } + err = nc_get_vara_ulonglong(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_ULONGLONG) && (expect[j] >= ulonglong_min && expect[j] <= ulonglong_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i],NCT_ULONGLONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + + + +int +test_nc_get_vars_text(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + text value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_text(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_text(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_text(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) ; + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_text(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_text(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_text(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_text(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_text(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_text(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_text(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_TEXT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_TEXT) && + 1) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_TEXT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_TEXT)) { + if (var_type[i] != NC_CHAR) + allInIntRange &= 1; + } else + allInExtRange = 0; + } + err = nc_get_vars_text(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (1) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_TEXT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vars_uchar(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + uchar value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_uchar(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_uchar(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_uchar(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_uchar(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_uchar(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_uchar(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_uchar(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_uchar(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_uchar(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_uchar(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_UCHAR); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_UCHAR) && + (expect[0] >= uchar_min && expect[0] <= uchar_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); +#endif + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_UCHAR); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UCHAR)) { + + allInIntRange &= (expect[j] >= uchar_min && expect[j] <= uchar_max); + } else + allInExtRange = 0; + } + err = nc_get_vars_uchar(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=8) + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } +#endif + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UCHAR) && (expect[j] >= uchar_min && expect[j] <= uchar_max)) { + + /* in put_vars(), API _put_vara_double() is used to + * write the NC_BYTE variables to files. In this + * case, NC_BYTE variables are treated as signed + * for CDF-1 and 2 formats. Thus, we must skip the + * equal test below for uchar. + */ + if (cdf_format < NC_FORMAT_CDF5 && var_type[i] == NC_BYTE && expect[j] > schar_max) continue; + IF (!equal((double)value[j],expect[j],var_type[i], NCT_UCHAR)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vars_schar(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + schar value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_schar(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_schar(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_schar(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_schar(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_schar(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_schar(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_schar(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_schar(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_schar(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_schar(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_SCHAR); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_SCHAR) && + (expect[0] >= schar_min && expect[0] <= schar_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_SCHAR); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SCHAR)) { + + allInIntRange &= (expect[j] >= schar_min && expect[j] <= schar_max); + } else + allInExtRange = 0; + } + err = nc_get_vars_schar(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + +#if defined(USE_PNETCDF) && PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR<7 + else if (cdf_format < NC_FORMAT_CDF5) { +#else + else { +#endif + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SCHAR) && (expect[j] >= schar_min && expect[j] <= schar_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_SCHAR)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vars_short(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + short value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_short(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_short(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_short(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_short(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_short(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_short(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_short(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_short(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_short(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_short(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_SHORT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_SHORT) && + (expect[0] >= short_min && expect[0] <= short_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_SHORT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SHORT)) { + + allInIntRange &= (expect[j] >= short_min && expect[j] <= short_max); + } else + allInExtRange = 0; + } + err = nc_get_vars_short(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SHORT) && (expect[j] >= short_min && expect[j] <= short_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_SHORT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vars_int(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + int value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_int(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_int(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_int(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_int(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_int(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_int(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_int(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_int(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_int(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_int(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_INT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_INT) && + (expect[0] >= int_min && expect[0] <= int_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_INT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_INT)) { + + allInIntRange &= (expect[j] >= int_min && expect[j] <= int_max); + } else + allInExtRange = 0; + } + err = nc_get_vars_int(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_INT) && (expect[j] >= int_min && expect[j] <= int_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_INT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vars_long(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + long value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_long(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_long(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_long(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_long(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_long(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_long(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_long(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_long(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_long(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_long(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_LONG); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_LONG) && + (expect[0] >= long_min && expect[0] <= long_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_LONG); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONG)) { + + allInIntRange &= (expect[j] >= long_min && expect[j] <= long_max); + } else + allInExtRange = 0; + } + err = nc_get_vars_long(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONG) && (expect[j] >= long_min && expect[j] <= long_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_LONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vars_float(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + float value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_float(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_float(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_float(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_float(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_float(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_float(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_float(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_float(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_float(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_float(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_FLOAT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_FLOAT) && + (expect[0] >= float_min && expect[0] <= float_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_FLOAT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_FLOAT)) { + + allInIntRange &= (expect[j] >= float_min && expect[j] <= float_max); + } else + allInExtRange = 0; + } + err = nc_get_vars_float(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_FLOAT) && (expect[j] >= float_min && expect[j] <= float_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_FLOAT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vars_double(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + double value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_double(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_double(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_double(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_double(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_double(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_double(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_double(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_double(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_double(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_double(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_DOUBLE); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_DOUBLE) && + (expect[0] >= double_min && expect[0] <= double_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_DOUBLE); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_DOUBLE)) { + + allInIntRange &= (expect[j] >= double_min && expect[j] <= double_max); + } else + allInExtRange = 0; + } + err = nc_get_vars_double(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_DOUBLE) && (expect[j] >= double_min && expect[j] <= double_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_DOUBLE)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vars_ushort(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + ushort value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_ushort(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_ushort(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_ushort(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_ushort(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_ushort(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_ushort(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_ushort(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_ushort(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_ushort(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_ushort(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_USHORT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_USHORT) && + (expect[0] >= ushort_min && expect[0] <= ushort_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_USHORT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_USHORT)) { + + allInIntRange &= (expect[j] >= ushort_min && expect[j] <= ushort_max); + } else + allInExtRange = 0; + } + err = nc_get_vars_ushort(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_USHORT) && (expect[j] >= ushort_min && expect[j] <= ushort_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_USHORT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vars_uint(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + uint value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_uint(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_uint(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_uint(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_uint(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_uint(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_uint(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_uint(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_uint(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_uint(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_uint(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_UINT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_UINT) && + (expect[0] >= uint_min && expect[0] <= uint_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_UINT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UINT)) { + + allInIntRange &= (expect[j] >= uint_min && expect[j] <= uint_max); + } else + allInExtRange = 0; + } + err = nc_get_vars_uint(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UINT) && (expect[j] >= uint_min && expect[j] <= uint_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_UINT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vars_longlong(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + longlong value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_longlong(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_longlong(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_longlong(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_longlong(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_longlong(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_longlong(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_longlong(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_longlong(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_longlong(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_longlong(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_LONGLONG); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_LONGLONG) && + (expect[0] >= longlong_min && expect[0] <= longlong_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_LONGLONG); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONGLONG)) { + + allInIntRange &= (expect[j] >= longlong_min && expect[j] <= longlong_max); + } else + allInExtRange = 0; + } + err = nc_get_vars_longlong(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONGLONG) && (expect[j] >= longlong_min && expect[j] <= longlong_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_LONGLONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_vars_ulonglong(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double expect[MAX_NELS]; + ulonglong value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_vars_ulonglong(BAD_ID, 0, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_vars_ulonglong(ncid, BAD_VARID, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_ulonglong(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars_ulonglong(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars_ulonglong(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars_ulonglong(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars_ulonglong(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_vars_ulonglong(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_vars_ulonglong(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_vars_ulonglong(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_ULONGLONG); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_ULONGLONG) && + (expect[0] >= ulonglong_min && expect[0] <= ulonglong_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_ULONGLONG); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_ULONGLONG)) { + + allInIntRange &= (expect[j] >= ulonglong_min && expect[j] <= ulonglong_max); + } else + allInExtRange = 0; + } + err = nc_get_vars_ulonglong(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_ULONGLONG) && (expect[j] >= ulonglong_min && expect[j] <= ulonglong_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_ULONGLONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + + + +int +test_nc_get_varm_text(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + text value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_text(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_text(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_text(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) ; + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_text(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_text(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_text(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_text(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_text(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_text(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_text(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_TEXT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_TEXT) && + 1) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_TEXT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_TEXT)) { + if (var_type[i] != NC_CHAR) + allInIntRange &= 1; + } else + allInExtRange = 0; + } + err = nc_get_varm_text(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (1) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_TEXT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_varm_uchar(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + uchar value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_uchar(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_uchar(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_uchar(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_uchar(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_uchar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_uchar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_uchar(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_uchar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_uchar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_uchar(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_UCHAR); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_UCHAR) && + (expect[0] >= uchar_min && expect[0] <= uchar_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); +#endif + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_UCHAR); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UCHAR)) { + + allInIntRange &= (expect[j] >= uchar_min && expect[j] <= uchar_max); + } else + allInExtRange = 0; + } + err = nc_get_varm_uchar(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=8) + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } +#endif + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UCHAR) && (expect[j] >= uchar_min && expect[j] <= uchar_max)) { + + /* in put_vars(), API _put_vara_double() is used to + * write the NC_BYTE variables to files. In this + * case, NC_BYTE variables are treated as signed + * for CDF-1 and 2 formats. Thus, we must skip the + * equal test below for uchar. + */ + if (cdf_format < NC_FORMAT_CDF5 && var_type[i] == NC_BYTE && expect[j] > schar_max) continue; + IF (!equal((double)value[j],expect[j],var_type[i], NCT_UCHAR)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_varm_schar(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + schar value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_schar(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_schar(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_schar(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_schar(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_schar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_schar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_schar(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_schar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_schar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_schar(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_SCHAR); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_SCHAR) && + (expect[0] >= schar_min && expect[0] <= schar_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_SCHAR); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SCHAR)) { + + allInIntRange &= (expect[j] >= schar_min && expect[j] <= schar_max); + } else + allInExtRange = 0; + } + err = nc_get_varm_schar(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + +#if defined(USE_PNETCDF) && PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR<7 + else if (cdf_format < NC_FORMAT_CDF5) { +#else + else { +#endif + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SCHAR) && (expect[j] >= schar_min && expect[j] <= schar_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_SCHAR)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_varm_short(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + short value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_short(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_short(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_short(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_short(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_short(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_short(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_short(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_short(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_short(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_short(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_SHORT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_SHORT) && + (expect[0] >= short_min && expect[0] <= short_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_SHORT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SHORT)) { + + allInIntRange &= (expect[j] >= short_min && expect[j] <= short_max); + } else + allInExtRange = 0; + } + err = nc_get_varm_short(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_SHORT) && (expect[j] >= short_min && expect[j] <= short_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_SHORT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_varm_int(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + int value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_int(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_int(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_int(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_int(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_int(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_int(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_int(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_int(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_int(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_int(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_INT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_INT) && + (expect[0] >= int_min && expect[0] <= int_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_INT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_INT)) { + + allInIntRange &= (expect[j] >= int_min && expect[j] <= int_max); + } else + allInExtRange = 0; + } + err = nc_get_varm_int(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_INT) && (expect[j] >= int_min && expect[j] <= int_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_INT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_varm_long(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + long value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_long(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_long(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_long(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_long(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_long(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_long(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_long(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_long(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_long(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_long(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_LONG); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_LONG) && + (expect[0] >= long_min && expect[0] <= long_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_LONG); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONG)) { + + allInIntRange &= (expect[j] >= long_min && expect[j] <= long_max); + } else + allInExtRange = 0; + } + err = nc_get_varm_long(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONG) && (expect[j] >= long_min && expect[j] <= long_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_LONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_varm_float(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + float value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_float(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_float(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_float(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_float(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_float(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_float(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_float(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_float(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_float(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_float(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_FLOAT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_FLOAT) && + (expect[0] >= float_min && expect[0] <= float_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_FLOAT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_FLOAT)) { + + allInIntRange &= (expect[j] >= float_min && expect[j] <= float_max); + } else + allInExtRange = 0; + } + err = nc_get_varm_float(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_FLOAT) && (expect[j] >= float_min && expect[j] <= float_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_FLOAT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_varm_double(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + double value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_double(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_double(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_double(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_double(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_double(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_double(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_double(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_double(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_double(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_double(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_DOUBLE); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_DOUBLE) && + (expect[0] >= double_min && expect[0] <= double_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_DOUBLE); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_DOUBLE)) { + + allInIntRange &= (expect[j] >= double_min && expect[j] <= double_max); + } else + allInExtRange = 0; + } + err = nc_get_varm_double(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_DOUBLE) && (expect[j] >= double_min && expect[j] <= double_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_DOUBLE)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_varm_ushort(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + ushort value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_ushort(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_ushort(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_ushort(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_ushort(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_ushort(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_ushort(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_ushort(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_ushort(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_ushort(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_ushort(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_USHORT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_USHORT) && + (expect[0] >= ushort_min && expect[0] <= ushort_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_USHORT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_USHORT)) { + + allInIntRange &= (expect[j] >= ushort_min && expect[j] <= ushort_max); + } else + allInExtRange = 0; + } + err = nc_get_varm_ushort(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_USHORT) && (expect[j] >= ushort_min && expect[j] <= ushort_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_USHORT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_varm_uint(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + uint value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_uint(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_uint(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_uint(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_uint(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_uint(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_uint(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_uint(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_uint(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_uint(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_uint(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_UINT); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_UINT) && + (expect[0] >= uint_min && expect[0] <= uint_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_UINT); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UINT)) { + + allInIntRange &= (expect[j] >= uint_min && expect[j] <= uint_max); + } else + allInExtRange = 0; + } + err = nc_get_varm_uint(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_UINT) && (expect[j] >= uint_min && expect[j] <= uint_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_UINT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_varm_longlong(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + longlong value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_longlong(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_longlong(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_longlong(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_longlong(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_longlong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_longlong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_longlong(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_longlong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_longlong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_longlong(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_LONGLONG); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_LONGLONG) && + (expect[0] >= longlong_min && expect[0] <= longlong_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_LONGLONG); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONGLONG)) { + + allInIntRange &= (expect[j] >= longlong_min && expect[j] <= longlong_max); + } else + allInExtRange = 0; + } + err = nc_get_varm_longlong(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_LONGLONG) && (expect[j] >= longlong_min && expect[j] <= longlong_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_LONGLONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_varm_ulonglong(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format; + int allInExtRange; /* all values within external range? */ + int allInIntRange; /* all values within internal range? */ + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* count of valid comparisons */ + int canConvert; /* Both text or both numeric */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double expect[MAX_NELS]; + ulonglong value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_varm_ulonglong(BAD_ID, 0, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_varm_ulonglong(ncid, BAD_VARID, NULL, NULL, NULL, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars_ulonglong(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + start[j] = var_shape[i][j]+1; /* should cause NC_EINVALCOORDS */ + err = nc_get_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + start[j] = 0; +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=7) + stride[j] = 0; + err = nc_get_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + stride[j] = 1; +#endif + } + + err = nc_get_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } else if (var_rank[i] == 0) { + expect[0] = hash4(cdf_format, var_type[i], 0, index, NCT_ULONGLONG); + if (inRange3(cdf_format, expect[0], var_type[i], NCT_ULONGLONG) && + (expect[0] >= ulonglong_min && expect[0] <= ulonglong_max)) { + IF (err != NC_NOERR) error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else IF (err != NC_ERANGE) error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j]-index[j]-1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + allInExtRange = allInIntRange = 1; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect[j] = hash4(cdf_format, var_type[i], var_rank[i], + index2, NCT_ULONGLONG); + if (inRange3(cdf_format, expect[j],var_type[i],NCT_ULONGLONG)) { + + allInIntRange &= (expect[j] >= ulonglong_min && expect[j] <= ulonglong_max); + } else + allInExtRange = 0; + } + err = nc_get_varm_ulonglong(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (j = 0; j < nels; j++) { + if (inRange3(cdf_format, expect[j],var_type[i],NCT_ULONGLONG) && (expect[j] >= ulonglong_min && expect[j] <= ulonglong_max)) { + + IF (!equal((double)value[j],expect[j],var_type[i], NCT_ULONGLONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("element number: %d, ", j); + error("expect: %g, ", expect[j]); + error("got: %g", (double) value[j]); + } + } + ELSE_NOK + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + + + +int +test_nc_get_att_text(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + text value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_text(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_text(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) ; + + err = nc_get_att_text(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_text(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_text(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_TEXT); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_TEXT)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + if (ATT_TYPE(i,j) != NC_CHAR) + + allInIntRange &= 1; + } else { + allInExtRange = 0; + } + } + err = nc_get_att_text(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (1) { + + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_TEXT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_att_uchar(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + uchar value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_uchar(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_uchar(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + err = nc_get_att_uchar(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_uchar(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_uchar(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_UCHAR); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_UCHAR)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + + if (cdf_format > NC_FORMAT_64BIT_OFFSET || (cdf_format < NC_FORMAT_CDF5 && ATT_TYPE(i,j) != NC_BYTE)) + allInIntRange &= (expect[k] >= uchar_min && expect[k] <= uchar_max); + } else { + allInExtRange = 0; + } + } + err = nc_get_att_uchar(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); +#endif + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_UCHAR) && (expect[k] >= uchar_min && expect[k] <= uchar_max)) { + + /* in put_vars(), API _put_vara_double() is used to + * write the NC_BYTE variables to files. In this + * case, NC_BYTE variables are treated as signed + * for CDF-1 and 2 formats. Thus, we must skip the + * equal test below for uchar. + */ + if (cdf_format < NC_FORMAT_CDF5 && ATT_TYPE(i,j) == NC_BYTE && expect[k] > schar_max) continue; + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_UCHAR)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_att_schar(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + schar value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_schar(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_schar(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + err = nc_get_att_schar(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_schar(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_schar(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_SCHAR); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_SCHAR)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + + + allInIntRange &= (expect[k] >= schar_min && expect[k] <= schar_max); + } else { + allInExtRange = 0; + } + } + err = nc_get_att_schar(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_SCHAR) && (expect[k] >= schar_min && expect[k] <= schar_max)) { + + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_SCHAR)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_att_short(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + short value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_short(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_short(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + err = nc_get_att_short(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_short(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_short(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_SHORT); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_SHORT)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + + + allInIntRange &= (expect[k] >= short_min && expect[k] <= short_max); + } else { + allInExtRange = 0; + } + } + err = nc_get_att_short(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_SHORT) && (expect[k] >= short_min && expect[k] <= short_max)) { + + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_SHORT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_att_int(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + int value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_int(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_int(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_INT == NCT_TEXT); + + err = nc_get_att_int(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_int(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_int(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_INT); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_INT)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + + + allInIntRange &= (expect[k] >= int_min && expect[k] <= int_max); + } else { + allInExtRange = 0; + } + } + err = nc_get_att_int(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_INT) && (expect[k] >= int_min && expect[k] <= int_max)) { + + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_INT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_att_long(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + long value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_long(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_long(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + err = nc_get_att_long(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_long(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_long(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_LONG); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_LONG)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + + + allInIntRange &= (expect[k] >= long_min && expect[k] <= long_max); + } else { + allInExtRange = 0; + } + } + err = nc_get_att_long(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_LONG) && (expect[k] >= long_min && expect[k] <= long_max)) { + + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_LONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_att_float(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + float value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_float(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_float(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + err = nc_get_att_float(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_float(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_float(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_FLOAT); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_FLOAT)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + + + allInIntRange &= (expect[k] >= float_min && expect[k] <= float_max); + } else { + allInExtRange = 0; + } + } + err = nc_get_att_float(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_FLOAT) && (expect[k] >= float_min && expect[k] <= float_max)) { + + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_FLOAT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_att_double(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + double value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_double(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_double(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + err = nc_get_att_double(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_double(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_double(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_DOUBLE); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_DOUBLE)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + + + allInIntRange &= (expect[k] >= double_min && expect[k] <= double_max); + } else { + allInExtRange = 0; + } + } + err = nc_get_att_double(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_DOUBLE) && (expect[k] >= double_min && expect[k] <= double_max)) { + + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_DOUBLE)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_att_ushort(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + ushort value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_ushort(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_ushort(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + err = nc_get_att_ushort(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_ushort(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_ushort(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_USHORT); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_USHORT)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + + + allInIntRange &= (expect[k] >= ushort_min && expect[k] <= ushort_max); + } else { + allInExtRange = 0; + } + } + err = nc_get_att_ushort(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_USHORT) && (expect[k] >= ushort_min && expect[k] <= ushort_max)) { + + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_USHORT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_att_uint(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + uint value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_uint(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_uint(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + err = nc_get_att_uint(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_uint(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_uint(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_UINT); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_UINT)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + + + allInIntRange &= (expect[k] >= uint_min && expect[k] <= uint_max); + } else { + allInExtRange = 0; + } + } + err = nc_get_att_uint(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_UINT) && (expect[k] >= uint_min && expect[k] <= uint_max)) { + + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_UINT)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_att_longlong(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + longlong value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_longlong(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_longlong(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + err = nc_get_att_longlong(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_longlong(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_longlong(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_LONGLONG); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_LONGLONG)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + + + allInIntRange &= (expect[k] >= longlong_min && expect[k] <= longlong_max); + } else { + allInExtRange = 0; + } + } + err = nc_get_att_longlong(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_LONGLONG) && (expect[k] >= longlong_min && expect[k] <= longlong_max)) { + + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_LONGLONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +int +test_nc_get_att_ulonglong(void) +{ + int i, j, err, ncid, cdf_format; + size_t k, ndx[1]; + int allInExtRange; + int allInIntRange; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + double expect[MAX_NELS]; + ulonglong value[MAX_NELS]; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + err = nc_get_att_ulonglong(BAD_ID, 0, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_get_att_ulonglong(ncid, BAD_VARID, NULL, value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + err = nc_get_att_ulonglong(ncid, BAD_VARID, ATT_NAME(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>7) + /* check if can detect a bad name */ + err = nc_get_att_ulonglong(ncid, i, NULL, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK +#endif + + err = nc_get_att_ulonglong(ncid, i, "noSuch", value); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s",nc_err_code_name(err)); + ELSE_NOK + + allInExtRange = allInIntRange = 1; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, ATT_TYPE(i,j), -1, ndx, NCT_ULONGLONG); + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_ULONGLONG)) { + /* netCDF specification make a special case for type + * conversion between uchar and scahr: do not check for + * range error. See + * http://www.unidata.ucar.edu/software/netcdf/docs/data_type.html#type_conversion + */ + + + allInIntRange &= (expect[k] >= ulonglong_min && expect[k] <= ulonglong_max); + } else { + allInExtRange = 0; + } + } + err = nc_get_att_ulonglong(ncid, i, ATT_NAME(i,j), value); + if (canConvert || ATT_LEN(i,j) == 0) { + if (allInExtRange) { + if (allInIntRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + + } + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < ATT_LEN(i,j); k++) { + if (inRange3(cdf_format, expect[k],ATT_TYPE(i,j),NCT_ULONGLONG) && (expect[k] >= ulonglong_min && expect[k] <= ulonglong_max)) { + + IF (!equal((double)value[k],expect[k],ATT_TYPE(i,j), NCT_ULONGLONG)){ + error("value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + if (i == -1) + error("var_type: GLOBAL, "); + else + error("var_name: %s var_type: %s, ", var_name[i],s_nc_type(var_type[i])); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d, ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + diff --git a/nc_test/test_put.c b/nc_test/test_put.c new file mode 100644 index 0000000000..703feeda44 --- /dev/null +++ b/nc_test/test_put.c @@ -0,0 +1,13743 @@ +/* Do not edit this file. It is produced from the corresponding .m4 source */ +/* + * Copyright (C) 2003, Northwestern University and Argonne National Laboratory + * See COPYRIGHT notice in top-level directory. + */ +/* $Id: test_put.m4 2672 2016-12-03 19:23:53Z wkliao $ */ + + +#include "tests.h" + +#ifdef USE_PNETCDF +#include +#ifndef PNETCDF_VERSION_MAJOR +#error("PNETCDF_VERSION_MAJOR is not defined in pnetcdf.h") +#endif +#ifndef PNETCDF_VERSION_MINOR +#error("PNETCDF_VERSION_MAJOR is not defined in pnetcdf.h") +#endif +#endif + + + + + + + + + + +/* + * ensure hash value within range for internal TYPE + */ +text +hash_text(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + return (text)value; +} + +/* + * ensure hash value within range for internal TYPE + */ +uchar +hash_uchar(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + + if (value > uchar_max) return uchar_max; + else if (value < uchar_min) return uchar_min; + else return (uchar)value; +} + +/* + * ensure hash value within range for internal TYPE + */ +schar +hash_schar(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + + if (value > schar_max) return schar_max; + else if (value < schar_min) return schar_min; + else return (schar)value; +} + +/* + * ensure hash value within range for internal TYPE + */ +short +hash_short(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + + if (value > short_max) return short_max; + else if (value < short_min) return short_min; + else return (short)value; +} + +/* + * ensure hash value within range for internal TYPE + */ +int +hash_int(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + + if (value > int_max) return int_max; + else if (value < int_min) return int_min; + else return (int)value; +} + +/* + * ensure hash value within range for internal TYPE + */ +long +hash_long(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + + if (value > long_max) return long_max; + else if (value < long_min) return long_min; + else return (long)value; +} + +/* + * ensure hash value within range for internal TYPE + */ +float +hash_float(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + + if (value > float_max) return float_max; + else if (value < float_min) return float_min; + else return (float)value; +} + +/* + * ensure hash value within range for internal TYPE + */ +double +hash_double(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + + if (value > double_max) return double_max; + else if (value < double_min) return double_min; + else return (double)value; +} + +/* + * ensure hash value within range for internal TYPE + */ +ushort +hash_ushort(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + + if (value > ushort_max) return ushort_max; + else if (value < ushort_min) return ushort_min; + else return (ushort)value; +} + +/* + * ensure hash value within range for internal TYPE + */ +uint +hash_uint(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + + if (value > uint_max) return uint_max; + else if (value < uint_min) return uint_min; + else return (uint)value; +} + +/* + * ensure hash value within range for internal TYPE + */ +longlong +hash_longlong(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + + if (value > longlong_max) return longlong_max; + else if (value < longlong_min) return longlong_min; + else return (longlong)value; +} + +/* + * ensure hash value within range for internal TYPE + */ +ulonglong +hash_ulonglong(const int cdf_format, + const nc_type type, + const int rank, + const size_t *index, + const nct_itype itype) +{ + double value; + + value = hash4(cdf_format, type, rank, index, itype); + + if (value > ulonglong_max) return ulonglong_max; + else if (value < ulonglong_min) return ulonglong_min; + else return (ulonglong)value; +} + + + + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_text(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + text value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) ; + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_TEXT); + err = nc_get_var1_text(ncid, i, index, &value); + if (1) { + IF (err != NC_NOERR) { + error("nc_get_var1_text: %s", nc_strerror(err)); + } else { + + IF (!equal((double)value,expect,var_type[i],NCT_TEXT)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_uchar(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + uchar value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_UCHAR); + err = nc_get_var1_uchar(ncid, i, index, &value); + if (inRange3(cdf_format, (double)expect,datatype,NCT_UCHAR) && (expect >= uchar_min && expect <= uchar_max)) { + IF (err != NC_NOERR) { + error("nc_get_var1_uchar: %s", nc_strerror(err)); + } else { + + /* In put_vars(), nc_put_vara_double() is used to write + * variables of type NC_BYTE to files. For uchar APIs, + * NC_BYTE variables are treated as unsigned for CDF-1 and 2 + * formats. Thus, we skip the equal test for out-of-bound + * values below for uchar APIs. + */ + if (cdf_format < NC_FORMAT_CDF5 && + var_type[i] == NC_BYTE && expect > schar_max) + continue; + IF (!equal((double)value,expect,var_type[i],NCT_UCHAR)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_schar(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + schar value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_SCHAR); + err = nc_get_var1_schar(ncid, i, index, &value); + if (inRange3(cdf_format, (double)expect,datatype,NCT_SCHAR) && (expect >= schar_min && expect <= schar_max)) { + IF (err != NC_NOERR) { + error("nc_get_var1_schar: %s", nc_strerror(err)); + } else { + + IF (!equal((double)value,expect,var_type[i],NCT_SCHAR)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_short(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + short value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_SHORT); + err = nc_get_var1_short(ncid, i, index, &value); + if (inRange3(cdf_format, (double)expect,datatype,NCT_SHORT) && (expect >= short_min && expect <= short_max)) { + IF (err != NC_NOERR) { + error("nc_get_var1_short: %s", nc_strerror(err)); + } else { + + IF (!equal((double)value,expect,var_type[i],NCT_SHORT)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_int(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + int value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_INT); + err = nc_get_var1_int(ncid, i, index, &value); + if (inRange3(cdf_format, (double)expect,datatype,NCT_INT) && (expect >= int_min && expect <= int_max)) { + IF (err != NC_NOERR) { + error("nc_get_var1_int: %s", nc_strerror(err)); + } else { + + IF (!equal((double)value,expect,var_type[i],NCT_INT)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_long(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + long value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_LONG); + err = nc_get_var1_long(ncid, i, index, &value); + if (inRange3(cdf_format, (double)expect,datatype,NCT_LONG) && (expect >= long_min && expect <= long_max)) { + IF (err != NC_NOERR) { + error("nc_get_var1_long: %s", nc_strerror(err)); + } else { + + IF (!equal((double)value,expect,var_type[i],NCT_LONG)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_float(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + float value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_FLOAT); + err = nc_get_var1_float(ncid, i, index, &value); + if (inRange3(cdf_format, (double)expect,datatype,NCT_FLOAT) && (expect >= float_min && expect <= float_max)) { + IF (err != NC_NOERR) { + error("nc_get_var1_float: %s", nc_strerror(err)); + } else { + + IF (!equal((double)value,expect,var_type[i],NCT_FLOAT)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_double(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + double value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_DOUBLE); + err = nc_get_var1_double(ncid, i, index, &value); + if (inRange3(cdf_format, (double)expect,datatype,NCT_DOUBLE) && (expect >= double_min && expect <= double_max)) { + IF (err != NC_NOERR) { + error("nc_get_var1_double: %s", nc_strerror(err)); + } else { + + IF (!equal((double)value,expect,var_type[i],NCT_DOUBLE)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_ushort(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + ushort value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_USHORT); + err = nc_get_var1_ushort(ncid, i, index, &value); + if (inRange3(cdf_format, (double)expect,datatype,NCT_USHORT) && (expect >= ushort_min && expect <= ushort_max)) { + IF (err != NC_NOERR) { + error("nc_get_var1_ushort: %s", nc_strerror(err)); + } else { + + IF (!equal((double)value,expect,var_type[i],NCT_USHORT)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_uint(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + uint value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_UINT); + err = nc_get_var1_uint(ncid, i, index, &value); + if (inRange3(cdf_format, (double)expect,datatype,NCT_UINT) && (expect >= uint_min && expect <= uint_max)) { + IF (err != NC_NOERR) { + error("nc_get_var1_uint: %s", nc_strerror(err)); + } else { + + IF (!equal((double)value,expect,var_type[i],NCT_UINT)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_longlong(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + longlong value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_LONGLONG); + err = nc_get_var1_longlong(ncid, i, index, &value); + if (inRange3(cdf_format, (double)expect,datatype,NCT_LONGLONG) && (expect >= longlong_min && expect <= longlong_max)) { + IF (err != NC_NOERR) { + error("nc_get_var1_longlong: %s", nc_strerror(err)); + } else { + + IF (!equal((double)value,expect,var_type[i],NCT_LONGLONG)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + +/* + * check all vars in file which are (text/numeric) compatible with TYPE + */ +int +check_vars_ulonglong(const char *filename, int numVars) +{ + int i, d, err, ncid, cdf_format, ndims; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + int dimids[MAX_RANK]; + nc_type datatype; + char name[NC_MAX_NAME]; + size_t j, length, index[MAX_RANK]; + double expect; + ulonglong value; + + err = file_open(filename, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) error("inq_format: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, NULL); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, var_name[i]) != 0) + error("Unexpected var_name"); + IF (datatype != var_type[i]) + error("Unexpected type"); + IF (ndims != var_rank[i]) + error("Unexpected rank"); + for (j = 0; j < ndims; j++) { + err = nc_inq_dim(ncid, dimids[j], 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + IF (length != var_shape[i][j]) + error("Unexpected shape"); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash4(cdf_format, var_type[i], var_rank[i], index, + NCT_ULONGLONG); + err = nc_get_var1_ulonglong(ncid, i, index, &value); + if (inRange3(cdf_format, (double)expect,datatype,NCT_ULONGLONG) && (expect >= ulonglong_min && expect <= ulonglong_max)) { + IF (err != NC_NOERR) { + error("nc_get_var1_ulonglong: %s", nc_strerror(err)); + } else { + + IF (!equal((double)value,expect,var_type[i],NCT_ULONGLONG)){ + error("Var value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("var_type: %s, ", s_nc_type(var_type[i])); + error("index:"); + for (d = 0; d < var_rank[i]; d++) + error(" %d", index[d]); + error(", expect: %g, ", expect); + error("got: %g", (double) value); + } + } else { + ++nok; + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + + + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type text + */ +int +check_atts_text(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + text value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) ; + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_TEXT); + if (inRange3(cdf_format, expect[k], datatype, NCT_TEXT)) { + ++nInExtRange; + if (0) + ++nInIntRange; + } + } + err = nc_get_att_text(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (1) { + + IF (!equal((double)value[k],expect[k],datatype,NCT_TEXT)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type uchar + */ +int +check_atts_uchar(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + uchar value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_UCHAR); + if (inRange3(cdf_format, expect[k], datatype, NCT_UCHAR)) { + ++nInExtRange; + if ((expect[k] >= uchar_min && expect[k] <= uchar_max)) + ++nInIntRange; + } + } + err = nc_get_att_uchar(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (inRange3(cdf_format, (double)expect[k],datatype,NCT_UCHAR) && (expect[k] >= uchar_min && expect[k] <= uchar_max)) { + + /* In put_vars(), nc_put_vara_double() is used to write + * variables of type NC_BYTE to files. For uchar APIs, + * NC_BYTE variables are treated as unsigned for CDF-1 and 2 + * formats. Thus, we skip the equal test for out-of-bound + * values below for uchar APIs. + */ + if (cdf_format < NC_FORMAT_CDF5 && + ATT_TYPE(i,j) == NC_BYTE && expect[k] > schar_max) + continue; + IF (!equal((double)value[k],expect[k],datatype,NCT_UCHAR)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type schar + */ +int +check_atts_schar(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + schar value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_SCHAR); + if (inRange3(cdf_format, expect[k], datatype, NCT_SCHAR)) { + ++nInExtRange; + if ((expect[k] >= schar_min && expect[k] <= schar_max)) + ++nInIntRange; + } + } + err = nc_get_att_schar(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (inRange3(cdf_format, (double)expect[k],datatype,NCT_SCHAR) && (expect[k] >= schar_min && expect[k] <= schar_max)) { + + IF (!equal((double)value[k],expect[k],datatype,NCT_SCHAR)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type short + */ +int +check_atts_short(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + short value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_SHORT); + if (inRange3(cdf_format, expect[k], datatype, NCT_SHORT)) { + ++nInExtRange; + if ((expect[k] >= short_min && expect[k] <= short_max)) + ++nInIntRange; + } + } + err = nc_get_att_short(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (inRange3(cdf_format, (double)expect[k],datatype,NCT_SHORT) && (expect[k] >= short_min && expect[k] <= short_max)) { + + IF (!equal((double)value[k],expect[k],datatype,NCT_SHORT)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type int + */ +int +check_atts_int(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + int value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_INT == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_INT); + if (inRange3(cdf_format, expect[k], datatype, NCT_INT)) { + ++nInExtRange; + if ((expect[k] >= int_min && expect[k] <= int_max)) + ++nInIntRange; + } + } + err = nc_get_att_int(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (inRange3(cdf_format, (double)expect[k],datatype,NCT_INT) && (expect[k] >= int_min && expect[k] <= int_max)) { + + IF (!equal((double)value[k],expect[k],datatype,NCT_INT)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type long + */ +int +check_atts_long(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + long value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_LONG == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_LONG); + if (inRange3(cdf_format, expect[k], datatype, NCT_LONG)) { + ++nInExtRange; + if ((expect[k] >= long_min && expect[k] <= long_max)) + ++nInIntRange; + } + } + err = nc_get_att_long(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (inRange3(cdf_format, (double)expect[k],datatype,NCT_LONG) && (expect[k] >= long_min && expect[k] <= long_max)) { + + IF (!equal((double)value[k],expect[k],datatype,NCT_LONG)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type float + */ +int +check_atts_float(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + float value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_FLOAT); + if (inRange3(cdf_format, expect[k], datatype, NCT_FLOAT)) { + ++nInExtRange; + if ((expect[k] >= float_min && expect[k] <= float_max)) + ++nInIntRange; + } + } + err = nc_get_att_float(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (inRange3(cdf_format, (double)expect[k],datatype,NCT_FLOAT) && (expect[k] >= float_min && expect[k] <= float_max)) { + + IF (!equal((double)value[k],expect[k],datatype,NCT_FLOAT)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type double + */ +int +check_atts_double(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + double value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_DOUBLE); + if (inRange3(cdf_format, expect[k], datatype, NCT_DOUBLE)) { + ++nInExtRange; + if ((expect[k] >= double_min && expect[k] <= double_max)) + ++nInIntRange; + } + } + err = nc_get_att_double(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (inRange3(cdf_format, (double)expect[k],datatype,NCT_DOUBLE) && (expect[k] >= double_min && expect[k] <= double_max)) { + + IF (!equal((double)value[k],expect[k],datatype,NCT_DOUBLE)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type ushort + */ +int +check_atts_ushort(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + ushort value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_USHORT); + if (inRange3(cdf_format, expect[k], datatype, NCT_USHORT)) { + ++nInExtRange; + if ((expect[k] >= ushort_min && expect[k] <= ushort_max)) + ++nInIntRange; + } + } + err = nc_get_att_ushort(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (inRange3(cdf_format, (double)expect[k],datatype,NCT_USHORT) && (expect[k] >= ushort_min && expect[k] <= ushort_max)) { + + IF (!equal((double)value[k],expect[k],datatype,NCT_USHORT)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type uint + */ +int +check_atts_uint(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + uint value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_UINT == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_UINT); + if (inRange3(cdf_format, expect[k], datatype, NCT_UINT)) { + ++nInExtRange; + if ((expect[k] >= uint_min && expect[k] <= uint_max)) + ++nInIntRange; + } + } + err = nc_get_att_uint(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (inRange3(cdf_format, (double)expect[k],datatype,NCT_UINT) && (expect[k] >= uint_min && expect[k] <= uint_max)) { + + IF (!equal((double)value[k],expect[k],datatype,NCT_UINT)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type longlong + */ +int +check_atts_longlong(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + longlong value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_LONGLONG); + if (inRange3(cdf_format, expect[k], datatype, NCT_LONGLONG)) { + ++nInExtRange; + if ((expect[k] >= longlong_min && expect[k] <= longlong_max)) + ++nInIntRange; + } + } + err = nc_get_att_longlong(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (inRange3(cdf_format, (double)expect[k],datatype,NCT_LONGLONG) && (expect[k] >= longlong_min && expect[k] <= longlong_max)) { + + IF (!equal((double)value[k],expect[k],datatype,NCT_LONGLONG)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + +/* + * for _text tests, check all attributes in file which are of text type + * Note no NC_ERANGE check for text attributes as text is not convertible to + * any other numerical data types (i.e. NC_ECHAR) + * + * for other tests, check all numerical attributes in file against values + * outside range of type ulonglong + */ +int +check_atts_ulonglong(int ncid, int numGatts, int numVars) +{ + int i, j, cdf_format, err; + int canConvert; /* Both text or both numeric */ + int nok = 0; /* count of valid comparisons */ + size_t k, length, ndx[1]; + nc_type datatype; + size_t nInExtRange; /* number values within external range */ + size_t nInIntRange; /* number values within internal range */ + double expect[MAX_NELS]; + ulonglong value[MAX_NELS]; + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + canConvert = (ATT_TYPE(i,j) == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + if (!canConvert) continue; + + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != ATT_TYPE(i,j)) + error("inq_att: unexpected type"); + IF (length != ATT_LEN(i,j)) + error("inq_att: unexpected length"); + assert(length <= MAX_NELS); + nInIntRange = nInExtRange = 0; + for (k = 0; k < length; k++) { + ndx[0] = k; + expect[k] = hash4(cdf_format, datatype, -1, ndx, NCT_ULONGLONG); + if (inRange3(cdf_format, expect[k], datatype, NCT_ULONGLONG)) { + ++nInExtRange; + if ((expect[k] >= ulonglong_min && expect[k] <= ulonglong_max)) + ++nInIntRange; + } + } + err = nc_get_att_ulonglong(ncid, i, ATT_NAME(i,j), value); + if (nInExtRange == length && nInIntRange == length) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + } else { + IF (err != NC_NOERR && err != NC_ERANGE) + error("expecting NC_NOERR or NC_ERANGE but got %s",nc_err_code_name(err)); + } + for (k = 0; k < length; k++) { + if (inRange3(cdf_format, (double)expect[k],datatype,NCT_ULONGLONG) && (expect[k] >= ulonglong_min && expect[k] <= ulonglong_max)) { + + IF (!equal((double)value[k],expect[k],datatype,NCT_ULONGLONG)) { + error("att. value read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("att_name: %s, ", ATT_NAME(i,j)); + error("att_type: %s, ", s_nc_type(ATT_TYPE(i,j))); + error("element number: %d ", k); + error("expect: %g, ", expect[k]); + error("got: %g", (double) value[k]); + } + } else { + nok++; + } + } + } + } + } + return nok; +} + + + + +int +test_nc_put_var1_text(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + text value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_text(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_text(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_text(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) ; + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_text(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_text(cdf_format, var_type[i], var_rank[i], index, + NCT_TEXT); + err = nc_put_var1_text(ncid, i, index, value); + if (canConvert) { + if (1) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_text(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var1_uchar(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + uchar value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_uchar(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_uchar(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_uchar(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_uchar(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_uchar(cdf_format, var_type[i], var_rank[i], index, + NCT_UCHAR); + err = nc_put_var1_uchar(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, (double)value[0],var_type[i],NCT_UCHAR)) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=8) + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } +#endif + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_uchar(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var1_schar(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + schar value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_schar(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_schar(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_schar(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_schar(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_schar(cdf_format, var_type[i], var_rank[i], index, + NCT_SCHAR); + err = nc_put_var1_schar(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, (double)value[0],var_type[i],NCT_SCHAR)) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if defined(USE_PNETCDF) && PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR<7 + else if (cdf_format < NC_FORMAT_CDF5) { +#else + else { +#endif + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_schar(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var1_short(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + short value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_short(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_short(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_short(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_short(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_short(cdf_format, var_type[i], var_rank[i], index, + NCT_SHORT); + err = nc_put_var1_short(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, (double)value[0],var_type[i],NCT_SHORT)) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_short(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var1_int(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + int value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_int(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_int(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_int(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_int(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_int(cdf_format, var_type[i], var_rank[i], index, + NCT_INT); + err = nc_put_var1_int(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, (double)value[0],var_type[i],NCT_INT)) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_int(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var1_long(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + long value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_long(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_long(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_long(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_long(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_long(cdf_format, var_type[i], var_rank[i], index, + NCT_LONG); + err = nc_put_var1_long(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, (double)value[0],var_type[i],NCT_LONG)) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_long(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var1_float(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + float value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_float(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_float(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_float(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_float(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_float(cdf_format, var_type[i], var_rank[i], index, + NCT_FLOAT); + err = nc_put_var1_float(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, (double)value[0],var_type[i],NCT_FLOAT)) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_float(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var1_double(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + double value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_double(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_double(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_double(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_double(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_double(cdf_format, var_type[i], var_rank[i], index, + NCT_DOUBLE); + err = nc_put_var1_double(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, (double)value[0],var_type[i],NCT_DOUBLE)) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_double(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var1_ushort(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + ushort value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_ushort(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_ushort(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_ushort(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_ushort(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_ushort(cdf_format, var_type[i], var_rank[i], index, + NCT_USHORT); + err = nc_put_var1_ushort(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, (double)value[0],var_type[i],NCT_USHORT)) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_ushort(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var1_uint(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + uint value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_uint(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_uint(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_uint(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_uint(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_uint(cdf_format, var_type[i], var_rank[i], index, + NCT_UINT); + err = nc_put_var1_uint(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, (double)value[0],var_type[i],NCT_UINT)) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_uint(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var1_longlong(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + longlong value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_longlong(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_longlong(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_longlong(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_longlong(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_longlong(cdf_format, var_type[i], var_rank[i], index, + NCT_LONGLONG); + err = nc_put_var1_longlong(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, (double)value[0],var_type[i],NCT_LONGLONG)) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_longlong(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var1_ulonglong(void) +{ + int i, err, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + size_t j, index[MAX_RANK]; + ulonglong value[1]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1_ulonglong(BAD_ID, 0, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1_ulonglong(ncid, BAD_VARID, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var1_ulonglong(BAD_ID, i, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1_ulonglong(ncid, i, index, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash_ulonglong(cdf_format, var_type[i], var_rank[i], index, + NCT_ULONGLONG); + err = nc_put_var1_ulonglong(ncid, i, index, value); + if (canConvert) { + if (inRange3(cdf_format, (double)value[0],var_type[i],NCT_ULONGLONG)) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_ulonglong(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + + + + +int +test_nc_put_var_text(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + text value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_text(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_text(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_text(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) ; + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_text(cdf_format,var_type[i], var_rank[i], index, + NCT_TEXT); + if (var_type[i] != NC_CHAR) + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_TEXT); + } + err = nc_put_var_text(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) ; + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_text(cdf_format,var_type[i], var_rank[i], index, + NCT_TEXT); + if (var_type[i] != NC_CHAR) + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_TEXT); + } + err = nc_put_var_text(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_text(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var_uchar(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + uchar value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_uchar(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_uchar(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_uchar(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_uchar(cdf_format,var_type[i], var_rank[i], index, + NCT_UCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_UCHAR); + } + err = nc_put_var_uchar(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=8) + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } +#endif + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_uchar(cdf_format,var_type[i], var_rank[i], index, + NCT_UCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_UCHAR); + } + err = nc_put_var_uchar(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_uchar(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var_schar(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + schar value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_schar(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_schar(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_schar(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_schar(cdf_format,var_type[i], var_rank[i], index, + NCT_SCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_SCHAR); + } + err = nc_put_var_schar(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if defined(USE_PNETCDF) && PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR<7 + else if (cdf_format < NC_FORMAT_CDF5) { +#else + else { +#endif + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_schar(cdf_format,var_type[i], var_rank[i], index, + NCT_SCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_SCHAR); + } + err = nc_put_var_schar(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_schar(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var_short(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + short value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_short(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_short(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_short(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_short(cdf_format,var_type[i], var_rank[i], index, + NCT_SHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_SHORT); + } + err = nc_put_var_short(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_short(cdf_format,var_type[i], var_rank[i], index, + NCT_SHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_SHORT); + } + err = nc_put_var_short(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_short(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var_int(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + int value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_int(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_int(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_int(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_int(cdf_format,var_type[i], var_rank[i], index, + NCT_INT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_INT); + } + err = nc_put_var_int(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_int(cdf_format,var_type[i], var_rank[i], index, + NCT_INT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_INT); + } + err = nc_put_var_int(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_int(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var_long(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + long value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_long(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_long(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_long(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_long(cdf_format,var_type[i], var_rank[i], index, + NCT_LONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_LONG); + } + err = nc_put_var_long(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_long(cdf_format,var_type[i], var_rank[i], index, + NCT_LONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_LONG); + } + err = nc_put_var_long(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_long(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var_float(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + float value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_float(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_float(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_float(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_float(cdf_format,var_type[i], var_rank[i], index, + NCT_FLOAT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_FLOAT); + } + err = nc_put_var_float(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_float(cdf_format,var_type[i], var_rank[i], index, + NCT_FLOAT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_FLOAT); + } + err = nc_put_var_float(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_float(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var_double(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + double value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_double(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_double(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_double(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_double(cdf_format,var_type[i], var_rank[i], index, + NCT_DOUBLE); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_DOUBLE); + } + err = nc_put_var_double(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_double(cdf_format,var_type[i], var_rank[i], index, + NCT_DOUBLE); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_DOUBLE); + } + err = nc_put_var_double(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_double(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var_ushort(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + ushort value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_ushort(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_ushort(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_ushort(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_ushort(cdf_format,var_type[i], var_rank[i], index, + NCT_USHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_USHORT); + } + err = nc_put_var_ushort(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_ushort(cdf_format,var_type[i], var_rank[i], index, + NCT_USHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_USHORT); + } + err = nc_put_var_ushort(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_ushort(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var_uint(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + uint value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_uint(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_uint(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_uint(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_uint(cdf_format,var_type[i], var_rank[i], index, + NCT_UINT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_UINT); + } + err = nc_put_var_uint(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_uint(cdf_format,var_type[i], var_rank[i], index, + NCT_UINT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_UINT); + } + err = nc_put_var_uint(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_uint(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var_longlong(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + longlong value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_longlong(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_longlong(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_longlong(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_longlong(cdf_format,var_type[i], var_rank[i], index, + NCT_LONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_LONGLONG); + } + err = nc_put_var_longlong(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_longlong(cdf_format,var_type[i], var_rank[i], index, + NCT_LONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_LONGLONG); + } + err = nc_put_var_longlong(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_longlong(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_var_ulonglong(void) +{ + int i, err, ncid, varid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, index[MAX_RANK]; + ulonglong value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var_ulonglong(BAD_ID, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var_ulonglong(ncid, BAD_VARID, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + if (var_dimid[i][0] == RECDIM) continue; /* fixed-size variables only */ + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_var_ulonglong(BAD_ID, i, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_ulonglong(cdf_format,var_type[i], var_rank[i], index, + NCT_ULONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_ULONGLONG); + } + err = nc_put_var_ulonglong(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { /* should flag wrong type even if nothing to write */ + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + /* Preceding has written nothing for record variables, now try */ + /* again with more than 0 records */ + + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS-1; + err = nc_put_var1_text(ncid, varid, index, "x"); + IF (err != NC_NOERR) + error("put_var1_text: %s", nc_strerror(err)); + + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] != RECDIM) continue; /* only record variables here */ + + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + for (allInExtRange = 1, j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[j]= hash_ulonglong(cdf_format,var_type[i], var_rank[i], index, + NCT_ULONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_ULONGLONG); + } + err = nc_put_var_ulonglong(ncid, i, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } else { + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_ulonglong(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + + + + +int +test_nc_put_vara_text(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + text value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_text(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_text(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_text(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) ; + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_text(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_text(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_text(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_text(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_text(cdf_format,var_type[i], var_rank[i], index, + NCT_TEXT); + if (var_type[i] != NC_CHAR) + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_TEXT); + } + err = nc_put_vara_text(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_text(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vara_uchar(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + uchar value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_uchar(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_uchar(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_uchar(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_uchar(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_uchar(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_uchar(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_uchar(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_uchar(cdf_format,var_type[i], var_rank[i], index, + NCT_UCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_UCHAR); + } + err = nc_put_vara_uchar(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=8) + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } +#endif + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_uchar(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vara_schar(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + schar value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_schar(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_schar(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_schar(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_schar(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_schar(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_schar(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_schar(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_schar(cdf_format,var_type[i], var_rank[i], index, + NCT_SCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_SCHAR); + } + err = nc_put_vara_schar(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if defined(USE_PNETCDF) && PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR<7 + else if (cdf_format < NC_FORMAT_CDF5) { +#else + else { +#endif + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_schar(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vara_short(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + short value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_short(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_short(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_short(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_short(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_short(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_short(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_short(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_short(cdf_format,var_type[i], var_rank[i], index, + NCT_SHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_SHORT); + } + err = nc_put_vara_short(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_short(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vara_int(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + int value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_int(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_int(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_int(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_int(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_int(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_int(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_int(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_int(cdf_format,var_type[i], var_rank[i], index, + NCT_INT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_INT); + } + err = nc_put_vara_int(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_int(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vara_long(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + long value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_long(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_long(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_long(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_long(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_long(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_long(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_long(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_long(cdf_format,var_type[i], var_rank[i], index, + NCT_LONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_LONG); + } + err = nc_put_vara_long(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_long(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vara_float(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + float value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_float(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_float(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_float(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_float(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_float(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_float(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_float(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_float(cdf_format,var_type[i], var_rank[i], index, + NCT_FLOAT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_FLOAT); + } + err = nc_put_vara_float(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_float(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vara_double(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + double value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_double(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_double(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_double(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_double(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_double(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_double(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_double(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_double(cdf_format,var_type[i], var_rank[i], index, + NCT_DOUBLE); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_DOUBLE); + } + err = nc_put_vara_double(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_double(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vara_ushort(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + ushort value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_ushort(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_ushort(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_ushort(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_ushort(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_ushort(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_ushort(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_ushort(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_ushort(cdf_format,var_type[i], var_rank[i], index, + NCT_USHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_USHORT); + } + err = nc_put_vara_ushort(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_ushort(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vara_uint(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + uint value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_uint(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_uint(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_uint(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_uint(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_uint(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_uint(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_uint(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_uint(cdf_format,var_type[i], var_rank[i], index, + NCT_UINT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_UINT); + } + err = nc_put_vara_uint(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_uint(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vara_longlong(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + longlong value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_longlong(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_longlong(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_longlong(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_longlong(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_longlong(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_longlong(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_longlong(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_longlong(cdf_format,var_type[i], var_rank[i], index, + NCT_LONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_LONGLONG); + } + err = nc_put_vara_longlong(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_longlong(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vara_ulonglong(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, nels; + size_t start[MAX_RANK], edge[MAX_RANK]; + size_t mid[MAX_RANK], index[MAX_RANK]; + ulonglong value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara_ulonglong(BAD_ID, 0, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara_ulonglong(ncid, BAD_VARID, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara_ulonglong(BAD_ID, i, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_ulonglong(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara_ulonglong(ncid, i, start, edge, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara_ulonglong(ncid, i, start, edge, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara_ulonglong(ncid, i, start, edge, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value[j]= hash_ulonglong(cdf_format,var_type[i], var_rank[i], index, + NCT_ULONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_ULONGLONG); + } + err = nc_put_vara_ulonglong(ncid, i, start, edge, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_ulonglong(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + + + + +int +test_nc_put_vars_text(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + text value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_text(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_text(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_text(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) ; + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_text(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_text(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_text(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_text(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_text(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_text(cdf_format,var_type[i], var_rank[i], + index2, NCT_TEXT); + if (var_type[i] != NC_CHAR) + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_TEXT); + } + err = nc_put_vars_text(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_text(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vars_uchar(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + uchar value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_uchar(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_uchar(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_uchar(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_uchar(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_uchar(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_uchar(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_uchar(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_uchar(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_uchar(cdf_format,var_type[i], var_rank[i], + index2, NCT_UCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_UCHAR); + } + err = nc_put_vars_uchar(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=8) + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } +#endif + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_uchar(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vars_schar(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + schar value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_schar(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_schar(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_schar(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_schar(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_schar(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_schar(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_schar(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_schar(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_schar(cdf_format,var_type[i], var_rank[i], + index2, NCT_SCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_SCHAR); + } + err = nc_put_vars_schar(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if defined(USE_PNETCDF) && PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR<7 + else if (cdf_format < NC_FORMAT_CDF5) { +#else + else { +#endif + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_schar(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vars_short(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + short value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_short(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_short(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_short(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_short(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_short(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_short(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_short(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_short(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_short(cdf_format,var_type[i], var_rank[i], + index2, NCT_SHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_SHORT); + } + err = nc_put_vars_short(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_short(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vars_int(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + int value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_int(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_int(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_int(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_int(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_int(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_int(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_int(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_int(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_int(cdf_format,var_type[i], var_rank[i], + index2, NCT_INT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_INT); + } + err = nc_put_vars_int(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_int(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vars_long(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + long value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_long(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_long(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_long(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_long(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_long(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_long(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_long(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_long(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_long(cdf_format,var_type[i], var_rank[i], + index2, NCT_LONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_LONG); + } + err = nc_put_vars_long(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_long(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vars_float(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + float value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_float(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_float(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_float(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_float(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_float(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_float(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_float(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_float(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_float(cdf_format,var_type[i], var_rank[i], + index2, NCT_FLOAT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_FLOAT); + } + err = nc_put_vars_float(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_float(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vars_double(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + double value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_double(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_double(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_double(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_double(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_double(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_double(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_double(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_double(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_double(cdf_format,var_type[i], var_rank[i], + index2, NCT_DOUBLE); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_DOUBLE); + } + err = nc_put_vars_double(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_double(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vars_ushort(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + ushort value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_ushort(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_ushort(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_ushort(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_ushort(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_ushort(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_ushort(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_ushort(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_ushort(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_ushort(cdf_format,var_type[i], var_rank[i], + index2, NCT_USHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_USHORT); + } + err = nc_put_vars_ushort(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_ushort(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vars_uint(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + uint value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_uint(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_uint(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_uint(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_uint(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_uint(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_uint(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_uint(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_uint(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_uint(cdf_format,var_type[i], var_rank[i], + index2, NCT_UINT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_UINT); + } + err = nc_put_vars_uint(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_uint(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vars_longlong(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + longlong value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_longlong(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_longlong(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_longlong(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_longlong(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_longlong(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_longlong(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_longlong(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_longlong(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_longlong(cdf_format,var_type[i], var_rank[i], + index2, NCT_LONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_LONGLONG); + } + err = nc_put_vars_longlong(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_longlong(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_vars_ulonglong(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK]; + ulonglong value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars_ulonglong(BAD_ID, 0, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars_ulonglong(ncid, BAD_VARID, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars_ulonglong(BAD_ID, i, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_vars_ulonglong(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vars_ulonglong(ncid, i, start, edge, stride, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_vars_ulonglong(ncid, i, start, edge, stride, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars_ulonglong(ncid, i, start, edge, stride, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars_ulonglong(ncid, i, start, edge, stride, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_ulonglong(cdf_format,var_type[i], var_rank[i], + index2, NCT_ULONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_ULONGLONG); + } + err = nc_put_vars_ulonglong(ncid, i, index, count, stride, value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_ulonglong(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + + + + +int +test_nc_put_varm_text(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + text value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_text(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_text(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_text(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) ; + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_text(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_text(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_text(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_text(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_text(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_text(cdf_format,var_type[i], var_rank[i], + index2, NCT_TEXT); + if (var_type[i] != NC_CHAR) + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_TEXT); + } + err = nc_put_varm_text(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_text(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_varm_uchar(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + uchar value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_uchar(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_uchar(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_uchar(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_uchar(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_uchar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_uchar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_uchar(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_uchar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_uchar(cdf_format,var_type[i], var_rank[i], + index2, NCT_UCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_UCHAR); + } + err = nc_put_varm_uchar(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=8) + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } +#endif + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_uchar(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_varm_schar(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + schar value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_schar(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_schar(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_schar(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SCHAR == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_schar(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_schar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_schar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_schar(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_schar(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_schar(cdf_format,var_type[i], var_rank[i], + index2, NCT_SCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_SCHAR); + } + err = nc_put_varm_schar(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if defined(USE_PNETCDF) && PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR<7 + else if (cdf_format < NC_FORMAT_CDF5) { +#else + else { +#endif + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_schar(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_varm_short(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + short value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_short(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_short(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_short(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_SHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_short(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_short(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_short(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_short(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_short(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_short(cdf_format,var_type[i], var_rank[i], + index2, NCT_SHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_SHORT); + } + err = nc_put_varm_short(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_short(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_varm_int(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + int value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_int(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_int(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_int(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_INT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_int(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_int(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_int(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_int(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_int(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_int(cdf_format,var_type[i], var_rank[i], + index2, NCT_INT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_INT); + } + err = nc_put_varm_int(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_int(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_varm_long(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + long value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_long(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_long(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_long(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_long(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_long(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_long(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_long(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_long(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_long(cdf_format,var_type[i], var_rank[i], + index2, NCT_LONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_LONG); + } + err = nc_put_varm_long(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_long(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_varm_float(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + float value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_float(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_float(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_float(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_FLOAT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_float(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_float(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_float(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_float(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_float(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_float(cdf_format,var_type[i], var_rank[i], + index2, NCT_FLOAT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_FLOAT); + } + err = nc_put_varm_float(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_float(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_varm_double(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + double value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_double(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_double(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_double(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_DOUBLE == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_double(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_double(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_double(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_double(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_double(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_double(cdf_format,var_type[i], var_rank[i], + index2, NCT_DOUBLE); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_DOUBLE); + } + err = nc_put_varm_double(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_double(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_varm_ushort(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + ushort value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_ushort(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_ushort(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_ushort(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_USHORT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_ushort(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_ushort(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_ushort(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_ushort(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_ushort(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_ushort(cdf_format,var_type[i], var_rank[i], + index2, NCT_USHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_USHORT); + } + err = nc_put_varm_ushort(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_ushort(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_varm_uint(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + uint value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_uint(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_uint(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_uint(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_UINT == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_uint(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_uint(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_uint(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_uint(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_uint(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_uint(cdf_format,var_type[i], var_rank[i], + index2, NCT_UINT); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_UINT); + } + err = nc_put_varm_uint(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_uint(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_varm_longlong(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + longlong value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_longlong(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_longlong(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_longlong(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_LONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_longlong(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_longlong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_longlong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_longlong(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_longlong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_longlong(cdf_format,var_type[i], var_rank[i], + index2, NCT_LONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_LONGLONG); + } + err = nc_put_varm_longlong(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_longlong(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_varm_ulonglong(void) +{ + int i, k, d, err, nslabs, ncid, cdf_format, nok=0; + int canConvert; /* Both text or both numeric */ + int allInExtRange; /* all values within external range? */ + size_t j, m, nels; + size_t start[MAX_RANK], edge[MAX_RANK], index[MAX_RANK]; + size_t index2[MAX_RANK], mid[MAX_RANK], count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t nstarts; /* number of different starts */ + ptrdiff_t stride[MAX_RANK], imap[MAX_RANK]; + ulonglong value[MAX_NELS]; + + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm_ulonglong(BAD_ID, 0, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm_ulonglong(ncid, BAD_VARID, NULL, NULL, NULL, NULL, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm_ulonglong(BAD_ID, i, NULL, NULL, NULL, NULL, value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + canConvert = (var_type[i] == NC_CHAR) == (NCT_ULONGLONG == NCT_TEXT); + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_put_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned when nothing to put, i.e. edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + if (!canConvert) { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + continue; + } +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm_ulonglong(ncid, i, start, edge, stride, imap, value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* Put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + } else { + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } +*/ + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = 1; + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)count[jj]; + } + for (allInExtRange = 1, j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value[j] = hash_ulonglong(cdf_format,var_type[i], var_rank[i], + index2, NCT_ULONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[j], + var_type[i], NCT_ULONGLONG); + } + err = nc_put_varm_ulonglong(ncid,i,index,count,stride,imap,value); + if (canConvert) { + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } else { + IF (err != NC_ECHAR) + error("expecting NC_ECHAR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + nok += check_vars_ulonglong(scratch, numVars); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + + + +int +test_nc_put_att_text(void) +{ + int i, j, err, ncid, nok=0; + double dtmp; + size_t k, ndx[1]; + text value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_text(BAD_ID, 0, NULL, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_text(ncid, BAD_VARID, NULL, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + { + const char *const tval = "value for bad name"; + const size_t tval_len = (size_t)strlen(tval); + + err = nc_put_att_text(ncid, 0, "", tval_len, tval); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + } + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (ATT_TYPE(i,j) == NC_CHAR) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_text(ncid, BAD_VARID, ATT_NAME(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + dtmp = hash(ATT_TYPE(i,j), -1, ndx); + value[k] = (text)dtmp; + } + err = nc_put_att_text(ncid, i, ATT_NAME(i,j), ATT_LEN(i,j), value); + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + nok += check_atts_text(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + + + +int +test_nc_put_att_uchar(void) +{ + int i, j, err, ncid, cdf_format, nok=0; + int allInExtRange; /* all values within external range? */ + size_t k, ndx[1]; + uchar value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_uchar(BAD_ID, 0, NULL, 0, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_uchar(ncid, BAD_VARID, NULL, 0, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (!(ATT_TYPE(i,j) == NC_CHAR)) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_uchar(ncid, BAD_VARID, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad name */ + err = nc_put_att_uchar(ncid, i, NULL, 0, 0, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_put_att_uchar(ncid, i, ATT_NAME(i,j), BAD_TYPE, ATT_LEN(i,j), value); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (allInExtRange = 1, k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + value[k] = hash_uchar(cdf_format,ATT_TYPE(i,j), -1, ndx, NCT_UCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[k], ATT_TYPE(i,j), NCT_UCHAR); + } + err = nc_put_att_uchar(ncid, i, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if !defined(USE_PNETCDF) || (PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR>=8) + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } +#endif + + } + } + } + + nok += check_atts_uchar(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_att_schar(void) +{ + int i, j, err, ncid, cdf_format, nok=0; + int allInExtRange; /* all values within external range? */ + size_t k, ndx[1]; + schar value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_schar(BAD_ID, 0, NULL, 0, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_schar(ncid, BAD_VARID, NULL, 0, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (!(ATT_TYPE(i,j) == NC_CHAR)) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_schar(ncid, BAD_VARID, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad name */ + err = nc_put_att_schar(ncid, i, NULL, 0, 0, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_put_att_schar(ncid, i, ATT_NAME(i,j), BAD_TYPE, ATT_LEN(i,j), value); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (allInExtRange = 1, k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + value[k] = hash_schar(cdf_format,ATT_TYPE(i,j), -1, ndx, NCT_SCHAR); + + allInExtRange &= inRange3(cdf_format, (double)value[k], ATT_TYPE(i,j), NCT_SCHAR); + } + err = nc_put_att_schar(ncid, i, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + +#if defined(USE_PNETCDF) && PNETCDF_VERSION_MAJOR==1 && PNETCDF_VERSION_MINOR<7 + else if (cdf_format < NC_FORMAT_CDF5) { +#else + else { +#endif + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } + } + } + + nok += check_atts_schar(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_att_short(void) +{ + int i, j, err, ncid, cdf_format, nok=0; + int allInExtRange; /* all values within external range? */ + size_t k, ndx[1]; + short value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_short(BAD_ID, 0, NULL, 0, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_short(ncid, BAD_VARID, NULL, 0, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (!(ATT_TYPE(i,j) == NC_CHAR)) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_short(ncid, BAD_VARID, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad name */ + err = nc_put_att_short(ncid, i, NULL, 0, 0, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_put_att_short(ncid, i, ATT_NAME(i,j), BAD_TYPE, ATT_LEN(i,j), value); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (allInExtRange = 1, k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + value[k] = hash_short(cdf_format,ATT_TYPE(i,j), -1, ndx, NCT_SHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[k], ATT_TYPE(i,j), NCT_SHORT); + } + err = nc_put_att_short(ncid, i, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } + } + } + + nok += check_atts_short(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_att_int(void) +{ + int i, j, err, ncid, cdf_format, nok=0; + int allInExtRange; /* all values within external range? */ + size_t k, ndx[1]; + int value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_int(BAD_ID, 0, NULL, 0, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_int(ncid, BAD_VARID, NULL, 0, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (!(ATT_TYPE(i,j) == NC_CHAR)) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_int(ncid, BAD_VARID, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad name */ + err = nc_put_att_int(ncid, i, NULL, 0, 0, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_put_att_int(ncid, i, ATT_NAME(i,j), BAD_TYPE, ATT_LEN(i,j), value); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (allInExtRange = 1, k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + value[k] = hash_int(cdf_format,ATT_TYPE(i,j), -1, ndx, NCT_INT); + + allInExtRange &= inRange3(cdf_format, (double)value[k], ATT_TYPE(i,j), NCT_INT); + } + err = nc_put_att_int(ncid, i, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } + } + } + + nok += check_atts_int(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_att_long(void) +{ + int i, j, err, ncid, cdf_format, nok=0; + int allInExtRange; /* all values within external range? */ + size_t k, ndx[1]; + long value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_long(BAD_ID, 0, NULL, 0, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_long(ncid, BAD_VARID, NULL, 0, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (!(ATT_TYPE(i,j) == NC_CHAR)) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_long(ncid, BAD_VARID, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad name */ + err = nc_put_att_long(ncid, i, NULL, 0, 0, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_put_att_long(ncid, i, ATT_NAME(i,j), BAD_TYPE, ATT_LEN(i,j), value); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (allInExtRange = 1, k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + value[k] = hash_long(cdf_format,ATT_TYPE(i,j), -1, ndx, NCT_LONG); + + allInExtRange &= inRange3(cdf_format, (double)value[k], ATT_TYPE(i,j), NCT_LONG); + } + err = nc_put_att_long(ncid, i, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } + } + } + + nok += check_atts_long(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_att_float(void) +{ + int i, j, err, ncid, cdf_format, nok=0; + int allInExtRange; /* all values within external range? */ + size_t k, ndx[1]; + float value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_float(BAD_ID, 0, NULL, 0, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_float(ncid, BAD_VARID, NULL, 0, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (!(ATT_TYPE(i,j) == NC_CHAR)) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_float(ncid, BAD_VARID, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad name */ + err = nc_put_att_float(ncid, i, NULL, 0, 0, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_put_att_float(ncid, i, ATT_NAME(i,j), BAD_TYPE, ATT_LEN(i,j), value); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (allInExtRange = 1, k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + value[k] = hash_float(cdf_format,ATT_TYPE(i,j), -1, ndx, NCT_FLOAT); + + allInExtRange &= inRange3(cdf_format, (double)value[k], ATT_TYPE(i,j), NCT_FLOAT); + } + err = nc_put_att_float(ncid, i, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } + } + } + + nok += check_atts_float(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_att_double(void) +{ + int i, j, err, ncid, cdf_format, nok=0; + int allInExtRange; /* all values within external range? */ + size_t k, ndx[1]; + double value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_double(BAD_ID, 0, NULL, 0, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_double(ncid, BAD_VARID, NULL, 0, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (!(ATT_TYPE(i,j) == NC_CHAR)) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_double(ncid, BAD_VARID, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad name */ + err = nc_put_att_double(ncid, i, NULL, 0, 0, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_put_att_double(ncid, i, ATT_NAME(i,j), BAD_TYPE, ATT_LEN(i,j), value); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (allInExtRange = 1, k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + value[k] = hash_double(cdf_format,ATT_TYPE(i,j), -1, ndx, NCT_DOUBLE); + + allInExtRange &= inRange3(cdf_format, (double)value[k], ATT_TYPE(i,j), NCT_DOUBLE); + } + err = nc_put_att_double(ncid, i, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } + } + } + + nok += check_atts_double(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_att_ushort(void) +{ + int i, j, err, ncid, cdf_format, nok=0; + int allInExtRange; /* all values within external range? */ + size_t k, ndx[1]; + ushort value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_ushort(BAD_ID, 0, NULL, 0, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_ushort(ncid, BAD_VARID, NULL, 0, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (!(ATT_TYPE(i,j) == NC_CHAR)) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_ushort(ncid, BAD_VARID, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad name */ + err = nc_put_att_ushort(ncid, i, NULL, 0, 0, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_put_att_ushort(ncid, i, ATT_NAME(i,j), BAD_TYPE, ATT_LEN(i,j), value); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (allInExtRange = 1, k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + value[k] = hash_ushort(cdf_format,ATT_TYPE(i,j), -1, ndx, NCT_USHORT); + + allInExtRange &= inRange3(cdf_format, (double)value[k], ATT_TYPE(i,j), NCT_USHORT); + } + err = nc_put_att_ushort(ncid, i, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } + } + } + + nok += check_atts_ushort(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_att_uint(void) +{ + int i, j, err, ncid, cdf_format, nok=0; + int allInExtRange; /* all values within external range? */ + size_t k, ndx[1]; + uint value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_uint(BAD_ID, 0, NULL, 0, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_uint(ncid, BAD_VARID, NULL, 0, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (!(ATT_TYPE(i,j) == NC_CHAR)) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_uint(ncid, BAD_VARID, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad name */ + err = nc_put_att_uint(ncid, i, NULL, 0, 0, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_put_att_uint(ncid, i, ATT_NAME(i,j), BAD_TYPE, ATT_LEN(i,j), value); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (allInExtRange = 1, k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + value[k] = hash_uint(cdf_format,ATT_TYPE(i,j), -1, ndx, NCT_UINT); + + allInExtRange &= inRange3(cdf_format, (double)value[k], ATT_TYPE(i,j), NCT_UINT); + } + err = nc_put_att_uint(ncid, i, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } + } + } + + nok += check_atts_uint(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_att_longlong(void) +{ + int i, j, err, ncid, cdf_format, nok=0; + int allInExtRange; /* all values within external range? */ + size_t k, ndx[1]; + longlong value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_longlong(BAD_ID, 0, NULL, 0, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_longlong(ncid, BAD_VARID, NULL, 0, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (!(ATT_TYPE(i,j) == NC_CHAR)) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_longlong(ncid, BAD_VARID, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad name */ + err = nc_put_att_longlong(ncid, i, NULL, 0, 0, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_put_att_longlong(ncid, i, ATT_NAME(i,j), BAD_TYPE, ATT_LEN(i,j), value); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (allInExtRange = 1, k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + value[k] = hash_longlong(cdf_format,ATT_TYPE(i,j), -1, ndx, NCT_LONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[k], ATT_TYPE(i,j), NCT_LONGLONG); + } + err = nc_put_att_longlong(ncid, i, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } + } + } + + nok += check_atts_longlong(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + +int +test_nc_put_att_ulonglong(void) +{ + int i, j, err, ncid, cdf_format, nok=0; + int allInExtRange; /* all values within external range? */ + size_t k, ndx[1]; + ulonglong value[MAX_NELS]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + err = nc_inq_format(ncid, &cdf_format); + IF (err != NC_NOERR) + error("inq_format: %s", nc_strerror(err)); + + def_dims(ncid); + def_vars(ncid); + + /* check if can detect a bad file ID */ + err = nc_put_att_ulonglong(BAD_ID, 0, NULL, 0, 0, NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_att_ulonglong(ncid, BAD_VARID, NULL, 0, 0, NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + if (!(ATT_TYPE(i,j) == NC_CHAR)) { + assert(ATT_LEN(i,j) <= MAX_NELS); + + err = nc_put_att_ulonglong(ncid, BAD_VARID, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad name */ + err = nc_put_att_ulonglong(ncid, i, NULL, 0, 0, NULL); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s",nc_err_code_name(err)); + ELSE_NOK + + err = nc_put_att_ulonglong(ncid, i, ATT_NAME(i,j), BAD_TYPE, ATT_LEN(i,j), value); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (allInExtRange = 1, k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + value[k] = hash_ulonglong(cdf_format,ATT_TYPE(i,j), -1, ndx, NCT_ULONGLONG); + + allInExtRange &= inRange3(cdf_format, (double)value[k], ATT_TYPE(i,j), NCT_ULONGLONG); + } + err = nc_put_att_ulonglong(ncid, i, ATT_NAME(i,j), ATT_TYPE(i,j), ATT_LEN(i,j), value); + if (allInExtRange) { + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + else { + + IF (err != NC_ERANGE) + error("expecting NC_ERANGE but got %s",nc_err_code_name(err)); + ELSE_NOK + } + + + } + } + } + + nok += check_atts_ulonglong(ncid, numGatts, numVars); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("delete file %s failed", scratch); + return nok; +} + + diff --git a/nc_test/test_read.c b/nc_test/test_read.c new file mode 100644 index 0000000000..2028380e26 --- /dev/null +++ b/nc_test/test_read.c @@ -0,0 +1,1950 @@ +/* Do not edit this file. It is produced from the corresponding .m4 source */ +/* + * Copyright (C) 2003, Northwestern University and Argonne National Laboratory + * See COPYRIGHT notice in top-level directory. + */ +/* $Id: test_read.m4 2861 2017-02-09 19:38:02Z wkliao $ */ + + +#if defined (_WIN32) || defined (_WIN64) +#include +#endif + +#include /* open() */ +#include /* open() */ +#include /* open() */ +#ifdef _MSC_VER +#include +#else +#include /* unlink(), write() */ +#endif +#include /* errno, strerror() */ + +#include "tests.h" + + + + + + +/* + * Test nc_strerror. + * Try on a bad error status. + * Test for each defined error status. + */ +int +test_nc_strerror(void) +{ + int i; + const char *message, *expected_msg; + int nok=0; + + static const struct { + int status; + const char *msg; + } ncerrs[] = { + {NC_NOERR, "No error"}, + {NC_EBADID, "NetCDF: Not a valid ID"}, + {NC_ENFILE, "NetCDF: Too many files open"}, + {NC_EEXIST, "NetCDF: File exists && NC_NOCLOBBER"}, + {NC_EINVAL, "NetCDF: Invalid argument"}, + {NC_EPERM, "NetCDF: Write to read only"}, + {NC_ENOTINDEFINE, "NetCDF: Operation not allowed in data mode"}, + {NC_EINDEFINE, "NetCDF: Operation not allowed in define mode"}, + {NC_EINVALCOORDS, "NetCDF: Index exceeds dimension bound"}, + {NC_EMAXDIMS, "NetCDF: NC_MAX_DIMS exceeded"}, /* not enforced after 4.5.0 */ + {NC_ENAMEINUSE, "NetCDF: String match to name in use"}, + {NC_ENOTATT, "NetCDF: Attribute not found"}, + {NC_EMAXATTS, "NetCDF: NC_MAX_ATTRS exceeded"}, /* not enforced after 4.5.0 */ + {NC_EBADTYPE, "NetCDF: Not a valid data type or _FillValue type mismatch"}, + {NC_EBADDIM, "NetCDF: Invalid dimension ID or name"}, + {NC_EUNLIMPOS, "NetCDF: NC_UNLIMITED in the wrong index"}, + {NC_EMAXVARS, "NetCDF: NC_MAX_VARS exceeded"}, /* not enforced after 4.5.0 */ + {NC_ENOTVAR, "NetCDF: Variable not found"}, + {NC_EGLOBAL, "NetCDF: Action prohibited on NC_GLOBAL varid"}, + {NC_ENOTNC, "NetCDF: Unknown file format"}, + {NC_ESTS, "NetCDF: In Fortran, string too short"}, + {NC_EMAXNAME, "NetCDF: NC_MAX_NAME exceeded"}, + {NC_EUNLIMIT, "NetCDF: NC_UNLIMITED size already in use"}, + {NC_ENORECVARS, "NetCDF: nc_rec op when there are no record vars"}, + {NC_ECHAR, "NetCDF: Attempt to convert between text & numbers"}, + {NC_EEDGE, "NetCDF: Start+count exceeds dimension bound"}, + {NC_ESTRIDE, "NetCDF: Illegal stride"}, + {NC_EBADNAME, "NetCDF: Name contains illegal characters"}, + {NC_ERANGE, "NetCDF: Numeric conversion not representable"}, + {NC_ENOMEM, "NetCDF: Memory allocation (malloc) failure"}, + {NC_EVARSIZE, "NetCDF: One or more variable sizes violate format constraints"}, + {NC_EDIMSIZE, "NetCDF: Invalid dimension size"} + }; + + /* Try on a bad error status */ + message = nc_strerror(-666);/* should fail */ + expected_msg = "Unknown Error"; + IF (strncmp(message, expected_msg, strlen(expected_msg)) != 0) + error(" nc_strerror on bad error status returned: %s", message); + ELSE_NOK + + /* Try on each legitimate error status */ + for (i=0; i= 0); + close(fd); + } + + /* Open a file that is not a netCDF file. */ + err = file_open(NOT_NC_FILE, NC_NOWRITE, &ncid); /* should fail */ + IF (err != NC_ENOTNC) + error("expecting NC_ENOTNC or NC_EFILE but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* delete the not-nc file */ + unlink(NOT_NC_FILE); +#endif + + /* Open a netCDF file in read-only mode, check that write fails */ + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + ELSE_NOK + err = nc_redef(ncid); /* should fail */ + IF (err != NC_EPERM) + error("expecting NC_EPERM but got %s", nc_err_code_name(err)); + /* Opened OK, see if can open again and get a different netCDF ID */ + err = file_open(testfile, NC_NOWRITE, &ncid2); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + else { + nc_close(ncid2); + nok++; + } + IF (ncid2 == ncid) + error("netCDF IDs for first and second open calls should differ"); + + + { /* tests using netCDF scratch file */ + err = file_create(scratch, NC_NOCLOBBER, &ncid2); + IF (err != NC_NOERR) + error("create: %s", nc_strerror(err)); + else + nc_close(ncid2); + err = file_open(scratch, NC_WRITE, &ncid2); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + else { + nc_close(ncid2); + nok++; + } + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +/* + * Test nc_close. + * Try to close a netCDF file twice, check whether second close fails. + * Try on bad handle, check error return. + * Try in define mode and data mode. + */ +int +test_nc_close(void) +{ + int ncid, nok=0; + int err = file_open(testfile, NC_NOWRITE, &ncid); + + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + /* Close a netCDF file twice, second time should fail */ + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close failed: %s", nc_strerror(err)); + ELSE_NOK + err = nc_close(ncid); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* Try with a bad netCDF ID */ + err = nc_close(BAD_ID);/* should fail */ + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* Close in data mode */ + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close in data mode failed: %s", nc_strerror(err)); + ELSE_NOK + + + { /* tests using netCDF scratch file */ + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) + error("create: %s", nc_strerror(err)); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close in define mode: %s", nc_strerror(err)); + ELSE_NOK + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + } + return nok; +} + + +/* + * Test nc_inq + * Try on bad handle, check error return. + * Try in data mode, check returned values. + * Try asking for subsets of info. + * If in writable section of tests, + * Try in define mode, after adding an unlimited dimension, variable. + * On exit, any open netCDF files are closed. + */ +int +test_nc_inq(void) +{ + int ncid; + int ndims; /* number of dimensions */ + int nvars; /* number of variables */ + int ngatts; /* number of global attributes */ + int recdim; /* id of unlimited dimension */ + int err; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + /* Try on bad handle */ + err = nc_inq(BAD_ID, 0, 0, 0, 0); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + + err = nc_inq(ncid, &ndims, &nvars, &ngatts, &recdim); + IF (err != NC_NOERR) + error("inq: %s", nc_strerror(err)); + else IF (ndims != NDIMS) + error("inq: wrong number of dimensions returned, %d", ndims); + else IF (nvars != numVars) + error("inq: wrong number of variables returned, %d", nvars); + else IF (ngatts != numGatts) + error("inq: wrong number of global atts returned, %d", ngatts); + else IF (recdim != RECDIM) + error("inq: wrong record dimension ID returned, %d", recdim); + ELSE_NOK + + /* Inguire for no info (useless, but should still work) */ + err = nc_inq(ncid, 0, 0, 0, 0); + IF (err != NC_NOERR) + error("inq for no info failed: %s", nc_strerror(err)); + ELSE_NOK + + /* Inguire for subsets of info */ + ngatts = numGatts - 1; /* wipe out previous correct value */ + err = nc_inq(ncid, 0, 0, &ngatts, 0); + IF (err != NC_NOERR) + error("inq for one item failed: %s", nc_strerror(err)); + else IF (ngatts != numGatts) + error("inq subset: wrong number of global atts returned, %d", ngatts); + ELSE_NOK + ndims = NDIMS - 1; + nvars = numVars - 1; + err = nc_inq(ncid, &ndims, &nvars, 0, 0); + IF (err != NC_NOERR) + error("inq for two items failed: %s", nc_strerror(err)); + else IF (ndims != NDIMS) + error("inq subset: wrong number of dimensions returned, %d", ndims); + else IF (nvars != numVars) + error("inq subset: wrong number of variables returned, %d", nvars); + ELSE_NOK + + + { /* tests using netCDF scratch file */ + int ncid2; /* for scratch netCDF dataset */ + + err = file_create(scratch, NC_NOCLOBBER, &ncid2); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + } else { /* add dim, var, gatt, check inq */ + int ndims0; + int nvars0; + int ngatts0; + int recdim0; + err = nc_enddef(ncid2); /* enter data mode */ + err = nc_inq(ncid2, &ndims0, &nvars0, &ngatts0, &recdim0); + IF (err != NC_NOERR) + error("inq: %s", nc_strerror(err)); + ELSE_NOK + err = nc_redef(ncid2); /* enter define mode */ + /* Check that inquire still works in define mode */ + err = nc_inq(ncid2, &ndims, &nvars, &ngatts, &recdim); + IF (err != NC_NOERR) + error("inq in define mode: %s", nc_strerror(err)); + else IF (ndims != ndims0) + error("inq in define mode: ndims wrong, %d", ndims); + else IF (nvars != nvars0) + error("inq in define mode: nvars wrong, %d", nvars); + else IF (ngatts != ngatts0) + error("inq in define mode: ngatts wrong, %d", ngatts); + else IF (recdim != recdim0) + error("inq in define mode: recdim wrong, %d", recdim); + ELSE_NOK + + { + int did, vid; + /* Add dim, var, global att */ + err = nc_def_dim(ncid2, "inqd", 1L, &did); + IF (err != NC_NOERR) + error("def_dim: %s", nc_strerror(err)); + err = nc_def_var(ncid2, "inqv", NC_FLOAT, 0, 0, &vid); + IF (err != NC_NOERR) + error("def_var: %s", nc_strerror(err)); + } + err = nc_put_att_text(ncid2, NC_GLOBAL, "inqa", 1+strlen("stuff"), + "stuff"); + IF (err != NC_NOERR) + error("put_att_text: %s", nc_strerror(err)); + + /* Make sure nc_inq sees the additions while in define mode */ + err = nc_inq(ncid2, &ndims, &nvars, &ngatts, &recdim); + IF (err != NC_NOERR) + error("inq in define mode: %s", nc_strerror(err)); + else IF (ndims != ndims0 + 1) + error("inq in define mode: ndims wrong, %d", ndims); + else IF (nvars != nvars0 + 1) + error("inq in define mode: nvars wrong, %d", nvars); + else IF (ngatts != ngatts0 + 1) + error("inq in define mode: ngatts wrong, %d", ngatts); + ELSE_NOK + err = nc_enddef(ncid2); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* Make sure nc_inq stills sees additions in data mode */ + err = nc_inq(ncid2, &ndims, &nvars, &ngatts, &recdim); + IF (err != NC_NOERR) + error("inq failed in data mode: %s", nc_strerror(err)); + else IF (ndims != ndims0 + 1) + error("inq in define mode: ndims wrong, %d", ndims); + else IF (nvars != nvars0 + 1) + error("inq in define mode: nvars wrong, %d", nvars); + else IF (ngatts != ngatts0 + 1) + error("inq in define mode: ngatts wrong, %d", ngatts); + ELSE_NOK + nc_close(ncid2); + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_natts(void) +{ + int ncid; + int ngatts; /* number of global attributes */ + int err, nok=0; + + err = nc_inq_natts(BAD_ID, &ngatts); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_inq_natts(ncid, &ngatts); + IF (err != NC_NOERR) + error("inq_natts: %s", nc_strerror(err)); + else IF (ngatts != numGatts) + error("inq_natts: wrong number of global atts returned, %d", ngatts); + ELSE_NOK + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_ndims(void) +{ + int ncid; + int ndims; + int err; + int nok=0; + + err = nc_inq_ndims(BAD_ID, &ndims); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_inq_ndims(ncid, &ndims); + IF (err != NC_NOERR) + error("inq_ndims: %s", nc_strerror(err)); + else IF (ndims != NDIMS) + error("inq_ndims: wrong number returned, %d", ndims); + ELSE_NOK + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_nvars(void) +{ + int ncid; + int nvars; + int err; + int nok=0; + + err = nc_inq_nvars(BAD_ID, &nvars); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_inq_nvars(ncid, &nvars); + IF (err != NC_NOERR) + error("inq_nvars: %s", nc_strerror(err)); + else IF (nvars != numVars) + error("inq_nvars: wrong number returned, %d", nvars); + ELSE_NOK + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_unlimdim(void) +{ + int ncid; + int unlimdim; + int err; + int nok=0; + + err = nc_inq_unlimdim(BAD_ID, &unlimdim); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_inq_unlimdim(ncid, &unlimdim); + IF (err != NC_NOERR) + error("inq_unlimdim: %s", nc_strerror(err)); + else IF (unlimdim != RECDIM) + error("inq_unlimdim: wrong number returned, %d", unlimdim); + ELSE_NOK + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_dimid(void) +{ + int ncid; + int dimid; + int i; + int err; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_inq_dimid(ncid, "noSuch", &dimid); + IF (err != NC_EBADDIM) + error("expecting NC_EBADDIM but got %s", nc_err_code_name(err)); + ELSE_NOK + for (i = 0; i < NDIMS; i++) { + err = nc_inq_dimid(BAD_ID, dim_name[i], &dimid); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_dimid(ncid, dim_name[i], &dimid); + IF (err != NC_NOERR) + error("inq_dimid: %s", nc_strerror(err)); + else IF (dimid != i) + error("expected %d, got %d", i, dimid); + ELSE_NOK + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_dim(void) +{ + int ncid; + int i; + int err; + char name[NC_MAX_NAME]; + size_t length; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + for (i = 0; i < NDIMS; i++) { + err = nc_inq_dim(BAD_ID, i, name, &length); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_dim(ncid, BAD_DIMID, name, &length); + IF (err != NC_EBADDIM) + error("expecting NC_EBADDIM but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_dim(ncid, i, 0, 0); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + ELSE_NOK + err = nc_inq_dim(ncid, i, name, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + else IF (strcmp(dim_name[i],name)) + error("name expected: %s, got: %s",dim_name[i],name); + else IF (dim_len[i] != length) + error("size expected: %d, got: %d",dim_len[i],length); + ELSE_NOK + err = nc_inq_dim(ncid, i, name, 0); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + else IF (strcmp(dim_name[i],name)) + error("name expected: %s, got: %s",dim_name[i],name); + ELSE_NOK + err = nc_inq_dim(ncid, i, 0, &length); + IF (err != NC_NOERR) + error("inq_dim: %s", nc_strerror(err)); + else IF (dim_len[i] != length) + error("size expected: %d, got: %d",dim_len[i],length); + ELSE_NOK + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_dimlen(void) +{ + int ncid; + int i; + int err; + size_t length; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + for (i = 0; i < NDIMS; i++) { + err = nc_inq_dimlen(BAD_ID, i, &length); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_dimlen(ncid, BAD_DIMID, &length); + IF (err != NC_EBADDIM) + error("expecting NC_EBADDIM but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_dimlen(ncid, i, &length); + IF (err != NC_NOERR) + error("inq_dimlen: %s", nc_strerror(err)); + else IF (dim_len[i] != length) + error("size expected: %d, got: %d",dim_len[i],length); + ELSE_NOK + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_dimname(void) +{ + int ncid; + int i; + int err; + char name[NC_MAX_NAME]; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + for (i = 0; i < NDIMS; i++) { + err = nc_inq_dimname(BAD_ID, i, name); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_dimname(ncid, BAD_DIMID, name); + IF (err != NC_EBADDIM) + error("expecting NC_EBADDIM but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_dimname(ncid, i, name); + IF (err != NC_NOERR) + error("inq_dimname: %s", nc_strerror(err)); + else IF (strcmp(dim_name[i],name)) + error("name expected: %s, got: %s",dim_name[i],name); + ELSE_NOK + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_varid(void) +{ + int ncid; + int varid; + int i; + int err; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + err = nc_inq_varid(ncid, "noSuch", &varid); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + err = nc_inq_varid(BAD_ID, var_name[i], &varid); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_varid(ncid, var_name[i], &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + else IF (varid != i) + error("expected %d, got %d", i, varid); + ELSE_NOK + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_var(void) +{ + int ncid; + int i; + int err; + char name[NC_MAX_NAME]; + nc_type datatype; + int ndims; + int dimids[MAX_RANK]; + int natts; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + for (i = 0; i < numVars; i++) { + err = nc_inq_var(BAD_ID, i, name, &datatype, &ndims, dimids, &natts); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_var(ncid,BAD_VARID,name,&datatype,&ndims,dimids,&natts); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_var(ncid, i, 0, 0, 0, 0, 0); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + ELSE_NOK + err = nc_inq_var(ncid, i, name, &datatype, &ndims, dimids, &natts); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + else IF (strcmp(var_name[i],name)) + error("name expected: %s, got: %s",var_name[i],name); + else IF (var_type[i] != datatype) + error("type expected: %d, got: %d",var_type[i],datatype); + else IF (var_rank[i] != ndims) + error("ndims expected: %d, got: %d",var_rank[i],ndims); + else IF (!int_vec_eq(var_dimid[i],dimids,ndims)) + error("unexpected dimid"); + else IF (var_natts[i] != natts) + error("natts expected: %d, got: %d",var_natts[i],natts); + ELSE_NOK + err = nc_inq_var(ncid, i, name, 0, 0, 0, 0); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + else IF (strcmp(var_name[i],name)) + error("name expected: %s, got: %s",var_name[i],name); + ELSE_NOK + err = nc_inq_var(ncid, i, 0, &datatype, 0, 0, 0); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + else IF (var_type[i] != datatype) + error("type expected: %d, got: %d",var_type[i],datatype); + ELSE_NOK + err = nc_inq_var(ncid, i, 0, 0, &ndims, 0, 0); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + else IF (var_rank[i] != ndims) + error("ndims expected: %d, got: %d",var_rank[i],ndims); + ELSE_NOK + err = nc_inq_var(ncid, i, 0, 0, 0, dimids, 0); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + else IF (!int_vec_eq(var_dimid[i],dimids,ndims)) + error("unexpected dimid"); + ELSE_NOK + err = nc_inq_var(ncid, i, 0, 0, 0, 0, &natts); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + else IF (var_natts[i] != natts) + error("natts expected: %d, got: %d",var_natts[i],natts); + ELSE_NOK + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_vardimid(void) +{ + int ncid; + int i; + int err; + int dimids[MAX_RANK]; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + for (i = 0; i < numVars; i++) { + err = nc_inq_vardimid(BAD_ID, i, dimids); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_vardimid(ncid, BAD_VARID, dimids); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_vardimid(ncid, i, dimids); + IF (err != NC_NOERR) + error("inq_vardimid: %s", nc_strerror(err)); + else IF (!int_vec_eq(var_dimid[i], dimids, var_rank[i])) + error("unexpected dimid"); + ELSE_NOK + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_varname(void) +{ + int ncid; + int i; + int err; + char name[NC_MAX_NAME]; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + for (i = 0; i < numVars; i++) { + err = nc_inq_varname(BAD_ID, i, name); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + nok++; + err = nc_inq_varname(ncid, BAD_VARID, name); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_varname(ncid, i, name); + IF (err != NC_NOERR) + error("inq_varname: %s", nc_strerror(err)); + else IF (strcmp(var_name[i],name)) + error("name expected: %s, got: %s",var_name[i],name); + ELSE_NOK + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_varnatts(void) +{ + int ncid; + int i; + int err; + int natts; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + for (i = -1; i < numVars; i++) { + err = nc_inq_varnatts(BAD_ID, i, &natts); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_varnatts(ncid, BAD_VARID, &natts); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_varnatts(ncid, VARID(i), &natts); + IF (err != NC_NOERR) + error("inq_varnatts: %s", nc_strerror(err)); + else IF (NATTS(i) != natts) + error("natts expected: %d, got: %d",NATTS(i),natts); + ELSE_NOK + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_varndims(void) +{ + int ncid; + int i; + int err; + int ndims; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + for (i = 0; i < numVars; i++) { + err = nc_inq_varndims(BAD_ID, i, &ndims); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_varndims(ncid, BAD_VARID, &ndims); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_varndims(ncid, i, &ndims); + IF (err != NC_NOERR) + error("inq_varndims: %s", nc_strerror(err)); + else IF (var_rank[i] != ndims) + error("ndims expected: %d, got: %d",var_rank[i],ndims); + ELSE_NOK + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_vartype(void) +{ + int ncid; + int i; + int err; + nc_type datatype; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + for (i = 0; i < numVars; i++) { + err = nc_inq_vartype(BAD_ID, i, &datatype); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_vartype(ncid, BAD_VARID, &datatype); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_vartype(ncid, i, &datatype); + IF (err != NC_NOERR) + error("inq_vartype: %s", nc_strerror(err)); + else IF (var_type[i] != datatype) + error("type expected: %d, got: %d", var_type[i], datatype); + ELSE_NOK + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +/* + * Test nc_get_var1(,,,) + */ +int +test_nc_get_var1(void) +{ + int ncid; + int i; + int err; + double expect; + int nok = 0; /* count of valid comparisons */ + double buf[1]; /* (void *) buffer */ + double value[1]; + size_t j, index[MAX_RANK]; + + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) error("open: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_var1(BAD_ID,0,NULL,NULL); + IF (err != NC_EBADID) error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + + /* check if can detect a bad variable ID */ + err = nc_get_var1(ncid,BAD_VARID,NULL,NULL); + IF (err != NC_ENOTVAR) error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_var1(BAD_ID,i,NULL,value); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) { + index[j] = var_shape[i][j]; + err = nc_get_var1(ncid,i,index,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + err = nc_get_var1(ncid,i,index,value); + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if the contents are supposed to be */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash( var_type[i], var_rank[i], index ); + err = nc_get_var1(ncid,i,index,buf); + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + err = nc2dbl( var_type[i], buf, &value[0]); + IF (err) + error("error in nc2dbl"); + if (inRange(expect,var_type[i])) { + IF (!equal2(value[0],expect,var_type[i])) + error("expected: %G, got: %G", expect, value[0]); + ELSE_NOK + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +/* + * Test nc_get_vara(,,,,) + * Choose a random point dividing each dim into 2 parts + * Get 2^rank (nslabs) slabs so defined + * Each get overwrites buffer, so check after each get. + */ +int +test_nc_get_vara(void) +{ + int ncid, d, i, k, err, nslabs; + int nok = 0; /* count of valid comparisons */ + size_t j, nels; + size_t start[MAX_RANK]; + size_t edge[MAX_RANK]; + size_t index[MAX_RANK]; + size_t mid[MAX_RANK]; + + double buf[MAX_NELS]; /* (void *) buffer */ + double expect; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_vara(BAD_ID,0,NULL,NULL,NULL); + IF (err != NC_EBADID) error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + + /* check if can detect a bad variable ID */ + err = nc_get_vara(ncid,BAD_VARID,NULL,NULL,NULL); + IF (err != NC_ENOTVAR) error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vara(BAD_ID,i,NULL,NULL,buf); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* test NC_EINVALCOORDS, first when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + index[j] = var_shape[i][j]; + err = nc_get_vara(ncid,i,index,edge,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + edge[j] = var_shape[i][j] + 1; /* edge error check */ + err = nc_get_vara(ncid,i,start,edge,buf); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vara(ncid,i,start,edge,buf); +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_get_vara(ncid,i,start,edge,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + err = nc_get_vara(ncid,i,start,edge,buf); + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + }else{ + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + err = nc_get_vara(ncid,i,start,edge,buf); + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (j = 0; j < nels; j++) { + double got; + char *p = (char *) buf; + p += j * (size_t)nctypelen(var_type[i]); + err = nc2dbl( var_type[i], p, & got ); + IF (err) error("error in nc2dbl"); + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + expect = hash(var_type[i], var_rank[i], index); + if (inRange(expect,var_type[i])) { + IF (!equal2(got,expect,var_type[i])) { + error("buf read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("element number: %d ", j); + error("expect: %g", expect); + error("got: %g", got); + } + } + } + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +/* + * Test nc_get_vars(,,,,,) + * Choose a random point dividing each dim into 2 parts + * Get 2^rank (nslabs) slabs so defined + * Each get overwrites buffer, so check after each get. + */ +int +test_nc_get_vars(void) +{ + int ncid; + int d; + int i; + int k; + int err; + int nslabs; + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* total count of valid comparisons */ + int n; /* count of valid comparisons within var */ + size_t j, m, nels; + size_t start[MAX_RANK]; + size_t edge[MAX_RANK]; + size_t index[MAX_RANK]; + size_t index2[MAX_RANK]; + size_t mid[MAX_RANK]; + size_t count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + + double buf[MAX_NELS]; /* (void *) buffer */ + char *p; /* (void *) pointer */ + double expect; + double got; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_vars(BAD_ID,0,NULL,NULL,NULL,NULL); + IF (err != NC_EBADID) error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + + /* check if can detect a bad variable ID */ + err = nc_get_vars(ncid,BAD_VARID,NULL,NULL,NULL,NULL); + IF (err != NC_ENOTVAR) error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_vars(BAD_ID,i,NULL,NULL,NULL,buf); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* test NC_EINVALCOORDS, first when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_vars(ncid,i,start,edge,stride,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_vars(ncid,i,start,edge,stride,buf); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_get_vars(ncid,i,start,edge,stride,buf); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_vars(ncid,i,start,edge,stride,buf); +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_get_vars(ncid,i,start,edge,stride,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + err = nc_get_vars(ncid,i,start,edge,stride,buf); + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + n = 0; + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + }else{ + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + err = nc_get_vars(ncid,i,index,count,stride,buf); + IF (err != NC_NOERR) + error("%s", nc_strerror(err)); + ELSE_NOK + + for (j = 0; j < nels; j++) { + p = (char *) buf; + p += j * (size_t)nctypelen(var_type[i]); + err = nc2dbl( var_type[i], p, & got ); + IF (err != NC_NOERR) + error("error in nc2dbl"); + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + expect = hash(var_type[i], var_rank[i], index2); + if (inRange(expect,var_type[i])) { + IF (!equal2(got,expect,var_type[i])) { + error("buf read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("element number: %d ", j); + error("expect: %g, ", expect); + error("got: %g ", got); + } + } + ELSE_NOK + } + n++; + } + } + } + IF (n != var_nels[i]) { + error("count != nels"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("count: %d, ", n); + error("nels: %d ", var_nels[i]); + } + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +/* + * Test nc_get_varm(,,,,,,) + * Choose a random point dividing each dim into 2 parts + * Get 2^rank (nslabs) slabs so defined + * Choose random stride from 1 to edge + * Buffer should end up being bit image of external variable. + * So all gets for a variable store in different elements of buffer + */ +int +test_nc_get_varm(void) +{ + int ncid; + int i; + int k; + int err; + int nslabs; + ptrdiff_t nstarts; /* number of different starts */ + int nok = 0; /* total count of valid comparisons */ + size_t j, m, nels; + size_t start[MAX_RANK]; + size_t edge[MAX_RANK]; + size_t index[MAX_RANK]; + size_t mid[MAX_RANK]; + size_t count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + ptrdiff_t imap[MAX_RANK]; + ptrdiff_t imap2[MAX_RANK]; + + double buf[MAX_NELS]; /* (void *) buffer */ + char *p; /* (void *) pointer */ + double expect; + double got; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_get_varm(BAD_ID,0,NULL,NULL,NULL,NULL,NULL); + IF (err != NC_EBADID) error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + + /* check if can detect a bad variable ID */ + err = nc_get_varm(ncid,BAD_VARID,NULL,NULL,NULL,NULL,NULL); + IF (err != NC_ENOTVAR) error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + /* check if can detect a bad file ID */ + err = nc_get_varm(BAD_ID,i,NULL,NULL,NULL,NULL,buf); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* test NC_EINVALCOORDS, first when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + start[j] = var_shape[i][j]; + err = nc_get_varm(ncid,i,start,edge,stride,imap,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_get_varm(ncid,i,start,edge,stride,imap,buf); + IF (err != NC_EEDGE) + error("expecting NC_EEDGE but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; + err = nc_get_varm(ncid,i,start,edge,stride,imap,buf); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check non-scalars for correct error returned even when there is + * nothing to get (edge[j]==0) */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_get_varm(ncid,i,start,edge,stride,imap,buf); +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_get_varm(ncid,i,start,edge,stride,imap,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + err = nc_get_varm(ncid,i,start,edge,stride,imap,buf); + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + /* imap[jj] = nctypelen(var_type[i]); */ + imap[jj] = 1; /* in numbers of elements */ + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)var_shape[i][jj]; + } + + /* Choose a random point dividing each dim into 2 parts */ + /* get 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to get lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + }else{ + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + imap2[j] = imap[j] * stride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + if (var_rank[i] == 0 && i%2 ) { + err = nc_get_varm(ncid,i,NULL,NULL,NULL,NULL,buf); + } else { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + index[j] += start[j]; + nels *= count[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + j = fromMixedBase(var_rank[i], index, var_shape[i]); + p = (char *) buf + j * (size_t)nctypelen(var_type[i]); + err = nc_get_varm(ncid,i,index,count,stride,imap2,p); + } + IF (err != NC_NOERR) + error("%s", nc_strerror(err)); + ELSE_NOK + } + } + p = (char *) buf; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + expect = hash( var_type[i], var_rank[i], index); + err = nc2dbl( var_type[i], p, & got ); + IF (err != NC_NOERR) + error("error in nc2dbl"); + if (inRange(expect,var_type[i])) { + IF (!equal2(got,expect,var_type[i])) { + error("buf read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", var_name[i]); + error("element number: %d ", j); + error("expect: %g, ", expect); + error("got: %g ", got); + } + } + ELSE_NOK + } + p += nctypelen(var_type[i]); + } + } + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_get_att(void) +{ + int ncid; + int i; + int j; + size_t k, ndx[1]; + int err; + double buf[MAX_NELS]; /* (void *) buffer */ + char *p; /* (void *) pointer */ + double expect; + double got; + int nok = 0; /* count of valid comparisons */ + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + err = nc_get_att(BAD_ID, i, ATT_NAME(i,j), buf); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_get_att(ncid, BAD_VARID, ATT_NAME(i,j), buf); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_get_att(ncid, i, "noSuch", buf); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_get_att(ncid, i, ATT_NAME(i,j), buf); + IF (err != NC_NOERR) { + error("%s", nc_strerror(err)); + } else { + nok++; + for (k = 0; k < ATT_LEN(i,j); k++) { + ndx[0] = k; + expect = hash(ATT_TYPE(i,j), -1, ndx); + p = (char *) buf; + p += k * (size_t)nctypelen(ATT_TYPE(i,j)); + err = nc2dbl( ATT_TYPE(i,j), p, &got ); + IF (err != NC_NOERR) + error("error in nc2dbl"); + if (inRange(expect,ATT_TYPE(i,j))) { + IF (!equal2(got,expect,ATT_TYPE(i,j))) { + error("buf read not that expected"); + if (verbose) { + error("\n"); + error("varid: %d, ", i); + error("var_name: %s, ", + i >= 0 ? var_name[i] : "Global"); + error("att_name: %s, ", ATT_NAME(i,j)); + error("element number: %d\n", k); + error("expect: %-23.16e\n", expect); + error(" got: %-23.16e", got); + } + } + } + } + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_att(void) +{ + int ncid; + int i; + int j; + int err; + nc_type t; + size_t n; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + for (j = 0; j < NATTS(i); j++) { + err = nc_inq_att(BAD_ID, i, ATT_NAME(i,j), &t, &n); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_att(ncid, BAD_VARID, ATT_NAME(i,j), &t, &n); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_att(ncid, i, "noSuch", &t, &n); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_att(ncid, i, ATT_NAME(i,j), &t, &n); + IF (err != NC_NOERR) { + error("%s", nc_strerror(err)); + } else { + IF (t != ATT_TYPE(i,j)) + error("type not that expected"); + ELSE_NOK + IF (n != ATT_LEN(i,j)) + error("length not that expected"); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_attlen(void) +{ + int ncid; + int i; + int j; + int err; + size_t len; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + err = nc_inq_attlen(ncid, i, "noSuch", &len); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s", nc_err_code_name(err)); + ELSE_NOK + for (j = 0; j < NATTS(i); j++) { + err = nc_inq_attlen(BAD_ID, i, ATT_NAME(i,j), &len); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_attlen(ncid, BAD_VARID, ATT_NAME(i,j), &len); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_attlen(ncid, i, ATT_NAME(i,j), &len); + IF (err != NC_NOERR) { + error("%s", nc_strerror(err)); + } else { + IF (len != ATT_LEN(i,j)) + error("len not that expected"); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_atttype(void) +{ + int ncid; + int i; + int j; + int err; + nc_type datatype; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + err = nc_inq_atttype(ncid, i, "noSuch", &datatype); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s", nc_err_code_name(err)); + ELSE_NOK + for (j = 0; j < NATTS(i); j++) { + err = nc_inq_atttype(BAD_ID, i, ATT_NAME(i,j), &datatype); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_atttype(ncid, BAD_VARID, ATT_NAME(i,j), &datatype); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_atttype(ncid, i, ATT_NAME(i,j), &datatype); + IF (err != NC_NOERR) { + error("%s", nc_strerror(err)); + } else { + IF (datatype != ATT_TYPE(i,j)) + error("type not that expected"); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_attname(void) +{ + int ncid; + int i; + int j; + int err; + char name[NC_MAX_NAME]; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + err = nc_inq_attname(ncid, i, BAD_ATTNUM, name); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_attname(ncid, i, NATTS(i), name); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s", nc_err_code_name(err)); + ELSE_NOK + for (j = 0; j < NATTS(i); j++) { + err = nc_inq_attname(BAD_ID, i, j, name); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_attname(ncid, BAD_VARID, j, name); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_attname(ncid, i, j, name); + IF (err != NC_NOERR) { + error("%s", nc_strerror(err)); + } else { + IF (strcmp(ATT_NAME(i,j), name) != 0) + error("name not that expected"); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} + + +int +test_nc_inq_attid(void) +{ + int ncid; + int i; + int j; + int err; + int attnum; + int nok=0; + + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + err = nc_inq_attid(ncid, i, "noSuch", &attnum); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s", nc_err_code_name(err)); + ELSE_NOK + for (j = 0; j < NATTS(i); j++) { + err = nc_inq_attid(BAD_ID, i, ATT_NAME(i,j), &attnum); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_attid(ncid, BAD_VARID, ATT_NAME(i,j), &attnum); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_inq_attid(ncid, i, ATT_NAME(i,j), &attnum); + IF (err != NC_NOERR) { + error("%s", nc_strerror(err)); + } else { + IF (attnum != j) + error("attnum not that expected"); + ELSE_NOK + } + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + return nok; +} diff --git a/nc_test/test_write.c b/nc_test/test_write.c new file mode 100644 index 0000000000..6fba08a881 --- /dev/null +++ b/nc_test/test_write.c @@ -0,0 +1,2397 @@ +/* Do not edit this file. It is produced from the corresponding .m4 source */ +/* + * Copyright (C) 2003, Northwestern University and Argonne National Laboratory + * See COPYRIGHT notice in top-level directory. + */ +/* $Id: test_write.m4 2687 2016-12-08 18:32:13Z wkliao $ */ + + +#if defined (_WIN32) || defined (_WIN64) +#include +#endif + +#include /* open() */ +#include /* open() */ +#include /* open() */ +#ifdef _MSC_VER +#include +#else +#include /* read() */ +#endif + +#include "tests.h" +#include "config.h" +#include "math.h" + + + + + + + + +/* + * Test nc_create + * For mode in NC_NOCLOBBER, NC_CLOBBER do: + * create netcdf file 'scratch.nc' with no data, close it + * test that it can be opened, do nc_inq to check nvars = 0, etc. + * Try again in NC_NOCLOBBER mode, check error return + * On exit, delete this file + */ +int +test_nc_create(void) +{ + int clobber; /* 0 for NC_NOCLOBBER, 1 for NC_CLOBBER */ + int err; + int ncid; + int ndims; /* number of dimensions */ + int nvars; /* number of variables */ + int ngatts; /* number of global attributes */ + int recdim; /* id of unlimited dimension */ + int nok=0; + + for (clobber = 0; clobber < 2; clobber++) { + err = file_create(scratch, clobber ? NC_CLOBBER : NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) + error("create: %s", nc_strerror(err)); + ELSE_NOK + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + err = file_open(scratch, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_inq(ncid, &ndims, &nvars, &ngatts, &recdim); + IF (err != NC_NOERR) + error("inq: %s", nc_strerror(err)); + else IF (ndims != 0) + error("inq: wrong number of dimensions returned, %d", ndims); + else IF (nvars != 0) + error("inq: wrong number of variables returned, %d", nvars); + else IF (ngatts != 0) + error("inq: wrong number of global atts returned, %d", ngatts); + else IF (recdim != -1) + error("inq: wrong record dimension ID returned, %d", recdim); + ELSE_NOK + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + } + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_EEXIST) + error("expecting NC_EEXIST but got %s", nc_err_code_name(err)); + ELSE_NOK + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_redef + * (In fact also tests nc_enddef - called from test_nc_enddef) + * BAD_ID + * attempt redef (error) & enddef on read-only file + * create file, define dims & vars. + * attempt put var (error) + * attempt redef (error) & enddef. + * put vars + * attempt def new dims (error) + * redef + * def new dims, vars. + * put atts + * enddef + * put vars + * close + * check file: vars & atts + * check reopening with NC_WRITE and adding new dims, atts, vars + */ +int +test_nc_redef(void) +{ + int ncid; /* netcdf id */ + /* used to force effective test of ncio->move() in redef */ + size_t sizehint = 8192; + int dimid; /* dimension id */ + int varid; /* variable id */ + int varid1; /* variable id */ + int nok=0, err; + const char * title = "Not funny"; + double var; + char name[NC_MAX_NAME]; + size_t length; + int fmt_variant1, fmt_variant2; + + /* BAD_ID tests */ + err = nc_redef(BAD_ID); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_enddef(BAD_ID); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* read-only tests */ + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_redef(ncid); + IF (err != NC_EPERM) + error("expecting NC_EPERM but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_enddef(ncid); + IF (err != NC_ENOTINDEFINE) + error("expecting NC_ENOTINDEFINE but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + /* tests using scratch file */ + err = file__create(scratch, NC_NOCLOBBER, 0, &sizehint, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + /* limit for ncio implementations which have infinite chunksize */ + if(sizehint > 32768) sizehint = 16384; + def_dims(ncid); + def_vars(ncid); + put_atts(ncid); + err = nc_inq_varid(ncid, "d", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + var = 1.0; + + + err = nc_put_var1_double(ncid, varid, NULL, &var); + IF (err != NC_EINDEFINE) + error("expecting NC_EINDEFINE but got %s", nc_err_code_name(err)); + + + err = nc_redef(ncid); + IF (err != NC_EINDEFINE) + error("expecting NC_EINDEFINE but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + ELSE_NOK + put_vars(ncid); + err = nc_def_dim(ncid, "abc", sizehint, &dimid); + IF (err != NC_ENOTINDEFINE) + error("expecting NC_ENOTINDEFINE but got %s", nc_err_code_name(err)); + err = nc_redef(ncid); + IF (err != NC_NOERR) + error("redef: %s", nc_strerror(err)); + ELSE_NOK + + err = nc_set_fill(ncid, NC_NOFILL, NULL); + IF (err != NC_NOERR) + error("set_fill: %s", nc_strerror(err)); + + err = nc_def_dim(ncid, "abc", sizehint, &dimid); + IF (err != NC_NOERR) + error("def_dim: %s", nc_strerror(err)); + err = nc_def_var(ncid, "abcScalar", NC_INT, 0, NULL, &varid); + IF (err != NC_NOERR) + error("def_var: %s", nc_strerror(err)); + err = nc_def_var(ncid, "abc", NC_INT, 1, &dimid, &varid1); + IF (err != NC_NOERR) + error("def_var: %s", nc_strerror(err)); + { + int dimids[NDIMS +1]; + int ii = 0; + for(ii = 0; ii < NDIMS; ii++) dimids[ii] = ii; + dimids[NDIMS] = dimid; + err = nc_def_var(ncid, "abcRec", NC_INT, NDIMS, dimids, &varid1); + IF (err != NC_NOERR) + error("def_var: %s", nc_strerror(err)); + } + err = nc_put_att_text(ncid, NC_GLOBAL, "title", 1+strlen(title), title); + IF (err != NC_NOERR) + error("put_att_text: %s", nc_strerror(err)); + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + ELSE_NOK + var = 1.0; + + + err = nc_put_var1_double(ncid, varid, NULL, &var); + IF (err != NC_NOERR) + error("put_var1_double: %s", nc_strerror(err)); + err = nc_inq_format(ncid, &fmt_variant1); + IF (err) + error("inq_format: %s", nc_strerror(err)); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + /* check scratch file written as expected */ + check_file(scratch); /* checks all except "abc" stuff added above */ + + IF ((err = file_open(scratch, NC_NOWRITE, &ncid))) + error("open: %s", nc_strerror(err)); + IF ((err = nc_inq_dim(ncid, dimid, name, &length))) + error("inq_dim: %s", nc_strerror(err)); + IF (strcmp(name, "abc") != 0) + error("Unexpected dim name"); + IF (length != sizehint) + error("Unexpected dim length"); + IF ((err = nc_get_var1_double(ncid, varid, NULL, &var))) + error("get_var1_double: %s", nc_strerror(err)); + IF (var != 1.0) + error("get_var1_double: unexpected value"); + IF ((err = nc_close(ncid))) + error("close: %s", nc_strerror(err)); + + /* open scratch file for writing, add another dim, var, att, then check */ + IF ((err = file_open(scratch, NC_WRITE, &ncid))) + error("open: %s", nc_strerror(err)); + IF ((err = nc_redef(ncid))) + error("redef: %s", nc_strerror(err)); + IF ((err = nc_def_dim(ncid, "def", sizehint, &dimid))) + error("def_dim: %s", nc_strerror(err)); + IF ((err = nc_def_var(ncid, "defScalar", NC_INT, 0, NULL, &varid))) + error("def_var: %s", nc_strerror(err)); + IF ((err = nc_def_var(ncid, "def", NC_INT, 1, &dimid, &varid1))) + error("def_var: %s", nc_strerror(err)); + IF ((err = nc_put_att_text(ncid, NC_GLOBAL, "Credits", 1+strlen("Thanks!"), "Thanks!"))) + error("put_att_text: %s", nc_strerror(err)); + IF ((err = nc_enddef(ncid))) + error("enddef: %s", nc_strerror(err)); + var = 2.0; + IF ((err = nc_put_var1_double(ncid, varid, NULL, &var))) + error("put_var1_double: %s", nc_strerror(err)); + IF ((err = nc_close(ncid))) + error("close: %s", nc_strerror(err)); + + /* check scratch file written as expected */ + check_file(scratch); + + err = file_open(scratch, NC_NOWRITE, &ncid); + IF (err) + error("open: %s", nc_strerror(err)); + err = nc_inq_dim(ncid, dimid, name, &length); + IF (err) + error("inq_dim: %s", nc_strerror(err)); + IF (strcmp(name, "def") != 0) + error("Unexpected dim name"); + IF (length != sizehint) + error("Unexpected dim length"); + err = nc_get_var1_double(ncid, varid, NULL, &var); + IF (err) + error("get_var1_double: %s", nc_strerror(err)); + IF (var != 2.0) + error("get_var1_double: unexpected value"); + /* make sure format variant hasn't changed from when created */ + err = nc_inq_format(ncid, &fmt_variant2); + IF (err) + error("inq_format: %s", nc_strerror(err)); + IF (fmt_variant1 != fmt_variant2) + error("enddef changed format variant"); + err = nc_close(ncid); + IF (err) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_enddef + * Simply calls test_nc_redef which tests both nc_redef & nc_enddef + */ +int +test_nc_enddef(void) +{ + return test_nc_redef(); +} + + +/* + * Test nc_sync + * try with bad handle, check error + * try in define mode, check error + * try writing with one handle, reading with another on same netCDF + */ +int +test_nc_sync(void) +{ + int ncidw; /* netcdf id for writing */ + int ncidr; /* netcdf id for reading */ + int nok=0, err; + + /* BAD_ID test */ + err = nc_sync(BAD_ID); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* create scratch file & try nc_sync in define mode */ + err = file_create(scratch, NC_NOCLOBBER, &ncidw); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + err = nc_sync(ncidw); + IF (err != NC_EINDEFINE) + error("expecting NC_EINDEFINE but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* write using same handle */ + def_dims(ncidw); + def_vars(ncidw); + put_atts(ncidw); + err = nc_enddef(ncidw); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + put_vars(ncidw); + err = nc_sync(ncidw); + IF (err != NC_NOERR) + error("sync of ncidw failed: %s", nc_strerror(err)); + ELSE_NOK + + /* open another handle, nc_sync, read (check) */ + err = file_open(scratch, NC_NOWRITE, &ncidr); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_sync(ncidr); + IF (err != NC_NOERR) + error("sync of ncidr failed: %s", nc_strerror(err)); + ELSE_NOK + check_dims(ncidr); + check_atts(ncidr); + check_vars(ncidr); + + /* close both handles */ + err = nc_close(ncidr); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + err = nc_close(ncidw); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_abort + * try with bad handle, check error + * try in define mode before anything written, check that file was deleted + * try after nc_enddef, nc_redef, define new dims, vars, atts + * try after writing variable + */ +int +test_nc_abort(void) +{ + int ncid; /* netcdf id */ + int err; + int ndims; + int nvars; + int ngatts; + int nok=0; + + /* BAD_ID test */ + err = nc_abort(BAD_ID); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* create scratch file & try nc_abort in define mode */ + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + def_dims(ncid); + def_vars(ncid); + put_atts(ncid); + err = nc_abort(ncid); + IF (err != NC_NOERR) + error("abort of ncid failed: %s", nc_strerror(err)); + ELSE_NOK + err = nc_close(ncid); /* should already be closed */ + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + err = nc_delete(scratch); /* should already be deleted */ +IF (err != ENOENT && err != NC_EIO) + error("expecting ENOENT or NC_EIO but got %s", nc_err_code_name(err)); + /* + * create scratch file + * do nc_enddef & nc_redef + * define new dims, vars, atts + * try nc_abort: should restore previous state (no dims, vars, atts) + */ + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + err = nc_redef(ncid); + IF (err != NC_NOERR) + error("redef: %s", nc_strerror(err)); + def_dims(ncid); + def_vars(ncid); + put_atts(ncid); + err = nc_abort(ncid); + IF (err != NC_NOERR) + error("abort of ncid failed: %s", nc_strerror(err)); + ELSE_NOK + err = nc_close(ncid); /* should already be closed */ + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + err = file_open(scratch, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_inq(ncid, &ndims, &nvars, &ngatts, NULL); + IF (err != NC_NOERR) + error("inq: %s", nc_strerror(err)); + IF (ndims != 0) + error("ndims should be 0"); + IF (nvars != 0) + error("nvars should be 0"); + IF (ngatts != 0) + error("ngatts should be 0"); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + /* try nc_abort in data mode - should just close */ + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + def_dims(ncid); + def_vars(ncid); + put_atts(ncid); + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + put_vars(ncid); + err = nc_abort(ncid); + IF (err != NC_NOERR) + error("abort of ncid failed: %s", nc_strerror(err)); + ELSE_NOK + err = nc_close(ncid); /* should already be closed */ + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + check_file(scratch); + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_def_dim + * try with bad netCDF handle, check error + * try in data mode, check error + * check that returned id is one more than previous id + * try adding same dimension twice, check error + * try with illegal sizes, check error + * make sure unlimited size works, shows up in nc_inq_unlimdim + * try to define a second unlimited dimension, check error + */ +int +test_nc_def_dim(void) +{ + int ncid; + int err; /* status */ + int i, nok=0; + int dimid; /* dimension id */ + size_t length; + + /* BAD_ID test */ + err = nc_def_dim(BAD_ID, "abc", 8, &dimid); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* data mode test */ + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + err = nc_def_dim(ncid, "abc", 8, &dimid); + IF (err != NC_ENOTINDEFINE) + error("expecting NC_ENOTINDEFINE but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* define-mode tests: unlimited dim */ + err = nc_redef(ncid); + IF (err != NC_NOERR) + error("redef: %s", nc_strerror(err)); + err = nc_def_dim(ncid, dim_name[0], NC_UNLIMITED, &dimid); + IF (err != NC_NOERR) + error("def_dim: %s", nc_strerror(err)); + ELSE_NOK + IF (dimid != 0) + error("Unexpected dimid"); + ELSE_NOK + err = nc_inq_unlimdim(ncid, &dimid); + IF (err != NC_NOERR) + error("inq_unlimdim: %s", nc_strerror(err)); + IF (dimid != 0) + error("Unexpected recdim"); + err = nc_inq_dimlen(ncid, dimid, &length); + IF (length != 0) + error("Unexpected length"); + err = nc_def_dim(ncid, "abc", NC_UNLIMITED, &dimid); + IF (err != NC_EUNLIMIT) + error("expecting NC_EUNLIMIT but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* define-mode tests: remaining dims */ + for (i = 1; i < NDIMS; i++) { + err = nc_def_dim(ncid, dim_name[i-1], dim_len[i], &dimid); + IF (err != NC_ENAMEINUSE) + error("expecting NC_ENAMEINUSE but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_def_dim(ncid, BAD_NAME, dim_len[i], &dimid); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s", nc_err_code_name(err)); + ELSE_NOK +if(sizeof(long) > 4) /* Fix: dmh 11/4/2011: works only if sizeof(long) > 4 */ + { + err = nc_def_dim(ncid, dim_name[i], (size_t)(NC_UNLIMITED-1), &dimid); + IF (err != NC_EDIMSIZE) + error("expecting NC_EDIMSIZE but got %s", nc_err_code_name(err)); + ELSE_NOK + } + err = nc_def_dim(ncid, dim_name[i], dim_len[i], &dimid); + IF (err != NC_NOERR) + error("def_dim: %s", nc_strerror(err)); + ELSE_NOK + IF (dimid != i) + error("Unexpected dimid"); + } + + /* Following just to expand unlimited dim */ + def_vars(ncid); + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + put_vars(ncid); + + /* Check all dims */ + check_dims(ncid); + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_rename_dim + * try with bad netCDF handle, check error + * check that proper rename worked with nc_inq_dim + * try renaming to existing dimension name, check error + * try with bad dimension handle, check error + */ +int +test_nc_rename_dim(void) +{ + int ncid; + int err, nok=0; /* status */ + char name[NC_MAX_NAME]; + + /* BAD_ID test */ + err = nc_rename_dim(BAD_ID, 0, "abc"); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* main tests */ + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + def_dims(ncid); + err = nc_rename_dim(ncid, BAD_DIMID, "abc"); + IF (err != NC_EBADDIM) + error("expecting NC_EBADDIM but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_rename_dim(ncid, 2, "abc"); + IF (err != NC_NOERR) + error("rename_dim: %s", nc_strerror(err)); + ELSE_NOK + err = nc_inq_dimname(ncid, 2, name); + IF (strcmp(name, "abc") != 0) + error("Unexpected name: %s", name); + err = nc_rename_dim(ncid, 0, "abc"); + IF (err != NC_ENAMEINUSE) + error("expecting NC_ENAMEINUSE but got %s", nc_err_code_name(err)); + ELSE_NOK + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_def_var + * try with bad netCDF handle, check error + * try with bad name, check error + * scalar tests: + * check that proper define worked with nc_inq_var + * try redefining an existing variable, check error + * try with bad datatype, check error + * try with bad number of dimensions, check error + * try in data mode, check error + * check that returned id is one more than previous id + * try with bad dimension ids, check error + */ +int +test_nc_def_var(void) +{ + int ncid; + int varid; + int err, nok=0; /* status */ + int i; + int ndims; + int natts; + char name[NC_MAX_NAME]; + int dimids[MAX_RANK]; + nc_type datatype; + + /* BAD_ID test */ + err = nc_def_var(BAD_ID, "abc", NC_SHORT, 0, NULL, &varid); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* scalar tests */ + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + err = nc_def_var(ncid, "abc", NC_SHORT, 0, NULL, &varid); + IF (err != NC_NOERR) + error("def_var: %s", nc_strerror(err)); + ELSE_NOK + err = nc_inq_var(ncid, varid, name, &datatype, &ndims, dimids, &natts); + IF (err != NC_NOERR) + error("inq_var: %s", nc_strerror(err)); + IF (strcmp(name, "abc") != 0) + error("Unexpected name: %s", name); + IF (datatype != NC_SHORT) + error("Unexpected datatype"); + IF (ndims != 0) + error("Unexpected rank"); + err = nc_def_var(ncid, BAD_NAME, NC_SHORT, 0, NULL, &varid); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_def_var(ncid, "abc", NC_SHORT, 0, NULL, &varid); + IF (err != NC_ENAMEINUSE) + error("expecting NC_ENAMEINUSE but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_def_var(ncid, "ABC", BAD_TYPE, -1, dimids, &varid); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_def_var(ncid, "ABC", NC_SHORT, -1, dimids, &varid); + IF (err != NC_EINVAL) + error("expecting NC_EINVAL but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + err = nc_def_var(ncid, "ABC", NC_SHORT, 0, dimids, &varid); + IF (err != NC_ENOTINDEFINE) + error("expecting NC_ENOTINDEFINE but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + + /* general tests using global vars */ + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + def_dims(ncid); + for (i = 0; i < numVars; i++) { + err = nc_def_var(ncid, var_name[i], var_type[i], var_rank[i], + var_dimid[i], &varid); + IF (err != NC_NOERR) + error("def_var: %s", nc_strerror(err)); + ELSE_NOK + IF (varid != i) + error("Unexpected varid"); + ELSE_NOK + } + + /* try bad dim ids */ + dimids[0] = BAD_DIMID; + err = nc_def_var(ncid, "abc", NC_SHORT, 1, dimids, &varid); + IF (err != NC_EBADDIM) + error("expecting NC_EBADDIM but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_put_var1(,,,) + */ +int +test_nc_put_var1(void) +{ + int i, err, ncid, nok=0; + size_t j, index[MAX_RANK]; + double value[1]; + double buf[1]; /* (void *) buffer */ + + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_var1(BAD_ID,0,NULL,NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_var1(ncid,BAD_VARID,NULL,NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + value[0] = 5; /* reset to a value within bounds */ + + + + + /* test NC_EINVALCOORDS */ + for (j = 0; j < var_rank[i]; j++) index[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + index[j] = var_shape[i][j]; /* out of boundary check */ + err = nc_put_var1(ncid,i,index,value); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + index[j] = 0; + } + + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value[0] = hash(var_type[i], var_rank[i], index); + if (inRange(value[0], var_type[i])) { + err = dbl2nc(value[0], var_type[i], buf); + IF (err != NC_NOERR) + error("error in dbl2nc var:%s type:%s", + var_name[i],s_nc_type(var_type[i])); + err = nc_put_var1(ncid,i,index,buf); + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + check_vars(ncid); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_put_vara(,,,,) + * Choose a random point dividing each dim into 2 parts + * Put 2^rank (nslabs) slabs so defined + * Redefine buffer for each put. + * At end check all variables using check_vars() + */ +int +test_nc_put_vara(void) +{ + int d, i, k, err, nslabs, ncid, nok=0; + size_t j, nels; + size_t start[MAX_RANK]; + size_t edge[MAX_RANK]; + size_t index[MAX_RANK]; + size_t mid[MAX_RANK]; + double buf[MAX_NELS]; /* (void *) buffer */ + char *p; /* (void *) pointer */ + double value; + + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vara(BAD_ID,0,start,edge,buf); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vara(ncid,BAD_VARID,start,edge,buf); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + buf[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vara(BAD_ID,i,start,edge,buf); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara(ncid,i,start,edge,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; + err = nc_put_vara(ncid,i,start,edge,buf); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + } + /* Check correct error returned when nothing to put, when edge[*]==0 */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == RECDIM) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vara(ncid,i,start,edge,buf); +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vara(ncid,i,start,edge,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + for (k = 0; k < nslabs; k++) { + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + }else{ + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + nels *= edge[j]; + } + p = (char *) buf; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], edge, index); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index[d] += start[d]; + value = hash(var_type[i], var_rank[i], index); + if (!inRange(value, var_type[i])) + value = 0; + err = dbl2nc(value, var_type[i], p); + IF (err != NC_NOERR) + error("error in dbl2nc"); + p += nctypelen(var_type[i]); + } + err = nc_put_vara(ncid,i,start,edge,buf); + IF (err != NC_NOERR) + error("%s", nc_strerror(err)); + ELSE_NOK + } + } + + check_vars(ncid); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_put_vars(,,,,,) + * Choose a random point dividing each dim into 2 parts + * Put 2^rank (nslabs) slabs so defined + * Choose random stride from 1 to edge + * Redefine buffer for each put. + * At end check all variables using check_vars() + */ +int +test_nc_put_vars(void) +{ + int ncid, d, i, k, err, nslabs, nok=0; + ptrdiff_t nstarts; /* number of different starts */ + size_t j, m, nels; + size_t start[MAX_RANK]; + size_t edge[MAX_RANK]; + size_t index[MAX_RANK]; + size_t index2[MAX_RANK]; + size_t mid[MAX_RANK]; + size_t count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + double buf[MAX_NELS]; /* (void *) buffer */ + char *p; /* (void *) pointer */ + double value; + + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_vars(BAD_ID,0,NULL,NULL,NULL,NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_vars(ncid,BAD_VARID,NULL,NULL,NULL,NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + buf[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_vars(BAD_ID,i,NULL,NULL,NULL,buf); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == 0) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars(ncid,i,start,edge,stride,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* edge error check */ + err = nc_put_vars(ncid,i,start,edge,stride,buf); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; /* strided edge error check */ + err = nc_put_vars(ncid,i,start,edge,stride,buf); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == 0) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_vars(ncid,i,start,edge,stride,buf); +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_vars(ncid,i,start,edge,stride,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + /* Choose a random point dividing each dim into 2 parts */ + /* put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + }else{ + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + nels = 1; + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + nels *= count[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + p = (char *) buf; + for (j = 0; j < nels; j++) { + err = toMixedBase(j, var_rank[i], count, index2); + IF (err != 0) error("error in toMixedBase"); + for (d = 0; d < var_rank[i]; d++) + index2[d] = index[d] + index2[d] * (size_t)stride[d]; + value = hash(var_type[i], var_rank[i], index2); + if (!inRange(value, var_type[i])) + value = 0; + err = dbl2nc(value, var_type[i], p); + IF (err != NC_NOERR) + error("error in dbl2nc"); + p += nctypelen(var_type[i]); + } + err = nc_put_vars(ncid,i,index,count,stride,buf); + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + check_vars(ncid); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_put_varm(,,,,,,) + * Choose a random point dividing each dim into 2 parts + * Put 2^rank (nslabs) slabs so defined + * Choose random stride from 1 to edge + * Buffer is bit image of whole external variable. + * So all puts for a variable put different elements of buffer + * At end check all variables using check_vars() + */ +int +test_nc_put_varm(void) +{ + int ncid, nok=0; + int i; + int k; + int err; + int nslabs; + size_t j, m; + ptrdiff_t nstarts; /* number of different starts */ + size_t start[MAX_RANK]; + size_t edge[MAX_RANK]; + size_t index[MAX_RANK]; + size_t mid[MAX_RANK]; + size_t count[MAX_RANK]; + size_t sstride[MAX_RANK]; + ptrdiff_t stride[MAX_RANK]; + ptrdiff_t imap[MAX_RANK]; + ptrdiff_t imap2[MAX_RANK]; + + double buf[MAX_NELS]; /* (void *) buffer */ + char *p; /* (void *) pointer */ + double value; + + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + def_dims(ncid); + def_vars(ncid); + + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + /* check if can detect a bad file ID */ + err = nc_put_varm(NC_EBADID,0,NULL,NULL,NULL,NULL,NULL); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + /* check if can detect a bad variable ID */ + err = nc_put_varm(ncid,BAD_VARID,NULL,NULL,NULL,NULL,NULL); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s",nc_err_code_name(err)); + ELSE_NOK + + for (i = 0; i < numVars; i++) { + assert(var_rank[i] <= MAX_RANK); + assert(var_nels[i] <= MAX_NELS); + + buf[0] = 5; /* reset to a value within bounds */ + + /* check if can detect a bad file ID */ + err = nc_put_varm(BAD_ID,i,NULL,NULL,NULL,NULL,buf); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s",nc_err_code_name(err)); + ELSE_NOK + + + + for (j = 0; j < var_rank[i]; j++) { + start[j] = 0; + edge[j] = 1; + stride[j] = 1; + imap[j] = 1; + } + + + /* first test when edge[*] > 0 */ + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == 0) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm(ncid,i,start,edge,stride,imap,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + edge[j] = var_shape[i][j] + 1; /* edge error check */ + err = nc_put_varm(ncid,i,start,edge,stride,imap,buf); + IF (err != NC_EEDGE) + error("expecting NC_EEDG but got %s",nc_err_code_name(err)); + ELSE_NOK + edge[j] = 1; + stride[j] = 0; /* strided edge error check */ + err = nc_put_varm(ncid,i,start,edge,stride,imap,buf); + IF (err != NC_ESTRIDE) + error("expecting NC_ESTRIDE but got %s",nc_err_code_name(err)); + ELSE_NOK + stride[j] = 1; + } + /* Check correct error returned even when nothing to put */ + for (j = 0; j < var_rank[i]; j++) edge[j] = 0; + + for (j = 0; j < var_rank[i]; j++) { + if (var_dimid[i][j] == 0) continue; /* skip record dim */ + start[j] = var_shape[i][j]; + err = nc_put_varm(ncid,i,start,edge,stride,imap,buf); +#ifdef RELAX_COORD_BOUND + IF (err != NC_NOERR) /* allowed when edge[j]==0 */ + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); +#else + IF (err != NC_EINVALCOORDS) /* not allowed even when edge[j]==0 */ + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); +#endif + ELSE_NOK + start[j] = var_shape[i][j]+1; /* out of boundary check */ + err = nc_put_varm(ncid,i,start,edge,stride,imap,buf); + IF (err != NC_EINVALCOORDS) + error("expecting NC_EINVALCOORDS but got %s",nc_err_code_name(err)); + ELSE_NOK + start[j] = 0; + } + for (j = 0; j < var_rank[i]; j++) edge[j] = 1; + + if (var_rank[i] > 0) { + int jj = var_rank[i] - 1; + imap[jj] = nctypelen(var_type[i]); /* netCDF considers imap in bytes */ + imap[jj] = 1; /* PnetCDF considers imap in elements */ + for (; jj > 0; jj--) + imap[jj-1] = imap[jj] * (ptrdiff_t)var_shape[i][jj]; + } + p = (char *) buf; + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + value = hash(var_type[i], var_rank[i], index); + if (!inRange(value, var_type[i])) + value = 0; + err = dbl2nc(value, var_type[i], p); + IF (err != NC_NOERR) + error("error in dbl2nc"); + p += nctypelen(var_type[i]); + } + + /* Choose a random point dividing each dim into 2 parts */ + /* put 2^rank (nslabs) slabs so defined */ + nslabs = 1; + for (j = 0; j < var_rank[i]; j++) { + mid[j] = roll( var_shape[i][j] ); + nslabs *= 2; + } + /* bits of k determine whether to put lower or upper part of dim */ + /* choose random stride from 1 to edge */ + for (k = 0; k < nslabs; k++) { + nstarts = 1; + for (j = 0; j < var_rank[i]; j++) { + if ((k >> j) & 1) { + start[j] = 0; + edge[j] = mid[j]; + }else{ + start[j] = mid[j]; + edge[j] = var_shape[i][j] - mid[j]; + } + sstride[j] = edge[j] > 0 ? 1+roll(edge[j]) : 1; + stride[j] = (ptrdiff_t)sstride[j]; + imap2[j] = imap[j] * (ptrdiff_t)sstride[j]; + nstarts *= stride[j]; + } + for (m = 0; m < nstarts; m++) { + if (var_rank[i] == 0 && i%2 == 0) { + err = nc_put_varm(ncid,i,NULL,NULL,NULL,NULL,buf); + } else { + err = toMixedBase(m, var_rank[i], sstride, index); + IF (err != 0) error("error in toMixedBase"); + for (j = 0; j < var_rank[i]; j++) { + count[j] = 1 + (edge[j] - index[j] - 1) / (size_t)stride[j]; + index[j] += start[j]; + } + /* Random choice of forward or backward */ +/* TODO + if ( roll(2) ) { + for (j = 0; j < var_rank[i]; j++) { + index[j] += (count[j] - 1) * (size_t)stride[j]; + stride[j] = -stride[j]; + } + } + */ + j = fromMixedBase(var_rank[i], index, var_shape[i]); + p = (char *) buf + (int)j * nctypelen(var_type[i]); + + err = nc_put_varm(ncid,i,index,count,stride,imap2,p); + } + IF (err != NC_NOERR) + error("expecting NC_NOERR but got %s",nc_err_code_name(err)); + ELSE_NOK + } + } + } + + check_vars(ncid); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_rename_var + * try with bad netCDF handle, check error + * try with bad variable handle, check error + * try renaming to existing variable name, check error + * check that proper rename worked with nc_inq_varid + * try in data mode, check error + */ +int +test_nc_rename_var(void) +{ + int ncid; + int varid; + int err, nok=0; + int i; + char name[NC_MAX_NAME]; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + err = nc_rename_var(ncid, BAD_VARID, "newName"); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + def_dims(ncid); + def_vars(ncid); + + /* Prefix "new_" to each name */ + for (i = 0; i < numVars; i++) { + err = nc_rename_var(BAD_ID, i, "newName"); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_rename_var(ncid, i, var_name[numVars-1]); + IF (err != NC_ENAMEINUSE) + error("expecting NC_ENAMEINUSE but got %s", nc_err_code_name(err)); + ELSE_NOK + strcpy(name, "new_"); + strcat(name, var_name[i]); + err = nc_rename_var(ncid, i, name); + IF (err != NC_NOERR) + error("rename_var: %s", nc_strerror(err)); + ELSE_NOK + err = nc_inq_varid(ncid, name, &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + IF (varid != i) + error("Unexpected varid"); + } + + /* Change to data mode */ + /* Try making names even longer. Then restore original names */ + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + for (i = 0; i < numVars; i++) { + strcpy(name, "even_longer_"); + strcat(name, var_name[i]); + err = nc_rename_var(ncid, i, name); + IF (err != NC_ENOTINDEFINE) + error("expecting NC_ENOTINDEFINE but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_rename_var(ncid, i, var_name[i]); + IF (err != NC_NOERR) + error("rename_var: %s", nc_strerror(err)); + ELSE_NOK + err = nc_inq_varid(ncid, var_name[i], &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + IF (varid != i) + error("Unexpected varid"); + } + + put_vars(ncid); + check_vars(ncid); + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +int +test_nc_put_att(void) +{ + int ncid, nok=0; + int varid; + int i; + int j; + size_t k, ndx[1]; + int err; + double buf[MAX_NELS]; /* (void *) buffer */ + char *p; /* (void *) pointer */ + char *name; /* of att */ + nc_type datatype; /* of att */ + size_t length; /* of att */ + double value; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + def_dims(ncid); + def_vars(ncid); + + for (i = -1; i < numVars; i++) { + varid = VARID(i); + for (j = 0; j < NATTS(i); j++) { + name = ATT_NAME(i,j); + datatype = ATT_TYPE(i,j); + length = ATT_LEN(i,j); + err = nc_put_att(BAD_ID, varid, name, datatype, length, buf); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_put_att(ncid, varid, BAD_NAME, datatype, length, buf); + IF (err != NC_EBADNAME) + error("expecting NC_EBADNAME but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_put_att(ncid, BAD_VARID, name, datatype, length, buf); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_put_att(ncid, varid, name, BAD_TYPE, length, buf); + IF (err != NC_EBADTYPE) + error("expecting NC_EBADTYPE but got %s", nc_err_code_name(err)); + ELSE_NOK + p = (char *) buf; + for (k=0; k 0 && ATT_LEN(i,j) > 0) { + err = nc_rename_att(ncid_out, i, att_name[i][0], "a"); + IF (err != NC_NOERR) + error("rename_att: %s", nc_strerror(err)); + err = nc_copy_att(ncid_out, NC_GLOBAL, "a", ncid_out, i); + IF (err != NC_NOERR) + error("copy_att: %s", nc_strerror(err)); + ELSE_NOK + } + } + err = nc_close(ncid_out); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + /* Reopen & check */ + err = file_open(scratch, NC_WRITE, &ncid_out); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + for (i = 0; i < numVars; i++) { + if (NATTS(i) > 0 && ATT_LEN(i,j) > 0) { + err = nc_inq_att(ncid_out, i, "a", &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != NC_CHAR) + error("Unexpected type"); + IF (length != 1) + error("Unexpected length"); + err = nc_get_att_text(ncid_out, i, "a", &value); + IF (err != NC_NOERR) + error("get_att_text: %s", nc_strerror(err)); + IF (value != 'A') + error("Unexpected value"); + } + } + + err = nc_close(ncid_out); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_rename_att + * try with bad netCDF handle, check error + * try with bad variable handle, check error + * try with nonexisting att name, check error + * try renaming to existing att name, check error + * check that proper rename worked with nc_inq_attid + * try in data mode, check error + */ +int +test_nc_rename_att(void) +{ + int ncid; + int varid; + int err; + int i; + int j; + size_t k, ndx[1]; + int attnum; + char *attname; + char name[NC_MAX_NAME]; + char oldname[NC_MAX_NAME]; + char newname[NC_MAX_NAME]; + int nok = 0; /* count of valid comparisons */ + nc_type datatype; + nc_type atttype; + size_t length; + size_t attlength; + char text[MAX_NELS]; + double value[MAX_NELS]; + double expect; + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + err = nc_rename_att(ncid, BAD_VARID, "abc", "newName"); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + def_dims(ncid); + def_vars(ncid); + put_atts(ncid); + + for (i = -1; i < numVars; i++) { + varid = VARID(i); + for (j = 0; j < NATTS(i); j++) { + attname = ATT_NAME(i,j); + err = nc_rename_att(BAD_ID, varid, attname, "newName"); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_rename_att(ncid, varid, "noSuch", "newName"); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s", nc_err_code_name(err)); + ELSE_NOK + strcpy(newname, "new_"); + strcat(newname, attname); + err = nc_rename_att(ncid, varid, attname, newname); + IF (err != NC_NOERR) + error("rename_att: %s", nc_strerror(err)); + ELSE_NOK + err = nc_inq_attid(ncid, varid, newname, &attnum); + IF (err != NC_NOERR) + error("inq_attid: %s", nc_strerror(err)); + IF (attnum != j) + error("Unexpected attnum"); + } + } + + /* Close. Reopen & check */ + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + err = file_open(scratch, NC_WRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + varid = VARID(i); + for (j = 0; j < NATTS(i); j++) { + attname = ATT_NAME(i,j); + atttype = ATT_TYPE(i,j); + attlength = ATT_LEN(i,j); + strcpy(newname, "new_"); + strcat(newname, attname); + err = nc_inq_attname(ncid, varid, j, name); + IF (err != NC_NOERR) + error("inq_attname: %s", nc_strerror(err)); + IF (strcmp(name, newname) != 0) + error("inq_attname: unexpected name"); + err = nc_inq_att(ncid, varid, name, &datatype, &length); + IF (err != NC_NOERR) + error("inq_att: %s", nc_strerror(err)); + IF (datatype != atttype) + error("inq_att: unexpected type"); + IF (length != attlength) + error("inq_att: unexpected length"); + if (datatype == NC_CHAR) { + err = nc_get_att_text(ncid, varid, name, text); + IF (err != NC_NOERR) + error("get_att_text: %s", nc_strerror(err)); + for (k = 0; k < attlength; k++) { + ndx[0] = k; + expect = hash(datatype, -1, ndx); + IF (text[k] != (char)expect) + error("get_att_text: unexpected value"); + } + } else { + err = nc_get_att_double(ncid, varid, name, value); + IF (err != NC_NOERR) + error("get_att_double: %s", nc_strerror(err)); + for (k = 0; k < attlength; k++) { + ndx[0] = k; + expect = hash(datatype, -1, ndx); + if (inRange(expect, datatype)) { + IF (!equal(value[k],expect,datatype,NCT_DOUBLE)) + error("get_att_double: unexpected value"); + } + } + } + } + } + + /* Now in data mode */ + /* Try making names even longer. Then restore original names */ + + for (i = -1; i < numVars; i++) { + varid = VARID(i); + for (j = 0; j < NATTS(i); j++) { + attname = ATT_NAME(i,j); + strcpy(oldname, "new_"); + strcat(oldname, attname); + strcpy(newname, "even_longer_"); + strcat(newname, attname); + err = nc_rename_att(ncid, varid, oldname, newname); + IF (err != NC_ENOTINDEFINE) + error("expecting NC_ENOTINDEFINE but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_rename_att(ncid, varid, oldname, attname); + IF (err != NC_NOERR) + error("rename_att: %s", nc_strerror(err)); + ELSE_NOK + err = nc_inq_attid(ncid, varid, attname, &attnum); + IF (err != NC_NOERR) + error("inq_attid: %s", nc_strerror(err)); + IF (attnum != j) + error("Unexpected attnum"); + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_del_att + * try with bad netCDF handle, check error + * try with bad variable handle, check error + * try with nonexisting att name, check error + * check that proper delete worked using: + * nc_inq_attid, nc_inq_natts, nc_inq_varnatts + */ +int +test_nc_del_att(void) +{ + int ncid; + int err, nok=0; + int i; + int j; + int attnum; + int natts; + int numatts; + int varid; + char *name; /* of att */ + + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + err = nc_del_att(ncid, BAD_VARID, "abc"); + IF (err != NC_ENOTVAR) + error("expecting NC_ENOTVAR but got %s", nc_err_code_name(err)); + ELSE_NOK + def_dims(ncid); + def_vars(ncid); + put_atts(ncid); + + for (i = -1; i < numVars; i++) { + varid = VARID(i); + numatts = NATTS(i); + for (j = 0; j < numatts; j++) { + name = ATT_NAME(i,j); + err = nc_del_att(BAD_ID, varid, name); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_del_att(ncid, varid, "noSuch"); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s", nc_err_code_name(err)); + ELSE_NOK + err = nc_del_att(ncid, varid, name); + IF (err != NC_NOERR) + error("del_att: %s", nc_strerror(err)); + ELSE_NOK + err = nc_inq_attid(ncid, varid, name, &attnum); + IF (err != NC_ENOTATT) + error("expecting NC_ENOTATT but got %s", nc_err_code_name(err)); + if (i < 0) { + err = nc_inq_natts(ncid, &natts); + IF (err != NC_NOERR) + error("inq_natts: %s", nc_strerror(err)); + IF (natts != numatts-j-1) + error("natts: expected %d, got %d", numatts-j-1, natts); + } + err = nc_inq_varnatts(ncid, varid, &natts); + IF (err != NC_NOERR) + error("inq_natts: %s", nc_strerror(err)); + IF (natts != numatts-j-1) + error("natts: expected %d, got %d", numatts-j-1, natts); + } + } + + /* Close. Reopen & check no attributes left */ + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + err = file_open(scratch, NC_WRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_inq_natts(ncid, &natts); + IF (err != NC_NOERR) + error("inq_natts: %s", nc_strerror(err)); + IF (natts != 0) + error("natts: expected %d, got %d", 0, natts); + for (i = -1; i < numVars; i++) { + varid = VARID(i); + err = nc_inq_varnatts(ncid, varid, &natts); + IF (err != NC_NOERR) + error("inq_natts: %s", nc_strerror(err)); + IF (natts != 0) + error("natts: expected %d, got %d", 0, natts); + } + + /* restore attributes. change to data mode. try to delete */ + err = nc_redef(ncid); + IF (err != NC_NOERR) + error("redef: %s", nc_strerror(err)); + put_atts(ncid); + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + + for (i = -1; i < numVars; i++) { + varid = VARID(i); + numatts = NATTS(i); + for (j = 0; j < numatts; j++) { + name = ATT_NAME(i,j); + err = nc_del_att(ncid, varid, name); + IF (err != NC_ENOTINDEFINE) + error("expecting NC_ENOTINDEFINE but got %s", nc_err_code_name(err)); + ELSE_NOK + } + } + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + return nok; +} + + +/* + * Test nc_set_fill + * try with bad netCDF handle, check error + * try in read-only mode, check error + * try with bad new_fillmode, check error + * try in data mode, check error + * check that proper set to NC_FILL works for record & non-record variables + * (note that it is not possible to test NC_NOFILL mode!) + * close file & create again for test using attribute _FillValue + */ +int +test_nc_set_fill(void) +{ + int ncid; + int varid; + int err; + int i; + size_t j; + int old_fillmode; + int nok = 0; /* count of valid comparisons */ + char text = 0; + double value = 0; + double fill; + size_t index[MAX_RANK]; + + /* bad ncid */ + err = nc_set_fill(BAD_ID, NC_NOFILL, &old_fillmode); + IF (err != NC_EBADID) + error("expecting NC_EBADID but got %s", nc_err_code_name(err)); + + /* try in read-only mode */ + err = file_open(testfile, NC_NOWRITE, &ncid); + IF (err != NC_NOERR) + error("open: %s", nc_strerror(err)); + err = nc_set_fill(ncid, NC_NOFILL, &old_fillmode); + IF (err != NC_EPERM) + error("expecting NC_EPERM but got %s", nc_err_code_name(err)); + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + + /* create scratch */ + err = file_create(scratch, NC_NOCLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + + /* BAD_FILLMODE */ + err = nc_set_fill(ncid, BAD_FILLMODE, &old_fillmode); + IF (err != NC_EINVAL) + error("expecting NC_EINVAL but got %s", nc_err_code_name(err)); + + /* proper calls */ + err = nc_set_fill(ncid, NC_NOFILL, &old_fillmode); + IF (err != NC_NOERR) + error("set_fill: %s", nc_strerror(err)); + IF (old_fillmode != NC_NOFILL) + error("Unexpected old fill mode: %d", old_fillmode); + err = nc_set_fill(ncid, NC_FILL, &old_fillmode); + IF (err != NC_NOERR) + error("set_fill: %s", nc_strerror(err)); + IF (old_fillmode != NC_NOFILL) + error("Unexpected old fill mode: %d", old_fillmode); + + /* define dims & vars */ + def_dims(ncid); + def_vars(ncid); + + /* Change to data mode. Set fillmode again */ + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + err = nc_set_fill(ncid, NC_FILL, &old_fillmode); +IF (err) + error("nc_set_fill: %s", nc_strerror(err)); + IF (old_fillmode != NC_FILL) + error("Unexpected old fill mode: %d", old_fillmode); + /* Write record number NRECS to force writing of preceding records */ + /* Assumes variable cr is char vector with UNLIMITED dimension */ + err = nc_inq_varid(ncid, "cr", &varid); + IF (err != NC_NOERR) + error("inq_varid: %s", nc_strerror(err)); + index[0] = NRECS; + + + err = nc_put_var1_text(ncid, varid, index, &text); + IF (err != NC_NOERR) + error("put_var1_text_all: %s", nc_strerror(err)); + + /* get all variables & check all values equal default fill */ + for (i = 0; i < numVars; i++) { + + switch (var_type[i]) { + case NC_CHAR: fill = (double)NC_FILL_CHAR; break; + case NC_BYTE: fill = (double)NC_FILL_BYTE; break; + case NC_SHORT: fill = (double)NC_FILL_SHORT; break; + case NC_INT: fill = (double)NC_FILL_INT; break; + case NC_FLOAT: fill = (double)NC_FILL_FLOAT; break; + case NC_DOUBLE: fill = (double)NC_FILL_DOUBLE; break; + case NC_UBYTE: fill = (double)NC_FILL_UBYTE; break; + case NC_USHORT: fill = (double)NC_FILL_USHORT; break; + case NC_UINT: fill = (double)NC_FILL_UINT; break; + case NC_INT64: fill = (double)NC_FILL_INT64; break; + case NC_UINT64: fill = (double)NC_FILL_UINT64; break; + default: assert(0); + } + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + if (var_type[i] == NC_CHAR) { + err = nc_get_var1_text(ncid, i, index, &text); + IF (err != NC_NOERR) + error("get_var1_text_all failed: %s", nc_strerror(err)); + value = text; + } else { + err = nc_get_var1_double(ncid, i, index, &value); + IF (err != NC_NOERR) + error("get_var1_double_all failed: %s", nc_strerror(err)); + } + IF (value != fill && fabs((fill - value)/fill) > DBL_EPSILON) + error("\n\t\t%s Value expected: %-23.17e,\n\t\t read: %-23.17e\n", + var_name[i],fill, value); + ELSE_NOK + } + } + + /* close scratch & create again for test using attribute _FillValue */ + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + err = file_create(scratch, NC_CLOBBER, &ncid); + IF (err != NC_NOERR) { + error("create: %s", nc_strerror(err)); + return nok; + } + def_dims(ncid); + def_vars(ncid); + + /* set _FillValue = 42 for all vars */ + fill = 42; + text = 42; + for (i = 0; i < numVars; i++) { + if (var_type[i] == NC_CHAR) { + err = nc_put_att_text(ncid, i, "_FillValue", 1, &text); + IF (err != NC_NOERR) + error("put_att_text: %s", nc_strerror(err)); + } else { + err = nc_put_att_double(ncid, i, "_FillValue",var_type[i],1,&fill); + IF (err != NC_NOERR) + error("put_att_double: %s", nc_strerror(err)); + } + } + + /* data mode. write records */ + err = nc_enddef(ncid); + IF (err != NC_NOERR) + error("enddef: %s", nc_strerror(err)); + index[0] = NRECS; + + + err = nc_put_var1_text(ncid, varid, index, &text); + IF (err != NC_NOERR) + error("put_var1_text_all: %s", nc_strerror(err)); + + /* get all variables & check all values equal 42 */ + for (i = 0; i < numVars; i++) { + if (var_dimid[i][0] == RECDIM) continue; /* skip record variables */ + for (j = 0; j < var_nels[i]; j++) { + err = toMixedBase(j, var_rank[i], var_shape[i], index); + IF (err != 0) error("error in toMixedBase"); + if (var_type[i] == NC_CHAR) { + err = nc_get_var1_text(ncid, i, index, &text); + IF (err != NC_NOERR) + error("get_var1_text_all failed: %s", nc_strerror(err)); + value = text; + } else { + err = nc_get_var1_double(ncid, i, index, &value); + IF (err != NC_NOERR) + error("get_var1_double_all failed: %s", nc_strerror(err)); + } + IF (value != fill) + error(" %s Value expected: %g, read: %g\n", var_name[i],fill, value); + ELSE_NOK + } + } + + /* enter redef mode and add a new variable, check NC_ELATEFILL */ + err = nc_redef(ncid); + IF (err != NC_NOERR) + error("redef: %s", nc_strerror(err)); + + /* it is not allowed to define fill value when variable already exists */ + err = nc_def_var_fill(ncid, 0, 0, &value); + IF (err != NC_ELATEFILL) + error("redef: expect NC_ELATEFILL but got %s", nc_err_code_name(err)); + err = nc_def_var(ncid, "new_var", NC_INT, 0, NULL, &varid); + IF (err != NC_NOERR) + error("redef: %s", nc_strerror(err)); + err = nc_def_var_fill(ncid, varid, 0, &value); + IF (err != NC_NOERR) + error("def_var_fill: %s", nc_strerror(err)); + + err = nc_close(ncid); + IF (err != NC_NOERR) + error("close: %s", nc_strerror(err)); + err = nc_delete(scratch); + IF (err != NC_NOERR) + error("remove of %s failed", scratch); + + return nok; +} + + +/* This function gets the version of a netCDF file, 1 is for netCDF + classic, 2 for 64-bit offset format, (someday) 3 for HDF5 format, + 5 for 64-bit data format (CDF-5). +*/ +#define MAGIC_NUM_LEN 4 +static +int +nc_get_file_version(char *path, int *version) +{ + int fd; + ssize_t read_len; + char magic[MAGIC_NUM_LEN]; + + /* Need two valid pointers - check for NULL. */ + if (!version || !path) + return NC_EINVAL; + + /* Figure out if this is a netcdf or hdf5 file. */ + fd = open(path, O_RDONLY, 0600); + if (fd == -1) return errno; + + read_len = read(fd, magic, MAGIC_NUM_LEN); + if (-1 == close(fd)) return errno; + + if (read_len == -1) + return errno; + + if (read_len != MAGIC_NUM_LEN) { + printf("Error: reading NC magic string unexpected short read\n"); + return 0; + } + + if (strncmp(magic, "CDF", MAGIC_NUM_LEN-1)==0) { + if (magic[MAGIC_NUM_LEN-1] == NC_FORMAT_CLASSIC || + magic[MAGIC_NUM_LEN-1] == NC_FORMAT_64BIT_OFFSET +#ifdef ENABLE_CDF5 + || magic[MAGIC_NUM_LEN-1] == NC_FORMAT_CDF5 +#endif +) + *version = magic[MAGIC_NUM_LEN-1]; + else + return NC_ENOTNC; + } + /* tomorrow, tomorrow, I love you tomorrow, you're always a day + away! */ + /*if (magic[1] == 'H' && magic[2] == 'D' && magic[3] == 'F') + *version = 3;*/ + return NC_NOERR; +} + +/* + * Test nc_set_default_format + * try with bad default format + * try with NULL old_formatp + * try in data mode, check error + * check that proper set to NC_FILL works for record & non-record variables + * (note that it is not possible to test NC_NOFILL mode!) + * close file & create again for test using attribute _FillValue + */ +int +test_nc_set_default_format(void) +{ + int ncid, nok=0; + int err; + int i; + int version=1; + int old_format; + + /* bad format */ + err = nc_set_default_format(BAD_DEFAULT_FORMAT, &old_format); + IF (err != NC_EINVAL) + error("expecting NC_EINVAL but got %s", nc_err_code_name(err)); + ELSE_NOK + + /* NULL old_formatp */ + err = nc_set_default_format(NC_FORMAT_64BIT_OFFSET, NULL); + IF (err != NC_NOERR) + error("null old_fortmatp: status = %d", err); + ELSE_NOK + + /* Cycle through available formats. */ + + for(i=NC_FORMAT_CLASSIC; i