Merge pull request #2724 from DennisHeimbigner/transientname.dmh

Modify PR 2655 to ensure transient types have names.
This commit is contained in:
Ward Fisher 2023-07-24 11:01:14 -06:00 committed by GitHub
commit db2519cf89
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
23 changed files with 86 additions and 50 deletions

View File

@ -7,6 +7,7 @@ This file contains a high-level description of this package's evolution. Release
## 4.9.3 - TBD
* Support HDF5 transient types when reading an HDF5 file. See [Github #2724](https://github.com/Unidata/netcdf-c/pull/2724).
* Suppress filters on variables with non-fixed-size types. See [Github #2716](https://github.com/Unidata/netcdf-c/pull/2716).
* Provide a single option to disable all network access and testing. See [Github #2708](https://github.com/Unidata/netcdf-c/pull/2708).
* Fix some problems with earthdata authorization and data access. See [Github #2709](https://github.com/Unidata/netcdf-c/pull/2709).

View File

@ -8,7 +8,7 @@ types:
v1_f1_t f1(2) ;
}; // v1_t
dimensions:
_Anonymous2 = 2 ;
_AnonymousDim2 = 2 ;
variables:
v1_t v1 ;
data:

View File

@ -8,7 +8,7 @@ types:
v1_f1_t f1(2) ;
}; // v1_t
dimensions:
_Anonymous2 = 2 ;
_AnonymousDim2 = 2 ;
variables:
v1_t v1 ;
}

View File

@ -5,12 +5,12 @@
xmlns="http://xml.opendap.org/ns/DAP/4.0#"
xmlns:dap="http://xml.opendap.org/ns/DAP/4.0#">
<Dimensions>
<Dimension name="_Anonymous2" size="2"/>
<Dimension name="_AnonymousDim2" size="2"/>
</Dimensions>
<Types>
<Structure name="v1">
<Seq name="f1" type="/v1_f1_t">
<Dim name="/_Anonymous2"/>
<Dim name="/_AnonymousDim2"/>
</Sequence>
</Structure>
<Structure name="v1_f1_base">

View File

@ -1,9 +1,9 @@
netcdf amsre_20060131v5 {
dimensions:
_Anonymous3 = 3 ;
_Anonymous6 = 6 ;
_AnonymousDim3 = 3 ;
_AnonymousDim6 = 6 ;
variables:
byte time_a(_Anonymous3, _Anonymous6) ;
byte time_a(_AnonymousDim3, _AnonymousDim6) ;
string time_a:Equator_Crossing_Time = "1:30 PM" ;
data:

View File

@ -8,7 +8,7 @@ types:
v1_f1_t f1(2) ;
}; // v1_t
dimensions:
_Anonymous2 = 2 ;
_AnonymousDim2 = 2 ;
variables:
v1_t v1 ;
data:

View File

@ -2,13 +2,13 @@ netcdf test_atomic_array {
types:
opaque(16) opaque16_t ;
dimensions:
_Anonymous1 = 1 ;
_Anonymous2 = 2 ;
_AnonymousDim1 = 1 ;
_AnonymousDim2 = 2 ;
variables:
ubyte vu8(_Anonymous1, _Anonymous2) ;
double vd(_Anonymous1) ;
string vs(_Anonymous1, _Anonymous1) ;
opaque16_t vo(_Anonymous1, _Anonymous1) ;
ubyte vu8(_AnonymousDim1, _AnonymousDim2) ;
double vd(_AnonymousDim1) ;
string vs(_AnonymousDim1, _AnonymousDim1) ;
opaque16_t vo(_AnonymousDim1, _AnonymousDim1) ;
// global attributes:
string :_dap4.ce = "/vu8[1][0:2:2];/vd[1];/vs[1][0];/vo[0][1]" ;

View File

@ -1,8 +1,8 @@
netcdf test_atomic_array {
dimensions:
_Anonymous3 = 3 ;
_AnonymousDim3 = 3 ;
variables:
short v16(_Anonymous3) ;
short v16(_AnonymousDim3) ;
// global attributes:
string :_dap4.ce = "/v16[0:1,3]" ;

View File

@ -1,8 +1,8 @@
netcdf test_atomic_array {
dimensions:
_Anonymous3 = 3 ;
_AnonymousDim3 = 3 ;
variables:
short v16(_Anonymous3) ;
short v16(_AnonymousDim3) ;
// global attributes:
string :_dap4.ce = "/v16[3,0:1]" ;

View File

@ -5,9 +5,9 @@ types:
Altocumulus = 7, Cirrostratus = 8, Cirrocumulus = 9, Cirrus = 10,
Missing = 127} ;
dimensions:
_Anonymous2 = 2 ;
_AnonymousDim2 = 2 ;
variables:
cloud_class_t primary_cloud(_Anonymous2) ;
cloud_class_t primary_cloud(_AnonymousDim2) ;
cloud_class_t primary_cloud:_FillValue = Missing ;
// global attributes:

View File

@ -1,8 +1,8 @@
netcdf test_one_vararray {
dimensions:
_Anonymous1 = 1 ;
_AnonymousDim1 = 1 ;
variables:
int t(_Anonymous1) ;
int t(_AnonymousDim1) ;
// global attributes:
string :_dap4.ce = "/t[1]" ;

View File

@ -1,8 +1,8 @@
netcdf test_one_vararray {
dimensions:
_Anonymous2 = 2 ;
_AnonymousDim2 = 2 ;
variables:
int t(_Anonymous2) ;
int t(_AnonymousDim2) ;
// global attributes:
string :_dap4.ce = "/t[0:1]" ;

View File

@ -2,10 +2,10 @@ netcdf test_opaque_array {
types:
opaque(16) opaque16_t ;
dimensions:
_Anonymous1 = 1 ;
_Anonymous2 = 2 ;
_AnonymousDim1 = 1 ;
_AnonymousDim2 = 2 ;
variables:
opaque16_t vo2(_Anonymous1, _Anonymous2) ;
opaque16_t vo2(_AnonymousDim1, _AnonymousDim2) ;
// global attributes:
string :_dap4.ce = "/vo2[1][0:1]" ;

View File

@ -5,9 +5,9 @@ types:
int y ;
}; // s_t
dimensions:
_Anonymous2 = 2 ;
_AnonymousDim2 = 2 ;
variables:
s_t s(_Anonymous2, _Anonymous2) ;
s_t s(_AnonymousDim2, _AnonymousDim2) ;
// global attributes:
string :_dap4.ce = "/s[0:2:3][0:1]" ;

View File

@ -8,7 +8,7 @@ types:
v1_f1_t f1(2) ;
}; // v1_t
dimensions:
_Anonymous2 = 2 ;
_AnonymousDim2 = 2 ;
variables:
v1_t v1 ;
data:

View File

@ -1,9 +1,9 @@
netcdf \2004050300_eta_211 {
dimensions:
record = UNLIMITED ; // (1 currently)
_Anonymous1 = 1 ;
_Anonymous4 = 4 ;
_Anonymous15 = 15 ;
_AnonymousDim1 = 1 ;
_AnonymousDim4 = 4 ;
_AnonymousDim15 = 15 ;
variables:
double reftime(record) ;
string reftime:units = "hours since 1992-1-1" ;
@ -11,7 +11,7 @@ variables:
double valtime(record) ;
string valtime:units = "hours since 1992-1-1" ;
string valtime:long_name = "valid time" ;
float Z_sfc(_Anonymous1, _Anonymous4, _Anonymous15) ;
float Z_sfc(_AnonymousDim1, _AnonymousDim4, _AnonymousDim15) ;
string Z_sfc:navigation = "nav" ;
float Z_sfc:_FillValue = -9999.006f ;
string Z_sfc:units = "gp m" ;

View File

@ -60,6 +60,7 @@ struct NCauth;
/** Struct to hold HDF5-specific info for the file. */
typedef struct NC_HDF5_FILE_INFO {
hid_t hdfid;
unsigned transientid; /* counter for transient ids */
NCURI* uri; /* Parse of the incoming path, if url */
#if defined(ENABLE_BYTERANGE)
int byterange;

View File

@ -27,6 +27,10 @@
#include "config.h"
#endif
#include <stdlib.h>
#include <stdint.h>
#include <stdio.h>
/* Support headers */
#include <netcdf.h>
#include <netcdf_filter.h>
@ -142,7 +146,7 @@ typedef const void* (*H5PL_get_plugin_info_proto)(void);
#define H5MM_realloc realloc
#endif
#ifndef H5MM_xfree
#define H5MM_xfree nullfree
#define H5MM_xfree(x) do{if((x)!=NULL) free(x);}while(0)
#endif
#ifndef H5_ATTR_UNUSED
#define H5_ATTR_UNUSED

View File

@ -1357,7 +1357,7 @@ makeAnonDim(NCD4parser* parser, const char* sizestr)
ret = parseLL(sizestr,&size);
if(ret) return NULL;
snprintf(name,NC_MAX_NAME,"/_Anonymous%lld",size);
snprintf(name,NC_MAX_NAME,"/_AnonymousDim%lld",size);
/* See if it exists already */
dim = lookupFQN(parser,name,NCD4_DIM);
if(dim == NULL) {/* create it */

View File

@ -245,9 +245,8 @@ get_type_info2(NC_GRP_INFO_T *h5_grp, hid_t datasetid, NC_TYPE_INFO_T **type_inf
if (type == NULL) {
/* If we still can't read the type, ignore it, it probably
* means this object is a reference */
if (read_type(h5_grp, native_typeid, ""))
if (read_type(h5_grp, native_typeid, NULL))
return NC_EBADTYPID;
if((type = nc4_rec_find_hdf_type(h5, native_typeid)))
*type_info = type;
}
@ -1979,7 +1978,7 @@ hdf5free(void* memory)
*
* @param grp Pointer to group info struct.
* @param hdf_typeid HDF5 type ID.
* @param type_name Pointer that gets the type name.
* @param type_name Pointer that gets the type name; NULL => anonymous
*
* @return ::NC_NOERR No error.
* @return ::NC_EBADID Bad ncid.
@ -1991,19 +1990,26 @@ hdf5free(void* memory)
static int
read_type(NC_GRP_INFO_T *grp, hid_t hdf_typeid, char *type_name)
{
NC_TYPE_INFO_T *type;
NC_HDF5_TYPE_INFO_T *hdf5_type;
NC_FILE_INFO_T *h5 = NULL;
NC_TYPE_INFO_T *type = NULL;
NC_HDF5_FILE_INFO_T *hdf5_info = NULL;
NC_HDF5_TYPE_INFO_T *hdf5_type = NULL;
H5T_class_t class;
hid_t native_typeid;
size_t type_size;
int nmembers;
int retval;
char transientname[NC_MAX_NAME];
assert(grp && type_name);
assert(grp);
LOG((4, "%s: type_name %s grp->hdr.name %s", __func__, type_name,
LOG((4, "%s: type_name %s grp->hdr.name %s", __func__, (type_name?type_name:"NULL"),
grp->hdr.name));
/* Get HDF5-specific object info. */
h5 = (NC_FILE_INFO_T *)grp->nc4_info;
hdf5_info = (NC_HDF5_FILE_INFO_T*)h5->format_file_info;
/* What is the class of this type, compound, vlen, etc. */
if ((class = H5Tget_class(hdf_typeid)) < 0)
return NC_EHDFERR;
@ -2021,6 +2027,20 @@ read_type(NC_GRP_INFO_T *grp, hid_t hdf_typeid, char *type_name)
return NC_EHDFERR;
LOG((5, "type_size %d", type_size));
if(type_name == NULL) {
/* This is a transient/anonymous type, so generate a name for it */
const char* suffix = NULL; /* class */
switch (class) {
case H5T_ENUM: suffix = "Enum"; break;
case H5T_COMPOUND: suffix = "Compound"; break;
case H5T_VLEN: suffix = "Vlen"; break;
case H5T_OPAQUE: suffix = "Opaque"; break;
default: suffix = "Unknown"; break;
}
snprintf(transientname,sizeof(transientname),"_Anonymous%s%u",suffix,++hdf5_info->transientid);
type_name = transientname;
}
/* Add to the list for this new type, and get a local pointer to it. */
if ((retval = nc4_type_list_add(grp, type_size, type_name, &type)))
return retval;

View File

@ -76,17 +76,14 @@ main()
printf("*** Checking accessing file through netCDF-4 API...");
{
int ncid, varid, enumid;
int i, ncid, varid, enumid;
complex read_z;
int num_types, class;
int *typeids;
nc_type base_nc_type;
char name[NC_MAX_NAME];
size_t size, nfields;
bool read_b;
int num_types;
nc_set_log_level(4);
nc_set_log_level(0); /* Report HDF5 errors */
if (nc_open(FILE_NAME, NC_NOWRITE, &ncid)) ERR;
/* Read known types */
@ -97,7 +94,15 @@ main()
typeids = (int*)malloc((size_t)num_types * sizeof(int));
if (nc_inq_typeids(ncid, NULL, typeids)) ERR;
if (nc_inq_user_type(ncid, typeids[0], name, &size, &base_nc_type, &nfields, &class)) ERR;
/* Verify transient names */
for(i=0;i<num_types;i++) {
if (nc_inq_user_type(ncid, typeids[i], name, NULL, NULL, NULL, NULL)) ERR;
if(strlen(name) == 0) {
fprintf(stderr,"Transient type has no name\n");
ERR;
}
fprintf(stderr,"type: %s\n",name);
}
free(typeids);
/* Verify that the dataset is present */

View File

@ -27,7 +27,10 @@ extern "C" {
#endif
#include "netcdf_filter_build.h"
#ifdef HAVE_BLOSC
#include "blosc.h"
#endif
#ifdef _MSC_VER
#ifdef DLL_EXPORT /* define when building the library */

View File

@ -1,7 +1,9 @@
#ifndef H5ZSTD_H
#define H5ZSTD_H
#ifdef HAVE_ZSTD
#include "zstd.h"
#endif
#ifdef _MSC_VER
#ifdef DLL_EXPORT /* define when building the library */