[svn-r20513] Description:
Correct several problems with compound datatypes that don't have any
fields added:
- Change assertion to error report when a file is encountered which has this
situation.
- Added check to attribute creation to avoid creating attributes with a
datatype like this (datasets and named datatypes already have the check)
Tested on:
FreeBSD/32 6.3 (duty) in debug mode
FreeBSD/64 6.3 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (jam) w/PGI compilers, w/default API=1.8.x,
w/C++ & FORTRAN, w/threadsafe, in debug mode
Linux/64-amd64 2.6 (amani) w/Intel compilers, w/default API=1.6.x,
w/C++ & FORTRAN, in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, w/threadsafe, in production mode
Linux/PPC 2.6 (heiwa) w/C++ & FORTRAN, w/threadsafe, in debug mode
2011-04-16 03:06:38 +08:00
|
|
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
|
|
* Copyright by The HDF Group. *
|
|
|
|
* All rights reserved. *
|
|
|
|
* *
|
|
|
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
|
|
* terms governing use, modification, and redistribution, is contained in *
|
2017-04-18 03:32:16 +08:00
|
|
|
* the COPYING file, which can be found at the root of the source code *
|
2021-02-17 22:52:04 +08:00
|
|
|
* distribution tree, or in https://www.hdfgroup.org/licenses. *
|
2017-04-18 03:32:16 +08:00
|
|
|
* If you do not have access to either file, you may request a copy from *
|
|
|
|
* help@hdfgroup.org. *
|
[svn-r20513] Description:
Correct several problems with compound datatypes that don't have any
fields added:
- Change assertion to error report when a file is encountered which has this
situation.
- Added check to attribute creation to avoid creating attributes with a
datatype like this (datasets and named datatypes already have the check)
Tested on:
FreeBSD/32 6.3 (duty) in debug mode
FreeBSD/64 6.3 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (jam) w/PGI compilers, w/default API=1.8.x,
w/C++ & FORTRAN, w/threadsafe, in debug mode
Linux/64-amd64 2.6 (amani) w/Intel compilers, w/default API=1.6.x,
w/C++ & FORTRAN, in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, w/threadsafe, in production mode
Linux/PPC 2.6 (heiwa) w/C++ & FORTRAN, w/threadsafe, in debug mode
2011-04-16 03:06:38 +08:00
|
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Purpose: This program is run to generate an HDF5 data file with objects
|
|
|
|
* that use compound datatypes with no fields (now forbidden to
|
|
|
|
* be created by the library, as of v1.4.x). It must be built/run
|
|
|
|
* with a copy of the 1.2.x library.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
#include "hdf5.h"
|
|
|
|
|
|
|
|
#define FILENAME "bad_compound.h5"
|
|
|
|
|
2020-09-30 22:27:10 +08:00
|
|
|
int
|
2023-06-19 13:13:38 +08:00
|
|
|
main(void)
|
[svn-r20513] Description:
Correct several problems with compound datatypes that don't have any
fields added:
- Change assertion to error report when a file is encountered which has this
situation.
- Added check to attribute creation to avoid creating attributes with a
datatype like this (datasets and named datatypes already have the check)
Tested on:
FreeBSD/32 6.3 (duty) in debug mode
FreeBSD/64 6.3 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (jam) w/PGI compilers, w/default API=1.8.x,
w/C++ & FORTRAN, w/threadsafe, in debug mode
Linux/64-amd64 2.6 (amani) w/Intel compilers, w/default API=1.6.x,
w/C++ & FORTRAN, in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, w/threadsafe, in production mode
Linux/PPC 2.6 (heiwa) w/C++ & FORTRAN, w/threadsafe, in debug mode
2011-04-16 03:06:38 +08:00
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
hid_t file;
|
|
|
|
hid_t cmpd_dt;
|
|
|
|
hid_t sid;
|
|
|
|
hid_t did;
|
|
|
|
hid_t aid;
|
|
|
|
hid_t gid;
|
|
|
|
hsize_t dim = 1;
|
|
|
|
herr_t ret;
|
[svn-r20513] Description:
Correct several problems with compound datatypes that don't have any
fields added:
- Change assertion to error report when a file is encountered which has this
situation.
- Added check to attribute creation to avoid creating attributes with a
datatype like this (datasets and named datatypes already have the check)
Tested on:
FreeBSD/32 6.3 (duty) in debug mode
FreeBSD/64 6.3 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (jam) w/PGI compilers, w/default API=1.8.x,
w/C++ & FORTRAN, w/threadsafe, in debug mode
Linux/64-amd64 2.6 (amani) w/Intel compilers, w/default API=1.6.x,
w/C++ & FORTRAN, in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, w/threadsafe, in production mode
Linux/PPC 2.6 (heiwa) w/C++ & FORTRAN, w/threadsafe, in debug mode
2011-04-16 03:06:38 +08:00
|
|
|
|
|
|
|
/* Create compound datatype, but don't insert fields */
|
|
|
|
cmpd_dt = H5Tcreate(H5T_COMPOUND, (size_t)8);
|
|
|
|
assert(cmpd_dt > 0);
|
|
|
|
|
|
|
|
/* Create File */
|
|
|
|
file = H5Fcreate(FILENAME, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT);
|
|
|
|
assert(file > 0);
|
|
|
|
|
|
|
|
/* Create a dataspace to use */
|
|
|
|
sid = H5Screate_simple(1, &dim, NULL);
|
|
|
|
assert(sid > 0);
|
|
|
|
|
|
|
|
/* Create a dataset with the bad compound datatype */
|
|
|
|
did = H5Dcreate(file, "dataset", cmpd_dt, sid, H5P_DEFAULT);
|
|
|
|
assert(did > 0);
|
|
|
|
|
|
|
|
/* Create a group */
|
|
|
|
gid = H5Gcreate(file, "group", (size_t)0);
|
|
|
|
assert(gid > 0);
|
|
|
|
|
|
|
|
/* Create an attribute with the bad compound datatype */
|
|
|
|
aid = H5Acreate(gid, "attr", cmpd_dt, sid, H5P_DEFAULT);
|
|
|
|
assert(aid > 0);
|
|
|
|
|
2020-04-21 07:12:00 +08:00
|
|
|
/* Commit the datatype */
|
[svn-r20513] Description:
Correct several problems with compound datatypes that don't have any
fields added:
- Change assertion to error report when a file is encountered which has this
situation.
- Added check to attribute creation to avoid creating attributes with a
datatype like this (datasets and named datatypes already have the check)
Tested on:
FreeBSD/32 6.3 (duty) in debug mode
FreeBSD/64 6.3 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (jam) w/PGI compilers, w/default API=1.8.x,
w/C++ & FORTRAN, w/threadsafe, in debug mode
Linux/64-amd64 2.6 (amani) w/Intel compilers, w/default API=1.6.x,
w/C++ & FORTRAN, in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, w/threadsafe, in production mode
Linux/PPC 2.6 (heiwa) w/C++ & FORTRAN, w/threadsafe, in debug mode
2011-04-16 03:06:38 +08:00
|
|
|
ret = H5Tcommit(file, "cmpnd", cmpd_dt);
|
|
|
|
assert(ret >= 0);
|
|
|
|
|
|
|
|
/* Close IDs */
|
|
|
|
ret = H5Gclose(gid);
|
|
|
|
assert(ret >= 0);
|
|
|
|
ret = H5Aclose(aid);
|
|
|
|
assert(ret >= 0);
|
|
|
|
ret = H5Sclose(sid);
|
|
|
|
assert(ret >= 0);
|
|
|
|
ret = H5Dclose(did);
|
|
|
|
assert(ret >= 0);
|
|
|
|
ret = H5Tclose(cmpd_dt);
|
|
|
|
assert(ret >= 0);
|
|
|
|
ret = H5Fclose(file);
|
|
|
|
assert(ret >= 0);
|
|
|
|
|
2020-09-30 22:27:10 +08:00
|
|
|
return (0);
|
[svn-r20513] Description:
Correct several problems with compound datatypes that don't have any
fields added:
- Change assertion to error report when a file is encountered which has this
situation.
- Added check to attribute creation to avoid creating attributes with a
datatype like this (datasets and named datatypes already have the check)
Tested on:
FreeBSD/32 6.3 (duty) in debug mode
FreeBSD/64 6.3 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (jam) w/PGI compilers, w/default API=1.8.x,
w/C++ & FORTRAN, w/threadsafe, in debug mode
Linux/64-amd64 2.6 (amani) w/Intel compilers, w/default API=1.6.x,
w/C++ & FORTRAN, in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, w/threadsafe, in production mode
Linux/PPC 2.6 (heiwa) w/C++ & FORTRAN, w/threadsafe, in debug mode
2011-04-16 03:06:38 +08:00
|
|
|
}
|