netcdf-c/nc_test/tst_global_fillval.c

72 lines
1.5 KiB
C
Raw Normal View History

/* This is part of the netCDF package. Copyright 2017 University
Corporation for Atmospheric Research/Unidata See COPYRIGHT file for
conditions of use. See www.unidata.ucar.edu for more info.
Test proper elatefill return when fillvalue is assigned outside of
the initial define.
Contributed by wkliao, see the following for more information:
* https://github.com/Unidata/netcdf-c/issues/388
* https://github.com/Unidata/netcdf-c/pull/389
Modified by Ed Hartnett, see:
https://github.com/Unidata/netcdf-c/issues/392
*/
#include "config.h"
#include <nc_tests.h>
#include "err_macros.h"
2017-10-07 02:58:49 +08:00
#define FILE_NAME "tst_global_fillval.nc"
int
main(int argc, char **argv)
{
printf("*** testing proper elatefill return...");
{
int n = 0;
int i;
int num_formats = 2;
int *formats = NULL;
/* Determine how many formats are in use. */
#ifdef USE_NETCDF4
num_formats++;
#endif
#ifdef USE_CDF5
num_formats++;
#endif
formats = malloc(sizeof(int)*(unsigned long)num_formats);
formats[n++] = 0;
formats[n++] = NC_64BIT_OFFSET;
2017-10-07 02:58:49 +08:00
#ifdef USE_CDF5
formats[n++] = NC_64BIT_DATA;
#endif
#ifdef USE_NETCDF4
formats[n++] = NC_NETCDF4;
formats[n++] = NC_CLASSIC_MODEL | NC_NETCDF4;
2017-10-07 02:58:49 +08:00
#endif
2017-12-05 05:11:06 +08:00
for (i = 0; i < num_formats; i++)
{
int ncid, cmode, fillv = 9;
cmode = NC_CLOBBER | formats[i];
if (nc_create(FILE_NAME, cmode, &ncid)) ERR;
if (nc_put_att_int(ncid, NC_GLOBAL, "_FillValue", NC_INT, 1, &fillv)) ERR;
if (nc_close(ncid)) ERR;
2017-03-30 05:43:45 +08:00
}
free(formats);
}
SUMMARIZE_ERR;
FINAL_RESULTS;
}