/* Copyright 2018, UCAR/Unidata See netcdf/COPYRIGHT file for copying * and redistribution conditions.*/ /** * @file @internal HDF4 functions. * * @author Ed Hartnett */ #include "config.h" #include "nc4internal.h" #include "hdf4dispatch.h" #include /** * @internal Get the format (i.e. NC_FORMAT_NC_HDF4) of an open HDF4 * file. * * @param ncid File ID (ignored). * @param formatp Pointer that gets the constant indicating format. * @return ::NC_NOERR No error. * @return ::NC_EBADID Bad ncid. * @author Ed Hartnett */ int NC_HDF4_inq_format(int ncid, int *formatp) { /* HDF4 is the format. */ if (formatp) *formatp = NC_FORMATX_NC_HDF4; return NC_NOERR; } /** * @internal Return the extended format (i.e. the dispatch model), * plus the mode associated with an open file. * * @param ncid File ID. * @param formatp a pointer that gets the extended format. HDF4 files * will always get NC_FORMATX_NC_HDF4. * @param modep a pointer that gets the open/create mode associated with * this file. Ignored if NULL. * @return ::NC_NOERR No error. * @return ::NC_EBADID Bad ncid. * @author Ed Hartnett */ int NC_HDF4_inq_format_extended(int ncid, int *formatp, int *modep) { NC *nc; NC_HDF5_FILE_INFO_T* h5; LOG((2, "%s: ncid 0x%x", __func__, ncid)); if (!(nc = nc4_find_nc_file(ncid, &h5))) return NC_EBADID; if (modep) *modep = (nc->mode|NC_NETCDF4); if (formatp) *formatp = NC_FORMATX_NC_HDF4; return NC_NOERR; }