mirror of
https://github.com/Unidata/netcdf-c.git
synced 2025-01-06 15:34:44 +08:00
231ae96c4b
* re: https://github.com/Unidata/netcdf-c/pull/2278 * re: https://github.com/Unidata/netcdf-c/issues/2485 * re: https://github.com/Unidata/netcdf-c/issues/2474 This PR subsumes PR https://github.com/Unidata/netcdf-c/pull/2278. Actually is a bit an omnibus covering several issues. ## PR https://github.com/Unidata/netcdf-c/pull/2278 Add support for the Zarr string type. Zarr strings are restricted currently to be of fixed size. The primary issue to be addressed is to provide a way for user to specify the size of the fixed length strings. This is handled by providing the following new attributes special: 1. **_nczarr_default_maxstrlen** — This is an attribute of the root group. It specifies the default maximum string length for string types. If not specified, then it has the value of 64 characters. 2. **_nczarr_maxstrlen** — This is a per-variable attribute. It specifies the maximum string length for the string type associated with the variable. If not specified, then it is assigned the value of **_nczarr_default_maxstrlen**. This PR also requires some hacking to handle the existing netcdf-c NC_CHAR type, which does not exist in zarr. The goal was to choose numpy types for both the netcdf-c NC_STRING type and the netcdf-c NC_CHAR type such that if a pure zarr implementation read them, it would still work and an NC_CHAR type would be handled by zarr as a string of length 1. For writing variables and NCZarr attributes, the type mapping is as follows: * "|S1" for NC_CHAR. * ">S1" for NC_STRING && MAXSTRLEN==1 * ">Sn" for NC_STRING && MAXSTRLEN==n Note that it is a bit of a hack to use endianness, but it should be ok since for string/char, the endianness has no meaning. For reading attributes with pure zarr (i.e. with no nczarr atribute types defined), they will always be interpreted as of type NC_CHAR. ## Issue: https://github.com/Unidata/netcdf-c/issues/2474 This PR partly fixes this issue because it provided more comprehensive support for Zarr attributes that are JSON valued expressions. This PR still does not address the problem in that issue where the _ARRAY_DIMENSION attribute is incorrectly set. Than can only be fixed by the creator of the datasets. ## Issue: https://github.com/Unidata/netcdf-c/issues/2485 This PR also fixes the scalar failure shown in this issue. It generally cleans up scalar handling. It also adds a note to the documentation describing that NCZarr supports scalars while Zarr does not and also how scalar interoperability is achieved. ## Misc. Other Changes 1. Convert the nczarr special attributes and keys to be all lower case. So "_NCZARR_ATTR" now used "_nczarr_attr. Support back compatibility for the upper case names. 2. Cleanup my too-clever-by-half handling of scalars in libnczarr.
502 lines
23 KiB
C
502 lines
23 KiB
C
/* Copyright 2018-2018 University Corporation for Atmospheric
|
|
Research/Unidata. */
|
|
/**
|
|
* @file
|
|
* @internal This header file contains macros, types and prototypes
|
|
* used to build and manipulate the netCDF metadata model.
|
|
*
|
|
* @author Ed Hartnett, Dennis Heimbigner, Ward Fisher
|
|
*/
|
|
|
|
#ifndef _NC4INTERNAL_
|
|
#define _NC4INTERNAL_
|
|
#include "netcdf.h"
|
|
|
|
#include "config.h"
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <ctype.h>
|
|
#include <string.h>
|
|
|
|
#include "nc_logging.h"
|
|
#include "ncindex.h"
|
|
#include "nc_provenance.h"
|
|
#include "nchashmap.h"
|
|
|
|
#include "netcdf_f.h"
|
|
#include "netcdf_mem.h"
|
|
#include "netcdf_filter.h"
|
|
#ifdef USE_PARALLEL
|
|
#include "netcdf_par.h"
|
|
#endif /* USE_PARALLEL */
|
|
|
|
/* Always needed */
|
|
#include "nc.h"
|
|
|
|
/** The file ID is stored in the first two bytes of ncid. */
|
|
#define FILE_ID_MASK (0xffff0000)
|
|
|
|
/** The group ID is stored in the last two bytes of ncid. */
|
|
#define GRP_ID_MASK (0x0000ffff)
|
|
|
|
/** File and group IDs are each 16 bits of the ncid. */
|
|
#define ID_SHIFT (16)
|
|
|
|
/* typedef enum {GET, PUT} NC_PG_T; */
|
|
/** These are the different objects that can be in our hash-lists. */
|
|
typedef enum {NCNAT, NCVAR, NCDIM, NCATT, NCTYP, NCFLD, NCGRP, NCFIL} NC_SORT;
|
|
|
|
/** The netCDF V2 error code. */
|
|
#define NC_V2_ERR (-1)
|
|
|
|
/** The name of the root group. */
|
|
#define NC_GROUP_NAME "/"
|
|
|
|
/** One mega-byte. */
|
|
#define MEGABYTE 1048576
|
|
|
|
/** The HDF5 ID for the szip filter. */
|
|
#define HDF5_FILTER_SZIP 4
|
|
|
|
#define X_SCHAR_MIN (-128) /**< Minimum signed char value. */
|
|
#define X_SCHAR_MAX 127 /**< Maximum signed char value. */
|
|
#define X_UCHAR_MAX 255U /**< Maximum unsigned char value. */
|
|
#define X_SHORT_MIN (-32768) /**< Minimum short value. */
|
|
#define X_SHRT_MIN X_SHORT_MIN /**< This alias is compatible with limits.h. */
|
|
#define X_SHORT_MAX 32767 /**< Maximum short value. */
|
|
#define X_SHRT_MAX X_SHORT_MAX /**< This alias is compatible with limits.h. */
|
|
#define X_USHORT_MAX 65535U /**< Maximum unsigned short value. */
|
|
#define X_USHRT_MAX X_USHORT_MAX /**< This alias is compatible with limits.h. */
|
|
#define X_INT_MIN (-2147483647-1) /**< Minimum int value. */
|
|
#define X_INT_MAX 2147483647 /**< Maximum int value. */
|
|
#define X_LONG_MIN X_INT_MIN /**< Minimum long value. */
|
|
#define X_LONG_MAX X_INT_MAX /**< Maximum long value. */
|
|
#define X_UINT_MAX 4294967295U /**< Maximum unsigned int value. */
|
|
#define X_INT64_MIN (-9223372036854775807LL-1LL) /**< Minimum int64 value. */
|
|
#define X_INT64_MAX 9223372036854775807LL /**< Maximum int64 value. */
|
|
#define X_UINT64_MAX 18446744073709551615ULL /**< Maximum unsigned int64 value. */
|
|
#ifdef _WIN32 /* Windows, of course, has to be a *little* different. */
|
|
#define X_FLOAT_MAX 3.402823466e+38f
|
|
#else
|
|
#define X_FLOAT_MAX 3.40282347e+38f /**< Maximum float value. */
|
|
#endif /* _WIN32 */
|
|
#define X_FLOAT_MIN (-X_FLOAT_MAX) /**< Minimum float value. */
|
|
#define X_DOUBLE_MAX 1.7976931348623157e+308 /**< Maximum double value. */
|
|
#define X_DOUBLE_MIN (-X_DOUBLE_MAX) /**< Minimum double value. */
|
|
|
|
/** This is the number of netCDF atomic types. */
|
|
#define NUM_ATOMIC_TYPES (NC_MAX_ATOMIC_TYPE + 1)
|
|
|
|
/** Number of parameters needed for ZLIB filter. */
|
|
#define CD_NELEMS_ZLIB 1
|
|
|
|
/** Get a pointer to the NC_FILE_INFO_T from dispatchdata field. */
|
|
#define NC4_DATA(nc) ((NC_FILE_INFO_T *)(nc)->dispatchdata)
|
|
|
|
/** Set a pointer to the NC_FILE_INFO_T in the dispatchdata field. */
|
|
#define NC4_DATA_SET(nc,data) ((nc)->dispatchdata = (void *)(data))
|
|
|
|
/* Reserved attribute flags: must be powers of 2. */
|
|
/** Hidden attributes; immutable and unreadable thru API. */
|
|
#define HIDDENATTRFLAG 1
|
|
|
|
/** Readonly attributes; readable, but immutable thru the API. */
|
|
#define READONLYFLAG 2
|
|
|
|
/** Subset of readonly flags; readable by name only thru the API. */
|
|
#define NAMEONLYFLAG 4
|
|
|
|
/** Per-variable attribute, as opposed to global */
|
|
#define VARFLAG 16
|
|
|
|
/** Boolean type, to make the code easier to read. */
|
|
typedef enum {NC_FALSE = 0, NC_TRUE = 1} nc_bool_t;
|
|
|
|
/* Forward declarations. */
|
|
struct NC_GRP_INFO;
|
|
struct NC_TYPE_INFO;
|
|
struct NCRCinfo;
|
|
|
|
/**
|
|
* This struct provides indexed Access to Meta-data objects. See the
|
|
* document docs/indexing.dox for detailed information.
|
|
*
|
|
* Basically it provides a common header and use NCindex instances
|
|
* instead of linked lists.
|
|
*
|
|
* WARNING: ALL OBJECTS THAT CAN BE INSERTED INTO AN NCindex MUST HAVE
|
|
* AN INSTANCE of NC_OBJ AS THE FIRST FIELD.
|
|
*/
|
|
typedef struct NC_OBJ
|
|
{
|
|
NC_SORT sort; /**< Type of object. */
|
|
char* name; /**< Name, assumed to be null terminated. */
|
|
size_t id; /**< This objects ID. */
|
|
} NC_OBJ;
|
|
|
|
/**
|
|
* This struct holds information about reserved attributes. These
|
|
* attributes cannot be created or read by the user (through the
|
|
* netCDF API). */
|
|
typedef struct NC_reservedatt
|
|
{
|
|
const char *name; /**< Name of the reserved attribute. */
|
|
int flags; /**< Flags that control handling of reserved attribute. */
|
|
} NC_reservedatt;
|
|
|
|
/** This is a struct to handle the dimension metadata. */
|
|
typedef struct NC_DIM_INFO
|
|
{
|
|
NC_OBJ hdr; /**< The hdr contains the name and ID. */
|
|
struct NC_GRP_INFO *container; /**< Pointer to containing group. */
|
|
size_t len; /**< Length of this dimension. */
|
|
nc_bool_t unlimited; /**< True if the dimension is unlimited */
|
|
nc_bool_t extended; /**< True if the dimension needs to be extended. */
|
|
nc_bool_t too_long; /**< True if len is too big to fit in local size_t. */
|
|
void *format_dim_info; /**< Pointer to format-specific dim info. */
|
|
struct NC_VAR_INFO *coord_var; /**< The coord var, if it exists. */
|
|
} NC_DIM_INFO_T;
|
|
|
|
/** This is a struct to handle the attribute metadata. */
|
|
typedef struct NC_ATT_INFO
|
|
{
|
|
NC_OBJ hdr; /**< The hdr contains the name and ID. */
|
|
struct NC_OBJ *container; /**< Pointer to containing group|var. */
|
|
int len; /**< Length of attribute data. */
|
|
nc_bool_t dirty; /**< True if attribute modified. */
|
|
nc_bool_t created; /**< True if attribute already created. */
|
|
nc_type nc_typeid; /**< NetCDF type of attribute's data. */
|
|
void *format_att_info; /**< Pointer to format-specific att info. */
|
|
void *data; /**< The attribute data. */
|
|
#ifdef SEPDATA
|
|
nc_vlen_t *vldata; /**< VLEN data (only used for vlen types). */
|
|
char **stdata; /**< String data (only for string type). */
|
|
#endif
|
|
} NC_ATT_INFO_T;
|
|
|
|
/** This is a struct to handle the var metadata. */
|
|
typedef struct NC_VAR_INFO
|
|
{
|
|
NC_OBJ hdr; /**< The hdr contains the name and ID. */
|
|
char *alt_name; /**< Used if name in dispatcher must be different from hdr.name. */
|
|
struct NC_GRP_INFO *container; /**< Pointer to containing group. */
|
|
size_t ndims; /**< Number of dims. */
|
|
int *dimids; /**< Dim IDs. */
|
|
NC_DIM_INFO_T **dim; /**< Pointer to array of NC_DIM_INFO_T. */
|
|
nc_bool_t is_new_var; /**< True if variable is newly created. */
|
|
nc_bool_t was_coord_var; /**< True if variable was a coordinate var, but either the dim or var has been renamed. */
|
|
nc_bool_t became_coord_var; /**< True if variable _became_ a coordinate var, because either the dim or var has been renamed. */
|
|
nc_bool_t fill_val_changed; /**< True if variable's fill value changes after it has been created. */
|
|
nc_bool_t attr_dirty; /**< True if variable's attributes are dirty and should be rewritten. */
|
|
nc_bool_t created; /**< Variable has already been created (_not_ that it was just created). */
|
|
nc_bool_t written_to; /**< True if variable has data written to it. */
|
|
struct NC_TYPE_INFO *type_info; /**< Contains info about the variable type. */
|
|
int atts_read; /**< If true, the atts have been read. */
|
|
nc_bool_t meta_read; /**< True if this vars metadata has been completely read. */
|
|
nc_bool_t coords_read; /**< True if this var has hidden coordinates att, and it has been read. */
|
|
NCindex *att; /**< List of NC_ATT_INFO_T. */
|
|
nc_bool_t no_fill; /**< True if no fill value is defined for var. */
|
|
void *fill_value; /**< Pointer to fill value, or NULL. */
|
|
size_t *chunksizes; /**< For chunked storage, an array (size ndims) of chunksizes. */
|
|
int storage; /**< Storage of this var, compact, contiguous, or chunked. */
|
|
int endianness; /**< What endianness for the var? */
|
|
int parallel_access; /**< Type of parallel access for I/O on variable (collective or independent). */
|
|
struct ChunkCache {
|
|
size_t size; /**< Size in bytes of the var chunk cache. */
|
|
size_t nelems; /**< Number of slots in var chunk cache. */
|
|
float preemption; /**< Chunk cache preemtion policy. */
|
|
} chunkcache;
|
|
int quantize_mode; /**< Quantize mode. NC_NOQUANTIZE is 0, and means no quantization. */
|
|
int nsd; /**< Number of significant digits if quantization is used, 0 if not. */
|
|
void *format_var_info; /**< Pointer to any binary format info. */
|
|
void* filters; /**< Record of the list of filters to be applied to var data; format dependent */
|
|
} NC_VAR_INFO_T;
|
|
|
|
/** This is a struct to handle the field metadata from a user-defined
|
|
* type. */
|
|
typedef struct NC_FIELD_INFO
|
|
{
|
|
NC_OBJ hdr; /**< The hdr contains the name and ID. */
|
|
nc_type nc_typeid; /**< The type of this field. */
|
|
size_t offset; /**< Offset in bytes of field. */
|
|
int ndims; /**< Number of dims. */
|
|
int *dim_size; /**< Dim sizes. */
|
|
void *format_field_info; /**< Pointer to any binary format info for field. */
|
|
} NC_FIELD_INFO_T;
|
|
|
|
/** This is a struct to handle metadata for a user-defined enum
|
|
* type. */
|
|
typedef struct NC_ENUM_MEMBER_INFO
|
|
{
|
|
char *name; /**< Name of member. */
|
|
void *value; /**< Value of member. */
|
|
} NC_ENUM_MEMBER_INFO_T;
|
|
|
|
/** This is a struct to handle metadata for a user-defined type. */
|
|
typedef struct NC_TYPE_INFO
|
|
{
|
|
NC_OBJ hdr; /**< The hdr contains the name and ID. */
|
|
struct NC_GRP_INFO *container; /**< Containing group */
|
|
unsigned rc; /**< Ref. count of objects using this type */
|
|
int endianness; /**< What endianness for the type? */
|
|
size_t size; /**< Size of the type in memory, in bytes */
|
|
nc_bool_t committed; /**< True when datatype is committed in the file */
|
|
nc_type nc_type_class; /**< NC_VLEN, NC_COMPOUND, NC_OPAQUE, NC_ENUM, NC_INT, NC_FLOAT, or NC_STRING. */
|
|
void *format_type_info; /**< HDF5-specific type info. */
|
|
|
|
/** Information for each type or class */
|
|
union {
|
|
struct {
|
|
NClist* enum_member; /**< <! NClist<NC_ENUM_MEMBER_INFO_T*> */
|
|
nc_type base_nc_typeid; /**< Typeid of the base type. */
|
|
} e; /**< Enum */
|
|
struct Fields {
|
|
NClist* field; /**< <! NClist<NC_FIELD_INFO_T*> */
|
|
int varsized; /**< <! 1 if this compound is variable sized; 0 if fixed size */
|
|
} c; /**< Compound */
|
|
struct {
|
|
nc_type base_nc_typeid; /**< Typeid of the base type. */
|
|
} v; /**< Variable-length. */
|
|
} u; /**< Union of structs, for each type/class. */
|
|
} NC_TYPE_INFO_T;
|
|
|
|
/** This holds information for one group. Groups reproduce with
|
|
* parthenogenesis. */
|
|
typedef struct NC_GRP_INFO
|
|
{
|
|
NC_OBJ hdr; /**< The hdr contains the name and ID. */
|
|
void *format_grp_info; /**< Pointer to binary format info for group. */
|
|
struct NC_FILE_INFO *nc4_info; /**< Pointer containing NC_FILE_INFO_T. */
|
|
struct NC_GRP_INFO *parent; /**< Pointer tp parent group. */
|
|
int atts_read; /**< True if atts have been read for this group. */
|
|
NCindex* children; /**< NCindex<struct NC_GRP_INFO*> */
|
|
NCindex* dim; /**< NCindex<NC_DIM_INFO_T> * */
|
|
NCindex* att; /**< NCindex<NC_ATT_INFO_T> * */
|
|
NCindex* type; /**< NCindex<NC_TYPE_INFO_T> * */
|
|
/* Note that this is the list of vars with position == varid */
|
|
NCindex* vars; /**< NCindex<NC_VAR_INFO_T> * */
|
|
} NC_GRP_INFO_T;
|
|
|
|
/* These constants apply to the flags field in the
|
|
* HDF5_FILE_INFO_T defined below. */
|
|
#define NC_INDEF 0x01 /**< in define mode, cleared by ncendef */
|
|
|
|
/** This is the metadata we need to keep track of for each
|
|
* netcdf-4/ file; used by libhdf5, libnczarr, and libdap4 */
|
|
|
|
typedef struct NC_FILE_INFO
|
|
{
|
|
NC_OBJ hdr;
|
|
NC *controller; /**< Pointer to containing NC. */
|
|
#ifdef USE_PARALLEL4
|
|
MPI_Comm comm; /**< Copy of MPI Communicator used to open the file. */
|
|
MPI_Info info; /**< Copy of MPI Information Object used to open the file. */
|
|
#endif
|
|
int cmode; /**< Create/Open mode for the file. */
|
|
int flags; /**< State transition flags . */
|
|
nc_bool_t parallel; /**< True if file is open for parallel access */
|
|
nc_bool_t redef; /**< True if redefining an existing file */
|
|
nc_bool_t no_attr_create_order; /**< True if the creation order tracking of attributes is disabled (netcdf-4 only) */
|
|
nc_bool_t no_dimscale_attach; /**< True if attaching dimscales to variables is disabled (netcdf-4 only) */
|
|
int fill_mode; /**< Fill mode for vars - Unused internally currently */
|
|
nc_bool_t no_write; /**< true if nc_open has mode NC_NOWRITE. */
|
|
NC_GRP_INFO_T *root_grp; /**< Pointer to root group. */
|
|
short next_nc_grpid; /**< Next available group ID. */
|
|
int next_typeid; /**< Next available type ID. */
|
|
int next_dimid; /**< Next available dim ID. */
|
|
/* Provide convenience vectors indexed by the object id. This
|
|
allows for direct conversion of e.g. an nc_type to the
|
|
corresponding NC_TYPE_INFO_T object. */
|
|
NClist *alldims; /**< List of all dims. */
|
|
NClist *alltypes; /**< List of all types. */
|
|
NClist *allgroups; /**< List of all groups, including root group. */
|
|
void *format_file_info; /**< Pointer to binary format info for file. */
|
|
NC4_Provenance provenance; /**< File provenence info. */
|
|
struct NC4_Memio
|
|
{
|
|
NC_memio memio; /**< What we sent to image_init and what comes back. */
|
|
int locked; /**< Do not copy and do not free. */
|
|
int persist; /**< Should file be persisted out on close? */
|
|
int inmemory; /**< NC_INMEMORY flag was set. */
|
|
int diskless; /**< NC_DISKLESS flag was set => inmemory. */
|
|
int created; /**< 1 => create, 0 => open. */
|
|
unsigned int imageflags; /**< for H5LTopen_file_image. */
|
|
size_t initialsize; /**< Initial size. */
|
|
void *udata; /**< Extra memory allocated in NC4_image_init. */
|
|
} mem;
|
|
} NC_FILE_INFO_T;
|
|
|
|
/* Collect global state info in one place */
|
|
typedef struct NCglobalstate {
|
|
int initialized;
|
|
char* tempdir; /* track a usable temp dir */
|
|
char* home; /* track $HOME */
|
|
char* cwd; /* track getcwd */
|
|
struct NCRCinfo* rcinfo; /* Currently only one rc file per session */
|
|
struct GlobalZarr { /* Zarr specific parameters */
|
|
char dimension_separator;
|
|
} zarr;
|
|
struct Alignment { /* H5Pset_alignment parameters */
|
|
int defined; /* 1 => threshold and alignment explicitly set */
|
|
int threshold;
|
|
int alignment;
|
|
} alignment;
|
|
struct ChunkCache chunkcache;
|
|
} NCglobalstate;
|
|
|
|
/** Variable Length Datatype struct in memory. Must be identical to
|
|
* HDF5 hvl_t. (This is only used for VL sequences, not VL strings,
|
|
* which are stored in char *'s) */
|
|
typedef struct
|
|
{
|
|
size_t len; /**< Length of VL data (in base type units) */
|
|
void *p; /**< Pointer to VL data */
|
|
} nc_hvl_t;
|
|
|
|
/* Misc functions */
|
|
extern int NC4_inq_atomic_type(nc_type typeid1, char *name, size_t *size);
|
|
extern int NC4_lookup_atomic_type(const char *name, nc_type* idp, size_t *sizep);
|
|
|
|
/* These functions convert between netcdf and HDF5 types. */
|
|
extern int nc4_get_typelen_mem(NC_FILE_INFO_T *h5, nc_type xtype, size_t *len);
|
|
extern int nc4_convert_type(const void *src, void *dest, const nc_type src_type,
|
|
const nc_type dest_type, const size_t len, int *range_error,
|
|
const void *fill_value, int strict_nc3, int quantize_mode,
|
|
int nsd);
|
|
|
|
/* These functions do HDF5 things. */
|
|
extern int nc4_reopen_dataset(NC_GRP_INFO_T *grp, NC_VAR_INFO_T *var);
|
|
extern int nc4_read_atts(NC_GRP_INFO_T *grp, NC_VAR_INFO_T *var);
|
|
|
|
/* Find items in the in-memory lists of metadata. */
|
|
extern int nc4_find_nc_grp_h5(int ncid, NC **nc, NC_GRP_INFO_T **grp,
|
|
NC_FILE_INFO_T **h5);
|
|
extern int nc4_find_grp_h5(int ncid, NC_GRP_INFO_T **grp, NC_FILE_INFO_T **h5);
|
|
extern int nc4_find_nc4_grp(int ncid, NC_GRP_INFO_T **grp);
|
|
extern int nc4_find_dim(NC_GRP_INFO_T *grp, int dimid, NC_DIM_INFO_T **dim,
|
|
NC_GRP_INFO_T **dim_grp);
|
|
extern int nc4_find_var(NC_GRP_INFO_T *grp, const char *name, NC_VAR_INFO_T **var);
|
|
extern int nc4_find_dim_len(NC_GRP_INFO_T *grp, int dimid, size_t **len);
|
|
extern int nc4_find_type(const NC_FILE_INFO_T *h5, int typeid1, NC_TYPE_INFO_T **type);
|
|
extern NC_TYPE_INFO_T *nc4_rec_find_named_type(NC_GRP_INFO_T *start_grp, char *name);
|
|
extern NC_TYPE_INFO_T *nc4_rec_find_equal_type(NC_GRP_INFO_T *start_grp, int ncid1,
|
|
NC_TYPE_INFO_T *type);
|
|
extern int nc4_find_nc_att(int ncid, int varid, const char *name, int attnum,
|
|
NC_ATT_INFO_T **att);
|
|
extern int nc4_find_grp_h5_var(int ncid, int varid, NC_FILE_INFO_T **h5,
|
|
NC_GRP_INFO_T **grp, NC_VAR_INFO_T **var);
|
|
extern int nc4_find_grp_att(NC_GRP_INFO_T *grp, int varid, const char *name,
|
|
int attnum, NC_ATT_INFO_T **att);
|
|
extern int nc4_get_typeclass(const NC_FILE_INFO_T *h5, nc_type xtype,
|
|
int *type_class);
|
|
|
|
/* Free various types */
|
|
extern int nc4_type_free(NC_TYPE_INFO_T *type);
|
|
|
|
/* These list functions add and delete vars, atts. */
|
|
extern int nc4_nc4f_list_add(NC *nc, const char *path, int mode);
|
|
extern int nc4_nc4f_list_del(NC_FILE_INFO_T *h5);
|
|
extern int nc4_file_list_add(int ncid, const char *path, int mode,
|
|
void **dispatchdata);
|
|
extern int nc4_file_list_get(int ncid, char **path, int *mode,
|
|
void **dispatchdata);
|
|
extern int nc4_file_list_del(int ncid);
|
|
extern int nc4_file_change_ncid(int ncid, unsigned short new_ncid_index);
|
|
extern int nc4_var_list_add(NC_GRP_INFO_T* grp, const char* name, int ndims,
|
|
NC_VAR_INFO_T **var);
|
|
extern int nc4_var_list_add2(NC_GRP_INFO_T* grp, const char* name,
|
|
NC_VAR_INFO_T **var);
|
|
extern int nc4_var_set_ndims(NC_VAR_INFO_T *var, int ndims);
|
|
extern int nc4_var_list_del(NC_GRP_INFO_T *grp, NC_VAR_INFO_T *var);
|
|
extern int nc4_dim_list_add(NC_GRP_INFO_T *grp, const char *name, size_t len,
|
|
int assignedid, NC_DIM_INFO_T **dim);
|
|
extern int nc4_dim_list_del(NC_GRP_INFO_T *grp, NC_DIM_INFO_T *dim);
|
|
extern int nc4_type_new(size_t size, const char *name, int assignedid,
|
|
NC_TYPE_INFO_T **type);
|
|
extern int nc4_type_list_add(NC_GRP_INFO_T *grp, size_t size, const char *name,
|
|
NC_TYPE_INFO_T **type);
|
|
extern int nc4_type_list_del(NC_GRP_INFO_T *grp, NC_TYPE_INFO_T *type);
|
|
extern int nc4_type_free(NC_TYPE_INFO_T *type);
|
|
extern int nc4_field_list_add(NC_TYPE_INFO_T* parent, const char *name,
|
|
size_t offset, nc_type xtype, int ndims,
|
|
const int *dim_sizesp);
|
|
extern int nc4_att_list_add(NCindex *list, const char *name, NC_ATT_INFO_T **att);
|
|
extern int nc4_att_list_del(NCindex *list, NC_ATT_INFO_T *att);
|
|
extern int nc4_grp_list_add(NC_FILE_INFO_T *h5, NC_GRP_INFO_T *parent, char *name,
|
|
NC_GRP_INFO_T **grp);
|
|
extern int nc4_build_root_grp(NC_FILE_INFO_T *h5);
|
|
extern int nc4_rec_grp_del(NC_GRP_INFO_T *grp);
|
|
extern int nc4_enum_member_add(NC_TYPE_INFO_T *type, size_t size, const char *name,
|
|
const void *value);
|
|
extern int nc4_att_free(NC_ATT_INFO_T *att);
|
|
|
|
/* Check and normalize names. */
|
|
extern int NC_check_name(const char *name);
|
|
extern int nc4_check_name(const char *name, char *norm_name);
|
|
extern int nc4_normalize_name(const char *name, char *norm_name);
|
|
extern int nc4_check_dup_name(NC_GRP_INFO_T *grp, char *norm_name);
|
|
|
|
/* Get the fill value for a var. */
|
|
extern int nc4_get_fill_value(NC_FILE_INFO_T *h5, NC_VAR_INFO_T *var, void **fillp);
|
|
|
|
/* Find default fill value for atomic type. */
|
|
extern int nc4_get_default_atomic_fill_value(nc_type, void *fill_value);
|
|
|
|
/* Find default fill value for any type */
|
|
extern int nc4_get_default_fill_value(NC_TYPE_INFO_T*, void *fill_value);
|
|
|
|
/* Get an att given pointers to file, group, and perhaps ver info. */
|
|
extern int nc4_get_att_ptrs(NC_FILE_INFO_T *h5, NC_GRP_INFO_T *grp, NC_VAR_INFO_T *var,
|
|
const char *name, nc_type *xtype, nc_type mem_type,
|
|
size_t *lenp, int *attnum, void *data);
|
|
|
|
/* Get variable/fixed size flag for type */
|
|
extern int NC4_inq_type_fixed_size(int ncid, nc_type xtype, int* isfixedsizep);
|
|
|
|
/* Close the file. */
|
|
extern int nc4_close_netcdf4_file(NC_FILE_INFO_T *h5, int abort, NC_memio *memio);
|
|
|
|
/* Compute default chunksizes */
|
|
extern int nc4_find_default_chunksizes2(NC_GRP_INFO_T *grp, NC_VAR_INFO_T *var);
|
|
extern int nc4_check_chunksizes(NC_GRP_INFO_T* grp, NC_VAR_INFO_T* var, const size_t* chunksizes);
|
|
|
|
/* HDF5 initialization/finalization */
|
|
extern int nc4_hdf5_initialized;
|
|
extern void nc4_hdf5_initialize(void);
|
|
extern void nc4_hdf5_finalize(void);
|
|
|
|
/* This is only included if --enable-logging is used for configure; it
|
|
prints info about the metadata to stderr. */
|
|
#ifdef LOGGING
|
|
extern int log_metadata_nc(NC_FILE_INFO_T *h5);
|
|
#endif
|
|
|
|
/** @internal Names of atomic types. */
|
|
extern const char* nc4_atomic_name[NUM_ATOMIC_TYPES];
|
|
|
|
/* Binary searcher for reserved attributes */
|
|
extern const NC_reservedatt* NC_findreserved(const char* name);
|
|
|
|
/* Global State Management */
|
|
extern NCglobalstate* NC_getglobalstate(void);
|
|
extern void NC_freeglobalstate(void);
|
|
|
|
/* Generic reserved Attributes */
|
|
#define NC_ATT_REFERENCE_LIST "REFERENCE_LIST"
|
|
#define NC_ATT_CLASS "CLASS"
|
|
#define NC_ATT_DIMENSION_LIST "DIMENSION_LIST"
|
|
#define NC_ATT_NAME "NAME"
|
|
#define NC_ATT_COORDINATES "_Netcdf4Coordinates" /*see hdf5internal.h:COORDINATES*/
|
|
#define NC_ATT_FORMAT "_Format"
|
|
#define NC_ATT_DIMID_NAME "_Netcdf4Dimid"
|
|
#define NC_ATT_FILLVALUE "_FillValue"
|
|
#define NC_ATT_NC3_STRICT_NAME "_nc3_strict"
|
|
#define NC_XARRAY_DIMS "_ARRAY_DIMENSIONS"
|
|
#define NC_ATT_CODECS "_Codecs"
|
|
#define NC_NCZARR_ATTR "_nczarr_attr"
|
|
#define NC_NCZARR_ATTR_UC "_NCZARR_ATTR"
|
|
#define NC_NCZARR_MAXSTRLEN_ATTR "_nczarr_maxstrlen"
|
|
#define NC_NCZARR_DEFAULT_MAXSTRLEN_ATTR "_nczarr_default_maxstrlen"
|
|
|
|
#endif /* _NC4INTERNAL_ */
|