netcdf-c/ncdump/tst_dimsizes.c
Dennis Heimbigner d15f277252 The max dimension sizes do not take CDF-5 format into account.
NetCDF-c Github issue #185

The code in libsrc/dim.c has not been upgraded to support
CDF-5 format.

Rule we are implementing sets the max dimension sizes as follows:

Classic:	CDF-1	NC_MAX_INT - 3    = 2147483647 - 3
64 bit Offset:	CDF-2	NC_MAX_UINT - 3	  =  4294967295 - 3
64 bit Data:	CDF-5	NC_MAX_UINT64 - 3 = 18446744073709551615 - 3

The -3 is to handle rounding.
2016-01-05 21:26:25 -07:00

81 lines
2.7 KiB
C

#include <nc_tests.h>
#include <stdio.h>
#include <stdlib.h>
#include <netcdf.h>
#define FILECLASSIC "tst_dimsize_classic.nc"
#define FILE64OFFSET "tst_dimsize_64offset.nc"
#define FILE64DATA "tst_dimsize_64data.nc"
#define DIMMAXCLASSIC (NC_MAX_INT - 3)
#define DIMMAX64OFFSET (NC_MAX_UINT - 3)
#define DIMMAX64DATA (NC_MAX_UINT64 - 3)
/*
Test that at least the meta-data works
for dimension sizes X modes.
NC_CLASSIC => NC_INT_MAX - 3
NC_64BIT_OFFSET => NC_UINT_MAX - 3
NC_64BIT_DATA => NC_UINT64_MAX - 3
Note that this will not test the last case when
|size_t| == 4.
Also, leave the files around so we can test with ncdump.
*/
int
main(int argc, char **argv)
{
int ncid;
size_t dimsize;
int dimid;
int stat = NC_NOERR;
printf("\n*** Testing Max Dimension Sizes\n");
printf("\n|size_t|=%d\n",sizeof(size_t));
printf("\n*** Writing Max Dimension Size For NC_CLASSIC\n");
if ((stat=nc_create(FILECLASSIC, NC_CLOBBER, &ncid))) ERR;
dimsize = DIMMAXCLASSIC;
if ((stat=nc_def_dim(ncid, "testdim", dimsize, &dimid))) ERR;
if ((stat=nc_close(ncid))) ERR;
printf("\n*** Reading Max Dimension Size For NC_CLASSIC\n");
if ((stat=nc_open(FILECLASSIC, NC_NOCLOBBER, &ncid))) ERR;
if ((stat=nc_inq_dimid(ncid, "testdim", &dimid))) ERR;
if ((stat=nc_inq_dimlen(ncid, dimid, &dimsize))) ERR;
if(dimsize != DIMMAXCLASSIC) ERR;
if ((stat=nc_close(ncid))) ERR;
printf("\n*** Writing Max Dimension Size For NC_64BIT_OFFSET\n");
if ((stat=nc_create(FILE64OFFSET, NC_CLOBBER | NC_64BIT_OFFSET, &ncid))) ERR;
dimsize = DIMMAX64OFFSET;
if ((stat=nc_def_dim(ncid, "testdim", dimsize, &dimid))) ERR;
if ((stat=nc_close(ncid))) ERR;
printf("\n*** Reading Max Dimension Size For NC_64BIT_OFFSET\n");
if ((stat=nc_open(FILE64OFFSET, NC_NOCLOBBER|NC_64BIT_OFFSET, &ncid))) ERR;
if ((stat=nc_inq_dimid(ncid, "testdim", &dimid))) ERR;
if ((stat=nc_inq_dimlen(ncid, dimid, &dimsize))) ERR;
if(dimsize != DIMMAX64OFFSET) ERR;
if ((stat=nc_close(ncid))) ERR;
if(sizeof(size_t) == 8) {
printf("\n*** Writing Max Dimension Size For NC_64BIT_DATA\n");
if ((stat=nc_create(FILE64DATA, NC_CLOBBER | NC_64BIT_DATA, &ncid))) ERR;
dimsize = (size_t)DIMMAX64DATA;
if ((stat=nc_def_dim(ncid, "testdim", dimsize, &dimid))) ERR;
if ((stat=nc_close(ncid))) ERR;
printf("\n*** Reading Max Dimension Size For NC_64BIT_DATA\n");
if ((stat=nc_open(FILE64DATA, NC_NOCLOBBER|NC_64BIT_DATA, &ncid))) ERR;
if ((stat=nc_inq_dimid(ncid, "testdim", &dimid))) ERR;
if ((stat=nc_inq_dimlen(ncid, dimid, &dimsize))) ERR;
if(dimsize != DIMMAX64DATA) ERR;
if ((stat=nc_close(ncid))) ERR;
}
SUMMARIZE_ERR;
FINAL_RESULTS;
}