mirror of
https://github.com/Unidata/netcdf-c.git
synced 2024-12-15 08:30:11 +08:00
74 lines
1.6 KiB
C
74 lines
1.6 KiB
C
/* This is part of the netCDF package. Copyright 2018 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, Ward Fisher, see:
|
|
https://github.com/Unidata/netcdf-c/issues/392
|
|
*/
|
|
|
|
#include "config.h"
|
|
#include <nc_tests.h>
|
|
#include <stddef.h>
|
|
#include "err_macros.h"
|
|
|
|
#define FILE_NAME "tst_global_fillval.nc"
|
|
|
|
|
|
int
|
|
main(int argc, char **argv)
|
|
{
|
|
printf("*** testing proper elatefill return...");
|
|
{
|
|
|
|
int n = 0;
|
|
size_t i;
|
|
size_t num_formats = 2;
|
|
int *formats = NULL;
|
|
/* Determine how many formats are in use. */
|
|
|
|
#ifdef USE_HDF5
|
|
num_formats += 2;
|
|
#endif
|
|
|
|
#ifdef NETCDF_ENABLE_CDF5
|
|
num_formats++;
|
|
#endif
|
|
|
|
formats = malloc(sizeof(int)*num_formats);
|
|
|
|
|
|
formats[n++] = 0;
|
|
formats[n++] = NC_64BIT_OFFSET;
|
|
#ifdef NETCDF_ENABLE_CDF5
|
|
formats[n++] = NC_64BIT_DATA;
|
|
#endif
|
|
#ifdef USE_HDF5
|
|
formats[n++] = NC_NETCDF4;
|
|
formats[n++] = NC_CLASSIC_MODEL | NC_NETCDF4;
|
|
#endif
|
|
|
|
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;
|
|
|
|
}
|
|
free(formats);
|
|
}
|
|
|
|
SUMMARIZE_ERR;
|
|
FINAL_RESULTS;
|
|
}
|