mirror of
https://github.com/Unidata/netcdf-c.git
synced 2025-01-18 15:55:12 +08:00
134 lines
4.9 KiB
Plaintext
134 lines
4.9 KiB
Plaintext
/** \file
|
|
Documentation of error handling.
|
|
|
|
\page Programming Notes
|
|
|
|
\section error_handling Error Handling
|
|
|
|
Each netCDF function returns an integer status value. Non-zero values
|
|
indicate error.
|
|
|
|
The nc_strerror function is available to convert a returned integer
|
|
error status into an error message string.
|
|
|
|
If the returned status value indicates an error, you may handle it in
|
|
any way desired, from printing an associated error message and exiting
|
|
to ignoring the error indication and proceeding (not
|
|
recommended!). For simplicity, the examples in this guide check the
|
|
error status and call a separate function, handle_err(), to handle any
|
|
errors. One possible definition of handle_err() can be found within
|
|
the documentation of nc_strerror().
|
|
|
|
Occasionally, low-level I/O errors may occur in a layer below the
|
|
netCDF library. For example, if a write operation causes you to exceed
|
|
disk quotas or to attempt to write to a device that is no longer
|
|
available, you may get an error from a layer below the netCDF library,
|
|
but the resulting write error will still be reflected in the returned
|
|
status value.
|
|
|
|
\page ignored_if_null Ignored if NULL
|
|
|
|
Many of the argurments of netCDF functions are pointers. For example,
|
|
the nc_inq() functions takes four pointers:
|
|
|
|
\code
|
|
int nc_inq(int ncid, int *ndimsp, int *nvarsp, int *nattsp, int *unlimdimidp);
|
|
\endcode
|
|
|
|
A NULL may be passed for any of these pointers, and it will be
|
|
ignored. For example, interested in the number of dimensions only, the
|
|
following code will work:
|
|
|
|
\code
|
|
int ndims;
|
|
...
|
|
if (nc_inq(ncid, &ndims, NULL, NULL, NULL))
|
|
return SOME_ERROR;
|
|
\endcode
|
|
|
|
\section Allocating Storage for the Result
|
|
|
|
User must allocate space for the result of an inq function before the
|
|
function is called.
|
|
|
|
\page specify_hyperslab Specify a Hyperslab
|
|
|
|
The NetCDF allows specification of hyperslabs to be read or written
|
|
with vectors which specify the start, count, stride, and mapping.
|
|
|
|
\section start_vector A Vector Specifying Start Index for Each Dimension
|
|
|
|
A vector of size_t integers specifying the index in the
|
|
variable where the first of the data values will be read.
|
|
|
|
The indices are relative to 0, so for example, the first data value of
|
|
a variable would have index (0, 0, ... , 0).
|
|
|
|
The length of start vector must be the same as the number of
|
|
dimensions of the specified variable. The elements of start
|
|
correspond, in order, to the variable's dimensions.
|
|
|
|
\section count_vector A Vector Specifying Count for Each Dimension
|
|
|
|
A vector of size_t integers specifying the edge lengths
|
|
along each dimension of the block of data values to be read.
|
|
|
|
To read a single value, for example, specify count as (1, 1, ... , 1).
|
|
|
|
The length of count is the number of dimensions of the specified
|
|
variable. The elements of count correspond, in order, to the
|
|
variable's dimensions.
|
|
|
|
Setting any element of the count array to zero causes the function to
|
|
exit without error, and without doing anything.
|
|
|
|
\section stride_vector A Vector Specifying Stride for Each Dimension
|
|
|
|
A vector of size_t integers specifying the interval between selected
|
|
indices.
|
|
|
|
A value of 1 accesses adjacent values of the netCDF variable in the
|
|
corresponding dimension; a value of 2 accesses every other value of
|
|
the netCDF variable in the corresponding dimension; and so on.
|
|
|
|
The elements of the stride vector correspond, in order, to the
|
|
variable's dimensions.
|
|
|
|
A NULL stride argument is treated as (1, 1, ... , 1).
|
|
|
|
\section map_vector A Vector Specifying Mapping for Each Dimension
|
|
|
|
A vector of integers that specifies the mapping between the dimensions
|
|
of a netCDF variable and the in-memory structure of the internal data
|
|
array.
|
|
|
|
imap[0] gives the distance between elements of the internal array
|
|
corresponding to the most slowly varying dimension of the netCDF
|
|
variable. imap[n-1] (where n is the rank of the netCDF variable) gives
|
|
the distance between elements of the internal array corresponding to
|
|
the most rapidly varying dimension of the netCDF variable. Intervening
|
|
imap elements correspond to other dimensions of the netCDF variable in
|
|
the obvious way. Distances between elements are specified in
|
|
type-independent units of elements.
|
|
|
|
\note The distance between internal elements that occupy adjacent
|
|
memory locations is 1 and not the element's byte-length as in netCDF
|
|
2.
|
|
|
|
\page ncid NetCDF ID
|
|
|
|
Most netCDF function require the netCDF ID as a first parameter.
|
|
|
|
In the netCDF classic model, the netCDF ID is associated with an open
|
|
file. Each file, when opened by nc_open(), or created by nc_create(),
|
|
is assigned an ncid, which it retains until nc_close() is called.
|
|
|
|
In the netCDF enhanced model, the ncid refers to a group with a
|
|
file. (Each file contains at least the root group, which is the ncid
|
|
that is returned by nc_open() and nc_create().)
|
|
|
|
For netCDF-4/HDF5 files, netCDF IDs can come not just from nc_open()
|
|
and nc_create(), but also from nc_def_grp(), nc_inq_grps(),
|
|
nc_inq_ncid(), nc_inq_grp_parent(), and nc_inq_grp_full_ncid().
|
|
|
|
*/ |