mirror of
https://github.com/Unidata/netcdf-c.git
synced 2025-01-12 15:45:21 +08:00
112 lines
3.6 KiB
C
112 lines
3.6 KiB
C
|
/*! \file
|
||
|
Functions for User-Defined Types
|
||
|
|
||
|
Copyright 2011 University Corporation for Atmospheric
|
||
|
Research/Unidata. See \ref copyright file for more info. */
|
||
|
|
||
|
#include "ncdispatch.h"
|
||
|
|
||
|
/** \internal
|
||
|
\ingroup user_types
|
||
|
Learn if two types are equal
|
||
|
|
||
|
\param ncid1 \ref ncid of first typeid.
|
||
|
\param typeid1 First typeid.
|
||
|
\param ncid2 \ref ncid of second typeid.
|
||
|
\param typeid2 Second typeid.
|
||
|
\param equal Pointer to int. A non-zero value will be copied here if
|
||
|
the two types are equal, a zero if they are not equal.
|
||
|
|
||
|
\returns ::NC_NOERR No error.
|
||
|
\returns ::NC_EBADID Bad \ref ncid.
|
||
|
\returns ::NC_EBADTYPE Bad type id.
|
||
|
\returns ::NC_ENOTNC4 Not an netCDF-4 file, or classic model enabled.
|
||
|
\returns ::NC_EHDFERR An error was reported by the HDF5 layer.
|
||
|
*/
|
||
|
int
|
||
|
nc_inq_type_equal(int ncid1, nc_type typeid1, int ncid2,
|
||
|
nc_type typeid2, int *equal)
|
||
|
{
|
||
|
NC* ncp1;
|
||
|
int stat = NC_check_id(ncid1,&ncp1);
|
||
|
if(stat != NC_NOERR) return stat;
|
||
|
return ncp1->dispatch->inq_type_equal(ncid1,typeid1,ncid2,typeid2,equal);
|
||
|
}
|
||
|
|
||
|
/** \name Learning about User-Defined Types
|
||
|
|
||
|
Functions to learn about any kind of user-defined type. */
|
||
|
/*! \{ */ /* All these functions are part of this named group... */
|
||
|
|
||
|
/** \ingroup user_types
|
||
|
|
||
|
Find a type by name. Given a group ID and a type name, find the ID of
|
||
|
the type. If the type is not found in the group, then the parents are
|
||
|
searched. If still not found, the entire file is searched.
|
||
|
|
||
|
\param ncid \ref ncid
|
||
|
\param name \ref object_name of type to search for.
|
||
|
\param typeidp Typeid of named type will be copied here, if it is
|
||
|
found.
|
||
|
|
||
|
\returns ::NC_NOERR No error.
|
||
|
\returns ::NC_EBADID Bad \ref ncid.
|
||
|
\returns ::NC_EBADTYPE Bad type id.
|
||
|
\returns ::NC_ENOTNC4 Not an netCDF-4 file, or classic model enabled.
|
||
|
\returns ::NC_EHDFERR An error was reported by the HDF5 layer.
|
||
|
*/
|
||
|
int
|
||
|
nc_inq_typeid(int ncid, const char *name, nc_type *typeidp)
|
||
|
{
|
||
|
NC* ncp;
|
||
|
int stat = NC_check_id(ncid,&ncp);
|
||
|
if(stat != NC_NOERR) return stat;
|
||
|
return ncp->dispatch->inq_typeid(ncid,name,typeidp);
|
||
|
}
|
||
|
|
||
|
/** \ingroup user_types
|
||
|
Learn about a user defined type.
|
||
|
|
||
|
Given an ncid and a typeid, get the information about a user defined
|
||
|
type. This function will work on any user defined type, whether
|
||
|
compound, opaque, enumeration, or variable length array.
|
||
|
|
||
|
\param ncid \ref ncid
|
||
|
|
||
|
\param xtype The typeid
|
||
|
|
||
|
\param name The \ref object_name will be copied here. \ref
|
||
|
ignored_if_null.
|
||
|
|
||
|
\param size the (in-memory) size of the type in bytes will be copied
|
||
|
here. VLEN type size is the size of nc_vlen_t. String size is returned
|
||
|
as the size of a character pointer. The size may be used to malloc
|
||
|
space for the data, no matter what the type. \ref ignored_if_null.
|
||
|
|
||
|
\param base_nc_typep The base type will be copied here for enum and
|
||
|
VLEN types. \ref ignored_if_null.
|
||
|
|
||
|
\param nfieldsp The number of fields will be copied here for enum and
|
||
|
compound types. \ref ignored_if_null.
|
||
|
|
||
|
\param classp Return the class of the user defined type, ::NC_VLEN,
|
||
|
::NC_OPAQUE, ::NC_ENUM, or ::NC_COMPOUND. \ref ignored_if_null.
|
||
|
|
||
|
\returns ::NC_NOERR No error.
|
||
|
\returns ::NC_EBADID Bad \ref ncid.
|
||
|
\returns ::NC_EBADTYPE Bad type id.
|
||
|
\returns ::NC_ENOTNC4 Not an netCDF-4 file, or classic model enabled.
|
||
|
\returns ::NC_EHDFERR An error was reported by the HDF5 layer.
|
||
|
*/
|
||
|
int
|
||
|
nc_inq_user_type(int ncid, nc_type xtype, char *name, size_t *size,
|
||
|
nc_type *base_nc_typep, size_t *nfieldsp, int *classp)
|
||
|
{
|
||
|
NC *ncp;
|
||
|
int stat = NC_check_id(ncid,&ncp);
|
||
|
if(stat != NC_NOERR) return stat;
|
||
|
return ncp->dispatch->inq_user_type(ncid, xtype, name, size,
|
||
|
base_nc_typep, nfieldsp, classp);
|
||
|
}
|
||
|
/*! \} */ /* End of named group ...*/
|