2017-12-04 06:37:56 +08:00
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*
|
2018-12-07 05:56:42 +08:00
|
|
|
* Copyright 2018, University Corporation for Atmospheric
|
2017-12-04 06:37:56 +08:00
|
|
|
* Research. See netcdf-4/docs/COPYRIGHT file for copying and
|
|
|
|
* redistribution conditions.
|
|
|
|
*
|
|
|
|
* This file is part of netcdf-4, a netCDF-like interface for HDF5, or a
|
|
|
|
* HDF5 backend for netCDF, depending on your point of view.
|
|
|
|
*
|
2019-08-15 21:05:10 +08:00
|
|
|
* This file handles the inq_format functions.
|
2017-12-04 06:37:56 +08:00
|
|
|
*
|
|
|
|
* @author Ed Hartnett, Dennis Heimbigner
|
2019-02-19 20:56:30 +08:00
|
|
|
*/
|
2010-06-03 21:24:43 +08:00
|
|
|
|
|
|
|
#include "nc4internal.h"
|
2017-03-09 08:01:10 +08:00
|
|
|
#include "nc4dispatch.h"
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2017-11-22 23:21:24 +08:00
|
|
|
/**
|
2017-12-04 06:37:56 +08:00
|
|
|
* @internal Get the format (i.e. NC_FORMAT_NETCDF4 pr
|
2017-11-22 23:21:24 +08:00
|
|
|
* NC_FORMAT_NETCDF4_CLASSIC) of an open netCDF-4 file.
|
|
|
|
*
|
2017-12-04 06:37:56 +08:00
|
|
|
* @param ncid File ID (ignored).
|
|
|
|
* @param formatp Pointer that gets the constant indicating format.
|
2017-11-22 23:21:24 +08:00
|
|
|
|
2017-12-04 06:37:56 +08:00
|
|
|
* @return ::NC_NOERR No error.
|
|
|
|
* @return ::NC_EBADID Bad ncid.
|
|
|
|
* @author Ed Hartnett
|
2017-11-22 23:21:24 +08:00
|
|
|
*/
|
2010-06-03 21:24:43 +08:00
|
|
|
int
|
|
|
|
NC4_inq_format(int ncid, int *formatp)
|
|
|
|
{
|
2019-02-19 20:56:30 +08:00
|
|
|
NC_FILE_INFO_T *nc4_info;
|
|
|
|
int retval;
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2019-02-19 20:56:30 +08:00
|
|
|
LOG((2, "nc_inq_format: ncid 0x%x", ncid));
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2019-02-19 20:56:30 +08:00
|
|
|
if (!formatp)
|
|
|
|
return NC_NOERR;
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2019-02-19 20:56:30 +08:00
|
|
|
/* Find the file metadata. */
|
|
|
|
if ((retval = nc4_find_nc_grp_h5(ncid, NULL, NULL, &nc4_info)))
|
|
|
|
return retval;
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2019-02-19 20:56:30 +08:00
|
|
|
/* Check if classic NC3 rules are in effect for this file. */
|
|
|
|
if (nc4_info->cmode & NC_CLASSIC_MODEL)
|
|
|
|
*formatp = NC_FORMAT_NETCDF4_CLASSIC;
|
|
|
|
else
|
|
|
|
*formatp = NC_FORMAT_NETCDF4;
|
2010-06-03 21:24:43 +08:00
|
|
|
|
2019-02-19 20:56:30 +08:00
|
|
|
return NC_NOERR;
|
2010-06-03 21:24:43 +08:00
|
|
|
}
|
|
|
|
|
2017-11-22 23:21:24 +08:00
|
|
|
/**
|
2017-12-04 06:37:56 +08:00
|
|
|
* @internal Return the extended format (i.e. the dispatch model),
|
|
|
|
* plus the mode associated with an open file.
|
2017-11-22 23:21:24 +08:00
|
|
|
*
|
2017-12-04 06:37:56 +08:00
|
|
|
* @param ncid File ID (ignored).
|
|
|
|
* @param formatp a pointer that gets the extended format. Note that
|
2017-11-22 23:21:24 +08:00
|
|
|
* this is not the same as the format provided by nc_inq_format(). The
|
2019-09-18 10:27:43 +08:00
|
|
|
* extended format indicates the dispatch layer model. NetCDF-4 files
|
2018-02-08 21:20:58 +08:00
|
|
|
* will always get NC_FORMATX_NC4.
|
2017-12-04 06:37:56 +08:00
|
|
|
* @param modep a pointer that gets the open/create mode associated with
|
2017-11-22 23:21:24 +08:00
|
|
|
* this file. Ignored if NULL.
|
|
|
|
|
2017-12-04 06:37:56 +08:00
|
|
|
* @return ::NC_NOERR No error.
|
|
|
|
* @return ::NC_EBADID Bad ncid.
|
|
|
|
* @author Dennis Heimbigner
|
2017-11-22 23:21:24 +08:00
|
|
|
*/
|
2013-12-23 03:53:20 +08:00
|
|
|
int
|
|
|
|
NC4_inq_format_extended(int ncid, int *formatp, int *modep)
|
|
|
|
{
|
2019-02-19 20:56:30 +08:00
|
|
|
NC *nc;
|
|
|
|
int retval;
|
2013-12-23 03:53:20 +08:00
|
|
|
|
2019-02-19 20:56:30 +08:00
|
|
|
LOG((2, "%s: ncid 0x%x", __func__, ncid));
|
2013-12-23 03:53:20 +08:00
|
|
|
|
2019-02-19 20:56:30 +08:00
|
|
|
if ((retval = nc4_find_nc_grp_h5(ncid, &nc, NULL, NULL)))
|
|
|
|
return NC_EBADID;
|
2013-12-23 03:53:20 +08:00
|
|
|
|
2019-02-19 20:56:30 +08:00
|
|
|
if(modep)
|
|
|
|
*modep = nc->mode|NC_NETCDF4;
|
2013-12-23 03:53:20 +08:00
|
|
|
|
2019-02-19 20:56:30 +08:00
|
|
|
if (formatp)
|
|
|
|
*formatp = NC_FORMATX_NC_HDF5;
|
2018-02-08 21:20:58 +08:00
|
|
|
|
2019-02-19 20:56:30 +08:00
|
|
|
return NC_NOERR;
|
2013-12-23 03:53:20 +08:00
|
|
|
}
|