mirror of
https://github.com/Unidata/netcdf-c.git
synced 2024-12-27 08:49:16 +08:00
e4cb5c89a3
So, fixed the following: 1. Forgot to check for NC_FORMATX_PNETCDF case in one of the switches in NC_infermodel. 2. Accidentally turned on both the NC_64BIT_OFFSET and the NC_64BIT_DATA mode flags.
157 lines
4.4 KiB
C
157 lines
4.4 KiB
C
/*! \file
|
|
|
|
Copyright 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
|
2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014,
|
|
2015, 2016, 2017, 2018
|
|
University Corporation for Atmospheric Research/Unidata.
|
|
|
|
See \ref copyright file for more info.
|
|
|
|
*/
|
|
|
|
#include "config.h"
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <netcdf.h>
|
|
#include <netcdf_par.h>
|
|
|
|
#define ERR { \
|
|
if (err != exp_err) { \
|
|
printf("Error at %s line %d: %s\n", __FILE__, __LINE__, \
|
|
nc_strerror(err)); \
|
|
nerrs++; \
|
|
} \
|
|
}
|
|
|
|
static int default_format;
|
|
|
|
static const char*
|
|
formatstr(int format)
|
|
{
|
|
const char* str = NULL;
|
|
switch (format) {
|
|
case NC_FORMAT_CLASSIC: str="NC_FORMAT_CLASSIC"; break;
|
|
case NC_FORMAT_64BIT_OFFSET: str="NC_FORMAT_64BIT_OFFSET"; break;
|
|
case NC_FORMAT_64BIT_DATA: str="NC_FORMAT_64BIT_DATA"; break;
|
|
case NC_FORMAT_NETCDF4: str="NC_FORMAT_NETCDF4"; break;
|
|
case NC_FORMAT_NETCDF4_CLASSIC:
|
|
str="NC_FORMAT_NETCDF4_CLASSIC";break;
|
|
default: break;
|
|
}
|
|
return str;
|
|
}
|
|
|
|
|
|
static int
|
|
create_check_pnetcdf(char *fname, int cmode, int exp_format)
|
|
{
|
|
int nerrs=0, err, exp_err=NC_NOERR, ncid, format;
|
|
const char *exp_str;
|
|
|
|
#ifndef USE_PNETCDF
|
|
exp_err = NC_ENOTBUILT;
|
|
#endif
|
|
|
|
exp_str = formatstr(exp_format);
|
|
|
|
#ifndef ENABLE_CDF5
|
|
if (cmode & NC_64BIT_DATA) exp_err = NC_ENOTBUILT;
|
|
#endif
|
|
|
|
/* create a file */
|
|
cmode |= NC_CLOBBER;
|
|
err = nc_create_par(fname, cmode, MPI_COMM_WORLD, MPI_INFO_NULL, &ncid); ERR
|
|
if (exp_err == NC_ENOTBUILT) return 0;
|
|
|
|
err = nc_close(ncid); ERR
|
|
|
|
/* open the file and check its format */
|
|
err = nc_open(fname, NC_NOWRITE, &ncid); ERR
|
|
err = nc_inq_format(ncid, &format); ERR
|
|
if (format != exp_format) {
|
|
const char *f_str="", *d_str="";
|
|
f_str = formatstr(format);
|
|
d_str = formatstr(default_format);
|
|
|
|
printf("Error at %s line %d: default is %s and expect %s but got %s\n",
|
|
__FILE__, __LINE__, d_str, exp_str, f_str);
|
|
nerrs++;
|
|
}
|
|
err = nc_close(ncid); ERR
|
|
return nerrs;
|
|
}
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
char *fname="tst_default_format_pnetcdf.nc";
|
|
int err, exp_err=NC_NOERR, nerrs=0, ncid, cmode;
|
|
|
|
MPI_Init(&argc, &argv);
|
|
|
|
if (argc == 2) fname = argv[1];
|
|
|
|
default_format = NC_FORMAT_CLASSIC;
|
|
|
|
/* check illegal cmode */
|
|
cmode = NC_64BIT_OFFSET | NC_64BIT_DATA;
|
|
err = nc_create_par(fname, cmode, MPI_COMM_WORLD, MPI_INFO_NULL, &ncid);
|
|
if (err != NC_EINVAL) {
|
|
printf("Error at %s line %d: expect NC_EINVAL but got %d\n",
|
|
__FILE__, __LINE__, err);
|
|
nerrs++;
|
|
}
|
|
#ifdef USE_NETCDF4
|
|
/* check illegal cmode */
|
|
cmode = NC_NETCDF4 | NC_64BIT_OFFSET;
|
|
err = nc_create_par(fname, cmode, MPI_COMM_WORLD, MPI_INFO_NULL, &ncid);
|
|
if (err != NC_EINVAL) {
|
|
printf("Error at %s line %d: expect NC_EINVAL but got %d\n",
|
|
__FILE__, __LINE__, err);
|
|
nerrs++;
|
|
}
|
|
#endif
|
|
|
|
/* create a file in CDF1 format */
|
|
cmode = 0;
|
|
nerrs += create_check_pnetcdf(fname, cmode, NC_FORMAT_CLASSIC);
|
|
|
|
/* create a file in CDF2 format */
|
|
cmode = NC_64BIT_OFFSET;
|
|
nerrs += create_check_pnetcdf(fname, cmode, NC_FORMAT_64BIT_OFFSET);
|
|
|
|
#ifdef ENABLE_CDF5
|
|
/* create a file in CDF5 format */
|
|
cmode = NC_64BIT_DATA;
|
|
nerrs += create_check_pnetcdf(fname, cmode, NC_FORMAT_64BIT_DATA);
|
|
#endif
|
|
|
|
/* set default file format to NC_FORMAT_64BIT_OFFSET ------------------*/
|
|
default_format = NC_FORMAT_64BIT_OFFSET;
|
|
err = nc_set_default_format(default_format, NULL); ERR
|
|
|
|
/* create a file in default format */
|
|
cmode = 0;
|
|
nerrs += create_check_pnetcdf(fname, cmode, NC_FORMAT_64BIT_OFFSET);
|
|
|
|
#ifdef ENABLE_CDF5
|
|
/* create a file in CDF5 format (this should ignore default) */
|
|
cmode = NC_64BIT_DATA;
|
|
nerrs += create_check_pnetcdf(fname, cmode, NC_FORMAT_64BIT_DATA);
|
|
|
|
/* set default file format to NC_FORMAT_64BIT_DATA --------------------*/
|
|
default_format = NC_FORMAT_64BIT_DATA;
|
|
err = nc_set_default_format(default_format, NULL); ERR
|
|
|
|
/* create a file in default format */
|
|
cmode = 0;
|
|
nerrs += create_check_pnetcdf(fname, cmode, NC_FORMAT_64BIT_DATA);
|
|
#endif
|
|
|
|
/* create a file in CDF2 format (this should ignore default) */
|
|
cmode = NC_64BIT_OFFSET;
|
|
nerrs += create_check_pnetcdf(fname, cmode, NC_FORMAT_64BIT_OFFSET);
|
|
|
|
MPI_Finalize();
|
|
return (nerrs > 0);
|
|
}
|