netcdf-c/libsrc4/ncfunc.c

118 lines
2.6 KiB
C
Raw Normal View History

2010-06-03 21:24:43 +08:00
/*
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.
This file handles the nc_ calls, calling the appropriate nc3 or nc4
function, depending on ncid.
Copyright 2003, University Corporation for Atmospheric Research. See
netcdf-4/docs/COPYRIGHT file for copying and redistribution
conditions.
*/
#include "nc4internal.h"
2010-07-31 06:16:15 +08:00
#include "nc3dispatch.h"
2010-06-03 21:24:43 +08:00
2010-11-25 07:12:20 +08:00
#ifdef IGNORE
2010-06-03 21:24:43 +08:00
/* Keep a linked list of file info objects. */
extern NC_FILE_INFO_T *nc_file;
2010-11-25 07:12:20 +08:00
#endif
2010-06-03 21:24:43 +08:00
#ifdef IGNORE
/* This function deletes a member of parliment. Be careful! Last time
* this function was used, Labor got in! This function only does
* anything for netcdf-3 files. */
int
nc_delete(const char *path)
{
2010-07-31 06:16:15 +08:00
return NC3_delete_mp(path, 0);
2010-06-03 21:24:43 +08:00
}
int
nc_delete_mp(const char *path, int basepe)
{
2010-07-31 06:16:15 +08:00
return NC3_delete_mp(path, basepe);
2010-06-03 21:24:43 +08:00
}
#endif
/* This will return the length of a netcdf data type in bytes. Since
we haven't added any new types, I just call the v3 function.
Ed Hartnett 10/43/03
*/
/* This function only does anything for netcdf-3 files. */
int
NC4_set_base_pe(int ncid, int pe)
{
#if 0
NC *nc;
2010-06-03 21:24:43 +08:00
if (!(nc = nc4_find_nc_file(ncid)))
return NC_EBADID;
if (nc->nc4_info)
return NC_ENOTNC3;
2010-07-31 06:16:15 +08:00
return NC3_set_base_pe(nc->int_ncid, pe);
#else
return NC_ENOTNC3;
#endif
2010-06-03 21:24:43 +08:00
}
/* This function only does anything for netcdf-3 files. */
int
NC4_inq_base_pe(int ncid, int *pe)
{
#if 0
NC *nc;
2010-06-03 21:24:43 +08:00
if (!(nc = nc4_find_nc_file(ncid)))
return NC_EBADID;
if (nc->nc4_info)
return NC_ENOTNC3;
2010-07-31 06:16:15 +08:00
return NC3_inq_base_pe(nc->int_ncid, pe);
#else
return NC_ENOTNC3;
#endif
2010-06-03 21:24:43 +08:00
}
/* Get the format (i.e. classic, 64-bit-offset, or netcdf-4) of an
* open file. */
int
NC4_inq_format(int ncid, int *formatp)
{
NC *nc;
NC_HDF5_FILE_INFO_T* h5;
2010-06-03 21:24:43 +08:00
LOG((2, "nc_inq_format: ncid 0x%x", ncid));
if (!formatp)
return NC_NOERR;
/* Find the file metadata. */
if (!(nc = nc4_find_nc_file(ncid,&h5)))
2010-06-03 21:24:43 +08:00
return NC_EBADID;
#ifdef USE_PNETCDF
/* Take care of files created/opened with parallel-netcdf library. */
2013-01-18 10:25:12 +08:00
if (h5->pnetcdf_file)
return ncmpi_inq_format(nc->int_ncid, formatp);
#endif /* USE_PNETCDF */
#if 0
2010-06-03 21:24:43 +08:00
/* If this isn't a netcdf-4 file, pass this call on to the netcdf-3
* library. */
if (!nc->nc4_info)
2010-07-31 06:16:15 +08:00
return NC3_inq_format(nc->int_ncid, formatp);
#endif
2010-06-03 21:24:43 +08:00
/* Otherwise, this is a netcdf-4 file. Check if classic NC3 rules
* are in effect for this file. */
if (h5->cmode & NC_CLASSIC_MODEL)
2010-06-03 21:24:43 +08:00
*formatp = NC_FORMAT_NETCDF4_CLASSIC;
else
*formatp = NC_FORMAT_NETCDF4;
return NC_NOERR;
}