mirror of
https://github.com/Unidata/netcdf-c.git
synced 2025-01-12 15:45:21 +08:00
d15f277252
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.
81 lines
2.7 KiB
C
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;
|
|
}
|