#ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include "netcdf.h" #include "nclist.h" #include "zincludes.h" #include "test_utils.h" #undef DEBUG static void nccheck(int ret, int lineno) { if(ret == NC_NOERR) return; ncz_report(ret,lineno); } #define NCCHECK(err) nccheck(err,__LINE__) int main(int argc, char *argv[] ) { int err, ncid, varid, dimid[1]; size_t dimlen[1]; float *fdat; int *idat; const char* filename = NULL; const char* varname = "f"; const char* dimname = "x"; size_t i; NCCHECK(getoptions(&argc,&argv)); if(options->op == Write) NCCHECK(verifyoptions(options)); filename = options->file; NCCHECK(err = nc_open(filename,NC_NETCDF4,&ncid)); NCCHECK(err = nc_inq_varid(ncid, varname, &varid)); NCCHECK(err = nc_inq_dimid(ncid, dimname, dimid)); NCCHECK(err = nc_inq_dim(ncid, dimid[0], NULL, dimlen)); /* Make room for both double and floating dat */ fdat = (float *)calloc(1,sizeof(float) * dimlen[0]); idat = (int *)calloc(1,sizeof(int) * dimlen[0]); NCCHECK(err = nc_get_var_int(ncid, varid, idat)); NCCHECK(err = nc_get_var_float(ncid, varid, fdat)); #ifdef DEBUG printf("int[0..%d]:",(int)dimlen[0]); for(i=0; i