mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-03-31 17:10:47 +08:00
merge and fix
This commit is contained in:
commit
9be5b2842e
6
.gitattributes
vendored
6
.gitattributes
vendored
@ -216,10 +216,10 @@ java/src/hdf/hdf5lib/callbacks/H5D_iterate_cb.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5D_iterate_t.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5E_walk_cb.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5E_walk_t.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5L_iterate_cb.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5L_iterate_t.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5O_iterate_cb.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5L_iterate_opdata_t.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5O_iterate_t.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5O_iterate_opdata_t.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5P_cls_close_func_cb.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5P_cls_close_func_t.java -text
|
||||
java/src/hdf/hdf5lib/callbacks/H5P_cls_copy_func_cb.java -text
|
||||
@ -267,6 +267,8 @@ java/src/hdf/hdf5lib/structs/H5G_info_t.java -text
|
||||
java/src/hdf/hdf5lib/structs/H5L_info_t.java -text
|
||||
java/src/hdf/hdf5lib/structs/H5O_hdr_info_t.java -text
|
||||
java/src/hdf/hdf5lib/structs/H5O_info_t.java -text
|
||||
java/src/hdf/hdf5lib/structs/H5O_native_info_t.java -text
|
||||
java/src/hdf/hdf5lib/structs/H5O_token_t.java -text
|
||||
java/src/hdf/hdf5lib/structs/H5_ih_info_t.java -text
|
||||
java/src/hdf/overview.html -text
|
||||
java/src/jni/CMakeLists.txt -text
|
||||
|
9
MANIFEST
9
MANIFEST
@ -132,6 +132,7 @@
|
||||
./config/intel-flags
|
||||
./config/linux-gnu
|
||||
./config/linux-gnuaout
|
||||
./config/linux-gnueabihf
|
||||
./config/linux-gnulibc1
|
||||
./config/linux-gnulibc2
|
||||
./config/lt_vers.am
|
||||
@ -748,6 +749,7 @@
|
||||
./src/H5Ipublic.h
|
||||
./src/H5Itest.c
|
||||
./src/H5L.c
|
||||
./src/H5Ldeprec.c
|
||||
./src/H5Lexternal.c
|
||||
./src/H5Lmodule.h
|
||||
./src/H5Lpkg.h
|
||||
@ -938,6 +940,7 @@
|
||||
./src/H5VLnative_link.c
|
||||
./src/H5VLnative_introspect.c
|
||||
./src/H5VLnative_object.c
|
||||
./src/H5VLnative_token.c
|
||||
./src/H5VLnative_private.h
|
||||
./src/H5VLpassthru.c
|
||||
./src/H5VLpassthru.h
|
||||
@ -3044,10 +3047,10 @@
|
||||
./java/src/hdf/hdf5lib/callbacks/H5D_append_t.java
|
||||
./java/src/hdf/hdf5lib/callbacks/H5E_walk_cb.java
|
||||
./java/src/hdf/hdf5lib/callbacks/H5E_walk_t.java
|
||||
./java/src/hdf/hdf5lib/callbacks/H5L_iterate_cb.java
|
||||
./java/src/hdf/hdf5lib/callbacks/H5L_iterate_t.java
|
||||
./java/src/hdf/hdf5lib/callbacks/H5O_iterate_cb.java
|
||||
./java/src/hdf/hdf5lib/callbacks/H5L_iterate_opdata_t.java
|
||||
./java/src/hdf/hdf5lib/callbacks/H5O_iterate_t.java
|
||||
./java/src/hdf/hdf5lib/callbacks/H5O_iterate_opdata_t.java
|
||||
./java/src/hdf/hdf5lib/callbacks/H5P_cls_close_func_cb.java
|
||||
./java/src/hdf/hdf5lib/callbacks/H5P_cls_close_func_t.java
|
||||
./java/src/hdf/hdf5lib/callbacks/H5P_cls_copy_func_cb.java
|
||||
@ -3100,6 +3103,8 @@
|
||||
./java/src/hdf/hdf5lib/structs/H5L_info_t.java
|
||||
./java/src/hdf/hdf5lib/structs/H5O_hdr_info_t.java
|
||||
./java/src/hdf/hdf5lib/structs/H5O_info_t.java
|
||||
./java/src/hdf/hdf5lib/structs/H5O_native_info_t.java
|
||||
./java/src/hdf/hdf5lib/structs/H5O_token_t.java
|
||||
|
||||
./java/src/hdf/hdf5lib/H5.java
|
||||
./java/src/hdf/hdf5lib/HDF5Constants.java
|
||||
|
@ -90,7 +90,8 @@ sub print_checkoptions ($) {
|
||||
my $curr_idx; # Current API version index
|
||||
|
||||
# Print the option checking
|
||||
print $fh "\n/* Issue error if contradicting macros have been defined. */\n";
|
||||
print $fh "\n\n/* Issue error if contradicting macros have been defined. */\n";
|
||||
print $fh "/* (Can't use an older (deprecated) API version if deprecated symbols have been disabled) */\n";
|
||||
|
||||
# Print the #ifdef
|
||||
print $fh "#if (";
|
||||
@ -119,7 +120,30 @@ sub print_checkoptions ($) {
|
||||
##############################################################################
|
||||
# Print "global" API version macro settings
|
||||
#
|
||||
sub print_globalapivers ($) {
|
||||
sub print_globalapidefvers ($) {
|
||||
my $fh = shift; # File handle for output file
|
||||
my $curr_idx; # Current API version index
|
||||
|
||||
# Print the descriptive comment
|
||||
print $fh "\n\n/* If a particular default \"global\" version of the library's interfaces is\n";
|
||||
print $fh " * chosen, set the corresponding version macro for API symbols.\n";
|
||||
print $fh " *\n";
|
||||
print $fh " */\n";
|
||||
|
||||
for $curr_idx ($min_sup_idx .. ($max_idx - 1)) {
|
||||
# Print API version ifdef
|
||||
print $fh "\n#if defined(H5_USE_1", ($curr_idx * 2), "_API_DEFAULT) && !defined(H5_USE_1", ($curr_idx * 2), "_API)\n";
|
||||
# Print API version definition
|
||||
print $fh " " x $indent, "#define H5_USE_1", ($curr_idx * 2), "_API 1\n";
|
||||
# Print API version endif
|
||||
print $fh "#endif /* H5_USE_1", ($curr_idx * 2), "_API_DEFAULT && !H5_USE_1", ($curr_idx * 2), "_API */\n";
|
||||
}
|
||||
}
|
||||
|
||||
##############################################################################
|
||||
# Print "global" API symbol version macro settings
|
||||
#
|
||||
sub print_globalapisymbolvers ($) {
|
||||
my $fh = shift; # File handle for output file
|
||||
my $curr_idx; # Current API version index
|
||||
|
||||
@ -131,15 +155,6 @@ sub print_globalapivers ($) {
|
||||
print $fh " * API symbol, the individual API version macro takes priority.\n";
|
||||
print $fh " */\n";
|
||||
|
||||
for $curr_idx ($min_sup_idx .. ($max_idx - 1)) {
|
||||
# Print API version ifdef
|
||||
print $fh "#if defined(H5_USE_1", ($curr_idx * 2), "_API_DEFAULT) && !defined(H5_USE_1", ($curr_idx * 2), "_API)\n";
|
||||
# Print API version definition
|
||||
print $fh " " x $indent, "#define H5_USE_1", ($curr_idx * 2), "_API 1\n";
|
||||
# Print API version endif
|
||||
print $fh "#endif /* H5_USE_1", ($curr_idx * 2), "_API_DEFAULT && !H5_USE_1", ($curr_idx * 2), "_API */\n\n";
|
||||
}
|
||||
|
||||
# Loop over supported older library APIs and define the appropriate macros
|
||||
for $curr_idx ($min_sup_idx .. ($max_idx - 1)) {
|
||||
# Print API version ifdef
|
||||
@ -444,8 +459,9 @@ sub create_public ($) {
|
||||
print_copyright(*HEADER);
|
||||
print_warning(*HEADER);
|
||||
print_startprotect(*HEADER, $file);
|
||||
print_globalapidefvers(*HEADER);
|
||||
print_checkoptions(*HEADER);
|
||||
print_globalapivers(*HEADER);
|
||||
print_globalapisymbolvers(*HEADER);
|
||||
print_defaultapivers(*HEADER);
|
||||
print_endprotect(*HEADER, $file);
|
||||
|
||||
|
13
bin/trace
13
bin/trace
@ -71,6 +71,7 @@ $Source = "";
|
||||
"uint32_t" => "Iu",
|
||||
"uint64_t" => "UL",
|
||||
"H5I_type_t" => "It",
|
||||
"H5O_token_t" => "k",
|
||||
"H5G_link_t" => "Ll", #Same as H5L_type_t now
|
||||
"H5L_type_t" => "Ll",
|
||||
"MPI_Comm" => "Mc",
|
||||
@ -164,12 +165,18 @@ $Source = "";
|
||||
"H5I_search_func_t" => "x",
|
||||
"H5L_class_t" => "x",
|
||||
"H5L_elink_traverse_t" => "x",
|
||||
"H5L_iterate_t" => "x",
|
||||
"H5L_info1_t" => "x",
|
||||
"H5L_info2_t" => "x",
|
||||
"H5L_iterate1_t" => "x",
|
||||
"H5L_iterate2_t" => "x",
|
||||
"H5M_iterate_t" => 'x',
|
||||
"H5MM_allocate_t" => "x",
|
||||
"H5MM_free_t" => "x",
|
||||
"H5O_info_t" => "x",
|
||||
"H5O_iterate_t" => "x",
|
||||
"H5O_info1_t" => "x",
|
||||
"H5O_info2_t" => "x",
|
||||
"H5O_native_info_t" => "x",
|
||||
"H5O_iterate1_t" => "x",
|
||||
"H5O_iterate2_t" => "x",
|
||||
"H5O_mcdt_search_cb_t" => "x",
|
||||
"H5P_cls_create_func_t" => "x",
|
||||
"H5P_cls_copy_func_t" => "x",
|
||||
|
@ -36,7 +36,7 @@ const H5std_string FILE_NAME( "Group.h5" );
|
||||
const int RANK = 2;
|
||||
|
||||
// Operator function
|
||||
extern "C" herr_t file_info(hid_t loc_id, const char *name, const H5L_info_t *linfo,
|
||||
extern "C" herr_t file_info(hid_t loc_id, const char *name, const H5L_info2_t *linfo,
|
||||
void *opdata);
|
||||
|
||||
int main(void)
|
||||
@ -157,7 +157,7 @@ int main(void)
|
||||
* root directory.
|
||||
*/
|
||||
cout << endl << "Iterating over elements in the file" << endl;
|
||||
herr_t idx = H5Literate(file->getId(), H5_INDEX_NAME, H5_ITER_INC, NULL, file_info, NULL);
|
||||
herr_t idx = H5Literate2(file->getId(), H5_INDEX_NAME, H5_ITER_INC, NULL, file_info, NULL);
|
||||
cout << endl;
|
||||
|
||||
/*
|
||||
@ -175,7 +175,7 @@ int main(void)
|
||||
cout << "\"Data\" is unlinked" << endl;
|
||||
|
||||
cout << endl << "Iterating over elements in the file again" << endl;
|
||||
idx = H5Literate(file->getId(), H5_INDEX_NAME, H5_ITER_INC, NULL, file_info, NULL);
|
||||
idx = H5Literate2(file->getId(), H5_INDEX_NAME, H5_ITER_INC, NULL, file_info, NULL);
|
||||
cout << endl;
|
||||
|
||||
/*
|
||||
@ -219,7 +219,7 @@ int main(void)
|
||||
* Operator function.
|
||||
*/
|
||||
herr_t
|
||||
file_info(hid_t loc_id, const char *name, const H5L_info_t *linfo, void *opdata)
|
||||
file_info(hid_t loc_id, const char *name, const H5L_info2_t *linfo, void *opdata)
|
||||
{
|
||||
hid_t group;
|
||||
|
||||
|
@ -11493,7 +11493,7 @@ normal'><span style='font-size:14.0pt;mso-bidi-font-size:11.0pt;line-height:
|
||||
mso-border-top-alt:solid windowtext .5pt;mso-border-left-alt:solid windowtext .5pt;
|
||||
mso-border-alt:solid windowtext .5pt;padding:0in 5.4pt 0in 5.4pt'>
|
||||
<p class=MsoNormal style='margin-bottom:0in;margin-bottom:.0001pt;line-height:
|
||||
normal'>H5L_info_t getLinkInfo(const char* link_name,</p>
|
||||
normal'>H5L_info2_t getLinkInfo(const char* link_name,</p>
|
||||
<p class=MsoNormal style='margin-bottom:0in;margin-bottom:.0001pt;line-height:
|
||||
normal'><span style='mso-tab-count:1'> </span>const
|
||||
LinkAccPropList& lapl = LinkAccPropList::DEFAULT)</p>
|
||||
@ -11526,7 +11526,7 @@ normal'><span style='font-size:14.0pt;mso-bidi-font-size:11.0pt;line-height:
|
||||
mso-border-top-alt:solid windowtext .5pt;mso-border-left-alt:solid windowtext .5pt;
|
||||
mso-border-alt:solid windowtext .5pt;padding:0in 5.4pt 0in 5.4pt'>
|
||||
<p class=MsoNormal style='margin-bottom:0in;margin-bottom:.0001pt;line-height:
|
||||
normal'>H5L_info_t getLinkInfo(const H5std_string& link_name,</p>
|
||||
normal'>H5L_info2_t getLinkInfo(const H5std_string& link_name,</p>
|
||||
<p class=MsoNormal style='margin-bottom:0in;margin-bottom:.0001pt;line-height:
|
||||
normal'><span style='mso-tab-count:1'> </span>const
|
||||
LinkAccPropList& lapl = LinkAccPropList::DEFAULT)</p>
|
||||
|
@ -1403,6 +1403,121 @@ void H5Location::unlink(const H5std_string& name, const LinkAccPropList& lapl) c
|
||||
unlink(name.c_str(), lapl);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------
|
||||
// Function: H5Location::getNativeObjinfo
|
||||
///\brief Retrieves native information about an HDF5 object.
|
||||
///\param objinfo - OUT: Struct containing the native object info
|
||||
///\param fields - IN: Indicates the group of information to be retrieved
|
||||
///\par Description
|
||||
/// Valid values of \a fields are as follows:
|
||||
/// \li \c H5O_INFO_HDR (default)
|
||||
/// \li \c H5O_INFO_META_SIZE
|
||||
/// \li \c H5O_INFO_ALL
|
||||
// July, 2018
|
||||
//--------------------------------------------------------------------------
|
||||
void H5Location::getNativeObjinfo(H5O_native_info_t& objinfo, unsigned fields) const
|
||||
{
|
||||
|
||||
// Use C API to get information of the object
|
||||
herr_t ret_value = H5Oget_native_info(getId(), &objinfo, fields);
|
||||
|
||||
// Throw exception if C API returns failure
|
||||
if (ret_value < 0)
|
||||
throwException(inMemFunc("getNativeObjinfo"), "H5Oget_native_info failed");
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------
|
||||
// Function: H5Location::getNativeObjinfo
|
||||
///\brief Retrieves native information about an HDF5 object given its name.
|
||||
///\param name - IN: Name of the object to be queried - \c char *
|
||||
///\param objinfo - OUT: Struct containing the native object info
|
||||
///\param fields - IN: Indicates the group of information to be retrieved
|
||||
/// - default to H5O_INFO_HDR
|
||||
///\param lapl - IN: Link access property list
|
||||
///\par Description
|
||||
/// Valid values of \a fields are as follows:
|
||||
/// \li \c H5O_INFO_HDR (default)
|
||||
/// \li \c H5O_INFO_META_SIZE
|
||||
/// \li \c H5O_INFO_ALL
|
||||
// July, 2018
|
||||
//--------------------------------------------------------------------------
|
||||
void H5Location::getNativeObjinfo(const char* name, H5O_native_info_t& objinfo, unsigned fields, const LinkAccPropList& lapl) const
|
||||
{
|
||||
// Use C API to get information of the object
|
||||
herr_t ret_value = H5Oget_native_info_by_name(getId(), name, &objinfo, fields, lapl.getId());
|
||||
|
||||
// Throw exception if C API returns failure
|
||||
if (ret_value < 0)
|
||||
throwException(inMemFunc("getNativeObjinfo"), "H5Oget_native_info_by_name failed");
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------
|
||||
// Function: H5Location::getNativeObjinfo
|
||||
///\brief This is an overloaded member function, provided for convenience.
|
||||
/// It differs from the above function in that it takes
|
||||
/// a reference to an \c H5std_string for \a name.
|
||||
///\param name - IN: Name of the object to be queried - \c H5std_string
|
||||
///\param objinfo - OUT: Struct containing the native object info
|
||||
///\param fields - IN: Indicates the group of information to be retrieved
|
||||
/// - default to H5O_INFO_HDR
|
||||
///\param lapl - IN: Link access property list
|
||||
// July, 2018
|
||||
//--------------------------------------------------------------------------
|
||||
void H5Location::getNativeObjinfo(const H5std_string& name, H5O_native_info_t& objinfo, unsigned fields, const LinkAccPropList& lapl) const
|
||||
{
|
||||
getNativeObjinfo(name.c_str(), objinfo, fields, lapl);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------
|
||||
// Function: H5Location::getNativeObjinfo
|
||||
///\brief Retrieves native information about an HDF5 object given its index.
|
||||
///\param grp_name - IN: Group name where the object belongs - \c char *
|
||||
///\param idx_type - IN: Type of index
|
||||
///\param order - IN: Order to traverse
|
||||
///\param idx - IN: Object position
|
||||
///\param objinfo - OUT: Struct containing the native object info
|
||||
///\param fields - IN: Indicates the group of information to be retrieved
|
||||
/// - default to H5O_INFO_HDR
|
||||
///\param lapl - IN: Link access property list
|
||||
///\par Description
|
||||
/// Valid values of \a fields are as follows:
|
||||
/// \li \c H5O_INFO_HDR (default)
|
||||
/// \li \c H5O_INFO_META_SIZE
|
||||
/// \li \c H5O_INFO_ALL
|
||||
// July, 2018
|
||||
//--------------------------------------------------------------------------
|
||||
void H5Location::getNativeObjinfo(const char* grp_name, H5_index_t idx_type,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_native_info_t& objinfo, unsigned fields,
|
||||
const LinkAccPropList& lapl) const
|
||||
{
|
||||
// Use C API to get information of the object
|
||||
herr_t ret_value = H5Oget_native_info_by_idx(getId(), grp_name, idx_type, order,
|
||||
idx, &objinfo, fields, lapl.getId());
|
||||
|
||||
// Throw exception if C API returns failure
|
||||
if (ret_value < 0)
|
||||
throwException(inMemFunc("getNativeObjinfo"), "H5Oget_native_info_by_idx failed");
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------
|
||||
// Function: H5Location::getObjinfo
|
||||
///\brief This is an overloaded member function, provided for convenience.
|
||||
/// It differs from the above function in that it takes
|
||||
/// a reference to an \c H5std_string for \a name.
|
||||
///\param name - IN: Name of the object to be queried - \c H5std_string
|
||||
///\param objinfo - OUT: Struct containing the native object info
|
||||
///\param fields - IN: Indicates a group of information to be retrieved
|
||||
/// - default to H5O_INFO_HDR
|
||||
///\param lapl - IN: Link access property list
|
||||
// July, 2018
|
||||
//--------------------------------------------------------------------------
|
||||
void H5Location::getNativeObjinfo(const H5std_string& grp_name, H5_index_t idx_type,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_native_info_t& objinfo, unsigned fields,
|
||||
const LinkAccPropList& lapl) const
|
||||
{
|
||||
getNativeObjinfo(grp_name.c_str(), idx_type, order, idx, objinfo, fields, lapl);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------
|
||||
// Function: H5Location::getObjinfo
|
||||
///\brief Retrieves information about an HDF5 object.
|
||||
@ -1418,15 +1533,15 @@ void H5Location::unlink(const H5std_string& name, const LinkAccPropList& lapl) c
|
||||
/// \li \c H5O_INFO_ALL
|
||||
// July, 2018
|
||||
//--------------------------------------------------------------------------
|
||||
void H5Location::getObjinfo(H5O_info_t& objinfo, unsigned fields) const
|
||||
void H5Location::getObjinfo(H5O_info2_t& objinfo, unsigned fields) const
|
||||
{
|
||||
|
||||
// Use C API to get information of the object
|
||||
herr_t ret_value = H5Oget_info2(getId(), &objinfo, fields);
|
||||
herr_t ret_value = H5Oget_info3(getId(), &objinfo, fields);
|
||||
|
||||
// Throw exception if C API returns failure
|
||||
if (ret_value < 0)
|
||||
throwException(inMemFunc("getObjinfo"), "H5Oget_info2 failed");
|
||||
throwException(inMemFunc("getObjinfo"), "H5Oget_info3 failed");
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------
|
||||
@ -1447,10 +1562,10 @@ void H5Location::getObjinfo(H5O_info_t& objinfo, unsigned fields) const
|
||||
/// \li \c H5O_INFO_ALL
|
||||
// July, 2018
|
||||
//--------------------------------------------------------------------------
|
||||
void H5Location::getObjinfo(const char* name, H5O_info_t& objinfo, unsigned fields, const LinkAccPropList& lapl) const
|
||||
void H5Location::getObjinfo(const char* name, H5O_info2_t& objinfo, unsigned fields, const LinkAccPropList& lapl) const
|
||||
{
|
||||
// Use C API to get information of the object
|
||||
herr_t ret_value = H5Oget_info_by_name2(getId(), name, &objinfo, fields, lapl.getId());
|
||||
herr_t ret_value = H5Oget_info_by_name3(getId(), name, &objinfo, fields, lapl.getId());
|
||||
|
||||
// Throw exception if C API returns failure
|
||||
if (ret_value < 0)
|
||||
@ -1469,7 +1584,7 @@ void H5Location::getObjinfo(const char* name, H5O_info_t& objinfo, unsigned fiel
|
||||
///\param lapl - IN: Link access property list
|
||||
// July, 2018
|
||||
//--------------------------------------------------------------------------
|
||||
void H5Location::getObjinfo(const H5std_string& name, H5O_info_t& objinfo, unsigned fields, const LinkAccPropList& lapl) const
|
||||
void H5Location::getObjinfo(const H5std_string& name, H5O_info2_t& objinfo, unsigned fields, const LinkAccPropList& lapl) const
|
||||
{
|
||||
getObjinfo(name.c_str(), objinfo, fields, lapl);
|
||||
}
|
||||
@ -1496,11 +1611,11 @@ void H5Location::getObjinfo(const H5std_string& name, H5O_info_t& objinfo, unsig
|
||||
// July, 2018
|
||||
//--------------------------------------------------------------------------
|
||||
void H5Location::getObjinfo(const char* grp_name, H5_index_t idx_type,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_info_t& objinfo, unsigned fields,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_info2_t& objinfo, unsigned fields,
|
||||
const LinkAccPropList& lapl) const
|
||||
{
|
||||
// Use C API to get information of the object
|
||||
herr_t ret_value = H5Oget_info_by_idx2(getId(), grp_name, idx_type, order,
|
||||
herr_t ret_value = H5Oget_info_by_idx3(getId(), grp_name, idx_type, order,
|
||||
idx, &objinfo, fields, lapl.getId());
|
||||
|
||||
// Throw exception if C API returns failure
|
||||
@ -1521,7 +1636,7 @@ void H5Location::getObjinfo(const char* grp_name, H5_index_t idx_type,
|
||||
// July, 2018
|
||||
//--------------------------------------------------------------------------
|
||||
void H5Location::getObjinfo(const H5std_string& grp_name, H5_index_t idx_type,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_info_t& objinfo, unsigned fields,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_info2_t& objinfo, unsigned fields,
|
||||
const LinkAccPropList& lapl) const
|
||||
{
|
||||
getObjinfo(grp_name.c_str(), idx_type, order, idx, objinfo, fields, lapl);
|
||||
@ -1596,11 +1711,11 @@ void H5Location::getObjinfo(const H5std_string& name, H5G_stat_t& statbuf) const
|
||||
///\exception H5::FileIException/H5::GroupIException/H5::LocationException
|
||||
// 2000
|
||||
//--------------------------------------------------------------------------
|
||||
H5L_info_t H5Location::getLinkInfo(const char* link_name, const LinkAccPropList& lapl) const
|
||||
H5L_info2_t H5Location::getLinkInfo(const char* link_name, const LinkAccPropList& lapl) const
|
||||
{
|
||||
H5L_info_t linkinfo; // link info structure
|
||||
H5L_info2_t linkinfo; // link info structure
|
||||
|
||||
herr_t ret_value = H5Lget_info(getId(), link_name, &linkinfo, lapl.getId());
|
||||
herr_t ret_value = H5Lget_info2(getId(), link_name, &linkinfo, lapl.getId());
|
||||
if (ret_value < 0)
|
||||
throwException("getLinkInfo", "H5Lget_info to find buffer size failed");
|
||||
|
||||
@ -1613,7 +1728,7 @@ H5L_info_t H5Location::getLinkInfo(const char* link_name, const LinkAccPropList&
|
||||
/// It differs from the above function in that it takes an
|
||||
/// \c H5std_string for \a link_name.
|
||||
//--------------------------------------------------------------------------
|
||||
H5L_info_t H5Location::getLinkInfo(const H5std_string& link_name, const LinkAccPropList& lapl) const
|
||||
H5L_info2_t H5Location::getLinkInfo(const H5std_string& link_name, const LinkAccPropList& lapl) const
|
||||
{
|
||||
return(getLinkInfo(link_name.c_str(), lapl));
|
||||
}
|
||||
@ -1629,7 +1744,7 @@ H5L_info_t H5Location::getLinkInfo(const H5std_string& link_name, const LinkAccP
|
||||
//--------------------------------------------------------------------------
|
||||
H5std_string H5Location::getLinkval(const char* name, size_t size) const
|
||||
{
|
||||
H5L_info_t linkinfo;
|
||||
H5L_info2_t linkinfo;
|
||||
char *value_C; // value in C string
|
||||
size_t val_size = size;
|
||||
H5std_string value = "";
|
||||
@ -1638,7 +1753,7 @@ H5std_string H5Location::getLinkval(const char* name, size_t size) const
|
||||
// if user doesn't provide buffer size, determine it
|
||||
if (size == 0)
|
||||
{
|
||||
ret_value = H5Lget_info(getId(), name, &linkinfo, H5P_DEFAULT);
|
||||
ret_value = H5Lget_info2(getId(), name, &linkinfo, H5P_DEFAULT);
|
||||
if (ret_value < 0)
|
||||
throwException("getLinkval", "H5Lget_info to find buffer size failed");
|
||||
|
||||
@ -1941,11 +2056,11 @@ ssize_t H5Location::getObjnameByIdx(hsize_t idx, H5std_string& name, size_t size
|
||||
//--------------------------------------------------------------------------
|
||||
H5O_type_t H5Location::childObjType(const char* objname) const
|
||||
{
|
||||
H5O_info_t objinfo;
|
||||
H5O_info2_t objinfo;
|
||||
H5O_type_t objtype = H5O_TYPE_UNKNOWN;
|
||||
|
||||
// Use C API to get information of the object
|
||||
herr_t ret_value = H5Oget_info_by_name2(getId(), objname, &objinfo, H5O_INFO_BASIC, H5P_DEFAULT);
|
||||
herr_t ret_value = H5Oget_info_by_name3(getId(), objname, &objinfo, H5O_INFO_BASIC, H5P_DEFAULT);
|
||||
|
||||
// Throw exception if C API returns failure
|
||||
if (ret_value < 0)
|
||||
@ -2016,11 +2131,11 @@ H5O_type_t H5Location::childObjType(const H5std_string& objname) const
|
||||
H5O_type_t H5Location::childObjType(hsize_t index, H5_index_t index_type, H5_iter_order_t order, const char* objname) const
|
||||
{
|
||||
herr_t ret_value;
|
||||
H5O_info_t objinfo;
|
||||
H5O_info2_t objinfo;
|
||||
H5O_type_t objtype = H5O_TYPE_UNKNOWN;
|
||||
|
||||
// Use C API to get information of the object
|
||||
ret_value = H5Oget_info_by_idx2(getId(), objname, index_type, order, index, &objinfo, H5O_INFO_BASIC, H5P_DEFAULT);
|
||||
ret_value = H5Oget_info_by_idx3(getId(), objname, index_type, order, index, &objinfo, H5O_INFO_BASIC, H5P_DEFAULT);
|
||||
|
||||
// Throw exception if C API returns failure
|
||||
if (ret_value < 0)
|
||||
@ -2058,11 +2173,11 @@ H5O_type_t H5Location::childObjType(hsize_t index, H5_index_t index_type, H5_ite
|
||||
//--------------------------------------------------------------------------
|
||||
unsigned H5Location::childObjVersion(const char* objname) const
|
||||
{
|
||||
H5O_info_t objinfo;
|
||||
H5O_native_info_t objinfo;
|
||||
unsigned version = 0;
|
||||
|
||||
// Use C API to get information of the object
|
||||
herr_t ret_value = H5Oget_info_by_name2(getId(), objname, &objinfo, H5O_INFO_HDR, H5P_DEFAULT);
|
||||
herr_t ret_value = H5Oget_native_info_by_name(getId(), objname, &objinfo, H5O_NATIVE_INFO_HDR, H5P_DEFAULT);
|
||||
|
||||
// Throw exception if C API returns failure
|
||||
if (ret_value < 0)
|
||||
|
@ -118,8 +118,8 @@ class H5_DLLCPP H5Location : public IdComponent {
|
||||
DataSet openDataSet(const char* name, const DSetAccPropList& dapl = DSetAccPropList::DEFAULT) const;
|
||||
DataSet openDataSet(const H5std_string& name, const DSetAccPropList& dapl = DSetAccPropList::DEFAULT) const;
|
||||
|
||||
H5L_info_t getLinkInfo(const char* link_name, const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
H5L_info_t getLinkInfo(const H5std_string& link_name, const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
H5L_info2_t getLinkInfo(const char* link_name, const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
H5L_info2_t getLinkInfo(const H5std_string& link_name, const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
|
||||
// Returns the value of a symbolic link.
|
||||
H5std_string getLinkval(const char* link_name, size_t size=0) const;
|
||||
@ -147,26 +147,47 @@ class H5_DLLCPP H5Location : public IdComponent {
|
||||
unsigned childObjVersion(const H5std_string& objname) const;
|
||||
|
||||
// Retrieves information about an HDF5 object.
|
||||
void getObjinfo(H5O_info_t& objinfo, unsigned fields = H5O_INFO_BASIC) const;
|
||||
void getObjinfo(H5O_info2_t& objinfo, unsigned fields = H5O_INFO_BASIC) const;
|
||||
|
||||
// Retrieves information about an HDF5 object, given its name.
|
||||
void getObjinfo(const char* name, H5O_info_t& objinfo,
|
||||
void getObjinfo(const char* name, H5O_info2_t& objinfo,
|
||||
unsigned fields = H5O_INFO_BASIC,
|
||||
const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
void getObjinfo(const H5std_string& name, H5O_info_t& objinfo,
|
||||
void getObjinfo(const H5std_string& name, H5O_info2_t& objinfo,
|
||||
unsigned fields = H5O_INFO_BASIC,
|
||||
const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
|
||||
// Retrieves information about an HDF5 object, given its index.
|
||||
void getObjinfo(const char* grp_name, H5_index_t idx_type,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_info_t& objinfo,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_info2_t& objinfo,
|
||||
unsigned fields = H5O_INFO_BASIC,
|
||||
const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
void getObjinfo(const H5std_string& grp_name, H5_index_t idx_type,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_info_t& objinfo,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_info2_t& objinfo,
|
||||
unsigned fields = H5O_INFO_BASIC,
|
||||
const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
|
||||
// Retrieves native native information about an HDF5 object.
|
||||
void getNativeObjinfo(H5O_native_info_t& objinfo, unsigned fields = H5O_NATIVE_INFO_HDR) const;
|
||||
|
||||
// Retrieves native information about an HDF5 object, given its name.
|
||||
void getNativeObjinfo(const char* name, H5O_native_info_t& objinfo,
|
||||
unsigned fields = H5O_NATIVE_INFO_HDR,
|
||||
const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
void getNativeObjinfo(const H5std_string& name, H5O_native_info_t& objinfo,
|
||||
unsigned fields = H5O_NATIVE_INFO_HDR,
|
||||
const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
|
||||
// Retrieves native information about an HDF5 object, given its index.
|
||||
void getNativeObjinfo(const char* grp_name, H5_index_t idx_type,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_native_info_t& objinfo,
|
||||
unsigned fields = H5O_NATIVE_INFO_HDR,
|
||||
const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
void getNativeObjinfo(const H5std_string& grp_name, H5_index_t idx_type,
|
||||
H5_iter_order_t order, hsize_t idx, H5O_native_info_t& objinfo,
|
||||
unsigned fields = H5O_NATIVE_INFO_HDR,
|
||||
const LinkAccPropList& lapl = LinkAccPropList::DEFAULT) const;
|
||||
|
||||
#ifndef H5_NO_DEPRECATED_SYMBOLS
|
||||
// Returns the type of an object in this group, given the
|
||||
// object's index.
|
||||
|
@ -52,9 +52,9 @@ extern "C" herr_t userAttrOpWrpr(hid_t loc_id, const char *attr_name,
|
||||
}
|
||||
|
||||
// userVisitOpWrpr interfaces between the user's function and the
|
||||
// C library function H5Ovisit2
|
||||
// C library function H5Ovisit3
|
||||
extern "C" herr_t userVisitOpWrpr(hid_t obj_id, const char *attr_name,
|
||||
const H5O_info_t *obj_info, void *op_data)
|
||||
const H5O_info2_t *obj_info, void *op_data)
|
||||
{
|
||||
H5std_string s_attr_name = H5std_string(attr_name);
|
||||
UserData4Visit* myData = reinterpret_cast<UserData4Visit *> (op_data);
|
||||
@ -250,13 +250,11 @@ int H5Object::iterateAttrs(attr_operator_t user_op, unsigned *_idx, void *op_dat
|
||||
///\param *op_data - IN: User-defined pointer to data required by the
|
||||
/// application for its processing of the object
|
||||
///\param fields - IN: Flags specifying the fields to be retrieved
|
||||
/// to the callback op via the H5O_info_t argument.
|
||||
/// to the callback op via the H5O_info2_t argument.
|
||||
/// \li \c H5O_INFO_BASIC fileno, addr, type, and rc fields
|
||||
/// \li \c H5O_INFO_TIME atime, mtime, ctime, and btime fields
|
||||
/// \li \c H5O_INFO_NUM_ATTRS num_attrs field
|
||||
/// \li \c H5O_INFO_HDR hdr field
|
||||
/// \li \c H5O_INFO_META_SIZE meta_size field
|
||||
/// \li \c H5O_INFO_ALL H5O_INFO_BASIC | H5O_INFO_TIME | H5O_INFO_NUM_ATTRS | H5O_INFO_HDR | H5O_INFO_META_SIZE
|
||||
/// \li \c H5O_INFO_ALL H5O_INFO_BASIC | H5O_INFO_TIME | H5O_INFO_NUM_ATTRS
|
||||
///\return
|
||||
/// \li On success:
|
||||
/// \li the return value of the first operator that returns a positive value
|
||||
@ -266,7 +264,7 @@ int H5Object::iterateAttrs(attr_operator_t user_op, unsigned *_idx, void *op_dat
|
||||
/// wrong within the library or the operator failed
|
||||
///\exception H5::Exception
|
||||
///\par Description
|
||||
/// For information, please refer to the H5Ovisit2 API in the HDF5
|
||||
/// For information, please refer to the H5Ovisit3 API in the HDF5
|
||||
/// C Reference Manual.
|
||||
// Programmer Binh-Minh Ribler - Feb, 2019
|
||||
//--------------------------------------------------------------------------
|
||||
@ -279,15 +277,15 @@ void H5Object::visit(H5_index_t idx_type, H5_iter_order_t order, visit_operator_
|
||||
userData->obj = this;
|
||||
|
||||
// Call the C API passing in op wrapper and info
|
||||
herr_t ret_value = H5Ovisit2(getId(), idx_type, order, userVisitOpWrpr, static_cast<void *>(userData), fields);
|
||||
herr_t ret_value = H5Ovisit3(getId(), idx_type, order, userVisitOpWrpr, static_cast<void *>(userData), fields);
|
||||
|
||||
// Release memory
|
||||
delete userData;
|
||||
|
||||
// Throw exception if H5Ovisit2 failed, which could be a failure in
|
||||
// Throw exception if H5Ovisit3 failed, which could be a failure in
|
||||
// the library or in the call back operator
|
||||
if (ret_value < 0)
|
||||
throw Exception(inMemFunc("visit"), "H5Ovisit2 failed");
|
||||
throw Exception(inMemFunc("visit"), "H5Ovisit3 failed");
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------
|
||||
@ -304,15 +302,15 @@ void H5Object::visit(H5_index_t idx_type, H5_iter_order_t order, visit_operator_
|
||||
//--------------------------------------------------------------------------
|
||||
unsigned H5Object::objVersion() const
|
||||
{
|
||||
H5O_info_t objinfo;
|
||||
H5O_native_info_t objinfo;
|
||||
unsigned version = 0;
|
||||
|
||||
// Use C API to get information of the object
|
||||
herr_t ret_value = H5Oget_info2(getId(), &objinfo, H5O_INFO_HDR);
|
||||
herr_t ret_value = H5Oget_native_info(getId(), &objinfo, H5O_NATIVE_INFO_HDR);
|
||||
|
||||
// Throw exception if C API returns failure
|
||||
if (ret_value < 0)
|
||||
throw Exception(inMemFunc("objVersion"), "H5Oget_info failed");
|
||||
throw Exception(inMemFunc("objVersion"), "H5Oget_native_info failed");
|
||||
// Return a valid version or throw an exception for invalid value
|
||||
else
|
||||
{
|
||||
@ -332,9 +330,9 @@ unsigned H5Object::objVersion() const
|
||||
//--------------------------------------------------------------------------
|
||||
int H5Object::getNumAttrs() const
|
||||
{
|
||||
H5O_info_t oinfo; /* Object info */
|
||||
H5O_info2_t oinfo; /* Object info */
|
||||
|
||||
if(H5Oget_info2(getId(), &oinfo, H5O_INFO_NUM_ATTRS) < 0)
|
||||
if(H5Oget_info3(getId(), &oinfo, H5O_INFO_NUM_ATTRS) < 0)
|
||||
throw AttributeIException(inMemFunc("getNumAttrs"), "H5Oget_info failed");
|
||||
else
|
||||
return(static_cast<int>(oinfo.num_attrs));
|
||||
|
@ -44,10 +44,10 @@ typedef void (*attr_operator_t)(H5Object& loc,
|
||||
const H5std_string attr_name,
|
||||
void *operator_data);
|
||||
|
||||
// Define the operator function pointer for H5Ovisit2().
|
||||
// Define the operator function pointer for H5Ovisit3().
|
||||
typedef int (*visit_operator_t)(H5Object& obj,
|
||||
const H5std_string attr_name,
|
||||
const H5O_info_t *oinfo,
|
||||
const H5O_info2_t *oinfo,
|
||||
void *operator_data);
|
||||
|
||||
// User data for attribute iteration
|
||||
|
@ -1116,9 +1116,9 @@ static herr_t test_types(H5File& file)
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: test_getObjinfo
|
||||
* Function: test_getNativeObjinfo
|
||||
*
|
||||
* Purpose Tests getObjinfo()
|
||||
* Purpose Tests getNativeObjinfo()
|
||||
*
|
||||
* Return Success: 0
|
||||
* Failure: -1
|
||||
@ -1126,7 +1126,7 @@ static herr_t test_types(H5File& file)
|
||||
* July, 2018
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static herr_t test_getinfo(H5File& file)
|
||||
static herr_t test_getnativeinfo(H5File& file)
|
||||
{
|
||||
SUBTEST("Getting object information");
|
||||
|
||||
@ -1142,18 +1142,18 @@ static herr_t test_getinfo(H5File& file)
|
||||
DataSet dataset(file.openDataSet(DSET_CHUNKED_NAME));
|
||||
|
||||
// Get dataset header info
|
||||
H5O_info_t oinfo;
|
||||
HDmemset(&oinfo, 0, sizeof(oinfo));
|
||||
dataset.getObjinfo(oinfo, H5O_INFO_HDR);
|
||||
verify_val(oinfo.hdr.nchunks, 1, "DataSet::getObjinfo", __LINE__, __FILE__);
|
||||
H5O_native_info_t ninfo;
|
||||
HDmemset(&ninfo, 0, sizeof(ninfo));
|
||||
dataset.getNativeObjinfo(ninfo, H5O_NATIVE_INFO_HDR);
|
||||
verify_val(ninfo.hdr.nchunks, 1, "DataSet::getNativeObjinfo", __LINE__, __FILE__);
|
||||
dataset.close();
|
||||
|
||||
// Open the dataset we created above and then close it. This is one
|
||||
// way to open an existing dataset for accessing.
|
||||
dataset = file.openDataSet(DSET_DEFAULT_NAME);
|
||||
HDmemset(&oinfo, 0, sizeof(oinfo));
|
||||
dataset.getObjinfo(oinfo, H5O_INFO_ALL);
|
||||
verify_val(oinfo.hdr.nchunks, 1, "DataSet::getObjinfo", __LINE__, __FILE__);
|
||||
HDmemset(&ninfo, 0, sizeof(ninfo));
|
||||
dataset.getNativeObjinfo(ninfo, H5O_NATIVE_INFO_ALL);
|
||||
verify_val(ninfo.hdr.nchunks, 1, "DataSet::getNativeObjinfo", __LINE__, __FILE__);
|
||||
dataset.close();
|
||||
|
||||
PASSED();
|
||||
@ -1169,10 +1169,10 @@ static herr_t test_getinfo(H5File& file)
|
||||
// catch all other exceptions
|
||||
catch (Exception& E)
|
||||
{
|
||||
issue_fail_msg("test_getinfo", __LINE__, __FILE__);
|
||||
issue_fail_msg("test_getnativeinfo", __LINE__, __FILE__);
|
||||
return -1;
|
||||
}
|
||||
} // test_getinfo
|
||||
} // test_getnativeinfo
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
@ -1408,7 +1408,7 @@ void test_dset()
|
||||
|
||||
nerrors += test_create(file) < 0 ? 1:0;
|
||||
nerrors += test_simple_io(file) < 0 ? 1:0;
|
||||
nerrors += test_getinfo(file) < 0 ? 1:0;
|
||||
nerrors += test_getnativeinfo(file) < 0 ? 1:0;
|
||||
nerrors += test_tconv(file) < 0 ? 1:0;
|
||||
nerrors += test_compression(file) < 0 ? 1:0;
|
||||
nerrors += test_nbit_compression(file) < 0 ? 1:0;
|
||||
|
@ -519,7 +519,7 @@ static void test_attr_basic_read()
|
||||
verify_val(num_attrs, 3, "DataSet::getNumAttrs", __LINE__, __FILE__);
|
||||
|
||||
// Verify the correct number of attributes another way
|
||||
H5O_info_t oinfo;
|
||||
H5O_info2_t oinfo;
|
||||
HDmemset(&oinfo, 0, sizeof(oinfo));
|
||||
dataset.getObjinfo(oinfo, H5O_INFO_NUM_ATTRS);
|
||||
verify_val(oinfo.num_attrs, 3, "DataSet::getObjinfo", __LINE__, __FILE__);
|
||||
@ -670,7 +670,7 @@ static void test_attr_compound_read()
|
||||
verify_val(num_attrs, 1, "DataSet::getNumAttrs", __LINE__, __FILE__);
|
||||
|
||||
// Verify the correct number of attributes another way
|
||||
H5O_info_t oinfo;
|
||||
H5O_info2_t oinfo;
|
||||
HDmemset(&oinfo, 0, sizeof(oinfo));
|
||||
dataset.getObjinfo(oinfo, H5O_INFO_NUM_ATTRS);
|
||||
verify_val(oinfo.num_attrs, 1, "DataSet::getObjinfo", __LINE__, __FILE__);
|
||||
|
@ -716,10 +716,10 @@ static void test_libver_bounds_real(
|
||||
verify_val(obj_version, oh_vers_create, "H5File::childObjVersion", __LINE__, __FILE__);
|
||||
|
||||
// Verify object header version another way
|
||||
H5O_info_t oinfo;
|
||||
HDmemset(&oinfo, 0, sizeof(oinfo));
|
||||
file.getObjinfo(oinfo, H5O_INFO_HDR);
|
||||
verify_val(oinfo.hdr.version, oh_vers_create, "H5File::getObjinfo", __LINE__, __FILE__);
|
||||
H5O_native_info_t ninfo;
|
||||
HDmemset(&ninfo, 0, sizeof(ninfo));
|
||||
file.getNativeObjinfo(ninfo, H5O_NATIVE_INFO_HDR);
|
||||
verify_val(ninfo.hdr.version, oh_vers_create, "H5File::getNativeObjinfo", __LINE__, __FILE__);
|
||||
|
||||
/*
|
||||
* Reopen the file and make sure the root group still has the correct
|
||||
@ -744,9 +744,9 @@ static void test_libver_bounds_real(
|
||||
verify_val(obj_version, oh_vers_mod, "Group::objVersion", __LINE__, __FILE__);
|
||||
|
||||
// Verify object header version another way
|
||||
HDmemset(&oinfo, 0, sizeof(oinfo));
|
||||
group.getObjinfo(oinfo, H5O_INFO_HDR);
|
||||
verify_val(oinfo.hdr.version, oh_vers_mod, "Group::getObjinfo", __LINE__, __FILE__);
|
||||
HDmemset(&ninfo, 0, sizeof(ninfo));
|
||||
group.getNativeObjinfo(ninfo, H5O_NATIVE_INFO_HDR);
|
||||
verify_val(ninfo.hdr.version, oh_vers_mod, "Group::getNativeObjinfo", __LINE__, __FILE__);
|
||||
|
||||
group.close(); // close "/G1"
|
||||
|
||||
|
@ -96,7 +96,7 @@ int iter_strcmp(const void *s1, const void *s2)
|
||||
* Purpose Custom link iteration callback routine
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static herr_t liter_cb(hid_t H5_ATTR_UNUSED group, const char *name, const H5L_info_t H5_ATTR_UNUSED *link_info, void *op_data)
|
||||
static herr_t liter_cb(hid_t H5_ATTR_UNUSED group, const char *name, const H5L_info2_t H5_ATTR_UNUSED *link_info, void *op_data)
|
||||
{
|
||||
iter_info *info = (iter_info *)op_data;
|
||||
static int count = 0;
|
||||
@ -158,7 +158,7 @@ static void test_iter_group(FileAccPropList& fapl)
|
||||
/* Test iterating over empty group */
|
||||
info.command = RET_ZERO;
|
||||
idx = 0;
|
||||
ret = H5Literate(file.getId(), H5_INDEX_NAME, H5_ITER_INC, &idx, liter_cb, &info);
|
||||
ret = H5Literate2(file.getId(), H5_INDEX_NAME, H5_ITER_INC, &idx, liter_cb, &info);
|
||||
verify_val(ret, SUCCEED, "H5Literate", __LINE__, __FILE__);
|
||||
|
||||
DataType datatype(PredType::NATIVE_INT);
|
||||
@ -207,7 +207,7 @@ static void test_iter_group(FileAccPropList& fapl)
|
||||
H5std_string obj_name;
|
||||
for (i = 0; i < nobjs; i++)
|
||||
{
|
||||
//H5O_info_t oinfo; /* Object info */
|
||||
//H5O_info2_t oinfo; /* Object info */
|
||||
|
||||
obj_name = root_group.getObjnameByIdx(i);
|
||||
//ret = (herr_t)H5Lget_name_by_idx(root_group, ".", H5_INDEX_NAME, H5_ITER_INC, (hsize_t)i, dataset_name, (size_t)NAMELEN, H5P_DEFAULT);
|
||||
@ -287,7 +287,7 @@ static void test_iter_group(FileAccPropList& fapl)
|
||||
/* Test all objects in group, when callback always returns 0 */
|
||||
info.command = RET_ZERO;
|
||||
idx = 0;
|
||||
if((ret = H5Literate(file, H5_INDEX_NAME, H5_ITER_INC, &idx, liter_cb, &info)) > 0)
|
||||
if((ret = H5Literate2(file, H5_INDEX_NAME, H5_ITER_INC, &idx, liter_cb, &info)) > 0)
|
||||
TestErrPrintf("Group iteration function didn't return zero correctly!\n");
|
||||
|
||||
/* Test all objects in group, when callback always returns 1 */
|
||||
@ -295,7 +295,7 @@ static void test_iter_group(FileAccPropList& fapl)
|
||||
info.command = RET_TWO;
|
||||
i = 0;
|
||||
idx = 0;
|
||||
while((ret = H5Literate(file, H5_INDEX_NAME, H5_ITER_INC, &idx, liter_cb, &info)) > 0) {
|
||||
while((ret = H5Literate2(file, H5_INDEX_NAME, H5_ITER_INC, &idx, liter_cb, &info)) > 0) {
|
||||
/* Verify return value from iterator gets propagated correctly */
|
||||
verify_val(ret, 2, "H5Literate", __LINE__, __FILE__);
|
||||
|
||||
@ -321,7 +321,7 @@ static void test_iter_group(FileAccPropList& fapl)
|
||||
info.command = new_format ? RET_CHANGE2 : RET_CHANGE;
|
||||
i = 0;
|
||||
idx = 0;
|
||||
while((ret = H5Literate(file, H5_INDEX_NAME, H5_ITER_INC, &idx, liter_cb, &info)) >= 0) {
|
||||
while((ret = H5Literate2(file, H5_INDEX_NAME, H5_ITER_INC, &idx, liter_cb, &info)) >= 0) {
|
||||
/* Verify return value from iterator gets propagated correctly */
|
||||
verify_val(ret, 1, "H5Literate", __LINE__, __FILE__);
|
||||
|
||||
|
@ -190,7 +190,7 @@ const H5std_string GROUP2NAME("Second_group");
|
||||
static void
|
||||
test_lcpl(hid_t fapl_id, hbool_t new_format)
|
||||
{
|
||||
H5L_info_t linfo;
|
||||
H5L_info2_t linfo;
|
||||
char filename[1024];
|
||||
hsize_t dims[2];
|
||||
|
||||
@ -604,7 +604,7 @@ const int RANK = 2;
|
||||
const int DIM1 = 2;
|
||||
|
||||
// Operator function
|
||||
static int visit_obj_cb(H5Object& obj, const H5std_string name, const H5O_info_t *oinfo, void *_op_data)
|
||||
static int visit_obj_cb(H5Object& obj, const H5std_string name, const H5O_info2_t *oinfo, void *_op_data)
|
||||
{
|
||||
ovisit_ud_t *op_data = static_cast <ovisit_ud_t *>(_op_data);
|
||||
|
||||
|
@ -542,7 +542,7 @@ const H5std_string GROUP1NAME("group1");
|
||||
const H5std_string GROUP2NAME("group2");
|
||||
static void test_getobjectinfo_same_file()
|
||||
{
|
||||
H5O_info_t oinfo1, oinfo2; /* Object info structs */
|
||||
H5O_info2_t oinfo1, oinfo2; /* Object info structs */
|
||||
|
||||
// Output message about test being performed
|
||||
SUBTEST("Group::getObjinfo");
|
||||
|
@ -482,7 +482,7 @@ static void test_reference_group()
|
||||
verify_val(fname, FILE1, "H5Group::getFileName",__LINE__,__FILE__);
|
||||
|
||||
// Check object type using Group::getObjinfo()
|
||||
H5O_info_t oinfo;
|
||||
H5O_info2_t oinfo;
|
||||
HDmemset(&oinfo, 0, sizeof(oinfo));
|
||||
group.getObjinfo(".", H5_INDEX_NAME, H5_ITER_INC, (hsize_t)0, oinfo);
|
||||
verify_val(oinfo.type, H5O_TYPE_DATASET, "Group::getObjinfo",__LINE__,__FILE__);
|
||||
|
16
config/linux-gnueabihf
Normal file
16
config/linux-gnueabihf
Normal file
@ -0,0 +1,16 @@
|
||||
# -*- shell-script -*-
|
||||
#
|
||||
# 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
|
||||
# the COPYING file, which can be found at the root of the source code
|
||||
# distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases.
|
||||
# If you do not have access to either file, you may request a copy from
|
||||
# help@hdfgroup.org.
|
||||
|
||||
# ARM for Raspberry Pi, etc.
|
||||
# This is the same as linux-gnulibc1
|
||||
|
||||
. $srcdir/config/linux-gnulibc1
|
@ -60,7 +60,7 @@ main (void)
|
||||
float matrix[ADIM1][ADIM2]; /* Attribute data */
|
||||
|
||||
herr_t ret; /* Return value */
|
||||
H5O_info_t oinfo; /* Object info */
|
||||
H5O_info2_t oinfo; /* Object info */
|
||||
unsigned i, j; /* Counters */
|
||||
char string_out[80]; /* Buffer to read string attribute back */
|
||||
int point_out; /* Buffer to read scalar attribute back */
|
||||
@ -189,7 +189,7 @@ main (void)
|
||||
/*
|
||||
* Find string attribute by iterating through all attributes
|
||||
*/
|
||||
ret = H5Oget_info2(dataset, &oinfo, H5O_INFO_ALL);
|
||||
ret = H5Oget_info3(dataset, &oinfo, H5O_INFO_NUM_ATTRS);
|
||||
for(i = 0; i < (unsigned)oinfo.num_attrs; i++) {
|
||||
attr = H5Aopen_by_idx(dataset, ".", H5_INDEX_CRT_ORDER, H5_ITER_INC, (hsize_t)i, H5P_DEFAULT, H5P_DEFAULT);
|
||||
atype = H5Aget_type(attr);
|
||||
|
@ -316,7 +316,7 @@ static void hard_link_example(void)
|
||||
{
|
||||
hid_t file_id;
|
||||
hid_t group_id;
|
||||
H5L_info_t li;
|
||||
H5L_info2_t li;
|
||||
/* Define the link class that we'll use to register "user-defined hard
|
||||
* links" using the callbacks we defined above.
|
||||
* A link class can have NULL for any callback except its traverse
|
||||
@ -361,13 +361,13 @@ static void hard_link_example(void)
|
||||
* the target group's address. We do this by calling H5Lget_info
|
||||
* on a hard link to the object.
|
||||
*/
|
||||
H5Lget_info(file_id, TARGET_GROUP, &li, H5P_DEFAULT);
|
||||
H5Lget_info2(file_id, TARGET_GROUP, &li, H5P_DEFAULT);
|
||||
|
||||
/* Now create a user-defined link. We give it the group's address
|
||||
* as its udata.
|
||||
*/
|
||||
H5Lcreate_ud(file_id, UD_HARD_LINK_NAME, (H5L_type_t)UD_HARD_CLASS, &(li.u.address),
|
||||
sizeof(li.u.address), H5P_DEFAULT, H5P_DEFAULT);
|
||||
H5Lcreate_ud(file_id, UD_HARD_LINK_NAME, (H5L_type_t)UD_HARD_CLASS, &(li.u.token),
|
||||
sizeof(H5O_token_t), H5P_DEFAULT, H5P_DEFAULT);
|
||||
|
||||
/* The UD hard link has now incremented the group's reference count
|
||||
* like a normal hard link would. This means that we can unlink the
|
||||
@ -404,23 +404,23 @@ static void hard_link_example(void)
|
||||
static herr_t UD_hard_create(const char *link_name, hid_t loc_group,
|
||||
const void *udata, size_t udata_size, hid_t lcpl_id)
|
||||
{
|
||||
haddr_t addr;
|
||||
hid_t target_obj = -1;
|
||||
H5O_token_t token;
|
||||
hid_t target_obj = H5I_INVALID_HID;
|
||||
herr_t ret_value = 0;
|
||||
|
||||
/* Make sure that the address passed in looks valid */
|
||||
if(udata_size != sizeof(haddr_t))
|
||||
if(udata_size != sizeof(H5O_token_t))
|
||||
{
|
||||
ret_value = -1;
|
||||
goto done;
|
||||
}
|
||||
|
||||
addr = *((const haddr_t *) udata);
|
||||
token = *((H5O_token_t *) udata);
|
||||
|
||||
/* Open the object this link points to so that we can increment
|
||||
* its reference count. This also ensures that the address passed
|
||||
* its reference count. This also ensures that the token passed
|
||||
* in points to a real object (although this check is not perfect!) */
|
||||
target_obj= H5Oopen_by_addr(loc_group, addr);
|
||||
target_obj = H5Oopen_by_token(loc_group, token);
|
||||
if(target_obj < 0)
|
||||
{
|
||||
ret_value = -1;
|
||||
@ -448,23 +448,23 @@ done:
|
||||
static herr_t UD_hard_delete(const char *link_name, hid_t loc_group,
|
||||
const void *udata, size_t udata_size)
|
||||
{
|
||||
haddr_t addr;
|
||||
hid_t target_obj = -1;
|
||||
H5O_token_t token;
|
||||
hid_t target_obj = H5I_INVALID_HID;
|
||||
herr_t ret_value = 0;
|
||||
|
||||
/* Sanity check; we have already verified the udata's size in the creation
|
||||
* callback.
|
||||
*/
|
||||
if(udata_size != sizeof(haddr_t))
|
||||
if(udata_size != sizeof(H5O_token_t))
|
||||
{
|
||||
ret_value = -1;
|
||||
goto done;
|
||||
}
|
||||
|
||||
addr = *((const haddr_t *) udata);
|
||||
token = *((H5O_token_t *) udata);
|
||||
|
||||
/* Open the object this link points to */
|
||||
target_obj= H5Oopen_by_addr(loc_group, addr);
|
||||
target_obj = H5Oopen_by_token(loc_group, token);
|
||||
if(target_obj < 0)
|
||||
{
|
||||
ret_value = -1;
|
||||
@ -492,21 +492,21 @@ done:
|
||||
static hid_t UD_hard_traverse(const char *link_name, hid_t cur_group,
|
||||
const void *udata, size_t udata_size, hid_t lapl_id, hid_t dxpl_id)
|
||||
{
|
||||
haddr_t addr;
|
||||
hid_t ret_value = -1;
|
||||
H5O_token_t token;
|
||||
hid_t ret_value = H5I_INVALID_HID;
|
||||
|
||||
/* Sanity check; we have already verified the udata's size in the creation
|
||||
* callback.
|
||||
*/
|
||||
if(udata_size != sizeof(haddr_t))
|
||||
return -1;
|
||||
if(udata_size != sizeof(H5O_token_t))
|
||||
return H5I_INVALID_HID;
|
||||
|
||||
addr = *((const haddr_t *) udata);
|
||||
token = *((H5O_token_t *) udata);
|
||||
|
||||
/* Open the object by address. If H5Oopen_by_addr fails, ret_value will
|
||||
/* Open the object by token. If H5Oopen_by_token fails, ret_value will
|
||||
* be negative to indicate that the traversal function failed.
|
||||
*/
|
||||
ret_value = H5Oopen_by_addr(cur_group, addr);
|
||||
ret_value = H5Oopen_by_token(cur_group, token);
|
||||
|
||||
return ret_value;
|
||||
}
|
||||
@ -621,7 +621,7 @@ static hid_t UD_plist_traverse(const char *link_name, hid_t cur_group,
|
||||
const void *udata, size_t udata_size, hid_t lapl_id, hid_t dxpl_id)
|
||||
{
|
||||
char * path;
|
||||
hid_t ret_value = -1;
|
||||
hid_t ret_value = H5I_INVALID_HID;
|
||||
|
||||
/* If the link property isn't set or can't be found, traversal fails. */
|
||||
if(H5Pexist(lapl_id, PLIST_LINK_PROP) < 0)
|
||||
@ -638,7 +638,7 @@ static hid_t UD_plist_traverse(const char *link_name, hid_t cur_group,
|
||||
return ret_value;
|
||||
|
||||
error:
|
||||
return -1;
|
||||
return H5I_INVALID_HID;
|
||||
}
|
||||
|
||||
|
||||
|
@ -26,9 +26,9 @@
|
||||
#define H5FILE_NAME "group.h5"
|
||||
#define RANK 2
|
||||
|
||||
static herr_t file_info(hid_t loc_id, const char *name, const H5L_info_t *linfo,
|
||||
static herr_t file_info(hid_t loc_id, const char *name, const H5L_info2_t *linfo,
|
||||
void *opdata); /* Link iteration operator function */
|
||||
static herr_t group_info(hid_t loc_id, const char *name, const H5L_info_t *linfo,
|
||||
static herr_t group_info(hid_t loc_id, const char *name, const H5L_info2_t *linfo,
|
||||
void *opdata); /* Link iteration operator function */
|
||||
int
|
||||
main(void)
|
||||
@ -135,7 +135,7 @@ main(void)
|
||||
/*
|
||||
* Use iterator to see the names of the objects in the root group.
|
||||
*/
|
||||
idx_f = H5Literate(file, H5_INDEX_NAME, H5_ITER_INC, NULL, file_info, NULL);
|
||||
idx_f = H5Literate2(file, H5_INDEX_NAME, H5_ITER_INC, NULL, file_info, NULL);
|
||||
|
||||
/*
|
||||
* Unlink name "Data" and use iterator to see the names
|
||||
@ -146,13 +146,13 @@ main(void)
|
||||
else
|
||||
printf("\"Data\" is unlinked \n");
|
||||
|
||||
idx_f = H5Literate(file, H5_INDEX_NAME, H5_ITER_INC, NULL, file_info, NULL);
|
||||
idx_f = H5Literate2(file, H5_INDEX_NAME, H5_ITER_INC, NULL, file_info, NULL);
|
||||
|
||||
/*
|
||||
* Use iterator to see the names of the objects in the group
|
||||
* /Data_new.
|
||||
*/
|
||||
idx_g = H5Literate_by_name(grp, "/Data_new", H5_INDEX_NAME, H5_ITER_INC, NULL, group_info, NULL, H5P_DEFAULT);
|
||||
idx_g = H5Literate_by_name2(grp, "/Data_new", H5_INDEX_NAME, H5_ITER_INC, NULL, group_info, NULL, H5P_DEFAULT);
|
||||
|
||||
/*
|
||||
* Close the file.
|
||||
@ -168,7 +168,7 @@ main(void)
|
||||
* Operator function.
|
||||
*/
|
||||
static herr_t
|
||||
file_info(hid_t loc_id, const char *name, const H5L_info_t *linfo, void *opdata)
|
||||
file_info(hid_t loc_id, const char *name, const H5L_info2_t *linfo, void *opdata)
|
||||
{
|
||||
/* avoid compiler warnings */
|
||||
loc_id = loc_id;
|
||||
@ -189,7 +189,7 @@ file_info(hid_t loc_id, const char *name, const H5L_info_t *linfo, void *opdata)
|
||||
* Operator function.
|
||||
*/
|
||||
static herr_t
|
||||
group_info(hid_t loc_id, const char *name, const H5L_info_t *linfo, void *opdata)
|
||||
group_info(hid_t loc_id, const char *name, const H5L_info2_t *linfo, void *opdata)
|
||||
{
|
||||
hid_t did; /* dataset identifier */
|
||||
hid_t tid; /* datatype identifier */
|
||||
|
@ -308,8 +308,8 @@ echo "***"Version compatibility tests.
|
||||
# If H5_NO_DEPRECATED_SYMBOLS;
|
||||
# then only v18main works.
|
||||
# else if H5_USE_16_API_DEFAULT;
|
||||
# then v16main works and -DH5_NO_DEPRECATED_SYMBOLS v18main also works.
|
||||
# else v18main works and -DH5_USE_16_API_DEFAULT v16main also works.
|
||||
# then v16main works.
|
||||
# else v18main works and -DH5_USE_16_API_DEFAULT v16main also works.
|
||||
#
|
||||
if [ -n "$H5_USE_16_API_DEFAULT" ]; then
|
||||
echo "H5_USE_16_API_DEFAULT is defined."
|
||||
@ -326,7 +326,6 @@ if [ -n "$H5_NO_DEPRECATED_SYMBOLS" ]; then
|
||||
TOOLTEST $v18main
|
||||
elif [ -n "$H5_USE_16_API_DEFAULT" ]; then
|
||||
TOOLTEST $v16main
|
||||
TOOLTEST -DH5_NO_DEPRECATED_SYMBOLS $v18main
|
||||
else
|
||||
TOOLTEST -DH5_USE_16_API_DEFAULT $v16main
|
||||
TOOLTEST $v18main
|
||||
|
@ -137,13 +137,13 @@ int_f
|
||||
h5aget_num_attrs_c (hid_t_f *obj_id, int_f *attr_num)
|
||||
/******/
|
||||
{
|
||||
H5O_info_t oinfo; /* Object info */
|
||||
H5O_info2_t oinfo; /* Object info */
|
||||
int_f ret_value = 0; /* Return value */
|
||||
|
||||
/*
|
||||
* Call H5Oget_info function.
|
||||
*/
|
||||
if(H5Oget_info2((hid_t)*obj_id, &oinfo, H5O_INFO_NUM_ATTRS) < 0)
|
||||
if(H5Oget_info3((hid_t)*obj_id, &oinfo, H5O_INFO_NUM_ATTRS) < 0)
|
||||
HGOTO_DONE(FAIL);
|
||||
|
||||
/* Set number of attributes */
|
||||
|
@ -170,7 +170,7 @@ h5gget_obj_info_idx_c(hid_t_f *loc_id, _fcd name, int_f *namelen, int_f *idx,
|
||||
_fcd obj_name, int_f *obj_namelen, int_f *obj_type)
|
||||
/******/
|
||||
{
|
||||
H5O_info_t oinfo;
|
||||
H5O_info2_t oinfo;
|
||||
hid_t c_loc_id = (hid_t)*loc_id;
|
||||
char *c_name = NULL;
|
||||
size_t c_obj_namelen;
|
||||
@ -200,7 +200,7 @@ h5gget_obj_info_idx_c(hid_t_f *loc_id, _fcd name, int_f *namelen, int_f *idx,
|
||||
/* Query the object's information */
|
||||
if(H5Lget_name_by_idx(gid, ".", H5_INDEX_NAME, H5_ITER_INC, c_idx, c_obj_name, c_obj_namelen, H5P_DEFAULT) < 0)
|
||||
goto DONE;
|
||||
if(H5Oget_info_by_idx2(gid, ".", H5_INDEX_NAME, H5_ITER_INC, c_idx, &oinfo, H5O_INFO_BASIC, H5P_DEFAULT) < 0)
|
||||
if(H5Oget_info_by_idx3(gid, ".", H5_INDEX_NAME, H5_ITER_INC, c_idx, &oinfo, H5O_INFO_BASIC, H5P_DEFAULT) < 0)
|
||||
goto DONE;
|
||||
|
||||
/* XXX: Switch from using H5Gget_objtype_by_idx() means that this routine won't
|
||||
|
@ -441,7 +441,7 @@ done:
|
||||
* H5L_LINK_SOFT_F - Soft link
|
||||
* H5L_LINK_EXTERNAL_F - External link
|
||||
* H5L_LINK_ERROR_F - Error
|
||||
* address - If the link is a hard link, address specifies the file address that the link points to
|
||||
* token - If the link is a hard link, token specifies the token for the object that the link points to
|
||||
* val_size - If the link is a symbolic link, val_size will be the length of the link value
|
||||
*
|
||||
* RETURNS
|
||||
@ -456,13 +456,12 @@ done:
|
||||
int_f
|
||||
h5lget_info_c(hid_t_f *link_loc_id, _fcd link_name, size_t_f *link_namelen,
|
||||
int_f *cset, int_f *corder, int_f *corder_valid, int_f *link_type,
|
||||
haddr_t_f *address, size_t_f *val_size,
|
||||
hid_t_f *lapl_id)
|
||||
H5O_token_t *token, size_t_f *val_size, hid_t_f *lapl_id)
|
||||
/******/
|
||||
{
|
||||
char *c_link_name = NULL; /* Buffer to hold C string */
|
||||
int_f ret_value = 0; /* Return value */
|
||||
H5L_info_t link_buff;
|
||||
H5L_info2_t link_buff;
|
||||
|
||||
/*
|
||||
* Convert FORTRAN name to C name
|
||||
@ -473,7 +472,7 @@ h5lget_info_c(hid_t_f *link_loc_id, _fcd link_name, size_t_f *link_namelen,
|
||||
/*
|
||||
* Call H5Linfo function.
|
||||
*/
|
||||
if(H5Lget_info((hid_t)*link_loc_id, c_link_name, &link_buff, (hid_t)*lapl_id) < 0)
|
||||
if(H5Lget_info2((hid_t)*link_loc_id, c_link_name, &link_buff, (hid_t)*lapl_id) < 0)
|
||||
HGOTO_DONE(FAIL);
|
||||
|
||||
/* Unpack the structure */
|
||||
@ -482,7 +481,7 @@ h5lget_info_c(hid_t_f *link_loc_id, _fcd link_name, size_t_f *link_namelen,
|
||||
*corder_valid = 0;
|
||||
if(link_buff.corder_valid > 0) *corder_valid = 1;
|
||||
*link_type = (int_f)link_buff.type;
|
||||
*address = (haddr_t_f)link_buff.u.address;
|
||||
*token = link_buff.u.token;
|
||||
*val_size = (size_t_f)link_buff.u.val_size;
|
||||
|
||||
done:
|
||||
@ -525,14 +524,15 @@ done:
|
||||
int_f
|
||||
h5lget_info_by_idx_c(hid_t_f *loc_id, _fcd group_name, size_t_f *group_namelen,
|
||||
int_f *index_field, int_f *order, hsize_t_f *n,
|
||||
int_f *link_type, int_f *corder_valid, int_f *corder, int_f *cset, haddr_t_f *address, size_t_f *val_size, hid_t_f *lapl_id)
|
||||
int_f *link_type, int_f *corder_valid, int_f *corder,
|
||||
int_f *cset, H5O_token_t *token, size_t_f *val_size, hid_t_f *lapl_id)
|
||||
/******/
|
||||
{
|
||||
char *c_group_name = NULL; /* Buffer to hold C string */
|
||||
H5_index_t c_index_field;
|
||||
H5_iter_order_t c_order;
|
||||
int_f ret_value = 0; /* Return value */
|
||||
H5L_info_t link_buff;
|
||||
H5L_info2_t link_buff;
|
||||
|
||||
/*
|
||||
* Convert FORTRAN name to C name
|
||||
@ -545,7 +545,7 @@ h5lget_info_by_idx_c(hid_t_f *loc_id, _fcd group_name, size_t_f *group_namelen,
|
||||
/*
|
||||
* Call H5Linfo_by_idx function.
|
||||
*/
|
||||
if(H5Lget_info_by_idx((hid_t)*loc_id, c_group_name, c_index_field, c_order, (hsize_t)*n,
|
||||
if(H5Lget_info_by_idx2((hid_t)*loc_id, c_group_name, c_index_field, c_order, (hsize_t)*n,
|
||||
&link_buff, (hid_t)*lapl_id) < 0)
|
||||
HGOTO_DONE(FAIL);
|
||||
|
||||
@ -557,7 +557,7 @@ h5lget_info_by_idx_c(hid_t_f *loc_id, _fcd group_name, size_t_f *group_namelen,
|
||||
*corder = (int_f)link_buff.corder;
|
||||
*cset = (int_f)link_buff.cset;
|
||||
*link_type = (int_f)link_buff.type;
|
||||
*address = (haddr_t_f)link_buff.u.address;
|
||||
*token = link_buff.u.token;
|
||||
*val_size = (size_t_f)link_buff.u.val_size;
|
||||
|
||||
done:
|
||||
@ -988,7 +988,7 @@ done:
|
||||
* SOURCE
|
||||
*/
|
||||
int_f
|
||||
h5literate_c(hid_t_f *group_id, int_f *index_type, int_f *order, hsize_t_f *idx, H5L_iterate_t op, void *op_data )
|
||||
h5literate_c(hid_t_f *group_id, int_f *index_type, int_f *order, hsize_t_f *idx, H5L_iterate2_t op, void *op_data )
|
||||
/******/
|
||||
{
|
||||
int_f ret_value = -1; /* Return value */
|
||||
@ -1001,7 +1001,7 @@ h5literate_c(hid_t_f *group_id, int_f *index_type, int_f *order, hsize_t_f *idx,
|
||||
* Call H5Linterate
|
||||
*/
|
||||
|
||||
func_ret_value = H5Literate( (hid_t)*group_id, (H5_index_t)*index_type, (H5_iter_order_t)*order, &idx_c, op, op_data);
|
||||
func_ret_value = H5Literate2( (hid_t)*group_id, (H5_index_t)*index_type, (H5_iter_order_t)*order, &idx_c, op, op_data);
|
||||
|
||||
ret_value = (int_f)func_ret_value;
|
||||
*idx = (hsize_t_f)idx_c;
|
||||
@ -1038,7 +1038,7 @@ h5literate_c(hid_t_f *group_id, int_f *index_type, int_f *order, hsize_t_f *idx,
|
||||
* SOURCE
|
||||
*/
|
||||
int_f
|
||||
h5literate_by_name_c(hid_t_f *loc_id, _fcd name, size_t_f *namelen, int_f *index_type, int_f *order, hsize_t_f *idx, H5L_iterate_t op, void *op_data, hid_t_f *lapl_id)
|
||||
h5literate_by_name_c(hid_t_f *loc_id, _fcd name, size_t_f *namelen, int_f *index_type, int_f *order, hsize_t_f *idx, H5L_iterate2_t op, void *op_data, hid_t_f *lapl_id)
|
||||
/******/
|
||||
{
|
||||
int_f ret_value = -1; /* Return value */
|
||||
@ -1058,7 +1058,7 @@ h5literate_by_name_c(hid_t_f *loc_id, _fcd name, size_t_f *namelen, int_f *index
|
||||
* Call H5Linterate
|
||||
*/
|
||||
|
||||
func_ret_value = H5Literate_by_name((hid_t)*loc_id, c_name,(H5_index_t)*index_type,(H5_iter_order_t)*order,&idx_c,op,op_data,(hid_t)*lapl_id);
|
||||
func_ret_value = H5Literate_by_name2((hid_t)*loc_id, c_name,(H5_index_t)*index_type,(H5_iter_order_t)*order,&idx_c,op,op_data,(hid_t)*lapl_id);
|
||||
|
||||
ret_value = (int_f)func_ret_value;
|
||||
*idx = (hsize_t_f)idx_c;
|
||||
|
@ -46,7 +46,7 @@ MODULE H5L
|
||||
! Fortran2003 Derived Type:
|
||||
!
|
||||
TYPE, bind(c) :: union_t
|
||||
INTEGER(haddr_t) :: address
|
||||
TYPE(H5O_TOKEN_T_F) :: token
|
||||
INTEGER(size_t) :: val_size
|
||||
END TYPE union_t
|
||||
|
||||
@ -604,7 +604,7 @@ CONTAINS
|
||||
! H5L_TYPE_SOFT_F - Soft link
|
||||
! H5L_TYPE_EXTERNAL_F - External link
|
||||
! H5L_TYPE_ERROR_ F - Error
|
||||
! address - If the link is a hard link, address specifies the file address that the link points to
|
||||
! token - If the link is a hard link, token specifies the object token that the link points to
|
||||
! val_size - If the link is a symbolic link, val_size will be the length of the link value, e.g.,
|
||||
! the length of the name of the pointed-to object with a null terminator.
|
||||
! hdferr - Returns 0 if successful and -1 if fails
|
||||
@ -625,7 +625,7 @@ CONTAINS
|
||||
!
|
||||
! SOURCE
|
||||
SUBROUTINE h5lget_info_f(link_loc_id, link_name, &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
hdferr, lapl_id)
|
||||
IMPLICIT NONE
|
||||
|
||||
@ -641,7 +641,7 @@ CONTAINS
|
||||
! H5L_TYPE_SOFT_F - Soft link
|
||||
! H5L_TYPE_EXTERNAL_F - External link
|
||||
! H5L_TYPE_ERROR _F - Error
|
||||
INTEGER(HADDR_T), INTENT(OUT) :: address ! If the link is a hard link, address specifies the file address that the link points to
|
||||
TYPE(H5O_TOKEN_T_F), INTENT(OUT), TARGET :: token ! If the link is a hard link, token specifies the object token that the link points to
|
||||
INTEGER(SIZE_T), INTENT(OUT) :: val_size ! If the link is a symbolic link, val_size will be the length of the link value, e.g.,
|
||||
! the length of the name of the pointed-to object with a null terminator.
|
||||
INTEGER, INTENT(OUT) :: hdferr ! Error code:
|
||||
@ -654,17 +654,17 @@ CONTAINS
|
||||
|
||||
INTERFACE
|
||||
INTEGER FUNCTION h5lget_info_c(link_loc_id, link_name, link_namelen, &
|
||||
cset, corder, corder_valid, link_type, address, val_size, &
|
||||
cset, corder, corder_valid, link_type, token, val_size, &
|
||||
lapl_id_default) BIND(C,NAME='h5lget_info_c')
|
||||
IMPORT :: c_char
|
||||
IMPORT :: HID_T, SIZE_T, HADDR_T
|
||||
IMPORT :: HID_T, SIZE_T, H5O_TOKEN_T_F
|
||||
IMPLICIT NONE
|
||||
INTEGER(HID_T), INTENT(IN) :: link_loc_id
|
||||
CHARACTER(KIND=C_CHAR), DIMENSION(*), INTENT(IN) :: link_name
|
||||
INTEGER, INTENT(OUT) :: cset
|
||||
INTEGER, INTENT(OUT) :: corder
|
||||
INTEGER, INTENT(OUT) :: link_type
|
||||
INTEGER(HADDR_T), INTENT(OUT) :: address
|
||||
TYPE(H5O_TOKEN_T_F), INTENT(OUT) :: token
|
||||
INTEGER(SIZE_T), INTENT(OUT) :: val_size
|
||||
INTEGER(HID_T) :: lapl_id_default
|
||||
INTEGER(SIZE_T) :: link_namelen
|
||||
@ -677,10 +677,8 @@ CONTAINS
|
||||
lapl_id_default = H5P_DEFAULT_F
|
||||
IF(PRESENT(lapl_id)) lapl_id_default = lapl_id
|
||||
|
||||
hdferr = h5lget_info_c(link_loc_id, link_name, link_namelen, &
|
||||
cset, corder, corder_valid, link_type, &
|
||||
address, val_size, &
|
||||
lapl_id_default)
|
||||
hdferr = h5lget_info_c(link_loc_id, link_name, link_namelen, cset, &
|
||||
corder, corder_valid, link_type, token, val_size, lapl_id_default)
|
||||
|
||||
f_corder_valid =.FALSE.
|
||||
IF(corder_valid .EQ. 1) f_corder_valid =.TRUE.
|
||||
@ -708,8 +706,8 @@ CONTAINS
|
||||
! corder_valid - Indicates whether the creation order data is valid for this attribute
|
||||
! corder - Is a positive integer containing the creation order of the attribute
|
||||
! cset - Indicates the character set used for the attribute’s name
|
||||
! address - If the link is a hard link, address specifies the file address that the link points to
|
||||
! val_size - If the link is a symbolic link, val_size will be the length of the link value, e.g.,
|
||||
! token - If the link is a hard link, token specifies the object token that the link points to
|
||||
! val_size - If the link is a symbolic link, val_size will be the length of the link value, e.g.,
|
||||
! the length of the name of the pointed-to object with a null terminator.
|
||||
! hdferr - Returns 0 if successful and -1 if fails
|
||||
!
|
||||
@ -729,7 +727,7 @@ CONTAINS
|
||||
!
|
||||
! SOURCE
|
||||
SUBROUTINE h5lget_info_by_idx_f(loc_id, group_name, index_field, order, n, &
|
||||
link_type, f_corder_valid, corder, cset, address, val_size, hdferr, lapl_id)
|
||||
link_type, f_corder_valid, corder, cset, token, val_size, hdferr, lapl_id)
|
||||
IMPLICIT NONE
|
||||
INTEGER(HID_T), INTENT(IN) :: loc_id ! File or group identifier specifying location of subject group
|
||||
CHARACTER(LEN=*), INTENT(IN) :: group_name ! Name of subject group
|
||||
@ -752,7 +750,7 @@ CONTAINS
|
||||
LOGICAL, INTENT(OUT) :: f_corder_valid ! Indicates whether the creation order data is valid for this attribute
|
||||
INTEGER, INTENT(OUT) :: corder ! Is a positive integer containing the creation order of the attribute
|
||||
INTEGER, INTENT(OUT) :: cset ! Indicates the character set used for the attribute’s name
|
||||
INTEGER(HADDR_T), INTENT(OUT) :: address ! If the link is a hard link, address specifies the file address that the link points to
|
||||
TYPE(H5O_TOKEN_T_F), INTENT(OUT), TARGET :: token ! If the link is a hard link, token specifies the object token that the link points to
|
||||
INTEGER(SIZE_T), INTENT(OUT) :: val_size ! If the link is a symbolic link, val_size will be the length of the link value, e.g.,
|
||||
! the length of the name of the pointed-to object with a null terminator.
|
||||
INTEGER, INTENT(OUT) :: hdferr ! Error code:
|
||||
@ -767,10 +765,10 @@ CONTAINS
|
||||
!
|
||||
INTERFACE
|
||||
INTEGER FUNCTION h5lget_info_by_idx_c(loc_id, group_name, group_namelen, index_field, order, n, &
|
||||
link_type, corder_valid, corder, cset, address, val_size, lapl_id_default) &
|
||||
link_type, corder_valid, corder, cset, token, val_size, lapl_id_default) &
|
||||
BIND(C,NAME='h5lget_info_by_idx_c')
|
||||
IMPORT :: c_char
|
||||
IMPORT :: HID_T, SIZE_T, HSIZE_T, HADDR_T
|
||||
IMPORT :: HID_T, SIZE_T, HSIZE_T, H5O_TOKEN_T_F
|
||||
IMPLICIT NONE
|
||||
INTEGER(HID_T), INTENT(IN) :: loc_id
|
||||
CHARACTER(KIND=C_CHAR), DIMENSION(*), INTENT(IN) :: group_name
|
||||
@ -779,10 +777,10 @@ CONTAINS
|
||||
INTEGER, INTENT(IN) :: order
|
||||
INTEGER(HSIZE_T), INTENT(IN) :: n
|
||||
INTEGER, INTENT(OUT) :: link_type
|
||||
INTEGER :: corder_valid
|
||||
INTEGER :: corder_valid
|
||||
INTEGER, INTENT(OUT) :: corder
|
||||
INTEGER, INTENT(OUT) :: cset
|
||||
INTEGER(HADDR_T), INTENT(OUT) :: address
|
||||
TYPE(H5O_TOKEN_T_F), INTENT(OUT) :: token
|
||||
INTEGER(SIZE_T), INTENT(OUT) :: val_size
|
||||
INTEGER(HID_T) :: lapl_id_default
|
||||
END FUNCTION h5lget_info_by_idx_c
|
||||
@ -794,7 +792,7 @@ CONTAINS
|
||||
IF(PRESENT(lapl_id)) lapl_id_default = lapl_id
|
||||
|
||||
hdferr = h5lget_info_by_idx_c(loc_id, group_name, group_namelen, index_field, order, n, &
|
||||
link_type, corder_valid, corder, cset, address, val_size, lapl_id_default)
|
||||
link_type, corder_valid, corder, cset, token, val_size, lapl_id_default)
|
||||
|
||||
f_corder_valid =.FALSE.
|
||||
IF (corder_valid .EQ. 1) f_corder_valid =.TRUE.
|
||||
|
@ -22,10 +22,10 @@
|
||||
#include "H5f90.h"
|
||||
#include "H5Eprivate.h"
|
||||
int_f
|
||||
fill_h5o_info_t_f(H5O_info_t Oinfo, H5O_info_t_f *object_info);
|
||||
fill_h5o_info_t_f(H5O_info2_t Oinfo, H5O_info_t_f *object_info);
|
||||
|
||||
int_f
|
||||
fill_h5o_info_t_f(H5O_info_t Oinfo, H5O_info_t_f *object_info) {
|
||||
fill_h5o_info_t_f(H5O_info2_t Oinfo, H5O_info_t_f *object_info) {
|
||||
|
||||
/* This function does not used the field parameter because we want
|
||||
* this function to fill the unfilled fields with C's default values.
|
||||
@ -34,7 +34,7 @@ fill_h5o_info_t_f(H5O_info_t Oinfo, H5O_info_t_f *object_info) {
|
||||
struct tm *ts;
|
||||
|
||||
object_info->fileno = Oinfo.fileno;
|
||||
object_info->addr = (haddr_t_f)Oinfo.addr;
|
||||
object_info->token = Oinfo.token;
|
||||
|
||||
object_info->type = (int_f)Oinfo.type;
|
||||
object_info->rc = (int_f)Oinfo.rc;
|
||||
@ -85,24 +85,6 @@ fill_h5o_info_t_f(H5O_info_t Oinfo, H5O_info_t_f *object_info) {
|
||||
|
||||
object_info->num_attrs = (hsize_t_f)Oinfo.num_attrs;
|
||||
|
||||
object_info->hdr.version = (int_f)Oinfo.hdr.version;
|
||||
object_info->hdr.nmesgs = (int_f)Oinfo.hdr.nmesgs;
|
||||
object_info->hdr.nchunks = (int_f)Oinfo.hdr.nchunks;
|
||||
object_info->hdr.flags = (int_f)Oinfo.hdr.flags;
|
||||
|
||||
object_info->hdr.space.total = (hsize_t_f)Oinfo.hdr.space.total;
|
||||
object_info->hdr.space.meta = (hsize_t_f)Oinfo.hdr.space.meta;
|
||||
object_info->hdr.space.mesg = (hsize_t_f)Oinfo.hdr.space.mesg;
|
||||
object_info->hdr.space.free = (hsize_t_f)Oinfo.hdr.space.free;
|
||||
|
||||
object_info->hdr.mesg.present = Oinfo.hdr.mesg.present;
|
||||
object_info->hdr.mesg.shared = Oinfo.hdr.mesg.shared;
|
||||
|
||||
object_info->meta_size.obj.index_size = (hsize_t_f)Oinfo.meta_size.obj.index_size;
|
||||
object_info->meta_size.obj.heap_size = (hsize_t_f)Oinfo.meta_size.obj.heap_size;
|
||||
object_info->meta_size.attr.index_size = (hsize_t_f)Oinfo.meta_size.attr.index_size;
|
||||
object_info->meta_size.attr.heap_size = (hsize_t_f)Oinfo.meta_size.attr.heap_size;
|
||||
|
||||
return 0;
|
||||
|
||||
}
|
||||
@ -248,34 +230,35 @@ h5oclose_c ( hid_t_f *object_id )
|
||||
* SOURCE
|
||||
*/
|
||||
int_f
|
||||
h5ovisit_c(hid_t_f *group_id, int_f *index_type, int_f *order, H5O_iterate_t op, void *op_data, int_f *fields )
|
||||
h5ovisit_c(hid_t_f *group_id, int_f *index_type, int_f *order, H5O_iterate2_t op,
|
||||
void *op_data, int_f *fields )
|
||||
/******/
|
||||
{
|
||||
int_f ret_value = -1; /* Return value */
|
||||
herr_t func_ret_value; /* H5Linterate return value */
|
||||
|
||||
/*
|
||||
* Call H5Ovisit2
|
||||
* Call H5Ovisit
|
||||
*/
|
||||
|
||||
func_ret_value = H5Ovisit2( (hid_t)*group_id, (H5_index_t)*index_type, (H5_iter_order_t)*order, op, op_data, (unsigned)*fields);
|
||||
func_ret_value = H5Ovisit3( (hid_t)*group_id, (H5_index_t)*index_type, (H5_iter_order_t)*order, op, op_data, (unsigned)*fields);
|
||||
|
||||
ret_value = (int_f)func_ret_value;
|
||||
|
||||
return ret_value;
|
||||
}
|
||||
|
||||
/****if* H5Of/h5oopen_by_addr_c
|
||||
/****if* H5Of/h5oopen_by_token_c
|
||||
* NAME
|
||||
* h5oopen_by_addr_c
|
||||
* h5oopen_by_token_c
|
||||
* PURPOSE
|
||||
* Calls H5open_by_addr
|
||||
* Calls H5open_by_token
|
||||
* INPUTS
|
||||
* loc_id - File or group identifier
|
||||
* addr - Object’s address in the file
|
||||
* loc_id - File or group identifier
|
||||
* token - Object’s token in the file
|
||||
*
|
||||
* OUTPUTS
|
||||
* obj_id - Dataset identifier
|
||||
* obj_id - Object identifier
|
||||
*
|
||||
* RETURNS
|
||||
* 0 on success, -1 on failure
|
||||
@ -285,15 +268,15 @@ h5ovisit_c(hid_t_f *group_id, int_f *index_type, int_f *order, H5O_iterate_t op,
|
||||
* SOURCE
|
||||
*/
|
||||
int_f
|
||||
h5oopen_by_addr_c (hid_t_f *loc_id, haddr_t_f *addr, hid_t_f *obj_id)
|
||||
h5oopen_by_token_c(hid_t_f *loc_id, H5O_token_t *token, hid_t_f *obj_id)
|
||||
/******/
|
||||
{
|
||||
int_f ret_value = 0; /* Return value */
|
||||
|
||||
/*
|
||||
* Call H5Oopen_by_address function.
|
||||
* Call H5Oopen_by_token function.
|
||||
*/
|
||||
if((*obj_id = (hid_t_f)H5Oopen_by_addr((hid_t)*loc_id, (haddr_t)*addr)) < 0)
|
||||
if((*obj_id = (hid_t_f)H5Oopen_by_token((hid_t)*loc_id, *token)) < 0)
|
||||
HGOTO_DONE(FAIL);
|
||||
|
||||
done:
|
||||
@ -328,7 +311,7 @@ h5oget_info_by_name_c (hid_t_f *loc_id, _fcd name, size_t_f *namelen, hid_t_f *l
|
||||
{
|
||||
char *c_name = NULL; /* Buffer to hold C string */
|
||||
int_f ret_value = 0; /* Return value */
|
||||
H5O_info_t Oinfo;
|
||||
H5O_info2_t Oinfo;
|
||||
|
||||
/*
|
||||
* Convert FORTRAN name to C name
|
||||
@ -339,7 +322,7 @@ h5oget_info_by_name_c (hid_t_f *loc_id, _fcd name, size_t_f *namelen, hid_t_f *l
|
||||
/*
|
||||
* Call H5Oinfo_by_name function.
|
||||
*/
|
||||
if(H5Oget_info_by_name2((hid_t)*loc_id, c_name,
|
||||
if(H5Oget_info_by_name3((hid_t)*loc_id, c_name,
|
||||
&Oinfo, (unsigned)*fields, (hid_t)*lapl_id) < 0)
|
||||
HGOTO_DONE(FAIL);
|
||||
|
||||
@ -379,10 +362,10 @@ h5oget_info_by_idx_c (hid_t_f *loc_id, _fcd group_name, size_t_f *namelen,
|
||||
{
|
||||
char *c_group_name = NULL; /* Buffer to hold C string */
|
||||
int_f ret_value = 0; /* Return value */
|
||||
H5O_info_t Oinfo;
|
||||
H5O_info2_t Oinfo;
|
||||
H5_index_t c_index_field;
|
||||
H5_iter_order_t c_order;
|
||||
|
||||
|
||||
/*
|
||||
* Convert FORTRAN name to C name
|
||||
*/
|
||||
@ -395,7 +378,7 @@ h5oget_info_by_idx_c (hid_t_f *loc_id, _fcd group_name, size_t_f *namelen,
|
||||
/*
|
||||
* Call H5Oinfo_by_idx function.
|
||||
*/
|
||||
if(H5Oget_info_by_idx2((hid_t)*loc_id, c_group_name, c_index_field, c_order, (hsize_t)*n,
|
||||
if(H5Oget_info_by_idx3((hid_t)*loc_id, c_group_name, c_index_field, c_order, (hsize_t)*n,
|
||||
&Oinfo, (unsigned)*fields, (hid_t)*lapl_id) < 0)
|
||||
HGOTO_DONE(FAIL);
|
||||
|
||||
@ -430,12 +413,12 @@ h5oget_info_c (hid_t_f *object_id, H5O_info_t_f *object_info, int_f *fields)
|
||||
/******/
|
||||
{
|
||||
int_f ret_value = 0; /* Return value */
|
||||
H5O_info_t Oinfo;
|
||||
|
||||
H5O_info2_t Oinfo;
|
||||
|
||||
/*
|
||||
* Call H5Oinfo_by_name function.
|
||||
*/
|
||||
if(H5Oget_info2((hid_t)*object_id, &Oinfo, (unsigned)*fields) < 0)
|
||||
if(H5Oget_info3((hid_t)*object_id, &Oinfo, (unsigned)*fields) < 0)
|
||||
HGOTO_DONE(FAIL);
|
||||
|
||||
ret_value = fill_h5o_info_t_f(Oinfo,object_info);
|
||||
@ -528,7 +511,7 @@ h5ocopy_c (hid_t_f *src_loc_id, _fcd src_name, size_t_f *src_name_len,
|
||||
*/
|
||||
int_f
|
||||
h5ovisit_by_name_c(hid_t_f *loc_id, _fcd object_name, size_t_f *namelen, int_f *index_type, int_f *order,
|
||||
H5O_iterate_t op, void *op_data, hid_t_f *lapl_id, int_f *fields )
|
||||
H5O_iterate2_t op, void *op_data, hid_t_f *lapl_id, int_f *fields )
|
||||
/******/
|
||||
{
|
||||
int_f ret_value = -1; /* Return value */
|
||||
@ -542,9 +525,9 @@ h5ovisit_by_name_c(hid_t_f *loc_id, _fcd object_name, size_t_f *namelen, int_f
|
||||
HGOTO_DONE(FAIL);
|
||||
|
||||
/*
|
||||
* Call H5Ovisit
|
||||
* Call H5Ovisit_by_name
|
||||
*/
|
||||
func_ret_value = H5Ovisit_by_name2( (hid_t)*loc_id, c_object_name, (H5_index_t)*index_type, (H5_iter_order_t)*order,
|
||||
func_ret_value = H5Ovisit_by_name3( (hid_t)*loc_id, c_object_name, (H5_index_t)*index_type, (H5_iter_order_t)*order,
|
||||
op, op_data, (unsigned)*fields, (hid_t)*lapl_id);
|
||||
ret_value = (int_f)func_ret_value;
|
||||
|
||||
@ -934,3 +917,41 @@ h5oget_comment_by_name_c (hid_t_f *loc_id, _fcd name, size_t_f *name_size,
|
||||
|
||||
return ret_value;
|
||||
}
|
||||
|
||||
/****if* H5Of/h5otoken_cmp_c
|
||||
* NAME
|
||||
* h5otoken_cmp_c
|
||||
* PURPOSE
|
||||
* Calls H5Otoken_cmp
|
||||
* INPUTS
|
||||
* loc_id - Identifier of an object in the file / container.
|
||||
* token1 - The first token to compare.
|
||||
* token2 - The second token to compare.
|
||||
* cmp_value - Whether the tokens are equal.
|
||||
* RETURNS
|
||||
* 0 on success, -1 on failure
|
||||
* AUTHOR
|
||||
* Quincey Koziol
|
||||
* January 10, 2019
|
||||
* SOURCE
|
||||
*/
|
||||
int_f
|
||||
h5otoken_cmp_c(hid_t_f *loc_id, H5O_token_t *token1, H5O_token_t *token2,
|
||||
int_f *cmp_value_f)
|
||||
/******/
|
||||
{
|
||||
int cmp_value; /* Token comparison result */
|
||||
int_f ret_value = 0; /* Return value */
|
||||
|
||||
/* Call H5Otoken_cmp function */
|
||||
cmp_value = 0;
|
||||
if(H5Otoken_cmp((hid_t)*loc_id, token1, token2, &cmp_value) < 0)
|
||||
HGOTO_DONE(FAIL);
|
||||
|
||||
/* Set the comparison value to return */
|
||||
*cmp_value_f = cmp_value;
|
||||
|
||||
done:
|
||||
return ret_value;
|
||||
}
|
||||
|
||||
|
@ -44,7 +44,43 @@ MODULE H5O
|
||||
USE H5GLOBAL
|
||||
IMPLICIT NONE
|
||||
|
||||
!****t* H5T (F03)/h5o_info_t
|
||||
!****t* H5O (F03)/h5o_info_t
|
||||
!
|
||||
! Fortran2003 Derived Type:
|
||||
!
|
||||
TYPE, BIND(C) :: h5o_info_t
|
||||
INTEGER(C_LONG) :: fileno ! File number that object is located in
|
||||
TYPE(H5O_TOKEN_T_F) :: token ! Token for object in file
|
||||
INTEGER(C_INT) :: type ! Basic object type (group, dataset, etc.)
|
||||
INTEGER :: rc ! Reference count of object
|
||||
|
||||
INTEGER, DIMENSION(8) :: atime ! Access time ! -- NOTE --
|
||||
INTEGER, DIMENSION(8) :: mtime ! Modification time ! Returns an integer array
|
||||
INTEGER, DIMENSION(8) :: ctime ! Change time ! as specified in the Fortran
|
||||
INTEGER, DIMENSION(8) :: btime ! Birth time ! intrinsic DATE_AND_TIME(VALUES)
|
||||
|
||||
INTEGER(hsize_t) :: num_attrs ! # of attributes attached to object
|
||||
END TYPE h5o_info_t
|
||||
|
||||
! C interoperable structure for h5o_info_t. The Fortran derived type returns the time
|
||||
! values as an integer array as specified in the Fortran intrinsic DATE_AND_TIME(VALUES).
|
||||
! Whereas, this derived type does not.
|
||||
|
||||
TYPE, BIND(C) :: c_h5o_info_t
|
||||
INTEGER(C_LONG) :: fileno ! File number that object is located in
|
||||
TYPE(H5O_TOKEN_T_F) :: token ! Token for object in file
|
||||
INTEGER(C_INT) :: type ! Basic object type (group, dataset, etc.)
|
||||
INTEGER(C_INT) :: rc ! Reference count of object
|
||||
|
||||
INTEGER(KIND=TIME_T) :: atime ! Access time
|
||||
INTEGER(KIND=TIME_T) :: mtime ! Modify time
|
||||
INTEGER(KIND=TIME_T) :: ctime ! Create time
|
||||
INTEGER(KIND=TIME_T) :: btime ! Birth time
|
||||
|
||||
INTEGER(hsize_t) :: num_attrs ! # of attributes attached to object
|
||||
END TYPE c_h5o_info_t
|
||||
|
||||
!****t* H5O (F03)/h5o_native_info_t
|
||||
!
|
||||
! Fortran2003 Derived Type:
|
||||
!
|
||||
@ -59,13 +95,13 @@ MODULE H5O
|
||||
INTEGER(c_int64_t) :: present ! Flags to indicate presence of message type in header
|
||||
INTEGER(c_int64_t) :: shared ! Flags to indicate message type is shared in header
|
||||
END TYPE mesg_t
|
||||
|
||||
|
||||
TYPE, BIND(C) :: hdr_t
|
||||
INTEGER :: version ! Version number of header format in file
|
||||
INTEGER :: nmesgs ! Number of object header messages
|
||||
INTEGER :: nchunks ! Number of object header chunks
|
||||
INTEGER :: flags ! Object header status flags
|
||||
TYPE(space_t) :: space
|
||||
TYPE(space_t) :: space
|
||||
TYPE(mesg_t) :: mesg
|
||||
END TYPE hdr_t
|
||||
|
||||
@ -74,7 +110,7 @@ MODULE H5O
|
||||
INTEGER(C_INT) :: nmesgs ! Number of object header messages
|
||||
INTEGER(C_INT) :: nchunks ! Number of object header chunks
|
||||
INTEGER(C_INT) :: flags ! Object header status flags
|
||||
TYPE(space_t) :: space
|
||||
TYPE(space_t) :: space
|
||||
TYPE(mesg_t) :: mesg
|
||||
END TYPE c_hdr_t
|
||||
|
||||
@ -88,46 +124,17 @@ MODULE H5O
|
||||
TYPE(H5_ih_info_t) :: obj ! v1/v2 B-tree & local/fractal heap for groups, B-tree for chunked datasets
|
||||
TYPE(H5_ih_info_t) :: attr ! v2 B-tree & heap for attributes
|
||||
ENDTYPE meta_size_t
|
||||
|
||||
TYPE, BIND(C) :: h5o_info_t
|
||||
INTEGER(C_LONG) :: fileno ! File number that object is located in
|
||||
INTEGER(haddr_t) :: addr ! Object address in file
|
||||
INTEGER(C_INT) :: type ! Basic object type (group, dataset, etc.)
|
||||
INTEGER :: rc ! Reference count of object
|
||||
|
||||
INTEGER, DIMENSION(8) :: atime ! Access time ! -- NOTE --
|
||||
INTEGER, DIMENSION(8) :: mtime ! Modification time ! Returns an integer array
|
||||
INTEGER, DIMENSION(8) :: ctime ! Change time ! as specified in the Fortran
|
||||
INTEGER, DIMENSION(8) :: btime ! Birth time ! intrinsic DATE_AND_TIME(VALUES)
|
||||
|
||||
INTEGER(hsize_t) :: num_attrs ! # of attributes attached to object
|
||||
|
||||
TYPE, BIND(C) :: h5o_native_info_t
|
||||
TYPE(hdr_t) :: hdr
|
||||
|
||||
TYPE(meta_size_t) :: meta_size
|
||||
END TYPE h5o_info_t
|
||||
|
||||
! C interoperable structure for h5o_info_t. The Fortran derived type returns the time
|
||||
! values as an integer array as specified in the Fortran intrinsic DATE_AND_TIME(VALUES).
|
||||
! Whereas, this derived type does not.
|
||||
|
||||
TYPE, BIND(C) :: c_h5o_info_t
|
||||
INTEGER(C_LONG) :: fileno ! File number that object is located in
|
||||
INTEGER(haddr_t) :: addr ! Object address in file
|
||||
INTEGER(C_INT) :: type ! Basic object type (group, dataset, etc.)
|
||||
INTEGER(C_INT) :: rc ! Reference count of object
|
||||
|
||||
INTEGER(KIND=TIME_T) :: atime ! Access time
|
||||
INTEGER(KIND=TIME_T) :: mtime ! modify time
|
||||
INTEGER(KIND=TIME_T) :: ctime ! create time
|
||||
INTEGER(KIND=TIME_T) :: btime ! Access time
|
||||
|
||||
INTEGER(hsize_t) :: num_attrs ! # of attributes attached to object
|
||||
END TYPE h5o_native_info_t
|
||||
|
||||
! C interoperable structure for h5o_native_info_t.
|
||||
TYPE, BIND(C) :: c_h5o_native_info_t
|
||||
TYPE(c_hdr_t) :: hdr
|
||||
|
||||
TYPE(meta_size_t) :: meta_size
|
||||
END TYPE c_h5o_info_t
|
||||
END TYPE c_h5o_native_info_t
|
||||
|
||||
!*****
|
||||
|
||||
@ -292,46 +299,46 @@ CONTAINS
|
||||
END SUBROUTINE h5oclose_f
|
||||
|
||||
!
|
||||
!****s* H5O/h5open_by_addr_f
|
||||
! NAME
|
||||
! h5oopen_by_addr_f
|
||||
!****s* H5O/h5oopen_by_token_f
|
||||
! NAME
|
||||
! h5oopen_by_token_f
|
||||
!
|
||||
! PURPOSE
|
||||
! Opens an object using its address within an HDF5 file.
|
||||
! Opens an object using its token within an HDF5 file.
|
||||
!
|
||||
! Inputs:
|
||||
! Inputs:
|
||||
! loc_id - File or group identifier.
|
||||
! addr - Object’s address in the file.
|
||||
! token - Object’s token in the file.
|
||||
!
|
||||
! Outputs:
|
||||
! obj_id - Object identifier for the opened object.
|
||||
! hdferr - Returns 0 if successful and -1 if fails.
|
||||
!
|
||||
! AUTHOR
|
||||
! AUTHOR
|
||||
! M. Scot Breitenfeld
|
||||
! September 14, 2009
|
||||
!
|
||||
!
|
||||
! Fortran90 Interface:
|
||||
SUBROUTINE h5oopen_by_addr_f(loc_id, addr, obj_id, hdferr)
|
||||
SUBROUTINE h5oopen_by_token_f(loc_id, token, obj_id, hdferr)
|
||||
IMPLICIT NONE
|
||||
INTEGER(HID_T) , INTENT(IN) :: loc_id
|
||||
INTEGER(HADDR_T), INTENT(IN) :: addr
|
||||
INTEGER(HID_T) , INTENT(OUT) :: obj_id
|
||||
INTEGER , INTENT(OUT) :: hdferr
|
||||
INTEGER(HID_T) , INTENT(IN) :: loc_id
|
||||
TYPE(H5O_TOKEN_T_F), INTENT(IN) :: token
|
||||
INTEGER(HID_T) , INTENT(OUT) :: obj_id
|
||||
INTEGER , INTENT(OUT) :: hdferr
|
||||
!*****
|
||||
INTERFACE
|
||||
INTEGER FUNCTION h5oopen_by_addr_c(loc_id, addr, obj_id) BIND(C,NAME='h5oopen_by_addr_c')
|
||||
IMPORT :: HID_T, HADDR_T
|
||||
INTEGER FUNCTION h5oopen_by_token_c(loc_id, token, obj_id) BIND(C,NAME='h5oopen_by_token_c')
|
||||
IMPORT :: HID_T, H5O_TOKEN_T_F
|
||||
IMPLICIT NONE
|
||||
INTEGER(HID_T), INTENT(IN) :: loc_id
|
||||
INTEGER(HADDR_T), INTENT(IN) :: addr
|
||||
TYPE(H5O_TOKEN_T_F), INTENT(IN) :: token
|
||||
INTEGER(HID_T), INTENT(OUT) :: obj_id
|
||||
END FUNCTION h5oopen_by_addr_c
|
||||
END FUNCTION h5oopen_by_token_c
|
||||
END INTERFACE
|
||||
|
||||
hdferr = h5oopen_by_addr_c(loc_id, addr, obj_id)
|
||||
hdferr = h5oopen_by_token_c(loc_id, token, obj_id)
|
||||
|
||||
END SUBROUTINE h5oopen_by_addr_f
|
||||
END SUBROUTINE h5oopen_by_token_f
|
||||
!
|
||||
!****s* H5O/h5ocopy_f
|
||||
! NAME
|
||||
@ -966,7 +973,7 @@ CONTAINS
|
||||
CHARACTER(KIND=C_CHAR), DIMENSION(*), INTENT(IN) :: name
|
||||
INTEGER(SIZE_T) , INTENT(IN) :: namelen
|
||||
INTEGER(HID_T) , INTENT(IN) :: lapl_id_default
|
||||
TYPE(C_PTR),VALUE :: object_info
|
||||
TYPE(C_PTR), VALUE :: object_info
|
||||
INTEGER , INTENT(IN) :: fields
|
||||
END FUNCTION h5oget_info_by_name_c
|
||||
END INTERFACE
|
||||
@ -1212,5 +1219,50 @@ CONTAINS
|
||||
|
||||
END SUBROUTINE h5ovisit_by_name_f
|
||||
|
||||
!****s* H5O/h5otoken_cmp_f
|
||||
! NAME
|
||||
! h5otoken_cmp_f
|
||||
!
|
||||
! PURPOSE
|
||||
! Compare two tokens, which must be from the same file / containers.
|
||||
!
|
||||
! Inputs:
|
||||
! loc_id - Identifier of an object in the file / container.
|
||||
! token1 - The first token to compare.
|
||||
! token2 - The second token to compare.
|
||||
!
|
||||
! Outputs:
|
||||
! cmp_value - Returns 0 if tokens are equal, non-zero for unequal tokens.
|
||||
! hdferr - Returns 0 if successful and -1 if fails.
|
||||
!
|
||||
! AUTHOR
|
||||
! Quincey Koziol
|
||||
! January 10, 2019
|
||||
!
|
||||
! Fortran90 Interface:
|
||||
SUBROUTINE h5otoken_cmp_f(loc_id, token1, token2, cmp_value, hdferr)
|
||||
IMPLICIT NONE
|
||||
INTEGER(HID_T) , INTENT(IN) :: loc_id
|
||||
TYPE(H5O_TOKEN_T_F), INTENT(IN) :: token1 ! First token
|
||||
TYPE(H5O_TOKEN_T_F), INTENT(IN) :: token2 ! First token
|
||||
INTEGER , INTENT(OUT) :: cmp_value
|
||||
INTEGER , INTENT(OUT) :: hdferr
|
||||
!*****
|
||||
INTERFACE
|
||||
INTEGER FUNCTION h5otoken_cmp_c(loc_id, token1, token2, cmp_value) BIND(C,NAME='h5otoken_cmp_c')
|
||||
IMPORT :: HID_T, C_PTR, H5O_TOKEN_T_F
|
||||
IMPLICIT NONE
|
||||
INTEGER(HID_T), INTENT(IN) :: loc_id
|
||||
TYPE(H5O_TOKEN_T_F), INTENT(IN) :: token1 ! First token
|
||||
TYPE(H5O_TOKEN_T_F), INTENT(IN) :: token2 ! First token
|
||||
INTEGER, INTENT(OUT) :: cmp_value
|
||||
|
||||
END FUNCTION h5otoken_cmp_c
|
||||
END INTERFACE
|
||||
|
||||
hdferr = h5otoken_cmp_c(loc_id, token1, token2, cmp_value)
|
||||
|
||||
END SUBROUTINE h5otoken_cmp_f
|
||||
|
||||
END MODULE H5O
|
||||
|
||||
|
@ -167,10 +167,49 @@ CONTAINS
|
||||
END SUBROUTINE H5VLis_connector_registered_f
|
||||
|
||||
!
|
||||
!****s* H5VL/H5VLis_connector_registered_f
|
||||
!****s* H5VL/H5VLget_connector_id_f
|
||||
!
|
||||
! NAME
|
||||
! H5VLis_connector_registered_f
|
||||
! H5VLget_connector_id_f
|
||||
!
|
||||
! PURPOSE
|
||||
! Retrieves the ID for a registered VOL connector.
|
||||
!
|
||||
! INPUTS
|
||||
! obj_id - Object id
|
||||
! OUTPUTS
|
||||
! vol_id - Connector id
|
||||
! hdferr - Returns 0 if successful and -1 if fails
|
||||
! SOURCE
|
||||
|
||||
SUBROUTINE H5VLget_connector_id_f(obj_id, vol_id, hdferr)
|
||||
IMPLICIT NONE
|
||||
INTEGER(HID_T), INTENT(IN) :: obj_id
|
||||
INTEGER(HID_T), INTENT(OUT) :: vol_id
|
||||
INTEGER, INTENT(OUT) :: hdferr
|
||||
!*****
|
||||
|
||||
INTERFACE
|
||||
INTEGER(HID_T) FUNCTION H5VLget_connector_id(obj_id) BIND(C,NAME='H5VLget_connector_id')
|
||||
IMPORT :: HID_T
|
||||
INTEGER(HID_T), INTENT(IN) :: obj_id
|
||||
END FUNCTION H5VLget_connector_id
|
||||
END INTERFACE
|
||||
|
||||
vol_id = H5VLget_connector_id(obj_id)
|
||||
|
||||
IF(vol_id.LT.0)THEN
|
||||
hdferr = -1
|
||||
vol_id = H5I_INVALID_HID_F
|
||||
ENDIF
|
||||
|
||||
END SUBROUTINE H5VLget_connector_id_f
|
||||
|
||||
!
|
||||
!****s* H5VL/H5VLget_connector_id_by_name_f
|
||||
!
|
||||
! NAME
|
||||
! H5VLget_connector_id_by_name_f
|
||||
!
|
||||
! PURPOSE
|
||||
! Retrieves the ID for a registered VOL connector.
|
||||
@ -182,7 +221,7 @@ CONTAINS
|
||||
! hdferr - Returns 0 if successful and -1 if fails
|
||||
! SOURCE
|
||||
|
||||
SUBROUTINE H5VLget_connector_id_f(name, vol_id, hdferr)
|
||||
SUBROUTINE H5VLget_connector_id_by_name_f(name, vol_id, hdferr)
|
||||
IMPLICIT NONE
|
||||
CHARACTER(LEN=*), INTENT(IN) :: name
|
||||
INTEGER(HID_T), INTENT(OUT) :: vol_id
|
||||
@ -191,22 +230,23 @@ CONTAINS
|
||||
CHARACTER(LEN=LEN_TRIM(name)+1,KIND=C_CHAR) :: c_name
|
||||
|
||||
INTERFACE
|
||||
INTEGER(HID_T) FUNCTION H5VLget_connector_id(name) BIND(C,NAME='H5VLget_connector_id')
|
||||
INTEGER(HID_T) FUNCTION H5VLget_connector_id_by_name(name) BIND(C,NAME='H5VLget_connector_id_by_name')
|
||||
IMPORT :: C_CHAR
|
||||
IMPORT :: HID_T
|
||||
CHARACTER(KIND=C_CHAR), DIMENSION(*), INTENT(IN) :: name
|
||||
END FUNCTION H5VLget_connector_id
|
||||
END FUNCTION H5VLget_connector_id_by_name
|
||||
END INTERFACE
|
||||
|
||||
c_name = TRIM(name)//C_NULL_CHAR
|
||||
vol_id = H5VLget_connector_id(c_name)
|
||||
|
||||
vol_id = H5VLget_connector_id_by_name(c_name)
|
||||
|
||||
hdferr = 0
|
||||
IF(vol_id.LT.0)THEN
|
||||
hdferr = -1
|
||||
vol_id = H5I_INVALID_HID_F
|
||||
ENDIF
|
||||
|
||||
END SUBROUTINE H5VLget_connector_id_f
|
||||
END SUBROUTINE H5VLget_connector_id_by_name_f
|
||||
|
||||
SUBROUTINE H5VLget_connector_name_f(obj_id, name, hdferr, name_len)
|
||||
IMPLICIT NONE
|
||||
|
@ -56,7 +56,6 @@ h5init_types_c( hid_t_f * types, hid_t_f * floatingtypes, hid_t_f * integertypes
|
||||
{
|
||||
int ret_value = -1;
|
||||
hid_t c_type_id;
|
||||
size_t tmp_val;
|
||||
int i;
|
||||
|
||||
/* Fortran INTEGER may not be the same as C; do all checking to find
|
||||
@ -133,8 +132,7 @@ h5init_types_c( hid_t_f * types, hid_t_f * floatingtypes, hid_t_f * integertypes
|
||||
#endif
|
||||
|
||||
if ((c_type_id = H5Tcopy(H5T_FORTRAN_S1)) < 0) return ret_value;
|
||||
tmp_val = 1;
|
||||
if(H5Tset_size(c_type_id, tmp_val) < 0) return ret_value;
|
||||
if(H5Tset_size(c_type_id, 1) < 0) return ret_value;
|
||||
if(H5Tset_strpad(c_type_id, H5T_STR_SPACEPAD) < 0) return ret_value;
|
||||
types[8] = (hid_t_f)c_type_id;
|
||||
|
||||
@ -313,6 +311,7 @@ h5close_types_c( hid_t_f * types, int_f *lentypes,
|
||||
ret_value = 0;
|
||||
return ret_value;
|
||||
}
|
||||
|
||||
/****if* H5_f/h5init_flags_c
|
||||
* NAME
|
||||
* h5init_flags_c
|
||||
@ -370,7 +369,6 @@ h5init_flags_c( int_f *h5d_flags, size_t_f *h5d_size_flags,
|
||||
haddr_t_f *h5_haddr_generic_flags)
|
||||
/******/
|
||||
{
|
||||
int ret_value = -1;
|
||||
/*
|
||||
* H5D flags
|
||||
*/
|
||||
@ -538,196 +536,201 @@ h5init_flags_c( int_f *h5d_flags, size_t_f *h5d_size_flags,
|
||||
* but we need to assign each kind of message to a different bit so that
|
||||
* one index can hold multiple types.)
|
||||
*/
|
||||
h5o_flags[7] = (int_f)H5O_SHMESG_NONE_FLAG; /* No shared messages */
|
||||
h5o_flags[8] = (int_f)H5O_SHMESG_SDSPACE_FLAG; /* Simple Dataspace Message. */
|
||||
h5o_flags[9] = (int_f)H5O_SHMESG_DTYPE_FLAG; /* Datatype Message. */
|
||||
h5o_flags[10] = (int_f)H5O_SHMESG_FILL_FLAG; /* Fill Value Message. */
|
||||
h5o_flags[11] = (int_f)H5O_SHMESG_PLINE_FLAG; /* Filter pipeline message. */
|
||||
h5o_flags[12] = (int_f)H5O_SHMESG_ATTR_FLAG; /* Attribute Message. */
|
||||
h5o_flags[13] = (int_f)H5O_SHMESG_ALL_FLAG;
|
||||
h5o_flags[7] = (int_f)H5O_SHMESG_NONE_FLAG; /* No shared messages */
|
||||
h5o_flags[8] = (int_f)H5O_SHMESG_SDSPACE_FLAG; /* Simple Dataspace Message. */
|
||||
h5o_flags[9] = (int_f)H5O_SHMESG_DTYPE_FLAG; /* Datatype Message. */
|
||||
h5o_flags[10] = (int_f)H5O_SHMESG_FILL_FLAG; /* Fill Value Message. */
|
||||
h5o_flags[11] = (int_f)H5O_SHMESG_PLINE_FLAG; /* Filter pipeline message. */
|
||||
h5o_flags[12] = (int_f)H5O_SHMESG_ATTR_FLAG; /* Attribute Message. */
|
||||
h5o_flags[13] = (int_f)H5O_SHMESG_ALL_FLAG;
|
||||
|
||||
/* Object header status flag definitions */
|
||||
h5o_flags[14] = (int_f)H5O_HDR_CHUNK0_SIZE; /* 2-bit field indicating # of bytes to store the size of chunk 0's data */
|
||||
h5o_flags[15] = (int_f)H5O_HDR_ATTR_CRT_ORDER_TRACKED; /* Attribute creation order is tracked */
|
||||
h5o_flags[16] = (int_f)H5O_HDR_ATTR_CRT_ORDER_INDEXED; /* Attribute creation order has index */
|
||||
h5o_flags[17] = (int_f)H5O_HDR_ATTR_STORE_PHASE_CHANGE; /* Non-default attribute storage phase change values stored */
|
||||
h5o_flags[18] = (int_f)H5O_HDR_STORE_TIMES; /* Store access, modification, change & birth times for object */
|
||||
h5o_flags[19] = (int_f)H5O_HDR_ALL_FLAGS;
|
||||
h5o_flags[14] = (int_f)H5O_HDR_CHUNK0_SIZE; /* 2-bit field indicating # of bytes to store the size of chunk 0's data */
|
||||
h5o_flags[15] = (int_f)H5O_HDR_ATTR_CRT_ORDER_TRACKED; /* Attribute creation order is tracked */
|
||||
h5o_flags[16] = (int_f)H5O_HDR_ATTR_CRT_ORDER_INDEXED; /* Attribute creation order has index */
|
||||
h5o_flags[17] = (int_f)H5O_HDR_ATTR_STORE_PHASE_CHANGE; /* Non-default attribute storage phase change values stored */
|
||||
h5o_flags[18] = (int_f)H5O_HDR_STORE_TIMES; /* Store access, modification, change & birth times for object */
|
||||
h5o_flags[19] = (int_f)H5O_HDR_ALL_FLAGS;
|
||||
|
||||
/* Maximum shared message values. Number of indexes is 8 to allow room to add
|
||||
* new types of messages.
|
||||
*/
|
||||
h5o_flags[20] = (int_f)H5O_SHMESG_MAX_NINDEXES;
|
||||
h5o_flags[21] = (int_f)H5O_SHMESG_MAX_LIST_SIZE;
|
||||
h5o_flags[20] = (int_f)H5O_SHMESG_MAX_NINDEXES;
|
||||
h5o_flags[21] = (int_f)H5O_SHMESG_MAX_LIST_SIZE;
|
||||
|
||||
/* Types of objects in file */
|
||||
h5o_flags[22] = (int_f)H5O_TYPE_UNKNOWN; /* Unknown object type */
|
||||
h5o_flags[23] = (int_f)H5O_TYPE_GROUP; /* Object is a group */
|
||||
h5o_flags[24] = (int_f)H5O_TYPE_DATASET; /* Object is a dataset */
|
||||
h5o_flags[25] = (int_f)H5O_TYPE_NAMED_DATATYPE; /* Object is a named data type */
|
||||
h5o_flags[26] = (int_f)H5O_TYPE_NTYPES; /* Number of different object types */
|
||||
h5o_flags[22] = (int_f)H5O_TYPE_UNKNOWN; /* Unknown object type */
|
||||
h5o_flags[23] = (int_f)H5O_TYPE_GROUP; /* Object is a group */
|
||||
h5o_flags[24] = (int_f)H5O_TYPE_DATASET; /* Object is a dataset */
|
||||
h5o_flags[25] = (int_f)H5O_TYPE_NAMED_DATATYPE; /* Object is a named data type */
|
||||
h5o_flags[26] = (int_f)H5O_TYPE_NTYPES; /* Number of different object types */
|
||||
|
||||
/* Flags for H5Oget_info.
|
||||
* These flags determine which fields will be filled in in the H5O_info_t
|
||||
* struct.
|
||||
* struct.
|
||||
*/
|
||||
h5o_flags[27] = (int_f)H5O_INFO_ALL; /* (H5O_INFO_BASIC|H5O_INFO_TIME|H5O_INFO_NUM_ATTRS|H5O_INFO_HDR|H5O_INFO_META_SIZE) */
|
||||
h5o_flags[28] = (int_f)H5O_INFO_BASIC; /* Fill in the fileno, addr, type, and rc fields */
|
||||
h5o_flags[29] = (int_f)H5O_INFO_TIME; /* Fill in the atime, mtime, ctime, and btime fields */
|
||||
h5o_flags[30] = (int_f)H5O_INFO_NUM_ATTRS; /* Fill in the num_attrs field */
|
||||
h5o_flags[31] = (int_f)H5O_INFO_HDR; /* Fill in the hdr field */
|
||||
h5o_flags[32] = (int_f)H5O_INFO_META_SIZE; /* Fill in the meta_size field */
|
||||
h5o_flags[27] = (int_f)H5O_INFO_ALL; /* (H5O_INFO_BASIC|H5O_INFO_TIME|H5O_INFO_NUM_ATTRS) */
|
||||
h5o_flags[28] = (int_f)H5O_INFO_BASIC; /* Fill in the fileno, addr, type, and rc fields */
|
||||
h5o_flags[29] = (int_f)H5O_INFO_TIME; /* Fill in the atime, mtime, ctime, and btime fields */
|
||||
h5o_flags[30] = (int_f)H5O_INFO_NUM_ATTRS; /* Fill in the num_attrs field */
|
||||
|
||||
/* Flags for H5Oget_native_info.
|
||||
* These flags determine which fields will be filled in in the H5O_native_info_t
|
||||
* struct.
|
||||
*/
|
||||
h5o_flags[31] = (int_f)H5O_NATIVE_INFO_ALL; /* (H5O_NATIVE_INFO_HDR|H5O_NATIVE_INFO_META_SIZE) */
|
||||
h5o_flags[32] = (int_f)H5O_NATIVE_INFO_HDR; /* Fill in the hdr field */
|
||||
h5o_flags[33] = (int_f)H5O_NATIVE_INFO_META_SIZE; /* Fill in the meta_size field */
|
||||
/*
|
||||
* H5P flags
|
||||
*/
|
||||
h5p_flags[0] = (hid_t_f)H5P_FILE_CREATE;
|
||||
h5p_flags[1] = (hid_t_f)H5P_FILE_ACCESS;
|
||||
h5p_flags[2] = (hid_t_f)H5P_DATASET_CREATE;
|
||||
h5p_flags[3] = (hid_t_f)H5P_DATASET_XFER;
|
||||
h5p_flags[4] = (hid_t_f)H5P_FILE_MOUNT;
|
||||
h5p_flags[5] = (hid_t_f)H5P_DEFAULT;
|
||||
h5p_flags[6] = (hid_t_f)H5P_ROOT;
|
||||
h5p_flags[7] = (hid_t_f)H5P_OBJECT_CREATE;
|
||||
h5p_flags[8] = (hid_t_f)H5P_DATASET_ACCESS;
|
||||
h5p_flags[9] = (hid_t_f)H5P_GROUP_CREATE;
|
||||
h5p_flags[10] = (hid_t_f)H5P_GROUP_ACCESS;
|
||||
h5p_flags[11] = (hid_t_f)H5P_DATATYPE_CREATE;
|
||||
h5p_flags[12] = (hid_t_f)H5P_DATATYPE_ACCESS;
|
||||
h5p_flags[13] = (hid_t_f)H5P_STRING_CREATE;
|
||||
h5p_flags[14] = (hid_t_f)H5P_ATTRIBUTE_CREATE;
|
||||
h5p_flags[15] = (hid_t_f)H5P_OBJECT_COPY;
|
||||
h5p_flags[16] = (hid_t_f)H5P_LINK_CREATE;
|
||||
h5p_flags[17] = (hid_t_f)H5P_LINK_ACCESS;
|
||||
h5p_flags[0] = (hid_t_f)H5P_FILE_CREATE;
|
||||
h5p_flags[1] = (hid_t_f)H5P_FILE_ACCESS;
|
||||
h5p_flags[2] = (hid_t_f)H5P_DATASET_CREATE;
|
||||
h5p_flags[3] = (hid_t_f)H5P_DATASET_XFER;
|
||||
h5p_flags[4] = (hid_t_f)H5P_FILE_MOUNT;
|
||||
h5p_flags[5] = (hid_t_f)H5P_DEFAULT;
|
||||
h5p_flags[6] = (hid_t_f)H5P_ROOT;
|
||||
h5p_flags[7] = (hid_t_f)H5P_OBJECT_CREATE;
|
||||
h5p_flags[8] = (hid_t_f)H5P_DATASET_ACCESS;
|
||||
h5p_flags[9] = (hid_t_f)H5P_GROUP_CREATE;
|
||||
h5p_flags[10] = (hid_t_f)H5P_GROUP_ACCESS;
|
||||
h5p_flags[11] = (hid_t_f)H5P_DATATYPE_CREATE;
|
||||
h5p_flags[12] = (hid_t_f)H5P_DATATYPE_ACCESS;
|
||||
h5p_flags[13] = (hid_t_f)H5P_STRING_CREATE;
|
||||
h5p_flags[14] = (hid_t_f)H5P_ATTRIBUTE_CREATE;
|
||||
h5p_flags[15] = (hid_t_f)H5P_OBJECT_COPY;
|
||||
h5p_flags[16] = (hid_t_f)H5P_LINK_CREATE;
|
||||
h5p_flags[17] = (hid_t_f)H5P_LINK_ACCESS;
|
||||
|
||||
|
||||
/*
|
||||
* H5P integer flags
|
||||
*/
|
||||
h5p_flags_int[0] = (int_f)H5P_CRT_ORDER_INDEXED;
|
||||
h5p_flags_int[1] = (int_f)H5P_CRT_ORDER_TRACKED;
|
||||
h5p_flags_int[0] = (int_f)H5P_CRT_ORDER_INDEXED;
|
||||
h5p_flags_int[1] = (int_f)H5P_CRT_ORDER_TRACKED;
|
||||
|
||||
/*
|
||||
* H5R flags
|
||||
*/
|
||||
|
||||
h5r_flags[0] = (int_f)H5R_OBJECT;
|
||||
h5r_flags[1] = (int_f)H5R_DATASET_REGION;
|
||||
h5r_flags[0] = (int_f)H5R_OBJECT;
|
||||
h5r_flags[1] = (int_f)H5R_DATASET_REGION;
|
||||
|
||||
/*
|
||||
* H5S flags
|
||||
*/
|
||||
|
||||
h5s_hid_flags[0] = (hid_t_f)H5S_ALL;
|
||||
h5s_hid_flags[0] = (hid_t_f)H5S_ALL;
|
||||
|
||||
h5s_hsize_flags[0] = (hsize_t_f)H5S_UNLIMITED;
|
||||
h5s_hsize_flags[0] = (hsize_t_f)H5S_UNLIMITED;
|
||||
|
||||
h5s_flags[0] = (int_f)H5S_SCALAR;
|
||||
h5s_flags[1] = (int_f)H5S_SIMPLE;
|
||||
h5s_flags[2] = (int_f)H5S_NULL;
|
||||
h5s_flags[3] = (int_f)H5S_SELECT_SET;
|
||||
h5s_flags[4] = (int_f)H5S_SELECT_OR;
|
||||
h5s_flags[0] = (int_f)H5S_SCALAR;
|
||||
h5s_flags[1] = (int_f)H5S_SIMPLE;
|
||||
h5s_flags[2] = (int_f)H5S_NULL;
|
||||
h5s_flags[3] = (int_f)H5S_SELECT_SET;
|
||||
h5s_flags[4] = (int_f)H5S_SELECT_OR;
|
||||
|
||||
h5s_flags[5] = (int_f)H5S_SELECT_NOOP;
|
||||
h5s_flags[6] = (int_f)H5S_SELECT_AND;
|
||||
h5s_flags[7] = (int_f)H5S_SELECT_XOR;
|
||||
h5s_flags[8] = (int_f)H5S_SELECT_NOTB;
|
||||
h5s_flags[9] = (int_f)H5S_SELECT_NOTA;
|
||||
h5s_flags[5] = (int_f)H5S_SELECT_NOOP;
|
||||
h5s_flags[6] = (int_f)H5S_SELECT_AND;
|
||||
h5s_flags[7] = (int_f)H5S_SELECT_XOR;
|
||||
h5s_flags[8] = (int_f)H5S_SELECT_NOTB;
|
||||
h5s_flags[9] = (int_f)H5S_SELECT_NOTA;
|
||||
|
||||
h5s_flags[10] = (int_f)H5S_SELECT_APPEND;
|
||||
h5s_flags[11] = (int_f)H5S_SELECT_PREPEND;
|
||||
h5s_flags[12] = (int_f)H5S_SELECT_INVALID;
|
||||
h5s_flags[13] = (int_f)H5S_SEL_ERROR;
|
||||
h5s_flags[14] = (int_f)H5S_SEL_NONE;
|
||||
h5s_flags[10] = (int_f)H5S_SELECT_APPEND;
|
||||
h5s_flags[11] = (int_f)H5S_SELECT_PREPEND;
|
||||
h5s_flags[12] = (int_f)H5S_SELECT_INVALID;
|
||||
h5s_flags[13] = (int_f)H5S_SEL_ERROR;
|
||||
h5s_flags[14] = (int_f)H5S_SEL_NONE;
|
||||
|
||||
h5s_flags[15] = (int_f)H5S_SEL_POINTS;
|
||||
h5s_flags[16] = (int_f)H5S_SEL_HYPERSLABS;
|
||||
h5s_flags[17] = (int_f)H5S_SEL_ALL;
|
||||
|
||||
h5s_flags[15] = (int_f)H5S_SEL_POINTS;
|
||||
h5s_flags[16] = (int_f)H5S_SEL_HYPERSLABS;
|
||||
h5s_flags[17] = (int_f)H5S_SEL_ALL;
|
||||
/*
|
||||
* H5T flags
|
||||
*/
|
||||
h5t_flags[0] = (int_f)H5T_NO_CLASS;
|
||||
h5t_flags[1] = (int_f)H5T_INTEGER;
|
||||
h5t_flags[2] = (int_f)H5T_FLOAT;
|
||||
h5t_flags[3] = (int_f)H5T_TIME;
|
||||
h5t_flags[4] = (int_f)H5T_STRING;
|
||||
h5t_flags[5] = (int_f)H5T_BITFIELD;
|
||||
h5t_flags[6] = (int_f)H5T_OPAQUE;
|
||||
h5t_flags[7] = (int_f)H5T_COMPOUND;
|
||||
h5t_flags[8] = (int_f)H5T_REFERENCE;
|
||||
h5t_flags[9] = (int_f)H5T_ENUM;
|
||||
h5t_flags[10] = (int_f)H5T_ORDER_LE;
|
||||
h5t_flags[11] = (int_f)H5T_ORDER_BE;
|
||||
h5t_flags[12] = (int_f)H5T_ORDER_MIXED;
|
||||
h5t_flags[13] = (int_f)H5T_ORDER_VAX;
|
||||
h5t_flags[14] = (int_f)H5T_ORDER_NONE;
|
||||
h5t_flags[15] = (int_f)H5T_PAD_ZERO;
|
||||
h5t_flags[16] = (int_f)H5T_PAD_ONE;
|
||||
h5t_flags[17] = (int_f)H5T_PAD_BACKGROUND;
|
||||
h5t_flags[18] = (int_f)H5T_PAD_ERROR;
|
||||
h5t_flags[19] = (int_f)H5T_SGN_NONE;
|
||||
h5t_flags[20] = (int_f)H5T_SGN_2;
|
||||
h5t_flags[21] = (int_f)H5T_SGN_ERROR;
|
||||
h5t_flags[22] = (int_f)H5T_NORM_IMPLIED;
|
||||
h5t_flags[23] = (int_f)H5T_NORM_MSBSET;
|
||||
h5t_flags[24] = (int_f)H5T_NORM_NONE;
|
||||
h5t_flags[25] = (int_f)H5T_CSET_ASCII;
|
||||
h5t_flags[26] = (int_f)H5T_CSET_UTF8;
|
||||
h5t_flags[27] = (int_f)H5T_STR_NULLTERM;
|
||||
h5t_flags[28] = (int_f)H5T_STR_NULLPAD;
|
||||
h5t_flags[29] = (int_f)H5T_STR_SPACEPAD;
|
||||
h5t_flags[30] = (int_f)H5T_STR_ERROR;
|
||||
h5t_flags[31] = (int_f)H5T_VLEN;
|
||||
h5t_flags[32] = (int_f)H5T_ARRAY;
|
||||
h5t_flags[33] = (int_f)H5T_DIR_ASCEND;
|
||||
h5t_flags[34] = (int_f)H5T_DIR_DESCEND;
|
||||
h5t_flags[0] = (int_f)H5T_NO_CLASS;
|
||||
h5t_flags[1] = (int_f)H5T_INTEGER;
|
||||
h5t_flags[2] = (int_f)H5T_FLOAT;
|
||||
h5t_flags[3] = (int_f)H5T_TIME;
|
||||
h5t_flags[4] = (int_f)H5T_STRING;
|
||||
h5t_flags[5] = (int_f)H5T_BITFIELD;
|
||||
h5t_flags[6] = (int_f)H5T_OPAQUE;
|
||||
h5t_flags[7] = (int_f)H5T_COMPOUND;
|
||||
h5t_flags[8] = (int_f)H5T_REFERENCE;
|
||||
h5t_flags[9] = (int_f)H5T_ENUM;
|
||||
h5t_flags[10] = (int_f)H5T_ORDER_LE;
|
||||
h5t_flags[11] = (int_f)H5T_ORDER_BE;
|
||||
h5t_flags[12] = (int_f)H5T_ORDER_MIXED;
|
||||
h5t_flags[13] = (int_f)H5T_ORDER_VAX;
|
||||
h5t_flags[14] = (int_f)H5T_ORDER_NONE;
|
||||
h5t_flags[15] = (int_f)H5T_PAD_ZERO;
|
||||
h5t_flags[16] = (int_f)H5T_PAD_ONE;
|
||||
h5t_flags[17] = (int_f)H5T_PAD_BACKGROUND;
|
||||
h5t_flags[18] = (int_f)H5T_PAD_ERROR;
|
||||
h5t_flags[19] = (int_f)H5T_SGN_NONE;
|
||||
h5t_flags[20] = (int_f)H5T_SGN_2;
|
||||
h5t_flags[21] = (int_f)H5T_SGN_ERROR;
|
||||
h5t_flags[22] = (int_f)H5T_NORM_IMPLIED;
|
||||
h5t_flags[23] = (int_f)H5T_NORM_MSBSET;
|
||||
h5t_flags[24] = (int_f)H5T_NORM_NONE;
|
||||
h5t_flags[25] = (int_f)H5T_CSET_ASCII;
|
||||
h5t_flags[26] = (int_f)H5T_CSET_UTF8;
|
||||
h5t_flags[27] = (int_f)H5T_STR_NULLTERM;
|
||||
h5t_flags[28] = (int_f)H5T_STR_NULLPAD;
|
||||
h5t_flags[29] = (int_f)H5T_STR_SPACEPAD;
|
||||
h5t_flags[30] = (int_f)H5T_STR_ERROR;
|
||||
h5t_flags[31] = (int_f)H5T_VLEN;
|
||||
h5t_flags[32] = (int_f)H5T_ARRAY;
|
||||
h5t_flags[33] = (int_f)H5T_DIR_ASCEND;
|
||||
h5t_flags[34] = (int_f)H5T_DIR_DESCEND;
|
||||
|
||||
/*
|
||||
* H5Z flags
|
||||
*/
|
||||
h5z_flags[0] = (int_f)H5Z_FILTER_ERROR;
|
||||
h5z_flags[1] = (int_f)H5Z_FILTER_NONE;
|
||||
h5z_flags[2] = (int_f)H5Z_FILTER_DEFLATE;
|
||||
h5z_flags[3] = (int_f)H5Z_FILTER_SHUFFLE;
|
||||
h5z_flags[4] = (int_f)H5Z_FILTER_FLETCHER32;
|
||||
h5z_flags[5] = (int_f)H5Z_ERROR_EDC;
|
||||
h5z_flags[6] = (int_f)H5Z_DISABLE_EDC;
|
||||
h5z_flags[7] = (int_f)H5Z_ENABLE_EDC;
|
||||
h5z_flags[8] = (int_f)H5Z_NO_EDC;
|
||||
h5z_flags[9] = (int_f)H5Z_FILTER_SZIP;
|
||||
h5z_flags[10] = (int_f)H5Z_FLAG_OPTIONAL;
|
||||
h5z_flags[11] = (int_f)H5Z_FILTER_CONFIG_ENCODE_ENABLED;
|
||||
h5z_flags[12] = (int_f)H5Z_FILTER_CONFIG_DECODE_ENABLED;
|
||||
h5z_flags[13] = (int_f)H5Z_FILTER_ALL;
|
||||
h5z_flags[14] = (int_f)H5Z_FILTER_NBIT;
|
||||
h5z_flags[15] = (int_f)H5Z_FILTER_SCALEOFFSET;
|
||||
h5z_flags[16] = (int_f)H5Z_SO_FLOAT_DSCALE;
|
||||
h5z_flags[17] = (int_f)H5Z_SO_FLOAT_ESCALE;
|
||||
h5z_flags[18] = (int_f)H5Z_SO_INT;
|
||||
h5z_flags[19] = (int_f)H5Z_SO_INT_MINBITS_DEFAULT;
|
||||
h5z_flags[0] = (int_f)H5Z_FILTER_ERROR;
|
||||
h5z_flags[1] = (int_f)H5Z_FILTER_NONE;
|
||||
h5z_flags[2] = (int_f)H5Z_FILTER_DEFLATE;
|
||||
h5z_flags[3] = (int_f)H5Z_FILTER_SHUFFLE;
|
||||
h5z_flags[4] = (int_f)H5Z_FILTER_FLETCHER32;
|
||||
h5z_flags[5] = (int_f)H5Z_ERROR_EDC;
|
||||
h5z_flags[6] = (int_f)H5Z_DISABLE_EDC;
|
||||
h5z_flags[7] = (int_f)H5Z_ENABLE_EDC;
|
||||
h5z_flags[8] = (int_f)H5Z_NO_EDC;
|
||||
h5z_flags[9] = (int_f)H5Z_FILTER_SZIP;
|
||||
h5z_flags[10] = (int_f)H5Z_FLAG_OPTIONAL;
|
||||
h5z_flags[11] = (int_f)H5Z_FILTER_CONFIG_ENCODE_ENABLED;
|
||||
h5z_flags[12] = (int_f)H5Z_FILTER_CONFIG_DECODE_ENABLED;
|
||||
h5z_flags[13] = (int_f)H5Z_FILTER_ALL;
|
||||
h5z_flags[14] = (int_f)H5Z_FILTER_NBIT;
|
||||
h5z_flags[15] = (int_f)H5Z_FILTER_SCALEOFFSET;
|
||||
h5z_flags[16] = (int_f)H5Z_SO_FLOAT_DSCALE;
|
||||
h5z_flags[17] = (int_f)H5Z_SO_FLOAT_ESCALE;
|
||||
h5z_flags[18] = (int_f)H5Z_SO_INT;
|
||||
h5z_flags[19] = (int_f)H5Z_SO_INT_MINBITS_DEFAULT;
|
||||
|
||||
/*
|
||||
* H5 Generic flags introduced in version 1.8
|
||||
*/
|
||||
|
||||
/* H5_index_t enum struct */
|
||||
/* H5_index_t enum struct */
|
||||
|
||||
h5_generic_flags[0] = (int_f)H5_INDEX_UNKNOWN; /* Unknown index type */
|
||||
h5_generic_flags[1] = (int_f)H5_INDEX_NAME; /* Index on names */
|
||||
h5_generic_flags[2] = (int_f)H5_INDEX_CRT_ORDER; /* Index on creation order */
|
||||
h5_generic_flags[3] = (int_f)H5_INDEX_N; /* Index on creation order */
|
||||
h5_generic_flags[0] = (int_f)H5_INDEX_UNKNOWN; /* Unknown index type */
|
||||
h5_generic_flags[1] = (int_f)H5_INDEX_NAME; /* Index on names */
|
||||
h5_generic_flags[2] = (int_f)H5_INDEX_CRT_ORDER; /* Index on creation order */
|
||||
h5_generic_flags[3] = (int_f)H5_INDEX_N; /* Index on creation order */
|
||||
|
||||
|
||||
/* H5_iter_order_t enum struct */
|
||||
/* H5_iter_order_t enum struct */
|
||||
|
||||
h5_generic_flags[4] = (int_f)H5_ITER_UNKNOWN; /* Unknown order */
|
||||
h5_generic_flags[5] = (int_f)H5_ITER_INC; /* Increasing order */
|
||||
h5_generic_flags[6] = (int_f)H5_ITER_DEC; /* Decreasing order */
|
||||
h5_generic_flags[7] = (int_f)H5_ITER_NATIVE; /* No particular order, whatever is fastest */
|
||||
h5_generic_flags[8] = (int_f)H5_ITER_N; /* Number of iteration orders */
|
||||
h5_generic_flags[4] = (int_f)H5_ITER_UNKNOWN; /* Unknown order */
|
||||
h5_generic_flags[5] = (int_f)H5_ITER_INC; /* Increasing order */
|
||||
h5_generic_flags[6] = (int_f)H5_ITER_DEC; /* Decreasing order */
|
||||
h5_generic_flags[7] = (int_f)H5_ITER_NATIVE; /* No particular order, whatever is fastest */
|
||||
h5_generic_flags[8] = (int_f)H5_ITER_N; /* Number of iteration orders */
|
||||
|
||||
h5_haddr_generic_flags[0] = (haddr_t_f)HADDR_UNDEF; /* undefined address */
|
||||
h5_haddr_generic_flags[0] = (haddr_t_f)HADDR_UNDEF; /* undefined address */
|
||||
|
||||
ret_value = 0;
|
||||
return ret_value;
|
||||
return 0;
|
||||
}
|
||||
|
||||
int_f
|
||||
|
@ -25,5 +25,8 @@
|
||||
|
||||
/* Constants used in H5Gf.c files */
|
||||
#define OBJECT_NAMELEN_DEFAULT_F -1
|
||||
|
||||
#define H5_MAX(a,b) (((a)>(b)) ? (a) : (b))
|
||||
|
||||
#endif /* _H5f90_H */
|
||||
|
||||
|
@ -54,6 +54,7 @@ MODULE H5GLOBAL
|
||||
! If you change the value of these parameters, do not forget to change corresponding
|
||||
! values in the H5f90.h file.
|
||||
INTEGER, PARAMETER :: REF_REG_BUF_LEN = 3
|
||||
INTEGER, PARAMETER :: H5O_TOKEN_BUF_LEN = 16 ! Matches C defined value in H5public.h
|
||||
|
||||
! Parameters used in the function 'h5kind_to_type' located in H5_ff.F90.
|
||||
! The flag is used to tell the function whether the kind input variable
|
||||
@ -70,13 +71,17 @@ MODULE H5GLOBAL
|
||||
INTEGER, DIMENSION(1:REF_REG_BUF_LEN) :: ref
|
||||
END TYPE hdset_reg_ref_t_f
|
||||
|
||||
TYPE, BIND(C) :: h5o_token_t_f
|
||||
INTEGER(C_INT8_T), DIMENSION(1:H5O_TOKEN_BUF_LEN) :: token
|
||||
END TYPE h5o_token_t_f
|
||||
|
||||
! Do not forget to change these values when new predefined
|
||||
! datatypes are added
|
||||
INTEGER, PARAMETER :: PREDEF_TYPES_LEN = 19
|
||||
INTEGER, PARAMETER :: FLOATING_TYPES_LEN = 4
|
||||
INTEGER, PARAMETER :: INTEGER_TYPES_LEN = 27
|
||||
|
||||
! These arrays need to be global because they are used in
|
||||
! These arrays need to be global because they are used in
|
||||
! both h5open_f and in h5close_f; initialize to fix linking issues
|
||||
! on OSX and Intel compilers.
|
||||
INTEGER(HID_T), DIMENSION(1:PREDEF_TYPES_LEN) :: predef_types = -1
|
||||
|
@ -21,8 +21,7 @@
|
||||
*/
|
||||
#include "H5f90i_gen.h"
|
||||
|
||||
/* Define _fcd. These are the same on every system
|
||||
* but UNICOS.
|
||||
/* Define _fcd. These are the same on every system but UNICOS.
|
||||
*/
|
||||
#define _fcdtocp(desc) (desc)
|
||||
|
||||
|
@ -23,7 +23,7 @@ H5_FCDLL void HD5packFstring(char *src, char *dest, size_t len);
|
||||
|
||||
|
||||
/*
|
||||
* Storage info struct used by H5O_info_t and H5F_info_t
|
||||
* Storage info struct used by H5O_info_t and H5F_info_t
|
||||
* interoperable with Fortran.
|
||||
*/
|
||||
typedef struct H5_ih_info_t_f {
|
||||
@ -31,7 +31,7 @@ typedef struct H5_ih_info_t_f {
|
||||
hsize_t heap_size;
|
||||
} H5_ih_info_t_f;
|
||||
|
||||
/* Information struct for object header metadata (for H5Oget_info/H5Oget_info_by_name/H5Oget_info_by_idx)
|
||||
/* Information struct for object header metadata (for H5Oget_info/H5Oget_info_by_name/H5Oget_info_by_idx)
|
||||
* interoperable with Fortran.
|
||||
*/
|
||||
typedef struct H5O_hdr_info_t_f {
|
||||
@ -51,12 +51,11 @@ typedef struct H5O_hdr_info_t_f {
|
||||
} mesg;
|
||||
} H5O_hdr_info_t_f;
|
||||
|
||||
/* Information struct for object (for H5Oget_info/H5Oget_info_by_name/H5Oget_info_by_idx)
|
||||
* interoperable with Fortran.
|
||||
/* Information struct for object (for H5Oget_info/H5Oget_info_by_name/H5Oget_info_by_idx)
|
||||
*/
|
||||
typedef struct H5O_info_t_f {
|
||||
unsigned long fileno; /* File number that object is located in */
|
||||
haddr_t_f addr; /* Object address in file */
|
||||
H5O_token_t token; /* Token of object in file */
|
||||
int type; /* Basic object type (group, dataset, etc.) */
|
||||
int_f rc; /* Reference count of object */
|
||||
int_f atime[8]; /* Access time */
|
||||
@ -64,13 +63,18 @@ typedef struct H5O_info_t_f {
|
||||
int_f ctime[8]; /* Change time */
|
||||
int_f btime[8]; /* Birth time */
|
||||
hsize_t num_attrs; /* # of attributes attached to object */
|
||||
} H5O_info_t_f;
|
||||
|
||||
/* Information struct for native object (for H5Oget_native_info/H5Oget_native_info_by_name/H5Oget_native_info_by_idx)
|
||||
*/
|
||||
typedef struct H5O_native_info_t_f {
|
||||
H5O_hdr_info_t_f hdr; /* Object header information */
|
||||
/* Extra metadata storage for obj & attributes */
|
||||
struct {
|
||||
H5_ih_info_t_f obj; /* v1/v2 B-tree & local/fractal heap for groups, B-tree for chunked datasets */
|
||||
H5_ih_info_t_f attr; /* v2 B-tree & heap for attributes */
|
||||
} meta_size;
|
||||
} H5O_info_t_f;
|
||||
} H5O_native_info_t_f;
|
||||
|
||||
|
||||
/*
|
||||
@ -312,12 +316,12 @@ H5_FCDLL int_f h5tconvert_c(hid_t_f *src_id, hid_t_f *dst_id, size_t_f *nelmts,
|
||||
|
||||
H5_FCDLL int_f h5oopen_c(hid_t_f *loc_id, _fcd name, size_t_f *namelen, hid_t_f *lapl_id, hid_t_f *obj_id);
|
||||
H5_FCDLL int_f h5oclose_c(hid_t_f *object_id );
|
||||
H5_FCDLL int_f h5oopen_by_addr_c(hid_t_f *loc_id, haddr_t_f *addr, hid_t_f *obj_id);
|
||||
H5_FCDLL int_f h5oopen_by_token_c(hid_t_f *loc_id, H5O_token_t *token, hid_t_f *obj_id);
|
||||
H5_FCDLL int_f h5olink_c(hid_t_f *object_id, hid_t_f *new_loc_id, _fcd name, size_t_f *namelen,
|
||||
hid_t_f *lcpl_id, hid_t_f *lapl_id);
|
||||
H5_FCDLL int_f h5ovisit_c(hid_t_f *group_id, int_f *index_type, int_f *order, H5O_iterate_t op, void *op_data, int_f *fields);
|
||||
H5_FCDLL int_f h5ovisit_c(hid_t_f *group_id, int_f *index_type, int_f *order, H5O_iterate2_t op, void *op_data, int_f *fields);
|
||||
H5_FCDLL int_f h5ovisit_by_name_c(hid_t_f *loc_id, _fcd object_name, size_t_f *namelen, int_f *index_type, int_f *order,
|
||||
H5O_iterate_t op, void *op_data, hid_t_f *lapl_id, int_f *fields );
|
||||
H5O_iterate2_t op, void *op_data, hid_t_f *lapl_id, int_f *fields );
|
||||
H5_FCDLL int_f h5oget_info_c(hid_t_f *object_id, H5O_info_t_f *object_info, int_f *fields);
|
||||
H5_FCDLL int_f h5oget_info_by_idx_c(hid_t_f *loc_id, _fcd group_name, size_t_f *namelen,
|
||||
int_f *index_field, int_f *order, hsize_t_f *n, hid_t_f *lapl_id, H5O_info_t_f *object_info, int_f *fields);
|
||||
@ -336,6 +340,8 @@ H5_FCDLL int_f h5oopen_by_idx_c(hid_t_f *loc_id, _fcd group_name, size_t_f *gro
|
||||
H5_FCDLL int_f h5oget_comment_c(hid_t_f *object_id, _fcd comment, size_t_f *commentsize, hssize_t_f *bufsize);
|
||||
H5_FCDLL int_f h5oget_comment_by_name_c(hid_t_f *loc_id, _fcd name, size_t_f *name_size,
|
||||
_fcd comment, size_t_f *commentsize, size_t_f *bufsize, hid_t_f *lapl_id);
|
||||
H5_FCDLL int_f h5otoken_cmp_c(hid_t_f *loc_id, H5O_token_t *token1,
|
||||
H5O_token_t *token2, int_f *cmp_value);
|
||||
/*
|
||||
* Functions from H5Pf.c
|
||||
*/
|
||||
@ -568,11 +574,11 @@ H5_FCDLL int_f h5ldelete_by_idx_c(hid_t_f *loc_id, _fcd group_name, size_t_f *gr
|
||||
H5_FCDLL int_f h5lexists_c(hid_t_f *loc_id, _fcd name, size_t_f *namelen, hid_t_f *lapl_id, int_f *link_exists);
|
||||
H5_FCDLL int_f h5lget_info_c(hid_t_f *link_loc_id, _fcd link_name, size_t_f *link_namelen,
|
||||
int_f *cset, int_f *corder, int_f *corder_valid, int_f *link_type,
|
||||
haddr_t_f *address, size_t_f *val_size,
|
||||
hid_t_f *lapl_id);
|
||||
H5O_token_t *token, size_t_f *val_size, hid_t_f *lapl_id);
|
||||
H5_FCDLL int_f h5lget_info_by_idx_c(hid_t_f *loc_id, _fcd group_name, size_t_f *group_namelen,
|
||||
int_f *index_field, int_f *order, hsize_t_f *n,
|
||||
int_f *link_type, int_f *corder_valid, int_f *corder, int_f *cset, haddr_t_f *address, size_t_f *val_size, hid_t_f *lapl_id);
|
||||
int_f *link_type, int_f *corder_valid, int_f *corder,
|
||||
int_f *cset, H5O_token_t *token, size_t_f *val_size, hid_t_f *lapl_id);
|
||||
H5_FCDLL int_f h5lis_registered_c(int_f *link_cls_id);
|
||||
H5_FCDLL int_f h5lmove_c(hid_t_f *src_loc_id, _fcd src_name, size_t_f *src_namelen, hid_t_f *dest_loc_id,
|
||||
_fcd dest_name, size_t_f *dest_namelen, hid_t_f *lcpl_id, hid_t_f *lapl_id);
|
||||
@ -582,8 +588,8 @@ H5_FCDLL int_f h5lget_name_by_idx_c(hid_t_f *loc_id, _fcd group_name, size_t_f *
|
||||
H5_FCDLL int_f h5lget_val_c(hid_t_f *link_loc_id, _fcd link_name, size_t_f *link_namelen, size_t_f *size,
|
||||
void *linkval_buff, hid_t_f *lapl_id) ;
|
||||
|
||||
H5_FCDLL int_f h5literate_c(hid_t_f *group_id, int_f *index_type, int_f *order, hsize_t_f *idx, H5L_iterate_t op, void *op_data );
|
||||
H5_FCDLL int_f h5literate_by_name_c(hid_t_f *loc_id, _fcd name, size_t_f *namelen, int_f *index_type, int_f *order, hsize_t_f *idx, H5L_iterate_t op, void *op_data, hid_t_f *lapl_id);
|
||||
H5_FCDLL int_f h5literate_c(hid_t_f *group_id, int_f *index_type, int_f *order, hsize_t_f *idx, H5L_iterate2_t op, void *op_data );
|
||||
H5_FCDLL int_f h5literate_by_name_c(hid_t_f *loc_id, _fcd name, size_t_f *namelen, int_f *index_type, int_f *order, hsize_t_f *idx, H5L_iterate2_t op, void *op_data, hid_t_f *lapl_id);
|
||||
|
||||
|
||||
#endif /* _H5f90proto_H */
|
||||
|
@ -414,13 +414,19 @@ int main(void)
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* Need the buffer size for the fortran derive type 'hdset_reg_ref_t_f03'
|
||||
/* Need the buffer size for the fortran derived type 'hdset_reg_ref_t_f03'
|
||||
* in order to be interoperable with C's structure, the C buffer size
|
||||
* H5R_DSET_REG_REF_BUF_SIZE is (sizeof(haddr_t)+4)
|
||||
*/
|
||||
|
||||
|
||||
fprintf(fort_header, " INTEGER, PARAMETER :: H5R_DSET_REG_REF_BUF_SIZE_F = %u\n", H5_SIZEOF_HADDR_T + 4 );
|
||||
|
||||
/* Need the buffer size for the fortran derived type 'h5o_token_t'
|
||||
* in order to be interoperable with C's structure.
|
||||
*/
|
||||
|
||||
fprintf(fort_header, " INTEGER, PARAMETER :: H5O_MAX_TOKEN_SIZE_F = %u\n", H5O_MAX_TOKEN_SIZE);
|
||||
|
||||
/* Close files */
|
||||
endCfile();
|
||||
endFfile();
|
||||
|
@ -87,7 +87,7 @@ Quick overview of the Fortran APIs
|
||||
to the file, a C program will read it as a 6x4 two-dimensional dataset into
|
||||
memory. The HDF5 C utilities h5dump and h5ls display transposed data, if
|
||||
data is written from a Fortran program.
|
||||
|
||||
|
||||
* Fortran indices are 1 based.
|
||||
|
||||
============================
|
||||
@ -105,29 +105,29 @@ Procedure to add a new function
|
||||
Procedure for passing C variables to Fortran
|
||||
---------------------------------------------
|
||||
|
||||
(1) Find the C struct name you are interested in:
|
||||
(1) Find the C struct name you are interested in:
|
||||
(a) src/H5public.h if it is a generic type, i.e. H5_*
|
||||
or
|
||||
(b) src/H5*public.h if is a specific type, i.e. H5*_
|
||||
|
||||
(b) src/H5*public.h if is a specific type, i.e. H5*_
|
||||
|
||||
(2) Put that structure into an array that will be passed to fortran in:
|
||||
(a) fortran/src/H5_f.c (add to nh5init_flags_c subroutine)
|
||||
(b) edit fortran/src/H5f90proto.h and edit nh5init_flags_c interface call
|
||||
|
||||
|
||||
(3) Edit the function call in fortran/src/H5_ff.F90
|
||||
(a) edit the call: FUNCTION h5init_flags_c
|
||||
(a) edit the call: FUNCTION h5init_flags_c
|
||||
(b) edit h5init_flags_c call in h5open_f to match the number of arguments passing
|
||||
|
||||
(4) add the size of the array and array to fortran/src/H5f90global.F90
|
||||
|
||||
(4) add the size of the array and array to fortran/src/H5f90global.F90
|
||||
- must match the size found it H5_f.c
|
||||
|
||||
NOTE: To just add a default C value argument, do steps (2a) and (4)
|
||||
NOTE: To just add a default C value argument, do steps (2a) and (4)
|
||||
|
||||
|
||||
Procedure for adding a new file to the repository
|
||||
--------------------------------------------------
|
||||
|
||||
Add the name of the file to the:
|
||||
Add the name of the file to the:
|
||||
(1) Makefile.am located in the same directory as the newfile
|
||||
(2) CMakeLists.txt located in the same directory as the newfile
|
||||
(3) MANIFEST located in the top level directory
|
||||
|
@ -175,7 +175,7 @@ H5O_mp_H5OGET_COMMENT_F
|
||||
H5O_mp_H5OGET_COMMENT_BY_NAME_F
|
||||
H5O_mp_H5OINCR_REFCOUNT_F
|
||||
H5O_mp_H5OLINK_F
|
||||
H5O_mp_H5OOPEN_BY_ADDR_F
|
||||
H5O_mp_H5OOPEN_BY_TOKEN_F
|
||||
H5O_mp_H5OOPEN_BY_IDX_F
|
||||
H5O_mp_H5OOPEN_F
|
||||
H5O_mp_H5OSET_COMMENT_F
|
||||
@ -185,6 +185,7 @@ H5O_mp_H5OGET_INFO_BY_NAME_F
|
||||
H5O_mp_H5OGET_INFO_F
|
||||
H5O_mp_H5OVISIT_BY_NAME_F
|
||||
H5O_mp_H5OVISIT_F
|
||||
H5O_mp_H5OTOKEN_CMP_F
|
||||
; H5P
|
||||
H5P_mp_H5PCREATE_F
|
||||
H5P_mp_H5PSET_PRESERVE_F
|
||||
@ -459,6 +460,7 @@ H5VL_mp_H5VLREGISTER_CONNECTOR_BY_NAME_F
|
||||
H5VL_mp_H5VLREGISTER_CONNECTOR_BY_VALUE_F
|
||||
H5VL_mp_H5VLIS_CONNECTOR_REGISTERED_F
|
||||
H5VL_mp_H5VLGET_CONNECTOR_ID_F
|
||||
H5VL_mp_H5VLGET_CONNECTOR_ID_BY_NAME_F
|
||||
H5VL_mp_H5VLGET_CONNECTOR_NAME_F
|
||||
H5VL_mp_H5VLCLOSE_F
|
||||
H5VL_mp_H5VLUNREGISTER_CONNECTOR_F
|
||||
|
@ -665,11 +665,11 @@ SUBROUTINE group_info(cleanup, fapl, total_error)
|
||||
! H5L_TYPE_SOFT_F - Soft link
|
||||
! H5L_TYPE_EXTERNAL_F - External link
|
||||
! H5L_TYPE_ERROR _F - Error
|
||||
INTEGER(HADDR_T) :: address ! If the link is a hard link, address specifies the file address that the link points to
|
||||
TYPE(H5O_TOKEN_T_F) :: token ! If the link is a hard link, token specifies the object token that the link points to
|
||||
INTEGER(SIZE_T) :: val_size ! If the link is a symbolic link, val_size will be the length of the link value
|
||||
|
||||
|
||||
! WRITE(*,*) "link creation (w/new group format)"
|
||||
WRITE(*,*) "link creation (w/new group format)"
|
||||
|
||||
! Create a file
|
||||
CALL h5fcreate_f(FileName, H5F_ACC_TRUNC_F, file, error, H5P_DEFAULT_F, fapl)
|
||||
@ -698,7 +698,7 @@ SUBROUTINE group_info(cleanup, fapl, total_error)
|
||||
CALL check("H5Lcreate_soft_f", error, total_error)
|
||||
|
||||
CALL H5Lget_info_f(file, "grp1/soft", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error, H5P_DEFAULT_F)
|
||||
CALL check("H5Lget_info_f",error,total_error)
|
||||
|
||||
@ -770,7 +770,7 @@ SUBROUTINE group_info(cleanup, fapl, total_error)
|
||||
! H5L_TYPE_SOFT_F - Soft link
|
||||
! H5L_TYPE_EXTERNAL_F - External link
|
||||
! H5L_TYPE_ERROR _F - Error
|
||||
INTEGER(HADDR_T) :: address ! If the link is a hard link, address specifies the file address that the link points to
|
||||
TYPE(H5O_TOKEN_T_F) :: token ! If the link is a hard link, token specifies the object token that the link points to
|
||||
INTEGER(SIZE_T) :: val_size ! If the link is a symbolic link, val_size will be the length of the link value
|
||||
|
||||
INTEGER :: error
|
||||
@ -816,7 +816,7 @@ SUBROUTINE group_info(cleanup, fapl, total_error)
|
||||
|
||||
! Get the group's link's information
|
||||
CALL H5Lget_info_f(file_id, "group", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error, H5P_DEFAULT_F)
|
||||
CALL check("H5Lget_info_f",error,total_error)
|
||||
|
||||
@ -1179,7 +1179,7 @@ SUBROUTINE delete_by_idx(cleanup, fapl, total_error)
|
||||
INTEGER :: cset ! Indicates the character set used for the attribute’s name
|
||||
INTEGER(SIZE_T) :: val_size
|
||||
INTEGER :: link_type
|
||||
INTEGER(HADDR_T) :: address
|
||||
TYPE(H5O_TOKEN_T_F) :: token
|
||||
|
||||
INTEGER :: u ! Local index variable
|
||||
INTEGER :: Input1, i
|
||||
@ -1309,10 +1309,10 @@ SUBROUTINE delete_by_idx(cleanup, fapl, total_error)
|
||||
! HDmemset(&linfo, 0, sizeof(linfo));
|
||||
|
||||
CALL H5Lget_info_by_idx_f(group_id, ".", idx_type, iorder, INT(0,HSIZE_T), &
|
||||
link_type, f_corder_valid, corder, cset, address, val_size, error)
|
||||
link_type, f_corder_valid, corder, cset, token, val_size, error)
|
||||
|
||||
CALL H5Oopen_by_addr_f(group_id, address, grp, error)
|
||||
CALL check("H5Oopen_by_addr_f", error, total_error)
|
||||
CALL H5Oopen_by_token_f(group_id, token, grp, error)
|
||||
CALL check("H5Oopen_by_token_f", error, total_error)
|
||||
|
||||
CALL H5Iget_type_f(grp, id_type, error)
|
||||
CALL check("H5Iget_type_f", error, total_error)
|
||||
@ -1357,11 +1357,11 @@ SUBROUTINE delete_by_idx(cleanup, fapl, total_error)
|
||||
|
||||
! Close the group creation property list
|
||||
CALL H5Pclose_f(gcpl_id, error)
|
||||
CALL check("delete_by_idx.H5Gclose_f", error, total_error)
|
||||
CALL check("delete_by_idx.H5Pclose_f", error, total_error)
|
||||
|
||||
! Close the file
|
||||
CALL H5Fclose_f(file_id, error)
|
||||
CALL check("delete_by_idx.H5Gclose_f", error, total_error)
|
||||
CALL check("delete_by_idx.H5Fclose_f", error, total_error)
|
||||
|
||||
IF(cleanup) CALL h5_cleanup_f("file0", H5P_DEFAULT_F, error)
|
||||
CALL check("h5_cleanup_f", error, total_error)
|
||||
@ -1407,7 +1407,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
INTEGER :: corder ! Is a positive integer containing the creation order of the attribute
|
||||
INTEGER :: cset ! Indicates the character set used for the attribute’s name
|
||||
INTEGER :: link_type
|
||||
INTEGER(HADDR_T) :: address
|
||||
TYPE(H5O_TOKEN_T_F) :: token
|
||||
INTEGER(SIZE_T) :: val_size ! Indicates the size, in the number of characters, of the attribute
|
||||
|
||||
CHARACTER(LEN=7) :: tmpname ! Temporary link name
|
||||
@ -1427,14 +1427,14 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
! Verify the link information for first link, in increasing creation order
|
||||
! HDmemset(&linfo, 0, sizeof(linfo));
|
||||
CALL H5Lget_info_by_idx_f(group_id, ".", H5_INDEX_CRT_ORDER_F, H5_ITER_INC_F, INT(0,HSIZE_T), &
|
||||
link_type, f_corder_valid, corder, cset, address, val_size, error)
|
||||
link_type, f_corder_valid, corder, cset, token, val_size, error)
|
||||
CALL check("H5Lget_info_by_idx_f", error, total_error)
|
||||
CALL verify("H5Lget_info_by_idx_f", corder, 0, total_error)
|
||||
|
||||
! Verify the link information for new link, in increasing creation order
|
||||
! HDmemset(&linfo, 0, sizeof(linfo));
|
||||
CALL H5Lget_info_by_idx_f(group_id, ".", H5_INDEX_CRT_ORDER_F, H5_ITER_INC_F, INT(n,HSIZE_T), &
|
||||
link_type, f_corder_valid, corder, cset, address, val_size, error)
|
||||
link_type, f_corder_valid, corder, cset, token, val_size, error)
|
||||
CALL check("H5Lget_info_by_idx_f", error, total_error)
|
||||
CALL verify("H5Lget_info_by_idx_f", corder, n, total_error)
|
||||
|
||||
@ -1516,7 +1516,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
! H5L_TYPE_SOFT_F - Soft link
|
||||
! H5L_TYPE_EXTERNAL_F - External link
|
||||
! H5L_TYPE_ERROR _F - Error
|
||||
INTEGER(HADDR_T) :: address ! If the link is a hard link, address specifies the file address that the link points to
|
||||
TYPE(H5O_TOKEN_T_F) :: token ! If the link is a hard link, token specifies the object token that the link points to
|
||||
INTEGER(SIZE_T) :: val_size ! If the link is a symbolic link, val_size will be the length of the link value
|
||||
|
||||
CHARACTER(LEN=1024) :: filename = 'tempfile.h5'
|
||||
@ -1555,7 +1555,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
! Check that its character encoding is the default
|
||||
|
||||
CALL H5Lget_info_f(file_id, "group", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error, H5P_DEFAULT_F)
|
||||
|
||||
! File-wide default character encoding can not yet be set via the file
|
||||
@ -1575,7 +1575,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
|
||||
! Check that its character encoding is the default
|
||||
CALL H5Lget_info_f(file_id, "type", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error)
|
||||
CALL check("h5tclose_f", error, total_error)
|
||||
|
||||
@ -1636,7 +1636,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
|
||||
! Check that its character encoding is the default
|
||||
CALL H5Lget_info_f(file_id, "dataset", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error)
|
||||
CALL check("H5Lget_info_f", error, total_error)
|
||||
|
||||
@ -1661,7 +1661,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
|
||||
! Check that its character encoding is UTF-8
|
||||
CALL H5Lget_info_f(file_id, "group2", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error)
|
||||
CALL check("H5Lget_info_f", error, total_error)
|
||||
CALL verify("H5Lget_info_f",cset, H5T_CSET_UTF8_F,total_error)
|
||||
@ -1679,7 +1679,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
|
||||
! Check that its character encoding is UTF-8
|
||||
CALL H5Lget_info_f(file_id, "type2", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error)
|
||||
CALL check("H5Lget_info_f", error, total_error)
|
||||
CALL verify("H5Lget_info_f",cset, H5T_CSET_UTF8_F,total_error)
|
||||
@ -1697,7 +1697,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
|
||||
! Check that its character encoding is UTF-8
|
||||
CALL H5Lget_info_f(file_id, "dataset2", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error)
|
||||
CALL check("H5Lget_info_f", error, total_error)
|
||||
CALL verify("H5Lget_info_f2",cset, H5T_CSET_UTF8_F,total_error)
|
||||
@ -1719,7 +1719,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
|
||||
! Check that its character encoding is ASCII
|
||||
CALL H5Lget_info_f(file_id, "/dataset2_link", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error)
|
||||
CALL check("H5Lget_info_f", error, total_error)
|
||||
CALL verify("H5Lget_info_f",cset, H5T_CSET_ASCII_F,total_error)
|
||||
@ -1727,7 +1727,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
! Check that the first link's encoding hasn't changed
|
||||
|
||||
CALL H5Lget_info_f(file_id, "/dataset2", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error)
|
||||
CALL check("H5Lget_info_f", error, total_error)
|
||||
CALL verify("H5Lget_info_f3",cset, H5T_CSET_UTF8_F,total_error)
|
||||
@ -1742,7 +1742,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
CALL check("H5Lcreate_soft_f", error, total_error)
|
||||
|
||||
CALL H5Lget_info_f(file_id, "slink_to_dset2", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error)
|
||||
CALL check("H5Lget_info_f", error, total_error)
|
||||
CALL verify("H5Lget_info_f",cset, H5T_CSET_UTF8_F,total_error)
|
||||
@ -1756,7 +1756,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
CALL check("H5Lmove_f",error, total_error)
|
||||
|
||||
CALL H5Lget_info_f(file_id, "moved_slink", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error)
|
||||
CALL check("H5Lget_info_f", error, total_error)
|
||||
CALL verify("H5Lget_info_f",cset, H5T_CSET_ASCII_F,total_error)
|
||||
@ -1770,7 +1770,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
CALL H5Lcopy_f(file_id, "moved_slink", file_id, "copied_slink", error, lcpl_id)
|
||||
|
||||
CALL H5Lget_info_f(file_id, "copied_slink", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error)
|
||||
CALL check("H5Lget_info_f", error, total_error)
|
||||
CALL verify("H5Lget_info_f",cset, H5T_CSET_UTF8_F,total_error)
|
||||
@ -1782,7 +1782,7 @@ SUBROUTINE link_info_by_idx_check(group_id, linkname, n, &
|
||||
CALL check("H5Lcreate_external_f", error, total_error)
|
||||
|
||||
CALL H5Lget_info_f(file_id, "extlink", &
|
||||
cset, corder, f_corder_valid, link_type, address, val_size, &
|
||||
cset, corder, f_corder_valid, link_type, token, val_size, &
|
||||
error)
|
||||
CALL check("H5Lget_info_f", error, total_error)
|
||||
CALL verify("H5Lget_info_f",cset, H5T_CSET_UTF8_F,total_error)
|
||||
|
@ -63,27 +63,33 @@ MODULE visit_cb
|
||||
|
||||
CONTAINS
|
||||
|
||||
! Compares the field values of a C h5O_info_t and a Fortran H5O_info_t.
|
||||
! Compares the field values of a C H5O_info_t and a Fortran H5O_info_t.
|
||||
|
||||
INTEGER FUNCTION compare_h5o_info_t( loc_id, oinfo_f, oinfo_c, field, full_f_field ) RESULT(status)
|
||||
|
||||
INTEGER FUNCTION compare_h5o_info_t( oinfo_f, oinfo_c, field, full_f_field ) RESULT(status)
|
||||
|
||||
IMPLICIT NONE
|
||||
INTEGER(HID_T) :: loc_id
|
||||
TYPE(h5o_info_t) :: oinfo_f
|
||||
TYPE(c_h5o_info_t) :: oinfo_c
|
||||
TYPE(H5O_TOKEN_T_F) :: token_c
|
||||
INTEGER :: field
|
||||
LOGICAL :: full_f_field ! All the fields of Fortran H5O_info_t where filled
|
||||
LOGICAL :: full_f_field ! All the fields of Fortran H5O_info_t where filled
|
||||
! local
|
||||
INTEGER(C_INT), DIMENSION(1:8) :: atime, btime, ctime, mtime
|
||||
INTEGER :: cmp_value
|
||||
INTEGER :: i
|
||||
INTEGER :: ierr
|
||||
|
||||
status = 0
|
||||
|
||||
|
||||
IF( (field .EQ. H5O_INFO_BASIC_F).OR.(field .EQ. H5O_INFO_ALL_F) )THEN
|
||||
IF( (oinfo_f%fileno.LE.0) .OR. (oinfo_c%fileno .NE. oinfo_f%fileno) )THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF( (oinfo_f%addr.LE.0) .OR. (oinfo_c%addr .NE. oinfo_f%addr) )THEN
|
||||
token_c%token = oinfo_c%token%token
|
||||
CALL H5Otoken_cmp_f(loc_id, oinfo_f%token, token_c, cmp_value, ierr);
|
||||
IF( (ierr .EQ. -1) .OR. (cmp_value .NE. 0) ) THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
@ -131,7 +137,12 @@ CONTAINS
|
||||
! check other field values are not filled (using only a small subset to check)
|
||||
status = 0
|
||||
IF( oinfo_c%fileno .NE. oinfo_f%fileno) status = status + 1
|
||||
IF( oinfo_c%addr .NE. oinfo_f%addr) status = status + 1
|
||||
token_c%token = oinfo_c%token%token
|
||||
CALL H5Otoken_cmp_f(loc_id, oinfo_f%token, token_c, cmp_value, ierr);
|
||||
IF( (ierr .EQ. -1) .OR. (cmp_value .NE. 0) ) THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF( oinfo_c%type .NE. oinfo_f%type) status = status + 1
|
||||
IF( oinfo_c%rc .NE. oinfo_f%rc) status = status + 1
|
||||
IF(status.EQ.0) THEN ! There was no difference found, which is only possible if the field was filled.
|
||||
@ -150,93 +161,12 @@ CONTAINS
|
||||
! check other field values are not filled (using only a small subset to check)
|
||||
status = 0
|
||||
IF( oinfo_c%fileno .NE. oinfo_f%fileno) status = status + 1
|
||||
IF( oinfo_c%addr .NE. oinfo_f%addr) status = status + 1
|
||||
IF( oinfo_c%type .NE. oinfo_f%type) status = status + 1
|
||||
IF( oinfo_c%rc .NE. oinfo_f%rc) status = status + 1
|
||||
IF(status.EQ.0) THEN ! There was no difference found, which is only possible if the field was filled.
|
||||
token_c%token = oinfo_c%token%token
|
||||
CALL H5Otoken_cmp_f(loc_id, oinfo_f%token, token_c, cmp_value, ierr);
|
||||
IF( (ierr .EQ. -1) .OR. (cmp_value .NE. 0) ) THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
status = 0 ! reset
|
||||
|
||||
ENDIF
|
||||
|
||||
IF((field).EQ.H5O_INFO_HDR_F.OR.(field .EQ. H5O_INFO_ALL_F))THEN
|
||||
IF( (oinfo_f%hdr%version.LT.0) .OR. (oinfo_c%hdr%version .NE. oinfo_f%hdr%version) )THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF( (oinfo_f%hdr%nmesgs.LT.0) .OR. (oinfo_c%hdr%nmesgs .NE. oinfo_f%hdr%nmesgs) )THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF( (oinfo_f%hdr%nchunks.LT.0) .OR. (oinfo_c%hdr%nchunks .NE. oinfo_f%hdr%nchunks) )THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF( (oinfo_f%hdr%flags.LT.0) .OR. (oinfo_c%hdr%flags .NE. oinfo_f%hdr%flags) )THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF( (oinfo_f%hdr%space%total.LT.0) .OR. (oinfo_c%hdr%space%total .NE. oinfo_f%hdr%space%total) )THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF( (oinfo_f%hdr%space%meta.LT.0) .OR. (oinfo_c%hdr%space%meta .NE. oinfo_f%hdr%space%meta) )THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF( (oinfo_f%hdr%space%mesg.LT.0) .OR. (oinfo_c%hdr%space%mesg .NE. oinfo_f%hdr%space%mesg) )THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF( (oinfo_f%hdr%space%free.LT.0) .OR. (oinfo_c%hdr%space%free .NE. oinfo_f%hdr%space%free) )THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF( (oinfo_f%hdr%mesg%present.LT.0) .OR. (oinfo_c%hdr%mesg%present .NE. oinfo_f%hdr%mesg%present) )THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF( (oinfo_f%hdr%mesg%shared.LT.0) .OR. (oinfo_c%hdr%mesg%shared .NE. oinfo_f%hdr%mesg%shared) )THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
ELSE IF( field .EQ. H5O_INFO_HDR_F.AND.full_f_field)THEN
|
||||
! check other field values are not filled (using only a small subset to check)
|
||||
status = 0
|
||||
IF( oinfo_c%fileno .NE. oinfo_f%fileno) status = status + 1
|
||||
IF( oinfo_c%addr .NE. oinfo_f%addr) status = status + 1
|
||||
IF( oinfo_c%type .NE. oinfo_f%type) status = status + 1
|
||||
IF( oinfo_c%rc .NE. oinfo_f%rc) status = status + 1
|
||||
IF(status.EQ.0) THEN ! There was no difference found, which is only possible if the field was filled.
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
status = 0 ! reset
|
||||
ENDIF
|
||||
IF((field).EQ.H5O_INFO_META_SIZE_F.OR.(field .EQ. H5O_INFO_ALL_F))THEN
|
||||
IF((oinfo_f%meta_size%obj%index_size.LT.0).OR.(oinfo_c%meta_size%obj%index_size.NE.oinfo_f%meta_size%obj%index_size))THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF((oinfo_f%meta_size%obj%heap_size.LT.0).OR.(oinfo_c%meta_size%obj%heap_size.NE.oinfo_f%meta_size%obj%heap_size))THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF((oinfo_f%meta_size%attr%index_size.LT.0).OR.(oinfo_c%meta_size%attr%index_size.NE.oinfo_f%meta_size%attr%index_size))THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
IF((oinfo_f%meta_size%attr%heap_size.LT.0).OR.(oinfo_c%meta_size%attr%heap_size.NE.oinfo_f%meta_size%attr%heap_size))THEN
|
||||
status = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
ELSE IF( field .EQ. H5O_INFO_META_SIZE_F.AND.full_f_field)THEN
|
||||
! check other field values are not filled (using only a small subset to check)
|
||||
status = 0
|
||||
IF( oinfo_c%fileno .NE. oinfo_f%fileno) status = status + 1
|
||||
IF( oinfo_c%addr .NE. oinfo_f%addr) status = status + 1
|
||||
IF( oinfo_c%type .NE. oinfo_f%type) status = status + 1
|
||||
IF( oinfo_c%rc .NE. oinfo_f%rc) status = status + 1
|
||||
IF(status.EQ.0) THEN ! There was no difference found, which is only possible if the field was filled.
|
||||
@ -295,13 +225,13 @@ CONTAINS
|
||||
IF(op_data%field .EQ. H5O_INFO_ALL_F)THEN
|
||||
|
||||
idx = op_data%idx
|
||||
|
||||
|
||||
DO i = 1, len
|
||||
IF(op_data%info(idx)%path(i)(1:1) .NE. name(i)(1:1))THEN
|
||||
visit_obj_cb = -1
|
||||
RETURN
|
||||
ENDIF
|
||||
|
||||
|
||||
IF(op_data%info(idx)%type_obj .NE. oinfo_c%type)THEN
|
||||
visit_obj_cb = -1
|
||||
RETURN
|
||||
@ -310,14 +240,14 @@ CONTAINS
|
||||
|
||||
ENDIF
|
||||
|
||||
! Check H5Oget_info_by_name_f; if partial field values where filled correctly
|
||||
! Check H5Oget_info_by_name_f; if partial field values were filled correctly
|
||||
CALL H5Oget_info_by_name_f(group_id, name2, oinfo_f, ierr);
|
||||
visit_obj_cb = compare_h5o_info_t( oinfo_f, oinfo_c, op_data%field, .TRUE. )
|
||||
visit_obj_cb = compare_h5o_info_t( group_id, oinfo_f, oinfo_c, op_data%field, .TRUE. )
|
||||
IF(visit_obj_cb.EQ.-1) RETURN
|
||||
|
||||
! Check H5Oget_info_by_name_f, only check field values
|
||||
CALL H5Oget_info_by_name_f(group_id, name2, oinfo_f, ierr, fields = op_data%field);
|
||||
visit_obj_cb = compare_h5o_info_t( oinfo_f, oinfo_c, op_data%field, .FALSE. )
|
||||
visit_obj_cb = compare_h5o_info_t(group_id, oinfo_f, oinfo_c, op_data%field, .FALSE. )
|
||||
IF(visit_obj_cb.EQ.-1) RETURN
|
||||
|
||||
|
||||
@ -325,12 +255,12 @@ CONTAINS
|
||||
|
||||
! Check H5Oget_info_f, only check field values
|
||||
CALL H5Oget_info_f(group_id, oinfo_f, ierr, fields = op_data%field);
|
||||
visit_obj_cb = compare_h5o_info_t( oinfo_f, oinfo_c, op_data%field, .FALSE. )
|
||||
visit_obj_cb = compare_h5o_info_t(group_id, oinfo_f, oinfo_c, op_data%field, .FALSE. )
|
||||
IF(visit_obj_cb.EQ.-1) RETURN
|
||||
|
||||
! Check H5Oget_info_f; if partial field values where filled correctly
|
||||
CALL H5Oget_info_f(group_id, oinfo_f, ierr);
|
||||
visit_obj_cb = compare_h5o_info_t( oinfo_f, oinfo_c, op_data%field, .TRUE. )
|
||||
visit_obj_cb = compare_h5o_info_t(group_id, oinfo_f, oinfo_c, op_data%field, .TRUE. )
|
||||
IF(visit_obj_cb.EQ.-1) RETURN
|
||||
|
||||
ENDIF
|
||||
@ -583,20 +513,6 @@ SUBROUTINE test_obj_visit(total_error)
|
||||
IF(ret_val.LT.0)THEN
|
||||
CALL check("h5ovisit_f", -1, total_error)
|
||||
ENDIF
|
||||
udata%field = H5O_INFO_HDR_F
|
||||
udata%idx = 1
|
||||
CALL h5ovisit_f(fid, H5_INDEX_NAME_F, H5_ITER_INC_F, fun_ptr, f_ptr, ret_val, error, fields=udata%field)
|
||||
CALL check("h5ovisit_f", error, total_error)
|
||||
IF(ret_val.LT.0)THEN
|
||||
CALL check("h5ovisit_f", -1, total_error)
|
||||
ENDIF
|
||||
udata%field = H5O_INFO_META_SIZE_F
|
||||
udata%idx = 1
|
||||
CALL h5ovisit_f(fid, H5_INDEX_NAME_F, H5_ITER_INC_F, fun_ptr, f_ptr, ret_val, error, fields=udata%field)
|
||||
CALL check("h5ovisit_f", error, total_error)
|
||||
IF(ret_val.LT.0)THEN
|
||||
CALL check("h5ovisit_f", -1, total_error)
|
||||
ENDIF
|
||||
|
||||
! Test h5ovisit_by_name_f
|
||||
object_name = "/"
|
||||
@ -630,21 +546,7 @@ SUBROUTINE test_obj_visit(total_error)
|
||||
IF(ret_val.LT.0)THEN
|
||||
CALL check("h5ovisit_by_name_f", -1, total_error)
|
||||
ENDIF
|
||||
udata%idx = 1
|
||||
udata%field = H5O_INFO_HDR_F
|
||||
CALL h5ovisit_by_name_f(fid, object_name, H5_INDEX_NAME_F, H5_ITER_INC_F, fun_ptr, f_ptr, ret_val, error, fields=udata%field)
|
||||
CALL check("h5ovisit_by_name_f", error, total_error)
|
||||
IF(ret_val.LT.0)THEN
|
||||
CALL check("h5ovisit_by_name_f", -1, total_error)
|
||||
ENDIF
|
||||
udata%idx = 1
|
||||
udata%field = H5O_INFO_META_SIZE_F
|
||||
CALL h5ovisit_by_name_f(fid, object_name, H5_INDEX_NAME_F, H5_ITER_INC_F, fun_ptr, f_ptr, ret_val, error, fields=udata%field)
|
||||
CALL check("h5ovisit_by_name_f", error, total_error)
|
||||
IF(ret_val.LT.0)THEN
|
||||
CALL check("h5ovisit_by_name_f", -1, total_error)
|
||||
ENDIF
|
||||
|
||||
|
||||
CALL h5fclose_f(fid, error)
|
||||
CALL check("h5fclose_f",error, total_error)
|
||||
|
||||
|
@ -74,8 +74,8 @@ CONTAINS
|
||||
CALL check("H5VLis_connector_registered_f",error,total_error)
|
||||
CALL VERIFY("H5VLis_connector_registered_f", is_registered, .TRUE., total_error)
|
||||
|
||||
CALL H5VLget_connector_id_f(NATIVE_VOL_CONNECTOR_NAME, vol_id_out, error)
|
||||
CALL check("H5VLget_connector_id_f",error,total_error)
|
||||
CALL H5VLget_connector_id_by_name_f(NATIVE_VOL_CONNECTOR_NAME, vol_id_out, error)
|
||||
CALL check("H5VLget_connector_id_by_name_f",error,total_error)
|
||||
|
||||
CALL H5Fcreate_f("voltest.h5",H5F_ACC_TRUNC_F, file_id, error)
|
||||
CALL check("H5F_create_f",error,total_error)
|
||||
@ -201,9 +201,9 @@ CONTAINS
|
||||
CALL VERIFY("H5Pget_vol_id_f", vol_id_out, vol_id, total_error)
|
||||
ENDIF
|
||||
|
||||
CALL H5VLget_connector_id_f(NATIVE_VOL_CONNECTOR_NAME, vol_id_out, error)
|
||||
CALL check("H5VLget_connector_id_f",error,total_error)
|
||||
CALL VERIFY("H5VLget_connector_id_f", vol_id_out, vol_id, total_error)
|
||||
CALL H5VLget_connector_id_by_name_f(NATIVE_VOL_CONNECTOR_NAME, vol_id_out, error)
|
||||
CALL check("H5VLget_connector_id_by_name_f",error,total_error)
|
||||
CALL VERIFY("H5VLget_connector_id_by_name_f", vol_id_out, vol_id, total_error)
|
||||
CALL H5Fcreate_f("voltest.h5",H5F_ACC_TRUNC_F, file_id, error, H5P_DEFAULT_F, fapl_id)
|
||||
|
||||
CALL check("H5F_create_f",error,total_error)
|
||||
|
167
hl/src/H5DS.c
167
hl/src/H5DS.c
@ -140,10 +140,10 @@ herr_t H5DSattach_scale(hid_t did,
|
||||
hobj_ref_t ref_j; /* iterator reference */
|
||||
hvl_t *buf = NULL; /* VL buffer to store in the attribute */
|
||||
hid_t dsid_j; /* DS dataset ID in DIMENSION_LIST */
|
||||
H5O_info_t oi1, oi2;
|
||||
H5O_info2_t oi1, oi2;
|
||||
H5I_type_t it1, it2;
|
||||
int i;
|
||||
size_t len;
|
||||
size_t len;
|
||||
int found_ds=0;
|
||||
htri_t is_scale;
|
||||
|
||||
@ -156,20 +156,26 @@ herr_t H5DSattach_scale(hid_t did,
|
||||
return FAIL;
|
||||
|
||||
/* the dataset cannot be a DS dataset */
|
||||
if ( is_scale == 1)
|
||||
if (is_scale == 1)
|
||||
return FAIL;
|
||||
|
||||
/* get info for the dataset in the parameter list */
|
||||
if(H5Oget_info2(did, &oi1, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(did, &oi1, H5O_INFO_BASIC) < 0)
|
||||
return FAIL;
|
||||
|
||||
/* get info for the scale in the parameter list */
|
||||
if(H5Oget_info2(dsid, &oi2, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(dsid, &oi2, H5O_INFO_BASIC) < 0)
|
||||
return FAIL;
|
||||
|
||||
/* same object, not valid */
|
||||
if(oi1.fileno == oi2.fileno && oi1.addr == oi2.addr)
|
||||
return FAIL;
|
||||
if(oi1.fileno == oi2.fileno) {
|
||||
int token_cmp;
|
||||
|
||||
if(H5Otoken_cmp(did, &oi1.token, &oi2.token, &token_cmp) < 0)
|
||||
return FAIL;
|
||||
if(!token_cmp)
|
||||
return FAIL;
|
||||
} /* end if */
|
||||
|
||||
/* get ID type */
|
||||
if ((it1 = H5Iget_type(did)) < 0)
|
||||
@ -324,16 +330,22 @@ herr_t H5DSattach_scale(hid_t did,
|
||||
goto out;
|
||||
|
||||
/* get info for DS in the parameter list */
|
||||
if(H5Oget_info2(dsid, &oi1, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(dsid, &oi1, H5O_INFO_BASIC) < 0)
|
||||
goto out;
|
||||
|
||||
/* get info for this DS */
|
||||
if(H5Oget_info2(dsid_j, &oi2, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(dsid_j, &oi2, H5O_INFO_BASIC) < 0)
|
||||
goto out;
|
||||
|
||||
/* same object, so this DS scale is already in this DIM IDX */
|
||||
if(oi1.fileno == oi2.fileno && oi1.addr == oi2.addr)
|
||||
found_ds = 1;
|
||||
if(oi1.fileno == oi2.fileno) {
|
||||
int token_cmp;
|
||||
|
||||
if(H5Otoken_cmp(did, &oi1.token, &oi2.token, &token_cmp) < 0)
|
||||
goto out;
|
||||
if(!token_cmp)
|
||||
found_ds = 1;
|
||||
} /* end if */
|
||||
|
||||
/* close the dereferenced dataset */
|
||||
if(H5Dclose(dsid_j) < 0)
|
||||
@ -586,7 +598,7 @@ herr_t H5DSdetach_scale(hid_t did,
|
||||
int i;
|
||||
size_t j;
|
||||
hssize_t ii;
|
||||
H5O_info_t did_oi, dsid_oi, tmp_oi;
|
||||
H5O_info2_t did_oi, dsid_oi, tmp_oi;
|
||||
int found_dset = 0, found_ds = 0;
|
||||
int have_ds = 0;
|
||||
htri_t is_scale;
|
||||
@ -609,16 +621,22 @@ herr_t H5DSdetach_scale(hid_t did,
|
||||
return FAIL;
|
||||
|
||||
/* get info for the dataset in the parameter list */
|
||||
if(H5Oget_info2(did, &did_oi, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(did, &did_oi, H5O_INFO_BASIC) < 0)
|
||||
return FAIL;
|
||||
|
||||
/* get info for the scale in the parameter list */
|
||||
if(H5Oget_info2(dsid, &dsid_oi, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(dsid, &dsid_oi, H5O_INFO_BASIC) < 0)
|
||||
return FAIL;
|
||||
|
||||
/* same object, not valid */
|
||||
if(did_oi.fileno == dsid_oi.fileno && did_oi.addr == dsid_oi.addr)
|
||||
return FAIL;
|
||||
if(did_oi.fileno == dsid_oi.fileno) {
|
||||
int token_cmp;
|
||||
|
||||
if(H5Otoken_cmp(did, &did_oi.token, &dsid_oi.token, &token_cmp) < 0)
|
||||
return FAIL;
|
||||
if(!token_cmp)
|
||||
return FAIL;
|
||||
} /* end if */
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
@ -696,7 +714,7 @@ herr_t H5DSdetach_scale(hid_t did,
|
||||
goto out;
|
||||
|
||||
/* get info for this DS */
|
||||
if(H5Oget_info2(dsid_j, &tmp_oi, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(dsid_j, &tmp_oi, H5O_INFO_BASIC) < 0)
|
||||
goto out;
|
||||
|
||||
/* Close the dereferenced dataset */
|
||||
@ -704,30 +722,35 @@ herr_t H5DSdetach_scale(hid_t did,
|
||||
goto out;
|
||||
|
||||
/* same object, reset */
|
||||
if(dsid_oi.fileno == tmp_oi.fileno && dsid_oi.addr == tmp_oi.addr)
|
||||
{
|
||||
/* If there are more than one reference in the VL element
|
||||
and the reference we found is not the last one,
|
||||
copy the last one to replace the found one since the order
|
||||
of the references doesn't matter according to the spec;
|
||||
reduce the size of the VL element by 1;
|
||||
if the length of the element becomes 0, free the pointer
|
||||
and reset to NULL */
|
||||
if(dsid_oi.fileno == tmp_oi.fileno) {
|
||||
int token_cmp;
|
||||
|
||||
size_t len = buf[idx].len;
|
||||
if(H5Otoken_cmp(did, &dsid_oi.token, &tmp_oi.token, &token_cmp) < 0)
|
||||
goto out;
|
||||
if(!token_cmp) {
|
||||
/* If there are more than one reference in the VL element
|
||||
and the reference we found is not the last one,
|
||||
copy the last one to replace the found one since the order
|
||||
of the references doesn't matter according to the spec;
|
||||
reduce the size of the VL element by 1;
|
||||
if the length of the element becomes 0, free the pointer
|
||||
and reset to NULL */
|
||||
|
||||
if(j < len - 1)
|
||||
((hobj_ref_t *)buf[idx].p)[j] = ((hobj_ref_t *)buf[idx].p)[len-1];
|
||||
len = --buf[idx].len;
|
||||
if(len == 0) {
|
||||
HDfree(buf[idx].p);
|
||||
buf[idx].p = NULL;
|
||||
}
|
||||
/* Since a reference to a dim. scale can be inserted only once,
|
||||
we do not need to continue the search if it is found */
|
||||
found_ds = 1;
|
||||
break;
|
||||
}
|
||||
size_t len = buf[idx].len;
|
||||
|
||||
if(j < len - 1)
|
||||
((hobj_ref_t *)buf[idx].p)[j] = ((hobj_ref_t *)buf[idx].p)[len-1];
|
||||
len = --buf[idx].len;
|
||||
if(len == 0) {
|
||||
HDfree(buf[idx].p);
|
||||
buf[idx].p = NULL;
|
||||
}
|
||||
/* Since a reference to a dim. scale can be inserted only once,
|
||||
we do not need to continue the search if it is found */
|
||||
found_ds = 1;
|
||||
break;
|
||||
} /* end if */
|
||||
} /* end if */
|
||||
} /* j */
|
||||
} /* if */
|
||||
|
||||
@ -806,7 +829,7 @@ herr_t H5DSdetach_scale(hid_t did,
|
||||
goto out;
|
||||
|
||||
/* get info for this dataset */
|
||||
if(H5Oget_info2(did_i, &tmp_oi, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(did_i, &tmp_oi, H5O_INFO_BASIC) < 0)
|
||||
goto out;
|
||||
|
||||
/* close the dereferenced dataset */
|
||||
@ -814,13 +837,19 @@ herr_t H5DSdetach_scale(hid_t did,
|
||||
goto out;
|
||||
|
||||
/* same object, reset. we want to detach only for this DIM */
|
||||
if(did_oi.fileno == tmp_oi.fileno && did_oi.addr == tmp_oi.addr) {
|
||||
/* copy the last one to replace the one which is found */
|
||||
dsbuf[ii] = dsbuf[nelmts-1];
|
||||
nelmts--;
|
||||
found_dset=1;
|
||||
break;
|
||||
} /* if */
|
||||
if(did_oi.fileno == tmp_oi.fileno) {
|
||||
int token_cmp;
|
||||
|
||||
if(H5Otoken_cmp(did, &did_oi.token, &tmp_oi.token, &token_cmp) < 0)
|
||||
goto out;
|
||||
if(!token_cmp) {
|
||||
/* copy the last one to replace the one which is found */
|
||||
dsbuf[ii] = dsbuf[nelmts-1];
|
||||
nelmts--;
|
||||
found_dset=1;
|
||||
break;
|
||||
} /* end if */
|
||||
} /* end if */
|
||||
} /* if we have the same dimension index */
|
||||
} /* ii */
|
||||
|
||||
@ -954,7 +983,7 @@ htri_t H5DSis_attached(hid_t did,
|
||||
hvl_t *buf = NULL; /* VL buffer to store in the attribute */
|
||||
hid_t dsid_j; /* DS dataset ID in DIMENSION_LIST */
|
||||
hid_t did_i; /* dataset ID in REFERENCE_LIST */
|
||||
H5O_info_t oi1, oi2, oi3, oi4;
|
||||
H5O_info2_t oi1, oi2, oi3, oi4;
|
||||
H5I_type_t it1, it2;
|
||||
int i;
|
||||
int found_dset=0, found_ds=0;
|
||||
@ -973,16 +1002,22 @@ htri_t H5DSis_attached(hid_t did,
|
||||
return FAIL;
|
||||
|
||||
/* get info for the dataset in the parameter list */
|
||||
if(H5Oget_info2(did, &oi1, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(did, &oi1, H5O_INFO_BASIC) < 0)
|
||||
return FAIL;
|
||||
|
||||
/* get info for the scale in the parameter list */
|
||||
if(H5Oget_info2(dsid, &oi2, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(dsid, &oi2, H5O_INFO_BASIC) < 0)
|
||||
return FAIL;
|
||||
|
||||
/* same object, not valid */
|
||||
if(oi1.fileno == oi2.fileno && oi1.addr == oi2.addr)
|
||||
return FAIL;
|
||||
if(oi1.fileno == oi2.fileno) {
|
||||
int token_cmp;
|
||||
|
||||
if(H5Otoken_cmp(did, &oi1.token, &oi2.token, &token_cmp) < 0)
|
||||
return FAIL;
|
||||
if(!token_cmp)
|
||||
return FAIL;
|
||||
} /* end if */
|
||||
|
||||
/* get ID type */
|
||||
if ((it1 = H5Iget_type(did)) < 0)
|
||||
@ -1054,16 +1089,22 @@ htri_t H5DSis_attached(hid_t did,
|
||||
goto out;
|
||||
|
||||
/* get info for DS in the parameter list */
|
||||
if(H5Oget_info2(dsid, &oi1, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(dsid, &oi1, H5O_INFO_BASIC) < 0)
|
||||
goto out;
|
||||
|
||||
/* get info for this DS */
|
||||
if(H5Oget_info2(dsid_j, &oi2, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(dsid_j, &oi2, H5O_INFO_BASIC) < 0)
|
||||
goto out;
|
||||
|
||||
/* same object */
|
||||
if(oi1.fileno == oi2.fileno && oi1.addr == oi2.addr)
|
||||
found_ds = 1;
|
||||
if(oi1.fileno == oi2.fileno) {
|
||||
int token_cmp;
|
||||
|
||||
if(H5Otoken_cmp(did, &oi1.token, &oi2.token, &token_cmp) < 0)
|
||||
goto out;
|
||||
if(!token_cmp)
|
||||
found_ds = 1;
|
||||
} /* end if */
|
||||
|
||||
/* close the dereferenced dataset */
|
||||
if (H5Dclose(dsid_j) < 0)
|
||||
@ -1144,16 +1185,22 @@ htri_t H5DSis_attached(hid_t did,
|
||||
goto out;
|
||||
|
||||
/* get info for dataset in the parameter list */
|
||||
if(H5Oget_info2(did, &oi3, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(did, &oi3, H5O_INFO_BASIC) < 0)
|
||||
goto out;
|
||||
|
||||
/* get info for this dataset */
|
||||
if(H5Oget_info2(did_i, &oi4, H5O_INFO_BASIC) < 0)
|
||||
if(H5Oget_info3(did_i, &oi4, H5O_INFO_BASIC) < 0)
|
||||
goto out;
|
||||
|
||||
/* same object */
|
||||
if(oi3.fileno == oi4.fileno && oi3.addr == oi4.addr && idx==dsbuf[i].dim_idx)
|
||||
found_dset=1;
|
||||
if(oi3.fileno == oi4.fileno) {
|
||||
int token_cmp;
|
||||
|
||||
if(H5Otoken_cmp(did, &oi3.token, &oi4.token, &token_cmp) < 0)
|
||||
goto out;
|
||||
if(!token_cmp && (idx == dsbuf[i].dim_idx))
|
||||
found_dset=1;
|
||||
} /* end if */
|
||||
|
||||
/* close the dereferenced dataset */
|
||||
if (H5Dclose(did_i) < 0)
|
||||
|
@ -1360,7 +1360,7 @@ out:
|
||||
*/
|
||||
|
||||
static herr_t
|
||||
find_dataset(hid_t loc_id, const char *name, const H5L_info_t *linfo, void *op_data)
|
||||
find_dataset(hid_t loc_id, const char *name, const H5L_info2_t *linfo, void *op_data)
|
||||
{
|
||||
/* Define a default zero value for return. This will cause the iterator to continue if
|
||||
* the dataset is not found yet.
|
||||
@ -1411,7 +1411,7 @@ find_dataset(hid_t loc_id, const char *name, const H5L_info_t *linfo, void *op_d
|
||||
herr_t
|
||||
H5LTfind_dataset( hid_t loc_id, const char *dset_name )
|
||||
{
|
||||
return H5Literate(loc_id, H5_INDEX_NAME, H5_ITER_INC, 0, find_dataset, (void *)dset_name);
|
||||
return H5Literate2(loc_id, H5_INDEX_NAME, H5_ITER_INC, 0, find_dataset, (void *)dset_name);
|
||||
}
|
||||
|
||||
|
||||
|
@ -19,8 +19,8 @@ package examples.groups;
|
||||
|
||||
import hdf.hdf5lib.H5;
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_cb;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_t;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_opdata_t;
|
||||
import hdf.hdf5lib.structs.H5O_info_t;
|
||||
|
||||
import java.util.ArrayList;
|
||||
@ -53,9 +53,9 @@ public class H5Ex_G_Intermediate {
|
||||
// Print all the objects in the file_ids to show that intermediate group_ids have been created.
|
||||
System.out.println("Objects in the file_id:");
|
||||
|
||||
// H5O_iterate_t iter_data = null;
|
||||
H5O_iterate_t iter_data = new H5O_iter_data();
|
||||
H5O_iterate_cb iter_cb = new H5O_iter_callback();
|
||||
// H5O_iterate_opdata_t iter_data = null;
|
||||
H5O_iterate_opdata_t iter_data = new H5O_iter_data();
|
||||
H5O_iterate_t iter_cb = new H5O_iter_callback();
|
||||
|
||||
H5.H5Ovisit(file_id, HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_NATIVE, iter_cb, iter_data);
|
||||
}
|
||||
@ -92,12 +92,12 @@ public class H5Ex_G_Intermediate {
|
||||
}
|
||||
}
|
||||
|
||||
private class H5O_iter_data implements H5O_iterate_t {
|
||||
private class H5O_iter_data implements H5O_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
|
||||
private class H5O_iter_callback implements H5O_iterate_cb {
|
||||
public int callback(long group, String name, H5O_info_t info, H5O_iterate_t op_data) {
|
||||
private class H5O_iter_callback implements H5O_iterate_t {
|
||||
public int callback(long group, String name, H5O_info_t info, H5O_iterate_opdata_t op_data) {
|
||||
idata id = new idata(name, info.type);
|
||||
((H5O_iter_data) op_data).iterdata.add(id);
|
||||
|
||||
|
@ -19,6 +19,7 @@ package examples.groups;
|
||||
|
||||
import hdf.hdf5lib.H5;
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
import hdf.hdf5lib.structs.H5O_token_t;
|
||||
|
||||
import java.util.EnumSet;
|
||||
import java.util.HashMap;
|
||||
@ -75,8 +76,8 @@ public class H5Ex_G_Iterate {
|
||||
String[] oname = new String[count];
|
||||
int[] otype = new int[count];
|
||||
int[] ltype = new int[count];
|
||||
long[] orefs = new long[count];
|
||||
H5.H5Gget_obj_info_all(file_id, DATASETNAME, oname, otype, ltype, orefs, HDF5Constants.H5_INDEX_NAME);
|
||||
H5O_token_t[] otokens = new H5O_token_t[count];
|
||||
H5.H5Gget_obj_info_all(file_id, DATASETNAME, oname, otype, ltype, otokens, HDF5Constants.H5_INDEX_NAME);
|
||||
|
||||
// Get type of the object and display its name and type.
|
||||
for (int indx = 0; indx < otype.length; indx++) {
|
||||
|
@ -25,22 +25,22 @@ package examples.groups;
|
||||
|
||||
import hdf.hdf5lib.H5;
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_cb;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_t;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_opdata_t;
|
||||
import hdf.hdf5lib.structs.H5L_info_t;
|
||||
import hdf.hdf5lib.structs.H5O_info_t;
|
||||
import examples.groups.H5Ex_G_Iterate.H5O_type;
|
||||
|
||||
class opdata implements H5L_iterate_t {
|
||||
class opdata implements H5L_iterate_opdata_t {
|
||||
int recurs;
|
||||
opdata prev;
|
||||
long addr;
|
||||
H5O_token_t obj_token;
|
||||
}
|
||||
|
||||
public class H5Ex_G_Traverse {
|
||||
|
||||
private static String FILE = "h5ex_g_traverse.h5";
|
||||
public static H5L_iterate_cb iter_cb = new H5L_iter_callbackT();
|
||||
public static H5L_iterate_t iter_cb = new H5L_iter_callbackT();
|
||||
|
||||
private static void OpenGroup() {
|
||||
long file_id = -1;
|
||||
@ -54,7 +54,7 @@ public class H5Ex_G_Traverse {
|
||||
infobuf = H5.H5Oget_info(file_id);
|
||||
od.recurs = 0;
|
||||
od.prev = null;
|
||||
od.addr = infobuf.addr;
|
||||
od.obj_token = infobuf.token;
|
||||
}
|
||||
}
|
||||
catch (Exception e) {
|
||||
@ -64,7 +64,7 @@ public class H5Ex_G_Traverse {
|
||||
// Print the root group and formatting, begin iteration.
|
||||
try {
|
||||
System.out.println("/ {");
|
||||
// H5L_iterate_cb iter_cb = new H5L_iter_callbackT();
|
||||
// H5L_iterate_t iter_cb = new H5L_iter_callbackT();
|
||||
H5.H5Literate(file_id, HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_NATIVE, 0L, iter_cb, od);
|
||||
System.out.println("}");
|
||||
}
|
||||
@ -87,8 +87,8 @@ public class H5Ex_G_Traverse {
|
||||
}
|
||||
}
|
||||
|
||||
class H5L_iter_callbackT implements H5L_iterate_cb {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_t op_data) {
|
||||
class H5L_iter_callbackT implements H5L_iterate_t {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_opdata_t op_data) {
|
||||
|
||||
H5O_info_t infobuf;
|
||||
int return_val = 0;
|
||||
@ -105,7 +105,7 @@ class H5L_iter_callbackT implements H5L_iterate_cb {
|
||||
switch (H5O_type.get(infobuf.type)) {
|
||||
case H5O_TYPE_GROUP:
|
||||
System.out.println("Group: " + name + " { ");
|
||||
// Check group address against linked list of operator
|
||||
// Check group object token against linked list of operator
|
||||
// data structures. We will always run the check, as the
|
||||
// reference count cannot be relied upon if there are
|
||||
// symbolic links, and H5Oget_info_by_name always follows
|
||||
@ -114,7 +114,7 @@ class H5L_iter_callbackT implements H5L_iterate_cb {
|
||||
// links, however it could still fail if an object's
|
||||
// reference count was manually manipulated with
|
||||
// H5Odecr_refcount.
|
||||
if (group_check(od, infobuf.addr)) {
|
||||
if (group_check(od, infobuf.token)) {
|
||||
for (int i = 0; i < spaces; i++)
|
||||
System.out.print(" ");
|
||||
System.out.println(" Warning: Loop detected!");
|
||||
@ -127,8 +127,8 @@ class H5L_iter_callbackT implements H5L_iterate_cb {
|
||||
opdata nextod = new opdata();
|
||||
nextod.recurs = od.recurs + 1;
|
||||
nextod.prev = od;
|
||||
nextod.addr = infobuf.addr;
|
||||
H5L_iterate_cb iter_cb2 = new H5L_iter_callbackT();
|
||||
nextod.obj_token = infobuf.token;
|
||||
H5L_iterate_t iter_cb2 = new H5L_iter_callbackT();
|
||||
return_val = H5.H5Literate_by_name(group, name, HDF5Constants.H5_INDEX_NAME,
|
||||
HDF5Constants.H5_ITER_NATIVE, 0L, iter_cb2, nextod, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
@ -153,13 +153,13 @@ class H5L_iter_callbackT implements H5L_iterate_cb {
|
||||
return return_val;
|
||||
}
|
||||
|
||||
public boolean group_check(opdata od, long target_addr) {
|
||||
if (od.addr == target_addr)
|
||||
return true; // Addresses match
|
||||
public boolean group_check(opdata od, H5O_token_t target_token) {
|
||||
if (od.obj_token.equals(target_token))
|
||||
return true; // Object tokens match
|
||||
else if (od.recurs == 0)
|
||||
return false; // Root group reached with no matches
|
||||
else
|
||||
return group_check(od.prev, target_addr); // Recursively examine the next node
|
||||
return group_check(od.prev, target_token); // Recursively examine the next node
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -23,10 +23,10 @@ package examples.groups;
|
||||
|
||||
import hdf.hdf5lib.H5;
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_cb;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_t;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_cb;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_opdata_t;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_t;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_opdata_t;
|
||||
import hdf.hdf5lib.structs.H5L_info_t;
|
||||
import hdf.hdf5lib.structs.H5O_info_t;
|
||||
|
||||
@ -55,13 +55,13 @@ public class H5Ex_G_Visit {
|
||||
|
||||
// Begin iteration using H5Ovisit
|
||||
System.out.println("Objects in the file:");
|
||||
H5O_iterate_t iter_data = new H5O_iter_data();
|
||||
H5O_iterate_cb iter_cb = new H5O_iter_callback();
|
||||
H5O_iterate_opdata_t iter_data = new H5O_iter_data();
|
||||
H5O_iterate_t iter_cb = new H5O_iter_callback();
|
||||
H5.H5Ovisit(file_id, HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_NATIVE, iter_cb, iter_data);
|
||||
System.out.println();
|
||||
// Repeat the same process using H5Lvisit
|
||||
H5L_iterate_t iter_data2 = new H5L_iter_data();
|
||||
H5L_iterate_cb iter_cb2 = new H5L_iter_callback();
|
||||
H5L_iterate_opdata_t iter_data2 = new H5L_iter_data();
|
||||
H5L_iterate_t iter_cb2 = new H5L_iter_callback();
|
||||
System.out.println("Links in the file:");
|
||||
H5.H5Lvisit(file_id, HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_NATIVE, iter_cb2, iter_data2);
|
||||
|
||||
@ -91,12 +91,12 @@ public class H5Ex_G_Visit {
|
||||
}
|
||||
}
|
||||
|
||||
private class H5L_iter_data implements H5L_iterate_t {
|
||||
private class H5L_iter_data implements H5L_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
|
||||
private class H5L_iter_callback implements H5L_iterate_cb {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_t op_data) {
|
||||
private class H5L_iter_callback implements H5L_iterate_t {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_opdata_t op_data) {
|
||||
|
||||
idata id = new idata(name, info.type);
|
||||
((H5L_iter_data) op_data).iterdata.add(id);
|
||||
@ -107,8 +107,8 @@ public class H5Ex_G_Visit {
|
||||
// Get type of the object and display its name and type. The name of the object is passed to this
|
||||
// function by the Library.
|
||||
infobuf = H5.H5Oget_info_by_name(group, name, HDF5Constants.H5P_DEFAULT);
|
||||
H5O_iterate_cb iter_cbO = new H5O_iter_callback();
|
||||
H5O_iterate_t iter_dataO = new H5O_iter_data();
|
||||
H5O_iterate_t iter_cbO = new H5O_iter_callback();
|
||||
H5O_iterate_opdata_t iter_dataO = new H5O_iter_data();
|
||||
ret = iter_cbO.callback(group, name, infobuf, iter_dataO);
|
||||
}
|
||||
catch (Exception e) {
|
||||
@ -119,12 +119,12 @@ public class H5Ex_G_Visit {
|
||||
}
|
||||
}
|
||||
|
||||
private class H5O_iter_data implements H5O_iterate_t {
|
||||
private class H5O_iter_data implements H5O_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
|
||||
private class H5O_iter_callback implements H5O_iterate_cb {
|
||||
public int callback(long group, String name, H5O_info_t info, H5O_iterate_t op_data) {
|
||||
private class H5O_iter_callback implements H5O_iterate_t {
|
||||
public int callback(long group, String name, H5O_info_t info, H5O_iterate_opdata_t op_data) {
|
||||
idata id = new idata(name, info.type);
|
||||
((H5O_iter_data) op_data).iterdata.add(id);
|
||||
|
||||
|
@ -51,10 +51,10 @@ hdf5_java_JAVA = \
|
||||
${pkgpath}/callbacks/H5D_iterate_t.java \
|
||||
${pkgpath}/callbacks/H5E_walk_cb.java \
|
||||
${pkgpath}/callbacks/H5E_walk_t.java \
|
||||
${pkgpath}/callbacks/H5L_iterate_cb.java \
|
||||
${pkgpath}/callbacks/H5L_iterate_t.java \
|
||||
${pkgpath}/callbacks/H5O_iterate_cb.java \
|
||||
${pkgpath}/callbacks/H5L_iterate_opdata_t.java \
|
||||
${pkgpath}/callbacks/H5O_iterate_t.java \
|
||||
${pkgpath}/callbacks/H5O_iterate_opdata_t.java \
|
||||
${pkgpath}/callbacks/H5P_cls_close_func_cb.java \
|
||||
${pkgpath}/callbacks/H5P_cls_close_func_t.java \
|
||||
${pkgpath}/callbacks/H5P_cls_copy_func_cb.java \
|
||||
@ -103,6 +103,8 @@ hdf5_java_JAVA = \
|
||||
${pkgpath}/structs/H5G_info_t.java \
|
||||
${pkgpath}/structs/H5L_info_t.java \
|
||||
${pkgpath}/structs/H5O_info_t.java \
|
||||
${pkgpath}/structs/H5O_native_info_t.java \
|
||||
${pkgpath}/structs/H5O_token_t.java \
|
||||
${pkgpath}/structs/H5O_hdr_info_t.java \
|
||||
${pkgpath}/structs/H5AC_cache_config_t.java \
|
||||
${pkgpath}/H5.java \
|
||||
|
@ -18,10 +18,10 @@ set (HDF5_JAVA_HDF_HDF5_CALLBACKS_SOURCES
|
||||
callbacks/H5D_iterate_t.java
|
||||
callbacks/H5E_walk_cb.java
|
||||
callbacks/H5E_walk_t.java
|
||||
callbacks/H5L_iterate_cb.java
|
||||
callbacks/H5L_iterate_t.java
|
||||
callbacks/H5O_iterate_cb.java
|
||||
callbacks/H5L_iterate_opdata_t.java
|
||||
callbacks/H5O_iterate_t.java
|
||||
callbacks/H5O_iterate_opdata_t.java
|
||||
callbacks/H5P_cls_close_func_cb.java
|
||||
callbacks/H5P_cls_close_func_t.java
|
||||
callbacks/H5P_cls_copy_func_cb.java
|
||||
@ -79,6 +79,8 @@ set (HDF5_JAVA_HDF_HDF5_STRUCTS_SOURCES
|
||||
structs/H5L_info_t.java
|
||||
structs/H5O_hdr_info_t.java
|
||||
structs/H5O_info_t.java
|
||||
structs/H5O_native_info_t.java
|
||||
structs/H5O_token_t.java
|
||||
)
|
||||
|
||||
set (HDF5_JAVA_HDF_HDF5_SOURCES
|
||||
|
@ -24,10 +24,10 @@ import hdf.hdf5lib.callbacks.H5D_iterate_cb;
|
||||
import hdf.hdf5lib.callbacks.H5D_iterate_t;
|
||||
import hdf.hdf5lib.callbacks.H5E_walk_cb;
|
||||
import hdf.hdf5lib.callbacks.H5E_walk_t;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_cb;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_t;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_cb;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_opdata_t;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_t;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_opdata_t;
|
||||
import hdf.hdf5lib.callbacks.H5P_cls_close_func_cb;
|
||||
import hdf.hdf5lib.callbacks.H5P_cls_close_func_t;
|
||||
import hdf.hdf5lib.callbacks.H5P_cls_copy_func_cb;
|
||||
@ -55,6 +55,8 @@ import hdf.hdf5lib.structs.H5FD_ros3_fapl_t;
|
||||
import hdf.hdf5lib.structs.H5G_info_t;
|
||||
import hdf.hdf5lib.structs.H5L_info_t;
|
||||
import hdf.hdf5lib.structs.H5O_info_t;
|
||||
import hdf.hdf5lib.structs.H5O_native_info_t;
|
||||
import hdf.hdf5lib.structs.H5O_token_t;
|
||||
|
||||
/**
|
||||
* This class is the Java interface for the HDF5 library.
|
||||
@ -3577,8 +3579,8 @@ public class H5 implements java.io.Serializable {
|
||||
* OUT: Names of all objects under the group, name.
|
||||
* @param objTypes
|
||||
* OUT: Types of all objects under the group, name.
|
||||
* @param objRef
|
||||
* OUT: Reference number of all objects under the group, name.
|
||||
* @param tokens
|
||||
* OUT: Object token of all objects under the group, name.
|
||||
*
|
||||
* @return the number of items found
|
||||
*
|
||||
@ -3588,26 +3590,26 @@ public class H5 implements java.io.Serializable {
|
||||
* - name is null.
|
||||
*/
|
||||
public synchronized static int H5Gget_obj_info_all(long loc_id, String name, String[] objNames, int[] objTypes,
|
||||
long[] objRef) throws HDF5LibraryException, NullPointerException {
|
||||
H5O_token_t[] tokens) throws HDF5LibraryException, NullPointerException {
|
||||
if (objNames == null) {
|
||||
throw new NullPointerException("H5Gget_obj_info_all(): name array is null");
|
||||
}
|
||||
|
||||
return H5Gget_obj_info_all(loc_id, name, objNames, objTypes, null, null, objRef, HDF5Constants.H5_INDEX_NAME);
|
||||
return H5Gget_obj_info_all(loc_id, name, objNames, objTypes, null, null, tokens, HDF5Constants.H5_INDEX_NAME);
|
||||
}
|
||||
|
||||
public synchronized static int H5Gget_obj_info_all(long loc_id, String name, String[] oname, int[] otype,
|
||||
int[] ltype, long[] ref, int indx_type) throws HDF5LibraryException, NullPointerException {
|
||||
return H5Gget_obj_info_full(loc_id, name, oname, otype, ltype, null, ref, indx_type, -1);
|
||||
int[] ltype, H5O_token_t[] tokens, int indx_type) throws HDF5LibraryException, NullPointerException {
|
||||
return H5Gget_obj_info_full(loc_id, name, oname, otype, ltype, null, tokens, indx_type, -1);
|
||||
}
|
||||
|
||||
public synchronized static int H5Gget_obj_info_all(long loc_id, String name, String[] oname, int[] otype,
|
||||
int[] ltype, long[] fno, long[] ref, int indx_type) throws HDF5LibraryException, NullPointerException {
|
||||
return H5Gget_obj_info_full(loc_id, name, oname, otype, ltype, fno, ref, oname.length, indx_type, -1);
|
||||
int[] ltype, long[] fno, H5O_token_t[] tokens, int indx_type) throws HDF5LibraryException, NullPointerException {
|
||||
return H5Gget_obj_info_full(loc_id, name, oname, otype, ltype, fno, tokens, oname.length, indx_type, -1);
|
||||
}
|
||||
|
||||
public synchronized static int H5Gget_obj_info_full(long loc_id, String name, String[] oname, int[] otype,
|
||||
int[] ltype, long[] fno, long[] ref, int indx_type, int indx_order) throws HDF5LibraryException,
|
||||
int[] ltype, long[] fno, H5O_token_t[] tokens, int indx_type, int indx_order) throws HDF5LibraryException,
|
||||
NullPointerException {
|
||||
if (oname == null) {
|
||||
throw new NullPointerException("H5Gget_obj_info_full(): name array is null");
|
||||
@ -3629,7 +3631,7 @@ public class H5 implements java.io.Serializable {
|
||||
ltype = new int[otype.length];
|
||||
|
||||
if (fno == null)
|
||||
fno = new long[ref.length];
|
||||
fno = new long[tokens.length];
|
||||
|
||||
if (indx_type < 0)
|
||||
indx_type = HDF5Constants.H5_INDEX_NAME;
|
||||
@ -3638,7 +3640,7 @@ public class H5 implements java.io.Serializable {
|
||||
indx_order = HDF5Constants.H5_ITER_INC;
|
||||
|
||||
log.trace("H5Gget_obj_info_full: oname_len={}", oname.length);
|
||||
int status = H5Gget_obj_info_full(loc_id, name, oname, otype, ltype, fno, ref, oname.length, indx_type,
|
||||
int status = H5Gget_obj_info_full(loc_id, name, oname, otype, ltype, fno, tokens, oname.length, indx_type,
|
||||
indx_order);
|
||||
for (int indx = 0; indx < oname.length; indx++)
|
||||
log.trace("H5Gget_obj_info_full: oname={}", oname[indx]);
|
||||
@ -3646,7 +3648,7 @@ public class H5 implements java.io.Serializable {
|
||||
}
|
||||
|
||||
private synchronized static native int H5Gget_obj_info_full(long loc_id, String name, String[] oname, int[] otype,
|
||||
int[] ltype, long[] fno, long[] ref, int n, int indx_type, int indx_order) throws HDF5LibraryException,
|
||||
int[] ltype, long[] fno, H5O_token_t[] tokens, int n, int indx_type, int indx_order) throws HDF5LibraryException,
|
||||
NullPointerException;
|
||||
|
||||
/**
|
||||
@ -3701,8 +3703,8 @@ public class H5 implements java.io.Serializable {
|
||||
* OUT: Types of all objects under the group, name.
|
||||
* @param lnkTypes
|
||||
* OUT: Types of all links under the group, name.
|
||||
* @param objRef
|
||||
* OUT: Reference number of all objects under the group, name.
|
||||
* @param objToken
|
||||
* OUT: Object token of all objects under the group, name.
|
||||
* @param objMax
|
||||
* IN: Maximum number of all objects under the group, name.
|
||||
*
|
||||
@ -3714,7 +3716,7 @@ public class H5 implements java.io.Serializable {
|
||||
* - name is null.
|
||||
*/
|
||||
public synchronized static int H5Gget_obj_info_max(long loc_id, String[] objNames, int[] objTypes, int[] lnkTypes,
|
||||
long[] objRef, long objMax) throws HDF5LibraryException, NullPointerException {
|
||||
H5O_token_t[] objToken, long objMax) throws HDF5LibraryException, NullPointerException {
|
||||
if (objNames == null) {
|
||||
throw new NullPointerException("H5Gget_obj_info_max(): name array is null");
|
||||
}
|
||||
@ -3739,11 +3741,11 @@ public class H5 implements java.io.Serializable {
|
||||
throw new HDF5LibraryException("H5Gget_obj_info_max(): name and type array sizes are different");
|
||||
}
|
||||
|
||||
return H5Gget_obj_info_max(loc_id, objNames, objTypes, lnkTypes, objRef, objMax, objNames.length);
|
||||
return H5Gget_obj_info_max(loc_id, objNames, objTypes, lnkTypes, objToken, objMax, objNames.length);
|
||||
}
|
||||
|
||||
private synchronized static native int H5Gget_obj_info_max(long loc_id, String[] oname, int[] otype, int[] ltype,
|
||||
long[] ref, long amax, int n) throws HDF5LibraryException, NullPointerException;
|
||||
H5O_token_t[] tokens, long amax, int n) throws HDF5LibraryException, NullPointerException;
|
||||
|
||||
/**
|
||||
* H5Gn_members report the number of objects in a Group. The 'objects' include everything that will be visited by
|
||||
@ -4340,8 +4342,8 @@ public class H5 implements java.io.Serializable {
|
||||
* @exception HDF5LibraryException
|
||||
* - Error from the HDF-5 Library.
|
||||
**/
|
||||
public synchronized static native int H5Literate(long grp_id, int idx_type, int order, long idx, H5L_iterate_cb op,
|
||||
H5L_iterate_t op_data) throws HDF5LibraryException;
|
||||
public synchronized static native int H5Literate(long grp_id, int idx_type, int order, long idx, H5L_iterate_t op,
|
||||
H5L_iterate_opdata_t op_data) throws HDF5LibraryException;
|
||||
|
||||
/**
|
||||
* H5Literate_by_name iterates through links in a group.
|
||||
@ -4372,7 +4374,7 @@ public class H5 implements java.io.Serializable {
|
||||
* - group_name is null.
|
||||
**/
|
||||
public synchronized static native int H5Literate_by_name(long grp_id, String group_name, int idx_type, int order,
|
||||
long idx, H5L_iterate_cb op, H5L_iterate_t op_data, long lapl_id) throws HDF5LibraryException,
|
||||
long idx, H5L_iterate_t op, H5L_iterate_opdata_t op_data, long lapl_id) throws HDF5LibraryException,
|
||||
NullPointerException;
|
||||
|
||||
/**
|
||||
@ -4419,8 +4421,8 @@ public class H5 implements java.io.Serializable {
|
||||
* @exception HDF5LibraryException
|
||||
* - Error from the HDF-5 Library.
|
||||
**/
|
||||
public synchronized static native int H5Lvisit(long grp_id, int idx_type, int order, H5L_iterate_cb op,
|
||||
H5L_iterate_t op_data) throws HDF5LibraryException;
|
||||
public synchronized static native int H5Lvisit(long grp_id, int idx_type, int order, H5L_iterate_t op,
|
||||
H5L_iterate_opdata_t op_data) throws HDF5LibraryException;
|
||||
|
||||
/**
|
||||
* H5Lvisit_by_name recursively visits all links starting from a specified group.
|
||||
@ -4449,7 +4451,7 @@ public class H5 implements java.io.Serializable {
|
||||
* - group_name is null.
|
||||
**/
|
||||
public synchronized static native int H5Lvisit_by_name(long loc_id, String group_name, int idx_type, int order,
|
||||
H5L_iterate_cb op, H5L_iterate_t op_data, long lapl_id) throws HDF5LibraryException, NullPointerException;
|
||||
H5L_iterate_t op, H5L_iterate_opdata_t op_data, long lapl_id) throws HDF5LibraryException, NullPointerException;
|
||||
|
||||
|
||||
/**
|
||||
@ -4665,6 +4667,52 @@ public class H5 implements java.io.Serializable {
|
||||
public synchronized static native H5O_info_t H5Oget_info(long loc_id, int fields) throws HDF5LibraryException,
|
||||
NullPointerException;
|
||||
|
||||
/**
|
||||
* H5Oget_info_by_name retrieves the metadata for an object, identifying the object by location and relative name.
|
||||
*
|
||||
* @param loc_id
|
||||
* IN: File or group identifier specifying location of group in which object is located
|
||||
* @param name
|
||||
* IN: Relative name of group
|
||||
* @param lapl_id
|
||||
* IN: Access property list identifier for the link pointing to the object (Not currently used; pass as
|
||||
* H5P_DEFAULT.)
|
||||
*
|
||||
* @return object information
|
||||
*
|
||||
* @exception HDF5LibraryException
|
||||
* - Error from the HDF-5 Library.
|
||||
* @exception NullPointerException
|
||||
* - name is null.
|
||||
**/
|
||||
public static H5O_info_t H5Oget_info_by_name(long loc_id, String name, long lapl_id)
|
||||
throws HDF5LibraryException, NullPointerException {
|
||||
return H5Oget_info_by_name(loc_id, name, HDF5Constants.H5O_INFO_ALL, lapl_id);
|
||||
}
|
||||
|
||||
/**
|
||||
* H5Oget_info_by_name retrieves the metadata for an object, identifying the object by location and relative name.
|
||||
*
|
||||
* @param loc_id
|
||||
* IN: File or group identifier specifying location of group in which object is located
|
||||
* @param name
|
||||
* IN: Relative name of group
|
||||
* @param fields
|
||||
* IN: Object fields to select
|
||||
* @param lapl_id
|
||||
* IN: Access property list identifier for the link pointing to the object (Not currently used; pass as
|
||||
* H5P_DEFAULT.)
|
||||
*
|
||||
* @return object information
|
||||
*
|
||||
* @exception HDF5LibraryException
|
||||
* - Error from the HDF-5 Library.
|
||||
* @exception NullPointerException
|
||||
* - name is null.
|
||||
**/
|
||||
public synchronized static native H5O_info_t H5Oget_info_by_name(long loc_id, String name, int fields, long lapl_id)
|
||||
throws HDF5LibraryException, NullPointerException;
|
||||
|
||||
/**
|
||||
* H5Oget_info_by_idx retrieves the metadata for an object, identifying the object by an index position.
|
||||
*
|
||||
@ -4724,7 +4772,47 @@ public class H5 implements java.io.Serializable {
|
||||
int order, long n, int fields, long lapl_id) throws HDF5LibraryException, NullPointerException;
|
||||
|
||||
/**
|
||||
* H5Oget_info_by_name retrieves the metadata for an object, identifying the object by location and relative name.
|
||||
* H5Oget_native_info retrieves the native HDF5-specific metadata for an HDF5 object specified by an identifier.
|
||||
* Native HDF5-specific metadata includes things like object header information and object storage layout information.
|
||||
*
|
||||
* @param loc_id
|
||||
* IN: Identifier for target object
|
||||
*
|
||||
* @return object information
|
||||
*
|
||||
* @exception HDF5LibraryException
|
||||
* - Error from the HDF-5 Library.
|
||||
* @exception NullPointerException
|
||||
* - name is null.
|
||||
**/
|
||||
public static H5O_native_info_t H5Oget_native_info(long loc_id) throws HDF5LibraryException,
|
||||
NullPointerException {
|
||||
return H5Oget_native_info(loc_id, HDF5Constants.H5O_NATIVE_INFO_ALL);
|
||||
}
|
||||
|
||||
/**
|
||||
* H5Oget_native_info retrieves the native HDF5-specific metadata for an HDF5 object specified by an identifier.
|
||||
* Native HDF5-specific metadata includes things like object header information and object storage layout information.
|
||||
*
|
||||
* @param loc_id
|
||||
* IN: Identifier for target object
|
||||
* @param fields
|
||||
* IN: Object fields to select
|
||||
*
|
||||
* @return object information
|
||||
*
|
||||
* @exception HDF5LibraryException
|
||||
* - Error from the HDF-5 Library.
|
||||
* @exception NullPointerException
|
||||
* - name is null.
|
||||
**/
|
||||
public synchronized static native H5O_native_info_t H5Oget_native_info(long loc_id, int fields) throws HDF5LibraryException,
|
||||
NullPointerException;
|
||||
|
||||
/**
|
||||
* H5Oget_native_info_by_name retrieves the native HDF5-specific metadata for an HDF5 object, identifying the object
|
||||
* by location and relative name. Native HDF5-specific metadata includes things like object header information and
|
||||
* object storage layout information.
|
||||
*
|
||||
* @param loc_id
|
||||
* IN: File or group identifier specifying location of group in which object is located
|
||||
@ -4741,13 +4829,15 @@ public class H5 implements java.io.Serializable {
|
||||
* @exception NullPointerException
|
||||
* - name is null.
|
||||
**/
|
||||
public static H5O_info_t H5Oget_info_by_name(long loc_id, String name, long lapl_id)
|
||||
public static H5O_native_info_t H5Oget_native_info_by_name(long loc_id, String name, long lapl_id)
|
||||
throws HDF5LibraryException, NullPointerException {
|
||||
return H5Oget_info_by_name(loc_id, name, HDF5Constants.H5O_INFO_ALL, lapl_id);
|
||||
return H5Oget_native_info_by_name(loc_id, name, HDF5Constants.H5O_NATIVE_INFO_ALL, lapl_id);
|
||||
}
|
||||
|
||||
/**
|
||||
* H5Oget_info_by_name retrieves the metadata for an object, identifying the object by location and relative name.
|
||||
* H5Oget_native_info_by_name retrieves the native HDF5-specific metadata for an HDF5 object, identifying the object
|
||||
* by location and relative name. Native HDF5-specific metadata includes things like object header information and
|
||||
* object storage layout information.
|
||||
*
|
||||
* @param loc_id
|
||||
* IN: File or group identifier specifying location of group in which object is located
|
||||
@ -4766,9 +4856,71 @@ public class H5 implements java.io.Serializable {
|
||||
* @exception NullPointerException
|
||||
* - name is null.
|
||||
**/
|
||||
public synchronized static native H5O_info_t H5Oget_info_by_name(long loc_id, String name, int fields, long lapl_id)
|
||||
public synchronized static native H5O_native_info_t H5Oget_native_info_by_name(long loc_id, String name, int fields, long lapl_id)
|
||||
throws HDF5LibraryException, NullPointerException;
|
||||
|
||||
/**
|
||||
* H5Oget_native_info_by_idx retrieves the native HDF5-specific metadata for an HDF5 object, identifying the object
|
||||
* by an index position. Native HDF5-specific metadata includes things like object header information and
|
||||
* object storage layout information.
|
||||
*
|
||||
* @param loc_id
|
||||
* IN: File or group identifier
|
||||
* @param group_name
|
||||
* IN: Name of group, relative to loc_id, in which object is located
|
||||
* @param idx_type
|
||||
* IN: Type of index by which objects are ordered
|
||||
* @param order
|
||||
* IN: Order of iteration within index
|
||||
* @param n
|
||||
* IN: Object to open
|
||||
* @param lapl_id
|
||||
* IN: Access property list identifier for the link pointing to the object (Not currently used; pass as
|
||||
* H5P_DEFAULT.)
|
||||
*
|
||||
* @return object information
|
||||
*
|
||||
* @exception HDF5LibraryException
|
||||
* - Error from the HDF-5 Library.
|
||||
* @exception NullPointerException
|
||||
* - name is null.
|
||||
**/
|
||||
public static H5O_native_info_t H5Oget_native_info_by_idx(long loc_id, String group_name, int idx_type,
|
||||
int order, long n, long lapl_id) throws HDF5LibraryException, NullPointerException {
|
||||
return H5Oget_native_info_by_idx(loc_id, group_name, idx_type, order, n, HDF5Constants.H5O_NATIVE_INFO_ALL, lapl_id);
|
||||
}
|
||||
|
||||
/**
|
||||
* H5Oget_native_info_by_idx retrieves the native HDF5-specific metadata for an HDF5 object, identifying the object
|
||||
* by an index position. Native HDF5-specific metadata includes things like object header information and
|
||||
* object storage layout information.
|
||||
*
|
||||
* @param loc_id
|
||||
* IN: File or group identifier
|
||||
* @param group_name
|
||||
* IN: Name of group, relative to loc_id, in which object is located
|
||||
* @param idx_type
|
||||
* IN: Type of index by which objects are ordered
|
||||
* @param order
|
||||
* IN: Order of iteration within index
|
||||
* @param n
|
||||
* IN: Object to open
|
||||
* @param fields
|
||||
* IN: Object fields to select
|
||||
* @param lapl_id
|
||||
* IN: Access property list identifier for the link pointing to the object (Not currently used; pass as
|
||||
* H5P_DEFAULT.)
|
||||
*
|
||||
* @return object information
|
||||
*
|
||||
* @exception HDF5LibraryException
|
||||
* - Error from the HDF-5 Library.
|
||||
* @exception NullPointerException
|
||||
* - name is null.
|
||||
**/
|
||||
public synchronized static native H5O_native_info_t H5Oget_native_info_by_idx(long loc_id, String group_name, int idx_type,
|
||||
int order, long n, int fields, long lapl_id) throws HDF5LibraryException, NullPointerException;
|
||||
|
||||
/**
|
||||
* H5Olink creates a new hard link to an object in an HDF5 file.
|
||||
*
|
||||
@ -4843,7 +4995,7 @@ public class H5 implements java.io.Serializable {
|
||||
* @exception NullPointerException
|
||||
* - name is null.
|
||||
**/
|
||||
public static int H5Ovisit(long obj_id, int idx_type, int order, H5O_iterate_cb op, H5O_iterate_t op_data)
|
||||
public static int H5Ovisit(long obj_id, int idx_type, int order, H5O_iterate_t op, H5O_iterate_opdata_t op_data)
|
||||
throws HDF5LibraryException, NullPointerException {
|
||||
return H5Ovisit(obj_id, idx_type, order, op, op_data, HDF5Constants.H5O_INFO_ALL);
|
||||
}
|
||||
@ -4872,8 +5024,8 @@ public class H5 implements java.io.Serializable {
|
||||
* @exception NullPointerException
|
||||
* - name is null.
|
||||
**/
|
||||
public synchronized static native int H5Ovisit(long obj_id, int idx_type, int order, H5O_iterate_cb op,
|
||||
H5O_iterate_t op_data, int fields) throws HDF5LibraryException, NullPointerException;
|
||||
public synchronized static native int H5Ovisit(long obj_id, int idx_type, int order, H5O_iterate_t op,
|
||||
H5O_iterate_opdata_t op_data, int fields) throws HDF5LibraryException, NullPointerException;
|
||||
|
||||
/**
|
||||
* H5Ovisit_by_name recursively visits all objects starting from a specified object.
|
||||
@ -4902,7 +5054,7 @@ public class H5 implements java.io.Serializable {
|
||||
* - name is null.
|
||||
**/
|
||||
public static int H5Ovisit_by_name(long loc_id, String obj_name, int idx_type, int order,
|
||||
H5O_iterate_cb op, H5O_iterate_t op_data, long lapl_id) throws HDF5LibraryException, NullPointerException {
|
||||
H5O_iterate_t op, H5O_iterate_opdata_t op_data, long lapl_id) throws HDF5LibraryException, NullPointerException {
|
||||
return H5Ovisit_by_name(loc_id, obj_name, idx_type, order, op, op_data, HDF5Constants.H5O_INFO_ALL, lapl_id);
|
||||
}
|
||||
|
||||
@ -4935,7 +5087,7 @@ public class H5 implements java.io.Serializable {
|
||||
* - name is null.
|
||||
**/
|
||||
public synchronized static native int H5Ovisit_by_name(long loc_id, String obj_name, int idx_type, int order,
|
||||
H5O_iterate_cb op, H5O_iterate_t op_data, int fields, long lapl_id) throws HDF5LibraryException, NullPointerException;
|
||||
H5O_iterate_t op, H5O_iterate_opdata_t op_data, int fields, long lapl_id) throws HDF5LibraryException, NullPointerException;
|
||||
|
||||
|
||||
/**
|
||||
@ -4977,26 +5129,28 @@ public class H5 implements java.io.Serializable {
|
||||
public synchronized static native void H5Oincr_refcount(long object_id) throws HDF5LibraryException;
|
||||
|
||||
/**
|
||||
* H5Oopen_by_addr opens a group, dataset, or named datatype using its address within an HDF5 file.
|
||||
* H5Oopen_by_token opens a group, dataset, or named datatype using its object token within an HDF5 file.
|
||||
*
|
||||
* @param loc_id IN: File or group identifier
|
||||
* @param addr IN: Object's address in the file
|
||||
* @param token IN: Object's token in the file
|
||||
*
|
||||
* @return an object identifier for the opened object
|
||||
*
|
||||
* @exception HDF5LibraryException - Error from the HDF-5 Library.
|
||||
**/
|
||||
public static long H5Oopen_by_addr(long loc_id, long addr) throws HDF5LibraryException {
|
||||
long id = _H5Oopen_by_addr(loc_id, addr);
|
||||
public static long H5Oopen_by_token(long loc_id, H5O_token_t token) throws HDF5LibraryException {
|
||||
long id = _H5Oopen_by_token(loc_id, token);
|
||||
|
||||
if (id > 0) {
|
||||
log.trace("OPEN_IDS: H5Oopen_by_addr add {}", id);
|
||||
log.trace("OPEN_IDS: H5Oopen_by_token add {}", id);
|
||||
OPEN_IDS.add(id);
|
||||
log.trace("OPEN_IDS: {}", OPEN_IDS.size());
|
||||
}
|
||||
|
||||
return id;
|
||||
}
|
||||
|
||||
private synchronized static native long _H5Oopen_by_addr(long loc_id, long addr)
|
||||
private synchronized static native long _H5Oopen_by_token(long loc_id, H5O_token_t token)
|
||||
throws HDF5LibraryException, NullPointerException;
|
||||
|
||||
/**
|
||||
@ -5060,6 +5214,12 @@ public class H5 implements java.io.Serializable {
|
||||
public synchronized static native void H5Oenable_mdc_flushes(long object_id);
|
||||
public synchronized static native boolean H5Oare_mdc_flushes_disabled(long object_id);
|
||||
|
||||
// /////// unimplemented ////////
|
||||
// herr_t H5Otoken_cmp(hid_t loc_id, const H5O_token_t *token1, const H5O_token_t *token2,
|
||||
// int *cmp_value);
|
||||
// herr_t H5Otoken_to_str(hid_t loc_id, const H5O_token_t *token, char **token_str);
|
||||
// herr_t H5Otoken_from_str(hid_t loc_id, const char *token_str, H5O_token_t *token);
|
||||
|
||||
// ////////////////////////////////////////////////////////////
|
||||
// //
|
||||
// H5P: Property List Interface Functions //
|
||||
@ -10736,7 +10896,8 @@ public class H5 implements java.io.Serializable {
|
||||
public synchronized static native long H5VLregister_connector_by_name(String connector_name, long vipl_id);
|
||||
public synchronized static native long H5VLregister_connector_by_value(int connector_value, long vipl_id);
|
||||
public synchronized static native boolean H5VLis_connector_registered(String name);
|
||||
public synchronized static native long H5VLget_connector_id(String name);
|
||||
public synchronized static native long H5VLget_connector_id(long object_id);
|
||||
public synchronized static native long H5VLget_connector_id_by_name(String name);
|
||||
public synchronized static native String H5VLget_connector_name(long object_id);
|
||||
public synchronized static native void H5VLclose(long connector_id);
|
||||
public synchronized static native void H5VLunregister_connector(long connector_id);
|
||||
|
@ -14,6 +14,8 @@
|
||||
|
||||
package hdf.hdf5lib;
|
||||
|
||||
import hdf.hdf5lib.structs.H5O_token_t;
|
||||
|
||||
/**
|
||||
* /** This class contains C constants and enumerated types of HDF5 library. The
|
||||
* values of these constants are obtained from the library by calling J2C(int
|
||||
@ -344,9 +346,10 @@ public class HDF5Constants {
|
||||
public static final int H5O_INFO_BASIC = H5O_INFO_BASIC();
|
||||
public static final int H5O_INFO_TIME = H5O_INFO_TIME();
|
||||
public static final int H5O_INFO_NUM_ATTRS = H5O_INFO_NUM_ATTRS();
|
||||
public static final int H5O_INFO_HDR = H5O_INFO_HDR();
|
||||
public static final int H5O_INFO_META_SIZE = H5O_INFO_META_SIZE();
|
||||
public static final int H5O_INFO_ALL = H5O_INFO_ALL();
|
||||
public static final int H5O_NATIVE_INFO_HDR = H5O_NATIVE_INFO_HDR();
|
||||
public static final int H5O_NATIVE_INFO_META_SIZE = H5O_NATIVE_INFO_META_SIZE();
|
||||
public static final int H5O_NATIVE_INFO_ALL = H5O_NATIVE_INFO_ALL();
|
||||
public static final int H5O_SHMESG_NONE_FLAG = H5O_SHMESG_NONE_FLAG();
|
||||
public static final int H5O_SHMESG_SDSPACE_FLAG = H5O_SHMESG_SDSPACE_FLAG();
|
||||
public static final int H5O_SHMESG_DTYPE_FLAG = H5O_SHMESG_DTYPE_FLAG();
|
||||
@ -359,6 +362,8 @@ public class HDF5Constants {
|
||||
public static final int H5O_TYPE_DATASET = H5O_TYPE_DATASET();
|
||||
public static final int H5O_TYPE_NAMED_DATATYPE = H5O_TYPE_NAMED_DATATYPE();
|
||||
public static final int H5O_TYPE_NTYPES = H5O_TYPE_NTYPES();
|
||||
public static final int H5O_MAX_TOKEN_SIZE = H5O_MAX_TOKEN_SIZE();
|
||||
public static final H5O_token_t H5O_TOKEN_UNDEF = H5O_TOKEN_UNDEF();
|
||||
|
||||
public static final long H5P_ROOT = H5P_ROOT();
|
||||
public static final long H5P_OBJECT_CREATE = H5P_OBJECT_CREATE();
|
||||
@ -1308,12 +1313,14 @@ public class HDF5Constants {
|
||||
|
||||
private static native final int H5O_INFO_NUM_ATTRS();
|
||||
|
||||
private static native final int H5O_INFO_HDR();
|
||||
|
||||
private static native final int H5O_INFO_META_SIZE();
|
||||
|
||||
private static native final int H5O_INFO_ALL();
|
||||
|
||||
private static native final int H5O_NATIVE_INFO_HDR();
|
||||
|
||||
private static native final int H5O_NATIVE_INFO_META_SIZE();
|
||||
|
||||
private static native final int H5O_NATIVE_INFO_ALL();
|
||||
|
||||
private static native final int H5O_SHMESG_NONE_FLAG();
|
||||
|
||||
private static native final int H5O_SHMESG_SDSPACE_FLAG();
|
||||
@ -1338,6 +1345,10 @@ public class HDF5Constants {
|
||||
|
||||
private static native final int H5O_TYPE_NTYPES();
|
||||
|
||||
private static native final int H5O_MAX_TOKEN_SIZE();
|
||||
|
||||
private static native final H5O_token_t H5O_TOKEN_UNDEF();
|
||||
|
||||
private static native final long H5P_ROOT();
|
||||
|
||||
private static native final long H5P_OBJECT_CREATE();
|
||||
|
@ -13,9 +13,6 @@
|
||||
|
||||
package hdf.hdf5lib.callbacks;
|
||||
|
||||
import hdf.hdf5lib.structs.H5L_info_t;
|
||||
public interface H5L_iterate_opdata_t {
|
||||
|
||||
//Information class for link callback(for H5Lvisit/H5Lvisit_by_name)
|
||||
public interface H5L_iterate_cb extends Callbacks {
|
||||
int callback(long group, String name, H5L_info_t info, H5L_iterate_t op_data);
|
||||
}
|
@ -13,8 +13,9 @@
|
||||
|
||||
package hdf.hdf5lib.callbacks;
|
||||
|
||||
public interface H5L_iterate_t {
|
||||
/** public ArrayList iterdata = new ArrayList();
|
||||
* Any derived interfaces must define the single public variable as above.
|
||||
*/
|
||||
import hdf.hdf5lib.structs.H5L_info_t;
|
||||
|
||||
// Information class for link callback (for H5Lvisit/H5Lvisit_by_name).
|
||||
public interface H5L_iterate_t extends Callbacks {
|
||||
int callback(long group, String name, H5L_info_t info, H5L_iterate_opdata_t op_data);
|
||||
}
|
||||
|
@ -13,9 +13,6 @@
|
||||
|
||||
package hdf.hdf5lib.callbacks;
|
||||
|
||||
import hdf.hdf5lib.structs.H5O_info_t;
|
||||
public interface H5O_iterate_opdata_t {
|
||||
|
||||
//Information class for link callback(for H5Ovisit/H5Ovisit_by_name)
|
||||
public interface H5O_iterate_cb extends Callbacks {
|
||||
int callback(long group, String name, H5O_info_t info, H5O_iterate_t op_data);
|
||||
}
|
@ -13,8 +13,9 @@
|
||||
|
||||
package hdf.hdf5lib.callbacks;
|
||||
|
||||
public interface H5O_iterate_t {
|
||||
/** public ArrayList iterdata = new ArrayList();
|
||||
* Any derived interfaces must define the single public variable as above.
|
||||
*/
|
||||
import hdf.hdf5lib.structs.H5O_info_t;
|
||||
|
||||
// Information class for link callback(for H5Ovisit/H5Ovisit_by_name)
|
||||
public interface H5O_iterate_t extends Callbacks {
|
||||
int callback(long group, String name, H5O_info_t info, H5O_iterate_opdata_t op_data);
|
||||
}
|
||||
|
@ -15,22 +15,39 @@ package hdf.hdf5lib.structs;
|
||||
|
||||
import java.io.Serializable;
|
||||
|
||||
//Information struct for link (for H5Lget_info/H5Lget_info_by_idx)
|
||||
public class H5L_info_t implements Serializable{
|
||||
private static final long serialVersionUID = -4754320605310155033L;
|
||||
public int type;
|
||||
public boolean corder_valid;
|
||||
public long corder;
|
||||
public int cset;
|
||||
public long address_val_size;
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
|
||||
// Information struct for link (for H5Lget_info/H5Lget_info_by_idx)
|
||||
public class H5L_info_t implements Serializable {
|
||||
private static final long serialVersionUID = -4754320605310155033L;
|
||||
public int type;
|
||||
public boolean corder_valid;
|
||||
public long corder;
|
||||
public int cset;
|
||||
public H5O_token_t token;
|
||||
public long val_size;
|
||||
|
||||
// Constructor for using object token portion of C union
|
||||
H5L_info_t (int type, boolean corder_valid, long corder,
|
||||
int cset, long address_val_size)
|
||||
int cset, H5O_token_t token)
|
||||
{
|
||||
this.type = type;
|
||||
this.corder_valid = corder_valid;
|
||||
this.corder = corder;
|
||||
this.cset = cset;
|
||||
this.address_val_size = address_val_size;
|
||||
this.token = token;
|
||||
this.val_size = -1;
|
||||
}
|
||||
|
||||
// Constructor for using val_size portion of C union
|
||||
H5L_info_t (int type, boolean corder_valid, long corder,
|
||||
int cset, long val_size)
|
||||
{
|
||||
this.type = type;
|
||||
this.corder_valid = corder_valid;
|
||||
this.corder = corder;
|
||||
this.cset = cset;
|
||||
this.token = HDF5Constants.H5O_TOKEN_UNDEF;
|
||||
this.val_size = val_size;
|
||||
}
|
||||
}
|
||||
|
@ -16,7 +16,7 @@ package hdf.hdf5lib.structs;
|
||||
import java.io.Serializable;
|
||||
|
||||
// Information struct for object header metadata (for H5Oget_info/H5Oget_info_by_name/H5Oget_info_by_idx)
|
||||
public class H5O_hdr_info_t implements Serializable{
|
||||
public class H5O_hdr_info_t implements Serializable {
|
||||
private static final long serialVersionUID = 7883826382952577189L;
|
||||
public int version; /* Version number of header format in file */
|
||||
public int nmesgs; /* Number of object header messages */
|
||||
@ -44,4 +44,38 @@ public class H5O_hdr_info_t implements Serializable{
|
||||
this.mesg_present = mesg_present;
|
||||
this.mesg_shared = mesg_shared;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(Object o) {
|
||||
if (this == o)
|
||||
return true;
|
||||
|
||||
if (!(o instanceof H5O_hdr_info_t))
|
||||
return false;
|
||||
|
||||
H5O_hdr_info_t info = (H5O_hdr_info_t) o;
|
||||
|
||||
if (this.version != info.version)
|
||||
return false;
|
||||
if (this.nmesgs != info.nmesgs)
|
||||
return false;
|
||||
if (this.nchunks != info.nchunks)
|
||||
return false;
|
||||
if (this.flags != info.flags)
|
||||
return false;
|
||||
if (this.space_total != info.space_total)
|
||||
return false;
|
||||
if (this.space_meta != info.space_meta)
|
||||
return false;
|
||||
if (this.space_mesg != info.space_mesg)
|
||||
return false;
|
||||
if (this.space_free != info.space_free)
|
||||
return false;
|
||||
if (this.mesg_present != info.mesg_present)
|
||||
return false;
|
||||
if (this.mesg_shared != info.mesg_shared)
|
||||
return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -15,38 +15,30 @@ package hdf.hdf5lib.structs;
|
||||
|
||||
import java.io.Serializable;
|
||||
|
||||
//Information struct for object (for H5Oget_info/H5Oget_info_by_name/H5Oget_info_by_idx)
|
||||
public class H5O_info_t implements Serializable{
|
||||
// Information struct for object (for H5Oget_info/H5Oget_info_by_name/H5Oget_info_by_idx)
|
||||
public class H5O_info_t implements Serializable {
|
||||
private static final long serialVersionUID = 4691681163544054518L;
|
||||
public long fileno; /* File number that object is located in */
|
||||
public long addr; /* Object address in file */
|
||||
public int type; /* Basic object type (group, dataset, etc.) */
|
||||
public int rc; /* Reference count of object */
|
||||
public long atime; /* Access time */
|
||||
public long mtime; /* Modification time */
|
||||
public long ctime; /* Change time */
|
||||
public long btime; /* Birth time */
|
||||
public long num_attrs; /* # of attributes attached to object */
|
||||
public H5O_hdr_info_t hdr; /* Object header information */
|
||||
/* Extra metadata storage for obj & attributes */
|
||||
public H5_ih_info_t meta_size_obj; /* v1/v2 B-tree & local/fractal heap for groups, B-tree for chunked datasets */
|
||||
public H5_ih_info_t meta_size_attr; /* v2 B-tree & heap for attributes */
|
||||
public long fileno; /* File number that object is located in */
|
||||
public H5O_token_t token; /* Object token in file */
|
||||
public int type; /* Basic object type (group, dataset, etc.) */
|
||||
public int rc; /* Reference count of object */
|
||||
public long atime; /* Access time */
|
||||
public long mtime; /* Modification time */
|
||||
public long ctime; /* Change time */
|
||||
public long btime; /* Birth time */
|
||||
public long num_attrs; /* # of attributes attached to object */
|
||||
|
||||
public H5O_info_t (long fileno, long addr, int type,
|
||||
int rc, long num_attrs, long atime, long mtime, long ctime, long btime,
|
||||
H5O_hdr_info_t hdr, H5_ih_info_t meta_size_obj, H5_ih_info_t meta_size_attr)
|
||||
public H5O_info_t (long fileno, H5O_token_t token, int type,
|
||||
int rc, long atime, long mtime, long ctime, long btime, long num_attrs)
|
||||
{
|
||||
this.fileno = fileno;
|
||||
this.addr = addr;
|
||||
this.token = token;
|
||||
this.type = type;
|
||||
this.rc = rc;
|
||||
this.num_attrs = num_attrs;
|
||||
this.atime = atime;
|
||||
this.mtime = mtime;
|
||||
this.ctime = ctime;
|
||||
this.btime = btime;
|
||||
this.hdr = hdr;
|
||||
this.meta_size_obj = meta_size_obj;
|
||||
this.meta_size_attr = meta_size_attr;
|
||||
this.num_attrs = num_attrs;
|
||||
}
|
||||
}
|
||||
|
52
java/src/hdf/hdf5lib/structs/H5O_native_info_t.java
Normal file
52
java/src/hdf/hdf5lib/structs/H5O_native_info_t.java
Normal file
@ -0,0 +1,52 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Copyright by The HDF Group. *
|
||||
* Copyright by the Board of Trustees of the University of Illinois. *
|
||||
* All rights reserved. *
|
||||
* *
|
||||
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
||||
* terms governing use, modification, and redistribution, is contained in *
|
||||
* the COPYING file, which can be found at the root of the source code *
|
||||
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
||||
* If you do not have access to either file, you may request a copy from *
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
package hdf.hdf5lib.structs;
|
||||
|
||||
import java.io.Serializable;
|
||||
|
||||
// Information struct for native HDF5 object info, such as object header metadata (for H5Oget_info/H5Oget_info_by_name/H5Oget_info_by_idx).
|
||||
public class H5O_native_info_t implements Serializable {
|
||||
private static final long serialVersionUID = 7883826382952577189L;
|
||||
|
||||
public H5O_hdr_info_t hdr_info; /* Object header information */
|
||||
|
||||
/* Extra metadata storage for obj & attributes */
|
||||
public H5_ih_info_t obj_info; /* v1/v2 B-tree & local/fractal heap for groups, B-tree for chunked datasets */
|
||||
public H5_ih_info_t attr_info; /* v2 B-tree & heap for attributes */
|
||||
|
||||
H5O_native_info_t (H5O_hdr_info_t oheader_info, H5_ih_info_t obj_info, H5_ih_info_t attr_info)
|
||||
{
|
||||
this.hdr_info = oheader_info;
|
||||
this.obj_info = obj_info;
|
||||
this.attr_info = attr_info;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(Object o) {
|
||||
if (this == o)
|
||||
return true;
|
||||
|
||||
if (!(o instanceof H5O_native_info_t))
|
||||
return false;
|
||||
|
||||
H5O_native_info_t info = (H5O_native_info_t) o;
|
||||
|
||||
if (!this.hdr_info.equals(info.hdr_info)
|
||||
|| !this.obj_info.equals(info.obj_info)
|
||||
|| !this.attr_info.equals(info.attr_info))
|
||||
return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
45
java/src/hdf/hdf5lib/structs/H5O_token_t.java
Normal file
45
java/src/hdf/hdf5lib/structs/H5O_token_t.java
Normal file
@ -0,0 +1,45 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* 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 *
|
||||
* the COPYING file, which can be found at the root of the source code *
|
||||
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
||||
* If you do not have access to either file, you may request a copy from *
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
package hdf.hdf5lib.structs;
|
||||
|
||||
import java.io.Serializable;
|
||||
import java.util.Arrays;
|
||||
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
|
||||
// Object token, which is a unique and permanent identifier, for an HDF5 object within a container.
|
||||
public class H5O_token_t implements Serializable {
|
||||
private static final long serialVersionUID = -4754320605310155032L;
|
||||
public byte[] data;
|
||||
|
||||
H5O_token_t (byte[] data) {
|
||||
this.data = data;
|
||||
}
|
||||
|
||||
public boolean isUndefined() {
|
||||
return this.equals(HDF5Constants.H5O_TOKEN_UNDEF);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(Object o) {
|
||||
if (this == o)
|
||||
return true;
|
||||
|
||||
if (!(o instanceof H5O_token_t))
|
||||
return false;
|
||||
|
||||
H5O_token_t token = (H5O_token_t) o;
|
||||
|
||||
return Arrays.equals(this.data, token.data);
|
||||
}
|
||||
}
|
@ -26,4 +26,22 @@ public class H5_ih_info_t implements Serializable {
|
||||
this.index_size = index_size;
|
||||
this.heap_size = heap_size;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(Object o) {
|
||||
if (this == o)
|
||||
return true;
|
||||
|
||||
if (!(o instanceof H5_ih_info_t))
|
||||
return false;
|
||||
|
||||
H5_ih_info_t info = (H5_ih_info_t) o;
|
||||
|
||||
if (this.index_size != info.index_size)
|
||||
return false;
|
||||
if (this.heap_size != info.heap_size)
|
||||
return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@ -409,7 +409,7 @@ h5libraryError
|
||||
|
||||
if (msg_size > 0) {
|
||||
if (NULL == (msg_str = (char *) HDcalloc((size_t)msg_size + 1, sizeof(char))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5libraryerror: failed to allocate buffer for error message");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5libraryerror: failed to allocate buffer for error message");
|
||||
|
||||
if ((msg_size = H5Eget_msg(min_num, &error_msg_type, msg_str, (size_t)msg_size + 1)) < 0)
|
||||
goto done;
|
||||
|
@ -684,12 +684,14 @@ Java_hdf_hdf5lib_HDF5Constants_H5O_1INFO_1TIME(JNIEnv *env, jclass cls) { return
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1INFO_1NUM_1ATTRS(JNIEnv *env, jclass cls) { return H5O_INFO_NUM_ATTRS; }
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1INFO_1HDR(JNIEnv *env, jclass cls) { return H5O_INFO_HDR; }
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1INFO_1META_1SIZE(JNIEnv *env, jclass cls) { return H5O_INFO_META_SIZE; }
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1INFO_1ALL(JNIEnv *env, jclass cls) { return H5O_INFO_ALL; }
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1NATIVE_1INFO_1HDR(JNIEnv *env, jclass cls) { return H5O_NATIVE_INFO_HDR; }
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1NATIVE_1INFO_1META_1SIZE(JNIEnv *env, jclass cls) { return H5O_NATIVE_INFO_META_SIZE; }
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1NATIVE_1INFO_1ALL(JNIEnv *env, jclass cls) { return H5O_NATIVE_INFO_ALL; }
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1SHMESG_1NONE_1FLAG(JNIEnv *env, jclass cls){return H5O_SHMESG_NONE_FLAG; }
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1SHMESG_1SDSPACE_1FLAG(JNIEnv *env, jclass cls){return H5O_SHMESG_SDSPACE_FLAG; }
|
||||
@ -713,6 +715,16 @@ JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1TYPE_1NAMED_1DATATYPE(JNIEnv *env, jclass cls) { return H5O_TYPE_NAMED_DATATYPE; }
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1TYPE_1NTYPES(JNIEnv *env, jclass cls) { return H5O_TYPE_NTYPES; }
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1MAX_1TOKEN_1SIZE(JNIEnv *env, jclass cls) { return H5O_MAX_TOKEN_SIZE; }
|
||||
JNIEXPORT jobject JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5O_1TOKEN_1UNDEF(JNIEnv *env, jclass cls)
|
||||
{
|
||||
H5O_token_t undef_token = H5O_TOKEN_UNDEF;
|
||||
|
||||
/* TODO: Can be optimized by keeping a global reference to the undefined token class */
|
||||
return create_H5O_token_t(env, &undef_token, FALSE);
|
||||
}
|
||||
|
||||
JNIEXPORT jlong JNICALL
|
||||
Java_hdf_hdf5lib_HDF5Constants_H5P_1ROOT(JNIEnv *env, jclass cls){return H5P_ROOT;}
|
||||
|
@ -841,10 +841,10 @@ Java_hdf_hdf5lib_H5_H5Aread_1string
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (cstr = (char *) HDmalloc(str_len + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Aread_string: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Aread_string: memory allocation failed");
|
||||
|
||||
if (NULL == (c_buf = (char *) HDmalloc((size_t)n * str_len)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Aread_string: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Aread_string: memory allocation failed");
|
||||
|
||||
if ((status = H5Aread((hid_t)attr_id, (hid_t)mem_type_id, c_buf)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -855,7 +855,7 @@ Java_hdf_hdf5lib_H5_H5Aread_1string
|
||||
|
||||
if (NULL == (jstr = ENVPTR->NewStringUTF(ENVONLY, cstr))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Aread_string: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Aread_string: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, j_buf, i, jstr);
|
||||
@ -905,7 +905,7 @@ Java_hdf_hdf5lib_H5_H5Awrite_1string
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (c_buf = (char *) HDmalloc((size_t)n * str_len)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Awrite_string: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Awrite_string: memory allocation failed");
|
||||
|
||||
for (i = 0; i < (size_t) n; i++) {
|
||||
if (NULL == (obj = (jstring) ENVPTR->GetObjectArrayElement(ENVONLY, (jobjectArray)j_buf, (jsize) i))) {
|
||||
@ -1037,7 +1037,7 @@ H5AreadVL_str
|
||||
}
|
||||
|
||||
if (NULL == (strs = (char **) HDcalloc((size_t)n, sizeof(char *))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5AreadVL_str: failed to allocate variable length string read buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5AreadVL_str: failed to allocate variable length string read buffer");
|
||||
|
||||
if ((status = H5Aread(aid, tid, strs)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1110,7 +1110,7 @@ H5AreadVL_asstr
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (readBuf = HDcalloc((size_t)n, typeSize)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5AreadVL_asstr: failed to allocate read buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5AreadVL_asstr: failed to allocate read buffer");
|
||||
|
||||
if ((status = H5Aread(aid, tid, readBuf)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1119,7 +1119,7 @@ H5AreadVL_asstr
|
||||
h5str_new(&h5str, 4 * typeSize);
|
||||
|
||||
if (!h5str.s)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5AreadVL_asstr: failed to allocate buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5AreadVL_asstr: failed to allocate buffer");
|
||||
|
||||
/* Convert each element to a char string */
|
||||
for (i = 0; i < (size_t) n; i++) {
|
||||
@ -1243,7 +1243,7 @@ H5AwriteVL_str
|
||||
}
|
||||
|
||||
if (NULL == (writeBuf = (char **) HDcalloc((size_t)size + 1, sizeof(char *))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5AwriteVL_str: failed to allocate variable length string write buffer")
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5AwriteVL_str: failed to allocate variable length string write buffer");
|
||||
|
||||
for (i = 0; i < size; ++i) {
|
||||
jsize length;
|
||||
@ -1264,7 +1264,7 @@ H5AwriteVL_str
|
||||
PIN_JAVA_STRING(ENVONLY, obj, utf8, NULL, "H5AwriteVL_str: string not pinned");
|
||||
|
||||
if (NULL == (writeBuf[i] = (char *) HDmalloc((size_t)length + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5AwriteVL_str: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5AwriteVL_str: failed to allocate string buffer");
|
||||
|
||||
HDstrncpy(writeBuf[i], utf8, (size_t)length);
|
||||
writeBuf[i][length] = '\0';
|
||||
@ -1325,7 +1325,7 @@ H5AwriteVL_asstr
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (writeBuf = HDcalloc((size_t)n, typeSize)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5AwriteVL_asstr: failed to allocate write buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5AwriteVL_asstr: failed to allocate write buffer");
|
||||
|
||||
/*
|
||||
* When repeatedly writing a dataset with a large number of strs (e.g., 1,000,000 strings),
|
||||
@ -1406,7 +1406,7 @@ Java_hdf_hdf5lib_H5_H5Aread_1reg_1ref
|
||||
}
|
||||
|
||||
if (NULL == (ref_data = (H5R_ref_t *) HDcalloc(1, (size_t)n * sizeof(H5R_ref_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Aread_reg_ref: failed to allocate read buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Aread_reg_ref: failed to allocate read buffer");
|
||||
|
||||
if ((status = H5Aread((hid_t)attr_id, (hid_t)mem_type_id, ref_data)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1414,7 +1414,7 @@ Java_hdf_hdf5lib_H5_H5Aread_1reg_1ref
|
||||
h5str_new(&h5str, 1024);
|
||||
|
||||
if (!h5str.s)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Aread_reg_ref: failed to allocate buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Aread_reg_ref: failed to allocate buffer");
|
||||
|
||||
for (i = 0; i < n; i++) {
|
||||
h5str.s[0] = '\0';
|
||||
@ -1499,7 +1499,7 @@ Java_hdf_hdf5lib_H5_H5Aget_1name
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (attrName = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Aget_name: failed to allocate attribute name buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Aget_name: failed to allocate attribute name buffer");
|
||||
|
||||
if (H5Aget_name((hid_t)attr_id, (size_t)buf_size + 1, attrName) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1856,7 +1856,7 @@ Java_hdf_hdf5lib_H5_H5Aget_1name_1by_1idx
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (attrName = (char *) HDmalloc(sizeof(char) * (size_t) status_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Aget_name_by_idx: failed to allocate buffer for attribute name");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Aget_name_by_idx: failed to allocate buffer for attribute name");
|
||||
|
||||
if ((H5Aget_name_by_idx((hid_t)loc_id, objName, (H5_index_t)idx_type,
|
||||
(H5_iter_order_t) order, (hsize_t) n, (char *)attrName, (size_t)status_size + 1, (hid_t)lapl_id)) < 0)
|
||||
@ -2162,7 +2162,7 @@ static herr_t
|
||||
H5A_iterate_cb
|
||||
(hid_t g_id, const char *name, const H5A_info_t *info, void *cb_data) {
|
||||
cb_wrapper *wrapper = (cb_wrapper *)cb_data;
|
||||
jmethodID constructor, mid;
|
||||
jmethodID mid;
|
||||
jobject cb_info_t = NULL;
|
||||
jobject visit_callback = wrapper->visit_callback;
|
||||
jstring str;
|
||||
@ -2191,18 +2191,7 @@ H5A_iterate_cb
|
||||
args[2].i = info->cset;
|
||||
args[3].j = (jlong)info->data_size;
|
||||
|
||||
/* Get a reference to your class if you don't have it already */
|
||||
if (NULL == (cls = CBENVPTR->FindClass(CBENVONLY, "hdf/hdf5lib/structs/H5A_info_t")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
/* Get a reference to the constructor; the name is <init> */
|
||||
if (NULL == (constructor = CBENVPTR->GetMethodID(CBENVONLY, cls, "<init>", "(ZJIJ)V")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
if (NULL == (cb_info_t = CBENVPTR->NewObjectA(CBENVONLY, cls, constructor, args))) {
|
||||
HDprintf("FATAL ERROR: hdf/hdf5lib/structs/H5A_info_t: Creation failed\n");
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
}
|
||||
CALL_CONSTRUCTOR(CBENVONLY, "hdf/hdf5lib/structs/H5A_info_t", "(ZJIJ)V", args, cb_info_t);
|
||||
|
||||
status = CBENVPTR->CallIntMethod(CBENVONLY, visit_callback, mid, g_id, str, cb_info_t, op_data);
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
@ -975,10 +975,10 @@ Java_hdf_hdf5lib_H5_H5Dread_1string
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (cstr = (char *) HDmalloc(str_len + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Dread_string: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Dread_string: memory allocation failed");
|
||||
|
||||
if (NULL == (c_buf = (char *) HDmalloc((size_t)n * str_len)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Dread_string: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Dread_string: memory allocation failed");
|
||||
|
||||
if ((status = H5Dread((hid_t)dataset_id, (hid_t)mem_type_id, (hid_t)mem_space_id,
|
||||
(hid_t)file_space_id, (hid_t)xfer_plist_id, c_buf)) < 0)
|
||||
@ -990,7 +990,7 @@ Java_hdf_hdf5lib_H5_H5Dread_1string
|
||||
|
||||
if (NULL == (jstr = ENVPTR->NewStringUTF(ENVONLY, cstr))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Dread_string: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Dread_string: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, j_buf, i, jstr);
|
||||
@ -1041,7 +1041,7 @@ Java_hdf_hdf5lib_H5_H5Dwrite_1string
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (c_buf = (char *) HDmalloc((size_t)n * str_len)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Dwrite_string: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Dwrite_string: memory allocation failed");
|
||||
|
||||
for (i = 0; i < (size_t) n; i++) {
|
||||
if (NULL == (obj = (jstring) ENVPTR->GetObjectArrayElement(ENVONLY, (jobjectArray)j_buf, (jsize) i))) {
|
||||
@ -1177,7 +1177,7 @@ H5DreadVL_str
|
||||
}
|
||||
|
||||
if (NULL == (strs = (char **) HDcalloc((size_t)n, sizeof(char *))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5DreadVL_str: failed to allocate variable length string read buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5DreadVL_str: failed to allocate variable length string read buffer");
|
||||
|
||||
if ((status = H5Dread(did, tid, mem_sid, file_sid, xfer_plist_id, strs)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1263,7 +1263,7 @@ H5DreadVL_asstr
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (readBuf = HDcalloc((size_t)n, typeSize)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5DreadVL_asstr: failed to allocate read buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5DreadVL_asstr: failed to allocate read buffer");
|
||||
|
||||
if ((status = H5Dread(did, tid, mem_sid, file_sid, xfer_plist_id, readBuf)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1272,7 +1272,7 @@ H5DreadVL_asstr
|
||||
h5str_new(&h5str, 4 * typeSize);
|
||||
|
||||
if (!h5str.s)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5DreadVL_asstr: failed to allocate buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5DreadVL_asstr: failed to allocate buffer");
|
||||
|
||||
if ((tclass = H5Tget_class(tid)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1442,7 +1442,7 @@ H5DwriteVL_str
|
||||
}
|
||||
|
||||
if (NULL == (writeBuf = (char **) HDcalloc((size_t)size + 1, sizeof(char *))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5DwriteVL_str: failed to allocate variable length string write buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5DwriteVL_str: failed to allocate variable length string write buffer");
|
||||
|
||||
for (i = 0; i < size; ++i) {
|
||||
jsize length;
|
||||
@ -1463,7 +1463,7 @@ H5DwriteVL_str
|
||||
PIN_JAVA_STRING(ENVONLY, obj, utf8, NULL, "H5DwriteVL_str: string not pinned");
|
||||
|
||||
if (NULL == (writeBuf[i] = (char *) HDmalloc((size_t)length + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5DwriteVL_str: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5DwriteVL_str: failed to allocate string buffer");
|
||||
|
||||
HDstrncpy(writeBuf[i], utf8, (size_t)length + 1);
|
||||
writeBuf[i][length] = '\0';
|
||||
@ -1536,7 +1536,7 @@ H5DwriteVL_asstr
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (writeBuf = HDcalloc((size_t)n, typeSize)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5AwriteVL_asstr: failed to allocate write buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5AwriteVL_asstr: failed to allocate write buffer");
|
||||
|
||||
for (i = 0; i < (size_t) n; ++i) {
|
||||
if (NULL == (obj = (jstring) ENVPTR->GetObjectArrayElement(ENVONLY, (jobjectArray)buf, (jsize) i))) {
|
||||
@ -1646,7 +1646,7 @@ Java_hdf_hdf5lib_H5_H5Dread_1reg_1ref
|
||||
}
|
||||
|
||||
if (NULL == (ref_data = (H5R_ref_t *) HDcalloc(1, (size_t)n * sizeof(H5R_ref_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Dread_reg_ref: failed to allocate read buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Dread_reg_ref: failed to allocate read buffer");
|
||||
|
||||
if ((status = H5Dread((hid_t)dataset_id, (hid_t)mem_type_id, (hid_t)mem_space_id, (hid_t)file_space_id, xfer_plist_id, ref_data)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1654,7 +1654,7 @@ Java_hdf_hdf5lib_H5_H5Dread_1reg_1ref
|
||||
h5str_new(&h5str, 1024);
|
||||
|
||||
if (!h5str.s)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Dread_reg_ref: failed to allocate buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Dread_reg_ref: failed to allocate buffer");
|
||||
|
||||
for (i = 0; i < n; i++) {
|
||||
h5str.s[0] = '\0';
|
||||
@ -1909,7 +1909,7 @@ Java_hdf_hdf5lib_H5_H5Dset_1extent
|
||||
PIN_LONG_ARRAY(ENVONLY, buf, dimsBuf, &isCopy, "H5Dset_extent: buffer not pinned");
|
||||
|
||||
if (NULL == (dims = (hsize_t *) HDmalloc((size_t)rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Dset_extent: failed to allocate dataset dimension buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Dset_extent: failed to allocate dataset dimension buffer");
|
||||
|
||||
for (i = 0; i < rank; i++)
|
||||
dims[i] = (hsize_t)dimsBuf[i];
|
||||
|
@ -309,7 +309,7 @@ Java_hdf_hdf5lib_H5_H5Eget_1class_1name
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Eget_class_name: no class name");
|
||||
|
||||
if (NULL == (namePtr = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Eget_class_name: malloc failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Eget_class_name: malloc failed");
|
||||
|
||||
if ((H5Eget_class_name((hid_t)cls_id, (char *)namePtr, (size_t)buf_size + 1)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -464,10 +464,10 @@ Java_hdf_hdf5lib_H5_H5Eget_1msg
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (!buf_size)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Eget_msg: invalid message");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Eget_msg: invalid message");
|
||||
|
||||
if (NULL == (namePtr = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Eget_msg: malloc failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Eget_msg: malloc failed");
|
||||
|
||||
PIN_INT_ARRAY(ENVONLY, error_msg_type_list, theArray, NULL, "H5Eget_msg: error_msg_type_list not pinned");
|
||||
|
||||
@ -517,7 +517,6 @@ H5E_walk_cb
|
||||
(int nindx, const H5E_error2_t *info, void *cb_data)
|
||||
{
|
||||
cb_wrapper *wrapper = (cb_wrapper *)cb_data;
|
||||
jmethodID constructor;
|
||||
jmethodID mid;
|
||||
jobject visit_callback = wrapper->visit_callback;
|
||||
jstring str1, str2, str3;
|
||||
@ -559,16 +558,7 @@ H5E_walk_cb
|
||||
|
||||
args[6].l = str3;
|
||||
|
||||
/* Get a reference to your class if you don't have it already */
|
||||
if (NULL == (cls = CBENVPTR->FindClass(CBENVONLY, "hdf/hdf5lib/structs/H5E_error2_t")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
/* get a reference to the constructor; the name is <init> */
|
||||
if (NULL == (constructor = CBENVPTR->GetMethodID(CBENVONLY, cls, "<init>", "(JJJILjava/lang/String;Ljava/lang/String;Ljava/lang/String;)V")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
if (NULL == (cb_info_t = CBENVPTR->NewObjectA(CBENVONLY, cls, constructor, args)))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
CALL_CONSTRUCTOR(CBENVONLY, "hdf/hdf5lib/structs/H5E_error2_t", "(JJJILjava/lang/String;Ljava/lang/String;Ljava/lang/String;)V", args, cb_info_t);
|
||||
|
||||
status = CBENVPTR->CallIntMethod(CBENVONLY, visit_callback, mid, nindx, cb_info_t, op_data);
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
@ -131,7 +131,7 @@ Java_hdf_hdf5lib_H5_H5Fget_1name
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (namePtr = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Fget_name: malloc failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Fget_name: malloc failed");
|
||||
|
||||
if ((H5Fget_name((hid_t)file_id, namePtr, (size_t)buf_size + 1)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -446,7 +446,7 @@ Java_hdf_hdf5lib_H5_H5Fget_1obj_1ids
|
||||
}
|
||||
|
||||
if (NULL == (id_list = (hid_t *) HDmalloc((size_t)rank * sizeof(hid_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Fget_obj_ids: malloc failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Fget_obj_ids: malloc failed");
|
||||
|
||||
if ((ret_val = H5Fget_obj_ids((hid_t)file_id, (unsigned int)types, (size_t)maxObjs, id_list)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
@ -71,7 +71,7 @@ Java_hdf_hdf5lib_H5_H5Iget_1name_1long
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Iget_name_long: buf_size < 0");
|
||||
|
||||
if (NULL == (aName = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Iget_name_long: malloc failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Iget_name_long: malloc failed");
|
||||
|
||||
if ((size = H5Iget_name((hid_t)obj_id, aName, (size_t)buf_size + 1)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -111,7 +111,7 @@ Java_hdf_hdf5lib_H5_H5Iget_1name
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (aName = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Iget_name: malloc failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Iget_name: malloc failed");
|
||||
|
||||
if (H5Iget_name((hid_t)obj_id, aName, (size_t)buf_size + 1) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
@ -47,195 +47,6 @@
|
||||
*/
|
||||
#define UNUSED(o) (void) o
|
||||
|
||||
/* Macros for class access */
|
||||
/* Calling code must define ret_obj as jobject */
|
||||
#define CALL_CONSTRUCTOR(env, classname, classsig, args, ret_obj) \
|
||||
{ \
|
||||
jmethodID constructor; \
|
||||
jclass cls; \
|
||||
\
|
||||
if (NULL == (cls = ENVPTR->FindClass(env, (classname)))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, "JNI error: GetObjectClass"); \
|
||||
} \
|
||||
if (NULL == (constructor = ENVPTR->GetMethodID(ENVONLY, cls, "<init>", (classsig)))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, "JNI error: GetMethodID failed"); \
|
||||
} \
|
||||
if (NULL == (ret_obj = ENVPTR->NewObjectA(ENVONLY, cls, constructor, (args)))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_FALSE); \
|
||||
} \
|
||||
}
|
||||
|
||||
/*
|
||||
* Macros for pinning/unpinning objects.
|
||||
*/
|
||||
#define PIN_BYTE_ARRAY(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = ENVPTR->GetByteArrayElements(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define PIN_BYTE_ARRAY_CRITICAL(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = (jbyte *) ENVPTR->GetPrimitiveArrayCritical(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define UNPIN_BYTE_ARRAY(env, pinnedArray, bufToRelease, freeMode) \
|
||||
{ \
|
||||
ENVPTR->ReleaseByteArrayElements(env, pinnedArray, (jbyte *) bufToRelease, freeMode); \
|
||||
}
|
||||
|
||||
#define PIN_SHORT_ARRAY(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = ENVPTR->GetShortArrayElements(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define PIN_SHORT_ARRAY_CRITICAL(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = (jshort *) ENVPTR->GetPrimitiveArrayCritical(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define UNPIN_SHORT_ARRAY(env, pinnedArray, bufToRelease, freeMode) \
|
||||
{ \
|
||||
ENVPTR->ReleaseShortArrayElements(env, pinnedArray, (jshort *) bufToRelease, freeMode); \
|
||||
}
|
||||
|
||||
#define PIN_INT_ARRAY(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = ENVPTR->GetIntArrayElements(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define PIN_INT_ARRAY_CRITICAL(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = (jint *) ENVPTR->GetPrimitiveArrayCritical(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define UNPIN_INT_ARRAY(env, pinnedArray, bufToRelease, freeMode) \
|
||||
{ \
|
||||
ENVPTR->ReleaseIntArrayElements(env, pinnedArray, (jint *) bufToRelease, freeMode); \
|
||||
}
|
||||
|
||||
#define PIN_LONG_ARRAY(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = ENVPTR->GetLongArrayElements(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define PIN_LONG_ARRAY_CRITICAL(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = (jlong *) ENVPTR->GetPrimitiveArrayCritical(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define UNPIN_LONG_ARRAY(env, pinnedArray, bufToRelease, freeMode) \
|
||||
{ \
|
||||
ENVPTR->ReleaseLongArrayElements(env, pinnedArray, (jlong *) bufToRelease, freeMode); \
|
||||
}
|
||||
|
||||
#define PIN_FLOAT_ARRAY(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = ENVPTR->GetFloatArrayElements(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define PIN_FLOAT_ARRAY_CRITICAL(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = (jfloat *) ENVPTR->GetPrimitiveArrayCritical(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define UNPIN_FLOAT_ARRAY(env, pinnedArray, bufToRelease, freeMode) \
|
||||
{ \
|
||||
ENVPTR->ReleaseFloatArrayElements(env, pinnedArray, (jfloat *) bufToRelease, freeMode); \
|
||||
}
|
||||
|
||||
#define PIN_DOUBLE_ARRAY(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = ENVPTR->GetDoubleArrayElements(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define PIN_DOUBLE_ARRAY_CRITICAL(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = (jdouble *) ENVPTR->GetPrimitiveArrayCritical(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define UNPIN_DOUBLE_ARRAY(env, pinnedArray, bufToRelease, freeMode) \
|
||||
{ \
|
||||
ENVPTR->ReleaseDoubleArrayElements(env, pinnedArray, (jdouble *) bufToRelease, freeMode); \
|
||||
}
|
||||
|
||||
#define PIN_BOOL_ARRAY(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = ENVPTR->GetBooleanArrayElements(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define PIN_BOOL_ARRAY_CRITICAL(env, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outBuf = (jboolean *) ENVPTR->GetPrimitiveArrayCritical(env, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define UNPIN_BOOL_ARRAY(env, pinnedArray, bufToRelease, freeMode) \
|
||||
{ \
|
||||
ENVPTR->ReleaseBooleanArrayElements(env, pinnedArray, (jboolean *) bufToRelease, freeMode); \
|
||||
}
|
||||
|
||||
#define UNPIN_ARRAY_CRITICAL(env, pinnedArray, bufToRelease, freeMode) \
|
||||
{ \
|
||||
ENVPTR->ReleasePrimitiveArrayCritical(env, pinnedArray, bufToRelease, freeMode); \
|
||||
}
|
||||
|
||||
/* Macros for string access */
|
||||
#define PIN_JAVA_STRING(env, stringToPin, outString, isCopy, failErrMsg) \
|
||||
{ \
|
||||
if (NULL == (outString = ENVPTR->GetStringUTFChars(env, stringToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(env, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(env, failErrMsg); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define UNPIN_JAVA_STRING(env, pinnedString, stringToRelease) \
|
||||
{ \
|
||||
ENVPTR->ReleaseStringUTFChars(env, pinnedString, stringToRelease); \
|
||||
}
|
||||
|
||||
/*
|
||||
* Macro to check for a JNI exception after a JNI method is called.
|
||||
* If an exception occurred, the value of 'clearException' will determine
|
||||
@ -246,15 +57,205 @@
|
||||
* cleanup+return section of the native method, since at that point
|
||||
* cleaning up and returning is the only safe thing that can be done.
|
||||
*/
|
||||
#define CHECK_JNI_EXCEPTION(env, clearException) \
|
||||
{ \
|
||||
if (JNI_TRUE == (*env)->ExceptionCheck(env)) { \
|
||||
if (JNI_TRUE == clearException) \
|
||||
(*env)->ExceptionClear(env); \
|
||||
else \
|
||||
goto done; \
|
||||
} \
|
||||
}
|
||||
#define CHECK_JNI_EXCEPTION(envptr, clearException) \
|
||||
do { \
|
||||
if (JNI_TRUE == (*envptr)->ExceptionCheck(envptr)) { \
|
||||
if (JNI_TRUE == clearException) \
|
||||
(*envptr)->ExceptionClear(envptr); \
|
||||
else \
|
||||
goto done; \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
/* Macros for class access */
|
||||
/* Calling code must define ret_obj as jobject */
|
||||
#define CALL_CONSTRUCTOR(envptr, classname, classsig, args, ret_obj) \
|
||||
do { \
|
||||
jmethodID constructor; \
|
||||
jclass cls; \
|
||||
\
|
||||
if (NULL == (cls = (*envptr)->FindClass(envptr, (classname)))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, "JNI error: GetObjectClass"); \
|
||||
} \
|
||||
if (NULL == (constructor = (*envptr)->GetMethodID(envptr, cls, "<init>", (classsig)))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, "JNI error: GetMethodID failed"); \
|
||||
} \
|
||||
if (NULL == (ret_obj = (*envptr)->NewObjectA(envptr, cls, constructor, (args)))) { \
|
||||
HDprintf("FATAL ERROR: %s: Creation failed\n", classname); \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_FALSE); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
/*
|
||||
* Macros for pinning/unpinning objects.
|
||||
*/
|
||||
#define PIN_BYTE_ARRAY(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (*envptr)->GetByteArrayElements(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define PIN_BYTE_ARRAY_CRITICAL(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (jbyte *) (*envptr)->GetPrimitiveArrayCritical(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define UNPIN_BYTE_ARRAY(envptr, pinnedArray, bufToRelease, freeMode) \
|
||||
do { \
|
||||
(*envptr)->ReleaseByteArrayElements(envptr, pinnedArray, (jbyte *) bufToRelease, freeMode); \
|
||||
} while(0)
|
||||
|
||||
#define PIN_SHORT_ARRAY(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (*envptr)->GetShortArrayElements(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define PIN_SHORT_ARRAY_CRITICAL(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (jshort *) (*envptr)->GetPrimitiveArrayCritical(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define UNPIN_SHORT_ARRAY(envptr, pinnedArray, bufToRelease, freeMode) \
|
||||
do { \
|
||||
(*envptr)->ReleaseShortArrayElements(envptr, pinnedArray, (jshort *) bufToRelease, freeMode); \
|
||||
} while(0)
|
||||
|
||||
#define PIN_INT_ARRAY(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (*envptr)->GetIntArrayElements(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define PIN_INT_ARRAY_CRITICAL(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (jint *) (*envptr)->GetPrimitiveArrayCritical(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define UNPIN_INT_ARRAY(envptr, pinnedArray, bufToRelease, freeMode) \
|
||||
do { \
|
||||
(*envptr)->ReleaseIntArrayElements(envptr, pinnedArray, (jint *) bufToRelease, freeMode); \
|
||||
} while(0)
|
||||
|
||||
#define PIN_LONG_ARRAY(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (*envptr)->GetLongArrayElements(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define PIN_LONG_ARRAY_CRITICAL(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (jlong *) (*envptr)->GetPrimitiveArrayCritical(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define UNPIN_LONG_ARRAY(envptr, pinnedArray, bufToRelease, freeMode) \
|
||||
do { \
|
||||
(*envptr)->ReleaseLongArrayElements(envptr, pinnedArray, (jlong *) bufToRelease, freeMode); \
|
||||
} while(0)
|
||||
|
||||
#define PIN_FLOAT_ARRAY(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (*envptr)->GetFloatArrayElements(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define PIN_FLOAT_ARRAY_CRITICAL(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (jfloat *) (*envptr)->GetPrimitiveArrayCritical(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define UNPIN_FLOAT_ARRAY(envptr, pinnedArray, bufToRelease, freeMode) \
|
||||
do { \
|
||||
(*envptr)->ReleaseFloatArrayElements(envptr, pinnedArray, (jfloat *) bufToRelease, freeMode); \
|
||||
} while(0)
|
||||
|
||||
#define PIN_DOUBLE_ARRAY(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (*envptr)->GetDoubleArrayElements(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define PIN_DOUBLE_ARRAY_CRITICAL(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (jdouble *) (*envptr)->GetPrimitiveArrayCritical(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define UNPIN_DOUBLE_ARRAY(envptr, pinnedArray, bufToRelease, freeMode) \
|
||||
do { \
|
||||
(*envptr)->ReleaseDoubleArrayElements(envptr, pinnedArray, (jdouble *) bufToRelease, freeMode); \
|
||||
} while(0)
|
||||
|
||||
#define PIN_BOOL_ARRAY(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (*envptr)->GetBooleanArrayElements(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define PIN_BOOL_ARRAY_CRITICAL(envptr, arrayToPin, outBuf, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outBuf = (jboolean *) (*envptr)->GetPrimitiveArrayCritical(envptr, arrayToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define UNPIN_BOOL_ARRAY(envptr, pinnedArray, bufToRelease, freeMode) \
|
||||
do { \
|
||||
(*envptr)->ReleaseBooleanArrayElements(envptr, pinnedArray, (jboolean *) bufToRelease, freeMode); \
|
||||
} while(0)
|
||||
|
||||
#define UNPIN_ARRAY_CRITICAL(envptr, pinnedArray, bufToRelease, freeMode) \
|
||||
do { \
|
||||
(*envptr)->ReleasePrimitiveArrayCritical(envptr, pinnedArray, bufToRelease, freeMode); \
|
||||
} while(0)
|
||||
|
||||
/* Macros for string access */
|
||||
#define PIN_JAVA_STRING(envptr, stringToPin, outString, isCopy, failErrMsg) \
|
||||
do { \
|
||||
if (NULL == (outString = (*envptr)->GetStringUTFChars(envptr, stringToPin, isCopy))) { \
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_TRUE); \
|
||||
H5_JNI_FATAL_ERROR(envptr, failErrMsg); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define UNPIN_JAVA_STRING(envptr, pinnedString, stringToRelease) \
|
||||
do { \
|
||||
(*envptr)->ReleaseStringUTFChars(envptr, pinnedString, stringToRelease); \
|
||||
} while(0)
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
@ -279,46 +280,46 @@ extern jboolean h5unimplemented( JNIEnv *env, const char *functName);
|
||||
* then do its own error handling, but we instead opt to immediately return.
|
||||
*/
|
||||
#define H5_JNI_FATAL_ERROR(env, message) \
|
||||
{ \
|
||||
do { \
|
||||
h5JNIFatalError(env, message); \
|
||||
goto done; \
|
||||
}
|
||||
} while(0)
|
||||
|
||||
#define H5_NULL_ARGUMENT_ERROR(env, message) \
|
||||
{ \
|
||||
do { \
|
||||
h5nullArgument(env, message); \
|
||||
goto done; \
|
||||
}
|
||||
} while(0)
|
||||
|
||||
#define H5_BAD_ARGUMENT_ERROR(env, message) \
|
||||
{ \
|
||||
do { \
|
||||
h5badArgument(env, message); \
|
||||
goto done; \
|
||||
}
|
||||
} while(0)
|
||||
|
||||
#define H5_OUT_OF_MEMORY_ERROR(env, message) \
|
||||
{ \
|
||||
do { \
|
||||
h5outOfMemory(env, message); \
|
||||
goto done; \
|
||||
}
|
||||
} while(0)
|
||||
|
||||
#define H5_LIBRARY_ERROR(env) \
|
||||
{ \
|
||||
do { \
|
||||
h5libraryError(env); \
|
||||
goto done; \
|
||||
}
|
||||
} while(0)
|
||||
|
||||
#define H5_RAISE_EXCEPTION(env, message, exception) \
|
||||
{ \
|
||||
do { \
|
||||
h5raiseException(env, message, exception); \
|
||||
goto done; \
|
||||
}
|
||||
} while(0)
|
||||
|
||||
#define H5_UNIMPLEMENTED(env, message) \
|
||||
{ \
|
||||
do { \
|
||||
h5unimplemented(env, message); \
|
||||
goto done; \
|
||||
}
|
||||
} while(0)
|
||||
|
||||
/* implemented at H5.c */
|
||||
extern jint get_enum_value(JNIEnv *env, jobject enum_obj);
|
||||
@ -328,6 +329,9 @@ extern jobject get_enum_object(JNIEnv *env, const char* enum_class_name,
|
||||
/* implemented at H5G.c */
|
||||
extern jobject create_H5G_info_t(JNIEnv *env, H5G_info_t group_info);
|
||||
|
||||
/* implemented at h5oimp.c */
|
||||
extern jobject create_H5O_token_t(JNIEnv *env, const H5O_token_t *token, hbool_t is_critical_pinning);
|
||||
|
||||
#ifdef __cplusplus
|
||||
} /* end extern "C" */
|
||||
#endif /* __cplusplus */
|
||||
|
@ -41,7 +41,7 @@ typedef struct _cb_wrapper {
|
||||
/* Local Prototypes */
|
||||
/********************/
|
||||
|
||||
static herr_t H5L_iterate_cb(hid_t g_id, const char *name, const H5L_info_t *info, void *cb_data);
|
||||
static herr_t H5L_iterate_cb(hid_t g_id, const char *name, const H5L_info2_t *info, void *cb_data);
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
@ -281,11 +281,11 @@ JNIEXPORT jobject JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Lget_1info
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jstring name, jlong access_id)
|
||||
{
|
||||
H5L_info_t infobuf;
|
||||
const char *linkName = NULL;
|
||||
jvalue args[5];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
H5L_info2_t infobuf;
|
||||
const char *linkName = NULL;
|
||||
jvalue args[5];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
@ -294,16 +294,38 @@ Java_hdf_hdf5lib_H5_H5Lget_1info
|
||||
|
||||
PIN_JAVA_STRING(ENVONLY, name, linkName, NULL, "H5Lget_info: link name not pinned");
|
||||
|
||||
if ((status = H5Lget_info((hid_t)loc_id, linkName, &infobuf, (hid_t)access_id)) < 0)
|
||||
if ((status = H5Lget_info2((hid_t)loc_id, linkName, &infobuf, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
args[0].i = infobuf.type;
|
||||
args[1].z = infobuf.corder_valid;
|
||||
args[2].j = infobuf.corder;
|
||||
args[3].i = infobuf.cset;
|
||||
args[4].j = (infobuf.type == H5L_TYPE_HARD) ? (jlong) infobuf.u.address : (jlong) infobuf.u.val_size;
|
||||
/*
|
||||
* Set the last argument based upon whether this is a hard link (which returns object tokens)
|
||||
* or a soft/user-defined link (which returns the link's value size). Then, call the appropriate
|
||||
* constructor to instantiate an H5L_info_t object.
|
||||
*/
|
||||
if (infobuf.type == H5L_TYPE_HARD) {
|
||||
jobject token;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5L_info_t", "(IZJIJ)V", args, ret_obj);
|
||||
/* Create an H5O_token_t object */
|
||||
if (NULL == (token = create_H5O_token_t(ENVONLY, &infobuf.u.token, FALSE)))
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
args[0].i = infobuf.type;
|
||||
args[1].z = infobuf.corder_valid;
|
||||
args[2].j = infobuf.corder;
|
||||
args[3].i = infobuf.cset;
|
||||
args[4].l = token;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5L_info_t", "(IZJILhdf/hdf5lib/structs/H5O_token_t;)V", args, ret_obj);
|
||||
}
|
||||
else {
|
||||
args[0].i = infobuf.type;
|
||||
args[1].z = infobuf.corder_valid;
|
||||
args[2].j = infobuf.corder;
|
||||
args[3].i = infobuf.cset;
|
||||
args[4].j = (jlong)infobuf.u.val_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5L_info_t", "(IZJIJ)V", args, ret_obj);
|
||||
}
|
||||
|
||||
done:
|
||||
if (linkName)
|
||||
@ -322,11 +344,11 @@ Java_hdf_hdf5lib_H5_H5Lget_1info_1by_1idx
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jstring name,
|
||||
jint index_field, jint order, jlong link_n, jlong access_id)
|
||||
{
|
||||
H5L_info_t infobuf;
|
||||
const char *groupName = NULL;
|
||||
jvalue args[5];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
H5L_info2_t infobuf;
|
||||
const char *groupName = NULL;
|
||||
jvalue args[5];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
@ -335,16 +357,38 @@ Java_hdf_hdf5lib_H5_H5Lget_1info_1by_1idx
|
||||
|
||||
PIN_JAVA_STRING(ENVONLY, name, groupName, NULL, "H5Lget_info_by_idx: group name not pinned");
|
||||
|
||||
if ((status = H5Lget_info_by_idx((hid_t)loc_id, groupName, (H5_index_t)index_field, (H5_iter_order_t)order, (hsize_t)link_n, &infobuf, (hid_t)access_id)) < 0)
|
||||
if ((status = H5Lget_info_by_idx2((hid_t)loc_id, groupName, (H5_index_t)index_field, (H5_iter_order_t)order, (hsize_t)link_n, &infobuf, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
args[0].i = infobuf.type;
|
||||
args[1].z = infobuf.corder_valid;
|
||||
args[2].j = infobuf.corder;
|
||||
args[3].i = infobuf.cset;
|
||||
args[4].j = (infobuf.type == H5L_TYPE_HARD) ? (jlong) infobuf.u.address : (jlong) infobuf.u.val_size;
|
||||
/*
|
||||
* Set the last argument based upon whether this is a hard link (which returns object tokens)
|
||||
* or a soft/user-defined link (which returns the link's value size). Then, call the appropriate
|
||||
* constructor to instantiate an H5L_info_t object.
|
||||
*/
|
||||
if (infobuf.type == H5L_TYPE_HARD) {
|
||||
jobject token;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5L_info_t", "(IZJIJ)V", args, ret_obj);
|
||||
/* Create an H5O_token_t object */
|
||||
if (NULL == (token = create_H5O_token_t(ENVONLY, &infobuf.u.token, FALSE)))
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
args[0].i = infobuf.type;
|
||||
args[1].z = infobuf.corder_valid;
|
||||
args[2].j = infobuf.corder;
|
||||
args[3].i = infobuf.cset;
|
||||
args[4].l = token;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5L_info_t", "(IZJILhdf/hdf5lib/structs/H5O_token_t;)V", args, ret_obj);
|
||||
}
|
||||
else {
|
||||
args[0].i = infobuf.type;
|
||||
args[1].z = infobuf.corder_valid;
|
||||
args[2].j = infobuf.corder;
|
||||
args[3].i = infobuf.cset;
|
||||
args[4].j = (jlong)infobuf.u.val_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5L_info_t", "(IZJIJ)V", args, ret_obj);
|
||||
}
|
||||
|
||||
done:
|
||||
if (groupName)
|
||||
@ -381,7 +425,7 @@ Java_hdf_hdf5lib_H5_H5Lget_1name_1by_1idx
|
||||
|
||||
/* add extra space for the null terminator */
|
||||
if (NULL == (linkName = (char *) HDmalloc(sizeof(char) * (size_t)status_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Lget_name_by_idx: failed to allocate buffer for link name");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Lget_name_by_idx: failed to allocate buffer for link name");
|
||||
|
||||
if ((H5Lget_name_by_idx((hid_t)loc_id, groupName, (H5_index_t)index_field, (H5_iter_order_t)order, (hsize_t)link_n, (char *)linkName, (size_t)status_size + 1, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -408,13 +452,13 @@ JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Lget_1value
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jstring name, jobjectArray link_value, jlong access_id)
|
||||
{
|
||||
H5L_info_t infobuf;
|
||||
const char *file_name = NULL;
|
||||
const char *obj_name = NULL;
|
||||
const char *linkName = NULL;
|
||||
jstring str;
|
||||
herr_t status;
|
||||
char *linkValue = NULL;
|
||||
H5L_info2_t infobuf;
|
||||
const char *file_name = NULL;
|
||||
const char *obj_name = NULL;
|
||||
const char *linkName = NULL;
|
||||
jstring str;
|
||||
herr_t status;
|
||||
char *linkValue = NULL;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
@ -426,14 +470,14 @@ Java_hdf_hdf5lib_H5_H5Lget_1value
|
||||
PIN_JAVA_STRING(ENVONLY, name, linkName, NULL, "H5Lget_value: link name not pinned");
|
||||
|
||||
/* Get the length of the link value */
|
||||
if ((status = H5Lget_info((hid_t)loc_id, linkName, &infobuf, H5P_DEFAULT)) < 0)
|
||||
if ((status = H5Lget_info2((hid_t)loc_id, linkName, &infobuf, H5P_DEFAULT)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (H5L_TYPE_HARD == infobuf.type)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Lget_val: hard links are unsupported");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Lget_val: hard links are unsupported");
|
||||
|
||||
if (NULL == (linkValue = (char *) HDmalloc(sizeof(char) * infobuf.u.val_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Lget_val: failed to allocate buffer for link value");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Lget_val: failed to allocate buffer for link value");
|
||||
|
||||
if ((status = H5Lget_val((hid_t)loc_id, linkName, (void *)linkValue, infobuf.u.val_size + 1, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -475,7 +519,7 @@ Java_hdf_hdf5lib_H5_H5Lget_1value
|
||||
case H5L_TYPE_MAX:
|
||||
case H5L_TYPE_HARD:
|
||||
default:
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Lget_val: invalid link type");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Lget_val: invalid link type");
|
||||
break;
|
||||
}
|
||||
|
||||
@ -498,13 +542,13 @@ Java_hdf_hdf5lib_H5_H5Lget_1value_1by_1idx
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jstring name, jint index_field, jint order,
|
||||
jlong link_n, jobjectArray link_value, jlong access_id)
|
||||
{
|
||||
H5L_info_t infobuf;
|
||||
const char *file_name = NULL;
|
||||
const char *obj_name = NULL;
|
||||
const char *grpName = NULL;
|
||||
jstring str;
|
||||
herr_t status;
|
||||
void *linkValue = NULL;
|
||||
H5L_info2_t infobuf;
|
||||
const char *file_name = NULL;
|
||||
const char *obj_name = NULL;
|
||||
const char *grpName = NULL;
|
||||
jstring str;
|
||||
herr_t status;
|
||||
void *linkValue = NULL;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
@ -516,17 +560,17 @@ Java_hdf_hdf5lib_H5_H5Lget_1value_1by_1idx
|
||||
PIN_JAVA_STRING(ENVONLY, name, grpName, NULL, "H5Lget_val_by_idx: group name not pinned");
|
||||
|
||||
/* Get the length of the link value */
|
||||
if ((status = H5Lget_info_by_idx((hid_t)loc_id, grpName, (H5_index_t)index_field, (H5_iter_order_t)order, (hsize_t)link_n, &infobuf, (hid_t)access_id)) < 0)
|
||||
if ((status = H5Lget_info_by_idx2((hid_t)loc_id, grpName, (H5_index_t)index_field, (H5_iter_order_t)order, (hsize_t)link_n, &infobuf, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (H5L_TYPE_HARD == infobuf.type)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Lget_val_by_idx: hard links are unsupported")
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Lget_val_by_idx: hard links are unsupported");
|
||||
|
||||
if (!infobuf.u.val_size)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (linkValue = (void *) HDmalloc(infobuf.u.val_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Lget_val_by_idx: failed to allocate buffer for link value");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Lget_val_by_idx: failed to allocate buffer for link value");
|
||||
|
||||
if ((status = H5Lget_val_by_idx((hid_t)loc_id, grpName, (H5_index_t)index_field, (H5_iter_order_t)order, (hsize_t)link_n, (void *)linkValue, infobuf.u.val_size + 1, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -568,7 +612,7 @@ Java_hdf_hdf5lib_H5_H5Lget_1value_1by_1idx
|
||||
case H5L_TYPE_MAX:
|
||||
case H5L_TYPE_HARD:
|
||||
default:
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Lget_val_by_idx: invalid link type");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Lget_val_by_idx: invalid link type");
|
||||
break;
|
||||
}
|
||||
|
||||
@ -615,12 +659,15 @@ done:
|
||||
UNPIN_JAVA_STRING(ENVONLY, cur_name, lCurName);
|
||||
} /* end Java_hdf_hdf5lib_H5_H5Lmove */
|
||||
|
||||
/*
|
||||
* Shim function for link iteration and link visiting which
|
||||
*/
|
||||
static herr_t
|
||||
H5L_iterate_cb
|
||||
(hid_t g_id, const char *name, const H5L_info_t *info, void *cb_data)
|
||||
(hid_t g_id, const char *name, const H5L_info2_t *info, void *cb_data)
|
||||
{
|
||||
cb_wrapper *wrapper = (cb_wrapper *)cb_data;
|
||||
jmethodID constructor, mid;
|
||||
jmethodID mid;
|
||||
jobject cb_info_t = NULL;
|
||||
jobject visit_callback = wrapper->visit_callback;
|
||||
jstring str;
|
||||
@ -635,32 +682,44 @@ H5L_iterate_cb
|
||||
H5_JNI_FATAL_ERROR(CBENVONLY, "H5L_iterate_cb: failed to attach current thread to JVM");
|
||||
}
|
||||
|
||||
/* Get the Method ID for the "callback" function of the H5L_iterate_t class */
|
||||
if (NULL == (cls = CBENVPTR->GetObjectClass(CBENVONLY, visit_callback)))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
if (NULL == (mid = CBENVPTR->GetMethodID(CBENVONLY, cls, "callback", "(JLjava/lang/String;Lhdf/hdf5lib/structs/H5L_info_t;Lhdf/hdf5lib/callbacks/H5L_iterate_t;)I")))
|
||||
if (NULL == (mid = CBENVPTR->GetMethodID(CBENVONLY, cls, "callback", "(JLjava/lang/String;Lhdf/hdf5lib/structs/H5L_info_t;Lhdf/hdf5lib/callbacks/H5L_iterate_opdata_t;)I")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
if (NULL == (str = CBENVPTR->NewStringUTF(CBENVONLY, name)))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
args[0].i = info->type;
|
||||
args[1].z = info->corder_valid;
|
||||
args[2].j = info->corder;
|
||||
args[3].i = info->cset;
|
||||
args[4].j = (info->type == H5L_TYPE_HARD) ? (jlong)info->u.address : (jlong)info->u.val_size;
|
||||
/*
|
||||
* Set the last argument based upon whether this is a hard link (which returns object tokens)
|
||||
* or a soft/user-defined link (which returns the link's value size). Then, call the appropriate
|
||||
* constructor to instantiate an H5L_info_t object.
|
||||
*/
|
||||
if (info->type == H5L_TYPE_HARD) {
|
||||
jobject token;
|
||||
|
||||
/* Get a reference to your class if you don't have it already */
|
||||
if (NULL == (cls = CBENVPTR->FindClass(CBENVONLY, "hdf/hdf5lib/structs/H5L_info_t")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
/* Create an H5O_token_t object */
|
||||
if (NULL == (token = create_H5O_token_t(CBENVONLY, &info->u.token, FALSE)))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
/* Get a reference to the constructor; the name is <init> */
|
||||
if (NULL == (constructor = CBENVPTR->GetMethodID(CBENVONLY, cls, "<init>", "(IZJIJ)V")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
args[0].i = info->type;
|
||||
args[1].z = info->corder_valid;
|
||||
args[2].j = info->corder;
|
||||
args[3].i = info->cset;
|
||||
args[4].l = token;
|
||||
|
||||
if (NULL == (cb_info_t = CBENVPTR->NewObjectA(CBENVONLY, cls, constructor, args))) {
|
||||
HDprintf("FATAL ERROR: hdf/hdf5lib/structs/H5L_info_t: Creation failed\n");
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
CALL_CONSTRUCTOR(CBENVONLY, "hdf/hdf5lib/structs/H5L_info_t", "(IZJILhdf/hdf5lib/structs/H5O_token_t;)V", args, cb_info_t);
|
||||
}
|
||||
else {
|
||||
args[0].i = info->type;
|
||||
args[1].z = info->corder_valid;
|
||||
args[2].j = info->corder;
|
||||
args[3].i = info->cset;
|
||||
args[4].j = (jlong)info->u.val_size;
|
||||
|
||||
CALL_CONSTRUCTOR(CBENVONLY, "hdf/hdf5lib/structs/H5L_info_t", "(IZJIJ)V", args, cb_info_t);
|
||||
}
|
||||
|
||||
status = CBENVPTR->CallIntMethod(CBENVONLY, visit_callback, mid, g_id, str, cb_info_t, op_data);
|
||||
@ -696,7 +755,8 @@ Java_hdf_hdf5lib_H5_H5Lvisit
|
||||
if (NULL == callback_op)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Lvisit: callback_op is NULL");
|
||||
|
||||
if ((status = H5Lvisit((hid_t)grp_id, (H5_index_t)idx_type, (H5_iter_order_t)order, (H5L_iterate_t)H5L_iterate_cb, (void *)&wrapper)) < 0)
|
||||
if ((status = H5Lvisit2((hid_t)grp_id, (H5_index_t)idx_type, (H5_iter_order_t)order,
|
||||
H5L_iterate_cb, (void *)&wrapper)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
done:
|
||||
@ -731,7 +791,8 @@ Java_hdf_hdf5lib_H5_H5Lvisit_1by_1name
|
||||
|
||||
PIN_JAVA_STRING(ENVONLY, name, grpName, NULL, "H5Lvisit_by_name: group name not pinned");
|
||||
|
||||
if ((status = H5Lvisit_by_name((hid_t)grp_id, grpName, (H5_index_t)idx_type, (H5_iter_order_t)order, (H5L_iterate_t)H5L_iterate_cb, (void *)&wrapper, (hid_t)access_id)) < 0)
|
||||
if ((status = H5Lvisit_by_name2((hid_t)grp_id, grpName, (H5_index_t)idx_type, (H5_iter_order_t)order,
|
||||
H5L_iterate_cb, (void *)&wrapper, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
done:
|
||||
@ -765,7 +826,8 @@ Java_hdf_hdf5lib_H5_H5Literate
|
||||
if (NULL == callback_op)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Literate: callback_op is NULL");
|
||||
|
||||
if ((status = H5Literate((hid_t)grp_id, (H5_index_t)idx_type, (H5_iter_order_t)order, (hsize_t *)&start_idx, (H5L_iterate_t)H5L_iterate_cb, (void *)&wrapper)) < 0)
|
||||
if ((status = H5Literate2((hid_t)grp_id, (H5_index_t)idx_type, (H5_iter_order_t)order,
|
||||
&start_idx, H5L_iterate_cb, (void *)&wrapper)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
done:
|
||||
@ -801,7 +863,8 @@ Java_hdf_hdf5lib_H5_H5Literate_1by_1name
|
||||
|
||||
PIN_JAVA_STRING(ENVONLY, name, groupName, NULL, "H5Literate_by_name: group name not pinned");
|
||||
|
||||
if ((status = H5Literate_by_name((hid_t)grp_id, groupName, (H5_index_t)idx_type, (H5_iter_order_t)order, (hsize_t*)&start_idx, (H5L_iterate_t)H5L_iterate_cb, (void*)&wrapper, (hid_t)access_id)) < 0)
|
||||
if ((status = H5Literate_by_name2((hid_t)grp_id, groupName, (H5_index_t)idx_type, (H5_iter_order_t)order,
|
||||
&start_idx, H5L_iterate_cb, (void*)&wrapper, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
done:
|
||||
|
@ -40,7 +40,58 @@ typedef struct _cb_wrapper {
|
||||
/* Local Prototypes */
|
||||
/********************/
|
||||
|
||||
static herr_t H5O_iterate_cb(hid_t g_id, const char *name, const H5O_info_t *info, void *cb_data);
|
||||
static herr_t H5O_iterate_cb(hid_t g_id, const char *name, const H5O_info2_t *info, void *cb_data);
|
||||
|
||||
/*
|
||||
* Create a java object of hdf.hdf5lib.structs.H5O_token_t.
|
||||
*/
|
||||
jobject
|
||||
create_H5O_token_t
|
||||
(JNIEnv *envptr, const H5O_token_t *token, hbool_t is_critical_pinning)
|
||||
{
|
||||
jbyteArray tokenByteBuf;
|
||||
jboolean token_buf_is_copy;
|
||||
jvalue constructor_args[1];
|
||||
jbyte *token_buf = NULL;
|
||||
jobject ret_token_obj = NULL;
|
||||
|
||||
if (NULL == (tokenByteBuf = (*envptr)->NewByteArray(envptr, H5O_MAX_TOKEN_SIZE)))
|
||||
CHECK_JNI_EXCEPTION(envptr, JNI_FALSE);
|
||||
|
||||
if (is_critical_pinning)
|
||||
PIN_BYTE_ARRAY_CRITICAL(envptr, tokenByteBuf, token_buf, &token_buf_is_copy, "create_H5O_token_t: object token buffer not pinned");
|
||||
else
|
||||
PIN_BYTE_ARRAY(envptr, tokenByteBuf, token_buf, &token_buf_is_copy, "create_H5O_token_t: object token buffer not pinned");
|
||||
|
||||
HDmemcpy(token_buf, token, sizeof(H5O_token_t));
|
||||
|
||||
if (is_critical_pinning)
|
||||
UNPIN_ARRAY_CRITICAL(envptr, tokenByteBuf, token_buf, 0);
|
||||
else
|
||||
UNPIN_BYTE_ARRAY(envptr, tokenByteBuf, token_buf, 0);
|
||||
|
||||
token_buf = NULL;
|
||||
|
||||
constructor_args[0].l = tokenByteBuf;
|
||||
CALL_CONSTRUCTOR(envptr, "hdf/hdf5lib/structs/H5O_token_t", "([B)V", constructor_args, ret_token_obj);
|
||||
|
||||
/*
|
||||
* If critical pinning is being used, this routine is probably being
|
||||
* called within a loop, so we'll clean up local references.
|
||||
*/
|
||||
if (is_critical_pinning)
|
||||
(*envptr)->DeleteLocalRef(envptr, tokenByteBuf);
|
||||
|
||||
done:
|
||||
if (token_buf) {
|
||||
if (is_critical_pinning)
|
||||
UNPIN_ARRAY_CRITICAL(envptr, tokenByteBuf, token_buf, JNI_ABORT);
|
||||
else
|
||||
UNPIN_BYTE_ARRAY(envptr, tokenByteBuf, token_buf, JNI_ABORT);
|
||||
} /* end if */
|
||||
|
||||
return ret_token_obj;
|
||||
} /* end create_H5O_token_t */
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
@ -134,59 +185,31 @@ JNIEXPORT jobject JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Oget_1info
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jint fields)
|
||||
{
|
||||
H5O_info_t infobuf;
|
||||
jobject hdrinfobuf;
|
||||
jobject ihinfobuf1;
|
||||
jobject ihinfobuf2;
|
||||
jvalue args[12];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
H5O_info2_t infobuf;
|
||||
jobject token;
|
||||
jvalue args[9];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
if ((status = H5Oget_info2((hid_t)loc_id, &infobuf, (unsigned)fields)) < 0)
|
||||
if ((status = H5Oget_info3((hid_t)loc_id, &infobuf, (unsigned)fields)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
args[0].i = (jint)infobuf.hdr.version;
|
||||
args[1].i = (jint)infobuf.hdr.nmesgs;
|
||||
args[2].i = (jint)infobuf.hdr.nchunks;
|
||||
args[3].i = (jint)infobuf.hdr.flags;
|
||||
args[4].j = (jlong)infobuf.hdr.space.total;
|
||||
args[5].j = (jlong)infobuf.hdr.space.meta;
|
||||
args[6].j = (jlong)infobuf.hdr.space.mesg;
|
||||
args[7].j = (jlong)infobuf.hdr.space.free;
|
||||
args[8].j = (jlong)infobuf.hdr.mesg.present;
|
||||
args[9].j = (jlong)infobuf.hdr.mesg.shared;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_hdr_info_t", "(IIIIJJJJJJ)V", args, ret_obj);
|
||||
hdrinfobuf = ret_obj;
|
||||
|
||||
args[0].j = (jlong)infobuf.meta_size.obj.index_size;
|
||||
args[1].j = (jlong)infobuf.meta_size.obj.heap_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5_ih_info_t", "(JJ)V", args, ret_obj);
|
||||
ihinfobuf1 = ret_obj;
|
||||
|
||||
args[0].j = (jlong)infobuf.meta_size.attr.index_size;
|
||||
args[1].j = (jlong)infobuf.meta_size.attr.heap_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5_ih_info_t", "(JJ)V", args, ret_obj);
|
||||
ihinfobuf2 = ret_obj;
|
||||
if (NULL == (token = create_H5O_token_t(ENVONLY, &infobuf.token, FALSE)))
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
args[0].j = (jlong)infobuf.fileno;
|
||||
args[1].j = (jlong)infobuf.addr;
|
||||
args[1].l = token;
|
||||
args[2].i = infobuf.type;
|
||||
args[3].i = (jint)infobuf.rc;
|
||||
args[4].j = (jlong)infobuf.num_attrs;
|
||||
args[5].j = infobuf.atime;
|
||||
args[6].j = infobuf.mtime;
|
||||
args[7].j = infobuf.ctime;
|
||||
args[8].j = infobuf.btime;
|
||||
args[9].l = hdrinfobuf;
|
||||
args[10].l = ihinfobuf1;
|
||||
args[11].l = ihinfobuf2;
|
||||
args[4].j = infobuf.atime;
|
||||
args[5].j = infobuf.mtime;
|
||||
args[6].j = infobuf.ctime;
|
||||
args[7].j = infobuf.btime;
|
||||
args[8].j = (jlong)infobuf.num_attrs;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_info_t", "(JJIIJJJJJLhdf/hdf5lib/structs/H5O_hdr_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;)V", args, ret_obj);
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_info_t", "(JLhdf/hdf5lib/structs/H5O_token_t;IIJJJJJ)V", args, ret_obj);
|
||||
|
||||
done:
|
||||
return ret_obj;
|
||||
@ -201,14 +224,12 @@ JNIEXPORT jobject JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Oget_1info_1by_1name
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jstring name, jint fields, jlong access_id)
|
||||
{
|
||||
H5O_info_t infobuf;
|
||||
const char *objName = NULL;
|
||||
jobject hdrinfobuf;
|
||||
jobject ihinfobuf1;
|
||||
jobject ihinfobuf2;
|
||||
jvalue args[12];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
H5O_info2_t infobuf;
|
||||
const char *objName = NULL;
|
||||
jobject token;
|
||||
jvalue args[9];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
@ -217,49 +238,24 @@ Java_hdf_hdf5lib_H5_H5Oget_1info_1by_1name
|
||||
|
||||
PIN_JAVA_STRING(ENVONLY, name, objName, NULL, "H5Oget_info_by_name: object name not pinned");
|
||||
|
||||
if ((status = H5Oget_info_by_name2((hid_t)loc_id, objName, &infobuf, (unsigned)fields, (hid_t)access_id)) < 0)
|
||||
if ((status = H5Oget_info_by_name3((hid_t)loc_id, objName, &infobuf, (unsigned)fields, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
args[0].i = (jint)infobuf.hdr.version;
|
||||
args[1].i = (jint)infobuf.hdr.nmesgs;
|
||||
args[2].i = (jint)infobuf.hdr.nchunks;
|
||||
args[3].i = (jint)infobuf.hdr.flags;
|
||||
args[4].j = (jlong)infobuf.hdr.space.total;
|
||||
args[5].j = (jlong)infobuf.hdr.space.meta;
|
||||
args[6].j = (jlong)infobuf.hdr.space.mesg;
|
||||
args[7].j = (jlong)infobuf.hdr.space.free;
|
||||
args[8].j = (jlong)infobuf.hdr.mesg.present;
|
||||
args[9].j = (jlong)infobuf.hdr.mesg.shared;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_hdr_info_t", "(IIIIJJJJJJ)V", args, ret_obj);
|
||||
hdrinfobuf = ret_obj;
|
||||
|
||||
args[0].j = (jlong)infobuf.meta_size.obj.index_size;
|
||||
args[1].j = (jlong)infobuf.meta_size.obj.heap_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5_ih_info_t", "(JJ)V", args, ret_obj);
|
||||
ihinfobuf1 = ret_obj;
|
||||
|
||||
args[0].j = (jlong)infobuf.meta_size.attr.index_size;
|
||||
args[1].j = (jlong)infobuf.meta_size.attr.heap_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5_ih_info_t", "(JJ)V", args, ret_obj);
|
||||
ihinfobuf2 = ret_obj;
|
||||
/* Create an H5O_token_t object */
|
||||
if (NULL == (token = create_H5O_token_t(ENVONLY, &infobuf.token, FALSE)))
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
args[0].j = (jlong)infobuf.fileno;
|
||||
args[1].j = (jlong)infobuf.addr;
|
||||
args[1].l = token;
|
||||
args[2].i = infobuf.type;
|
||||
args[3].i = (jint)infobuf.rc;
|
||||
args[4].j = (jlong)infobuf.num_attrs;
|
||||
args[5].j = infobuf.atime;
|
||||
args[6].j = infobuf.mtime;
|
||||
args[7].j = infobuf.ctime;
|
||||
args[8].j = infobuf.btime;
|
||||
args[9].l = hdrinfobuf;
|
||||
args[10].l = ihinfobuf1;
|
||||
args[11].l = ihinfobuf2;
|
||||
args[4].j = infobuf.atime;
|
||||
args[5].j = infobuf.mtime;
|
||||
args[6].j = infobuf.ctime;
|
||||
args[7].j = infobuf.btime;
|
||||
args[8].j = (jlong)infobuf.num_attrs;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_info_t", "(JJIIJJJJJLhdf/hdf5lib/structs/H5O_hdr_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;)V", args, ret_obj);
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_info_t", "(JLhdf/hdf5lib/structs/H5O_token_t;IIJJJJJ)V", args, ret_obj);
|
||||
|
||||
done:
|
||||
if (objName)
|
||||
@ -278,14 +274,12 @@ Java_hdf_hdf5lib_H5_H5Oget_1info_1by_1idx
|
||||
(JNIEnv *env, jclass clss, jlong loc_id,
|
||||
jstring name, jint index_field, jint order, jlong link_n, jint fields, jlong access_id)
|
||||
{
|
||||
H5O_info_t infobuf;
|
||||
const char *grpName = NULL;
|
||||
jobject hdrinfobuf;
|
||||
jobject ihinfobuf1;
|
||||
jobject ihinfobuf2;
|
||||
jvalue args[12];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
H5O_info2_t infobuf;
|
||||
const char *grpName = NULL;
|
||||
jobject token;
|
||||
jvalue args[9];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
@ -294,7 +288,53 @@ Java_hdf_hdf5lib_H5_H5Oget_1info_1by_1idx
|
||||
|
||||
PIN_JAVA_STRING(ENVONLY, name, grpName, NULL, "H5Oget_info_by_idx: group name not pinned");
|
||||
|
||||
if ((status = H5Oget_info_by_idx2((hid_t)loc_id, grpName, (H5_index_t)index_field, (H5_iter_order_t)order, (hsize_t)link_n, &infobuf, (unsigned)fields, (hid_t)access_id)) < 0)
|
||||
if ((status = H5Oget_info_by_idx3((hid_t)loc_id, grpName, (H5_index_t)index_field, (H5_iter_order_t)order, (hsize_t)link_n,
|
||||
&infobuf, (unsigned)fields, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
/* Create an H5O_token_t object */
|
||||
if (NULL == (token = create_H5O_token_t(ENVONLY, &infobuf.token, FALSE)))
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
args[0].j = (jlong)infobuf.fileno;
|
||||
args[1].l = token;
|
||||
args[2].i = infobuf.type;
|
||||
args[3].i = (jint)infobuf.rc;
|
||||
args[4].j = infobuf.atime;
|
||||
args[5].j = infobuf.mtime;
|
||||
args[6].j = infobuf.ctime;
|
||||
args[7].j = infobuf.btime;
|
||||
args[8].j = (jlong)infobuf.num_attrs;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_info_t", "(JLhdf/hdf5lib/structs/H5O_token_t;IIJJJJJ)V", args, ret_obj);
|
||||
|
||||
done:
|
||||
if (grpName)
|
||||
UNPIN_JAVA_STRING(ENVONLY, name, grpName);
|
||||
|
||||
return ret_obj;
|
||||
} /* end Java_hdf_hdf5lib_H5_H5Oget_1info_1by_1idx */
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: H5Oget_native_info
|
||||
* Signature: (JI)Lhdf/hdf5lib/structs/H5O_native_info_t;
|
||||
*/
|
||||
JNIEXPORT jobject JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Oget_1native_1info
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jint fields)
|
||||
{
|
||||
H5O_native_info_t infobuf;
|
||||
jobject hdrinfobuf;
|
||||
jobject obj_ihinfobuf;
|
||||
jobject attr_ihinfobuf;
|
||||
jvalue args[10];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
if ((status = H5Oget_native_info((hid_t)loc_id, &infobuf, (unsigned)fields)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
args[0].i = (jint)infobuf.hdr.version;
|
||||
@ -315,35 +355,159 @@ Java_hdf_hdf5lib_H5_H5Oget_1info_1by_1idx
|
||||
args[1].j = (jlong)infobuf.meta_size.obj.heap_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5_ih_info_t", "(JJ)V", args, ret_obj);
|
||||
ihinfobuf1 = ret_obj;
|
||||
obj_ihinfobuf = ret_obj;
|
||||
|
||||
args[0].j = (jlong)infobuf.meta_size.attr.index_size;
|
||||
args[1].j = (jlong)infobuf.meta_size.attr.heap_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5_ih_info_t", "(JJ)V", args, ret_obj);
|
||||
ihinfobuf2 = ret_obj;
|
||||
attr_ihinfobuf = ret_obj;
|
||||
|
||||
args[0].j = (jlong)infobuf.fileno;
|
||||
args[1].j = (jlong)infobuf.addr;
|
||||
args[2].i = infobuf.type;
|
||||
args[3].i = (jint)infobuf.rc;
|
||||
args[4].j = (jlong)infobuf.num_attrs;
|
||||
args[5].j = infobuf.atime;
|
||||
args[6].j = infobuf.mtime;
|
||||
args[7].j = infobuf.ctime;
|
||||
args[8].j = infobuf.btime;
|
||||
args[9].l = hdrinfobuf;
|
||||
args[10].l = ihinfobuf1;
|
||||
args[11].l = ihinfobuf2;
|
||||
args[0].l = hdrinfobuf;
|
||||
args[1].l = obj_ihinfobuf;
|
||||
args[2].l = attr_ihinfobuf;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_info_t", "(JJIIJJJJJLhdf/hdf5lib/structs/H5O_hdr_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;)V", args, ret_obj);
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_native_info_t", "(Lhdf/hdf5lib/structs/H5O_hdr_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;)V", args, ret_obj);
|
||||
|
||||
done:
|
||||
return ret_obj;
|
||||
} /* end Java_hdf_hdf5lib_H5_H5Oget_1native_1info */
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: H5Oget_native_info_by_name
|
||||
* Signature: (JLjava/lang/String;IJ)Lhdf/hdf5lib/structs/H5O_native_info_t;
|
||||
*/
|
||||
JNIEXPORT jobject JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Oget_1native_1info_1by_1name
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jstring name, jint fields, jlong access_id)
|
||||
{
|
||||
H5O_native_info_t infobuf;
|
||||
const char *objName = NULL;
|
||||
jobject hdrinfobuf;
|
||||
jobject obj_ihinfobuf;
|
||||
jobject attr_ihinfobuf;
|
||||
jvalue args[10];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
if (NULL == name)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Oget_native_info_by_name: object name is NULL");
|
||||
|
||||
PIN_JAVA_STRING(ENVONLY, name, objName, NULL, "H5Oget_native_info_by_name: object name not pinned");
|
||||
|
||||
if ((status = H5Oget_native_info_by_name((hid_t)loc_id, objName, &infobuf, (unsigned)fields, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
args[0].i = (jint)infobuf.hdr.version;
|
||||
args[1].i = (jint)infobuf.hdr.nmesgs;
|
||||
args[2].i = (jint)infobuf.hdr.nchunks;
|
||||
args[3].i = (jint)infobuf.hdr.flags;
|
||||
args[4].j = (jlong)infobuf.hdr.space.total;
|
||||
args[5].j = (jlong)infobuf.hdr.space.meta;
|
||||
args[6].j = (jlong)infobuf.hdr.space.mesg;
|
||||
args[7].j = (jlong)infobuf.hdr.space.free;
|
||||
args[8].j = (jlong)infobuf.hdr.mesg.present;
|
||||
args[9].j = (jlong)infobuf.hdr.mesg.shared;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_hdr_info_t", "(IIIIJJJJJJ)V", args, ret_obj);
|
||||
hdrinfobuf = ret_obj;
|
||||
|
||||
args[0].j = (jlong)infobuf.meta_size.obj.index_size;
|
||||
args[1].j = (jlong)infobuf.meta_size.obj.heap_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5_ih_info_t", "(JJ)V", args, ret_obj);
|
||||
obj_ihinfobuf = ret_obj;
|
||||
|
||||
args[0].j = (jlong)infobuf.meta_size.attr.index_size;
|
||||
args[1].j = (jlong)infobuf.meta_size.attr.heap_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5_ih_info_t", "(JJ)V", args, ret_obj);
|
||||
attr_ihinfobuf = ret_obj;
|
||||
|
||||
args[0].l = hdrinfobuf;
|
||||
args[1].l = obj_ihinfobuf;
|
||||
args[2].l = attr_ihinfobuf;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_native_info_t", "(Lhdf/hdf5lib/structs/H5O_hdr_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;)V", args, ret_obj);
|
||||
|
||||
done:
|
||||
if (objName)
|
||||
UNPIN_JAVA_STRING(ENVONLY, name, objName);
|
||||
|
||||
return ret_obj;
|
||||
} /* end Java_hdf_hdf5lib_H5_H5Oget_1native_1info_1by_1name */
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: H5Oget_native_info_by_idx
|
||||
* Signature: (JLjava/lang/String;IIJIJ)Lhdf/hdf5lib/structs/H5O_native_info_t;
|
||||
*/
|
||||
JNIEXPORT jobject JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Oget_1native_1info_1by_1idx
|
||||
(JNIEnv *env, jclass clss, jlong loc_id,
|
||||
jstring name, jint index_field, jint order, jlong link_n, jint fields, jlong access_id)
|
||||
{
|
||||
H5O_native_info_t infobuf;
|
||||
const char *grpName = NULL;
|
||||
jobject hdrinfobuf;
|
||||
jobject obj_ihinfobuf;
|
||||
jobject attr_ihinfobuf;
|
||||
jvalue args[10];
|
||||
herr_t status = FAIL;
|
||||
jobject ret_obj = NULL;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
if (NULL == name)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Oget_native_info_by_idx: group name is NULL");
|
||||
|
||||
PIN_JAVA_STRING(ENVONLY, name, grpName, NULL, "H5Oget_native_info_by_idx: group name not pinned");
|
||||
|
||||
if ((status = H5Oget_native_info_by_idx((hid_t)loc_id, grpName, (H5_index_t)index_field, (H5_iter_order_t)order, (hsize_t)link_n,
|
||||
&infobuf, (unsigned)fields, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
args[0].i = (jint)infobuf.hdr.version;
|
||||
args[1].i = (jint)infobuf.hdr.nmesgs;
|
||||
args[2].i = (jint)infobuf.hdr.nchunks;
|
||||
args[3].i = (jint)infobuf.hdr.flags;
|
||||
args[4].j = (jlong)infobuf.hdr.space.total;
|
||||
args[5].j = (jlong)infobuf.hdr.space.meta;
|
||||
args[6].j = (jlong)infobuf.hdr.space.mesg;
|
||||
args[7].j = (jlong)infobuf.hdr.space.free;
|
||||
args[8].j = (jlong)infobuf.hdr.mesg.present;
|
||||
args[9].j = (jlong)infobuf.hdr.mesg.shared;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_hdr_info_t", "(IIIIJJJJJJ)V", args, ret_obj);
|
||||
hdrinfobuf = ret_obj;
|
||||
|
||||
args[0].j = (jlong)infobuf.meta_size.obj.index_size;
|
||||
args[1].j = (jlong)infobuf.meta_size.obj.heap_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5_ih_info_t", "(JJ)V", args, ret_obj);
|
||||
obj_ihinfobuf = ret_obj;
|
||||
|
||||
args[0].j = (jlong)infobuf.meta_size.attr.index_size;
|
||||
args[1].j = (jlong)infobuf.meta_size.attr.heap_size;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5_ih_info_t", "(JJ)V", args, ret_obj);
|
||||
attr_ihinfobuf = ret_obj;
|
||||
|
||||
args[0].l = hdrinfobuf;
|
||||
args[1].l = obj_ihinfobuf;
|
||||
args[2].l = attr_ihinfobuf;
|
||||
|
||||
CALL_CONSTRUCTOR(ENVONLY, "hdf/hdf5lib/structs/H5O_native_info_t", "(Lhdf/hdf5lib/structs/H5O_hdr_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;)V", args, ret_obj);
|
||||
|
||||
done:
|
||||
if (grpName)
|
||||
UNPIN_JAVA_STRING(ENVONLY, name, grpName);
|
||||
|
||||
return ret_obj;
|
||||
} /* end Java_hdf_hdf5lib_H5_H5Oget_1info_1by_1idx */
|
||||
} /* end Java_hdf_hdf5lib_H5_H5Oget_1native_1info_1by_1idx */
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
@ -375,15 +539,13 @@ done:
|
||||
|
||||
static herr_t
|
||||
H5O_iterate_cb
|
||||
(hid_t g_id, const char *name, const H5O_info_t *info, void *cb_data)
|
||||
(hid_t g_id, const char *name, const H5O_info2_t *info, void *cb_data)
|
||||
{
|
||||
cb_wrapper *wrapper = (cb_wrapper *)cb_data;
|
||||
jmethodID constructor, mid;
|
||||
jmethodID mid;
|
||||
jobject cb_info_t = NULL;
|
||||
jobject visit_callback = wrapper->visit_callback;
|
||||
jobject hdrinfobuf;
|
||||
jobject ihinfobuf1;
|
||||
jobject ihinfobuf2;
|
||||
jobject token;
|
||||
jstring str;
|
||||
JNIEnv *cbenv = NULL;
|
||||
jclass cls;
|
||||
@ -399,85 +561,28 @@ H5O_iterate_cb
|
||||
if (NULL == (cls = CBENVPTR->GetObjectClass(CBENVONLY, visit_callback)))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
if (NULL == (mid = CBENVPTR->GetMethodID(CBENVONLY, cls, "callback", "(JLjava/lang/String;Lhdf/hdf5lib/structs/H5O_info_t;Lhdf/hdf5lib/callbacks/H5O_iterate_t;)I")))
|
||||
if (NULL == (mid = CBENVPTR->GetMethodID(CBENVONLY, cls, "callback", "(JLjava/lang/String;Lhdf/hdf5lib/structs/H5O_info_t;Lhdf/hdf5lib/callbacks/H5O_iterate_opdata_t;)I")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
if (NULL == (str = CBENVPTR->NewStringUTF(CBENVONLY, name)))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
args[0].i = (jint)info->hdr.version;
|
||||
args[1].i = (jint)info->hdr.nmesgs;
|
||||
args[2].i = (jint)info->hdr.nchunks;
|
||||
args[3].i = (jint)info->hdr.flags;
|
||||
args[4].j = (jlong)info->hdr.space.total;
|
||||
args[5].j = (jlong)info->hdr.space.meta;
|
||||
args[6].j = (jlong)info->hdr.space.mesg;
|
||||
args[7].j = (jlong)info->hdr.space.free;
|
||||
args[8].j = (jlong)info->hdr.mesg.present;
|
||||
args[9].j = (jlong)info->hdr.mesg.shared;
|
||||
|
||||
/* Get a reference to the H5_hdr_info_t class */
|
||||
if (NULL == (cls = CBENVPTR->FindClass(CBENVONLY, "hdf/hdf5lib/structs/H5O_hdr_info_t")))
|
||||
/* Create an H5O_token_t object */
|
||||
if (NULL == (token = create_H5O_token_t(CBENVONLY, &info->token, FALSE)))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
/* Get a reference to the constructor; the name is <init> */
|
||||
if (NULL == (constructor = CBENVPTR->GetMethodID(CBENVONLY, cls, "<init>", "(IIIIJJJJJJ)V")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
if (NULL == (hdrinfobuf = CBENVPTR->NewObjectA(CBENVONLY, cls, constructor, args))) {
|
||||
HDprintf("H5O_iterate_cb ERROR: hdf/hdf5lib/structs/H5O_hdr_info_t: Creation failed\n");
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
}
|
||||
|
||||
args[0].j = (jlong)info->meta_size.obj.index_size;
|
||||
args[1].j = (jlong)info->meta_size.obj.heap_size;
|
||||
|
||||
/* Get a reference to the H5_ih_info_t class */
|
||||
if (NULL == (cls = CBENVPTR->FindClass(CBENVONLY, "hdf/hdf5lib/structs/H5_ih_info_t")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
/* Get a reference to the constructor; the name is <init> */
|
||||
if (NULL == (constructor = CBENVPTR->GetMethodID(CBENVONLY, cls, "<init>", "(JJ)V")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
if (NULL == (ihinfobuf1 = CBENVPTR->NewObjectA(CBENVONLY, cls, constructor, args))) {
|
||||
HDprintf("H5O_iterate_cb ERROR: hdf/hdf5lib/structs/H5_ih_info_t: Creation failed\n");
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
}
|
||||
|
||||
args[0].j = (jlong)info->meta_size.attr.index_size;
|
||||
args[1].j = (jlong)info->meta_size.attr.heap_size;
|
||||
|
||||
if (NULL == (ihinfobuf2 = CBENVPTR->NewObjectA(CBENVONLY, cls, constructor, args))) {
|
||||
HDprintf("H5O_iterate_cb ERROR: hdf/hdf5lib/structs/H5_ih_info_t: Creation failed\n");
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
}
|
||||
|
||||
args[0].j = (jlong)info->fileno;
|
||||
args[1].j = (jlong)info->addr;
|
||||
args[1].l = token;
|
||||
args[2].i = info->type;
|
||||
args[3].i = (jint)info->rc;
|
||||
args[4].j = (jlong)info->num_attrs;
|
||||
args[5].j = info->atime;
|
||||
args[6].j = info->mtime;
|
||||
args[7].j = info->ctime;
|
||||
args[8].j = info->btime;
|
||||
args[9].l = hdrinfobuf;
|
||||
args[10].l = ihinfobuf1;
|
||||
args[11].l = ihinfobuf2;
|
||||
args[4].j = info->atime;
|
||||
args[5].j = info->mtime;
|
||||
args[6].j = info->ctime;
|
||||
args[7].j = info->btime;
|
||||
args[8].j = (jlong)info->num_attrs;
|
||||
|
||||
/* Get a reference to the H5O_info_t class */
|
||||
if (NULL == (cls = CBENVPTR->FindClass(CBENVONLY, "hdf/hdf5lib/structs/H5O_info_t")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
/* Get a reference to the constructor; the name is <init> */
|
||||
if (NULL == (constructor = CBENVPTR->GetMethodID(CBENVONLY, cls, "<init>", "(JJIIJJJJJLhdf/hdf5lib/structs/H5O_hdr_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;Lhdf/hdf5lib/structs/H5_ih_info_t;)V")))
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
|
||||
if (NULL == (cb_info_t = CBENVPTR->NewObjectA(CBENVONLY, cls, constructor, args))) {
|
||||
HDprintf("H5O_iterate_cb ERROR: hdf/hdf5lib/structs/H5O_info_t: Creation failed\n");
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
}
|
||||
CALL_CONSTRUCTOR(CBENVONLY, "hdf/hdf5lib/structs/H5O_info_t", "(JLhdf/hdf5lib/structs/H5O_token_t;IIJJJJJ)V", args, cb_info_t);
|
||||
|
||||
status = CBENVPTR->CallIntMethod(CBENVONLY, visit_callback, mid, g_id, str, cb_info_t, op_data);
|
||||
CHECK_JNI_EXCEPTION(CBENVONLY, JNI_FALSE);
|
||||
@ -512,7 +617,8 @@ Java_hdf_hdf5lib_H5_H5Ovisit
|
||||
if (NULL == callback_op)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Ovisit: callback_op is NULL");
|
||||
|
||||
if ((status = H5Ovisit2((hid_t)grp_id, (H5_index_t)idx_type, (H5_iter_order_t)order, (H5O_iterate_t)H5O_iterate_cb, (void *)&wrapper, (unsigned)fields)) < 0)
|
||||
if ((status = H5Ovisit3((hid_t)grp_id, (H5_index_t)idx_type, (H5_iter_order_t)order,
|
||||
H5O_iterate_cb, (void *)&wrapper, (unsigned)fields)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
done:
|
||||
@ -547,7 +653,8 @@ Java_hdf_hdf5lib_H5_H5Ovisit_1by_1name
|
||||
|
||||
PIN_JAVA_STRING(ENVONLY, name, objName, NULL, "H5Ovisit_by_name: object name not pinned");
|
||||
|
||||
if ((status = H5Ovisit_by_name2((hid_t)grp_id, objName, (H5_index_t)idx_type, (H5_iter_order_t)order, (H5O_iterate_t)H5O_iterate_cb, (void *)&wrapper, (unsigned)fields, (hid_t)access_id)) < 0)
|
||||
if ((status = H5Ovisit_by_name3((hid_t)grp_id, objName, (H5_index_t)idx_type, (H5_iter_order_t)order,
|
||||
H5O_iterate_cb, (void *)&wrapper, (unsigned)fields, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
done:
|
||||
@ -639,7 +746,7 @@ Java_hdf_hdf5lib_H5_H5Oget_1comment
|
||||
|
||||
if (buf_size) {
|
||||
if (NULL == (oComment = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Oget_comment: failed to allocate object comment buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Oget_comment: failed to allocate object comment buffer");
|
||||
|
||||
if ((status = H5Oget_comment((hid_t)loc_id, oComment, (size_t)buf_size + 1)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -684,7 +791,7 @@ Java_hdf_hdf5lib_H5_H5Oget_1comment_1by_1name
|
||||
|
||||
if (buf_size) {
|
||||
if (NULL == (objComment = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Oget_comment_by_name: failed to allocate buffer for object comment");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Oget_comment_by_name: failed to allocate buffer for object comment");
|
||||
|
||||
if ((status = H5Oget_comment_by_name((hid_t)loc_id, objName, objComment, (size_t)buf_size + 1, (hid_t)access_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -772,23 +879,46 @@ done:
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: _H5Oopen_by_addr
|
||||
* Signature: (JJ)J;
|
||||
* Method: _H5Oopen_by_token
|
||||
* Signature: (JLhdf/hdf5lib/structs/H5O_token_t;)J;
|
||||
*/
|
||||
JNIEXPORT jlong JNICALL
|
||||
Java_hdf_hdf5lib_H5__1H5Oopen_1by_1addr
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jlong addr)
|
||||
Java_hdf_hdf5lib_H5__1H5Oopen_1by_1token
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jobject token)
|
||||
{
|
||||
hid_t retVal = H5I_INVALID_HID;
|
||||
H5O_token_t obj_token;
|
||||
jboolean token_buf_is_copy;
|
||||
jfieldID token_data_field_id;
|
||||
jclass token_cls;
|
||||
jbyte *token_buf = NULL;
|
||||
jobject token_data;
|
||||
hid_t retVal = H5I_INVALID_HID;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
if ((retVal = H5Oopen_by_addr((hid_t)loc_id, (haddr_t)addr)) < 0)
|
||||
token_cls = ENVPTR->GetObjectClass(ENVONLY, token);
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
if (NULL == (token_data_field_id = ENVPTR->GetFieldID(ENVONLY, token_cls, "data", "[B")))
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
token_data = ENVPTR->GetObjectField(ENVONLY, token, token_data_field_id);
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
PIN_BYTE_ARRAY(ENVONLY, (jbyteArray)token_data, token_buf, &token_buf_is_copy, "H5Oopen_by_token: token buffer not pinned");
|
||||
HDmemcpy(&obj_token, token_buf, sizeof(H5O_token_t));
|
||||
UNPIN_BYTE_ARRAY(ENVONLY, (jbyteArray)token_data, token_buf, JNI_ABORT);
|
||||
token_buf = NULL;
|
||||
|
||||
if ((retVal = H5Oopen_by_token((hid_t)loc_id, obj_token)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
done:
|
||||
if (token_buf)
|
||||
UNPIN_BYTE_ARRAY(ENVONLY, (jbyteArray)token_data, token_buf, (retVal < 0) ? JNI_ABORT : 0);
|
||||
|
||||
return (jlong)retVal;
|
||||
} /* end Java_hdf_hdf5lib_H5__1H5Oopen_1by_1addr */
|
||||
} /* end Java_hdf_hdf5lib_H5__1H5Oopen_1by_1token */
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
|
@ -76,6 +76,33 @@ JNIEXPORT jobject JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Oget_1info_1by_1idx
|
||||
(JNIEnv*, jclass, jlong, jstring, jint, jint, jlong, jint fields, jlong);
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: H5Oget_native_info
|
||||
* Signature: (JI)Lhdf/hdf5lib/structs/H5O_native_info_t;
|
||||
*/
|
||||
JNIEXPORT jobject JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Oget_1native_1info
|
||||
(JNIEnv*, jclass, jlong, jint fields);
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: H5Oget_native_info_by_name
|
||||
* Signature: (JLjava/lang/String;IJ)Lhdf/hdf5lib/structs/H5O_native_info_t;
|
||||
*/
|
||||
JNIEXPORT jobject JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Oget_1native_1info_1by_1name
|
||||
(JNIEnv*, jclass, jlong, jstring, jint fields, jlong);
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: H5Oget_native_info_by_idx
|
||||
* Signature: (JLjava/lang/String;IIJIJ)Lhdf/hdf5lib/structs/H5O_native_info_t;
|
||||
*/
|
||||
JNIEXPORT jobject JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Oget_1native_1info_1by_1idx
|
||||
(JNIEnv*, jclass, jlong, jstring, jint, jint, jlong, jint fields, jlong);
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: H5Olink
|
||||
@ -168,12 +195,12 @@ Java_hdf_hdf5lib_H5_H5Oincr_1refcount
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: _H5Oopen_by_addr
|
||||
* Signature: (JJ)J;
|
||||
* Method: _H5Oopen_by_token
|
||||
* Signature: (JLhdf/hdf5lib/structs/H5O_token_t;)J;
|
||||
*/
|
||||
JNIEXPORT jlong JNICALL
|
||||
Java_hdf_hdf5lib_H5__1H5Oopen_1by_1addr
|
||||
(JNIEnv*, jclass, jlong, jlong);
|
||||
Java_hdf_hdf5lib_H5__1H5Oopen_1by_1token
|
||||
(JNIEnv*, jclass, jlong, jobject);
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
|
@ -151,7 +151,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1efile_1prefix
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (pre = (char *) HDmalloc(sizeof(char) * (size_t)prefix_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_efile_prefix: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_efile_prefix: memory allocation failed");
|
||||
|
||||
if (H5Pget_efile_prefix((hid_t)dapl_id, (char *)pre, (size_t)prefix_size + 1) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -159,7 +159,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1efile_1prefix
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, pre))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_efile_prefix: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_efile_prefix: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
done:
|
||||
|
@ -109,7 +109,7 @@ Java_hdf_hdf5lib_H5_H5Pset_1chunk
|
||||
PIN_BYTE_ARRAY(ENVONLY, dim, theArray, &isCopy, "H5Pset_chunk: dim array not pinned");
|
||||
|
||||
if (NULL == (da = lp = (hsize_t *) HDmalloc(rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pset_chunk: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pset_chunk: memory allocation failed");
|
||||
|
||||
jlp = (jlong *)theArray;
|
||||
for (i = 0; i < rank; i++) {
|
||||
@ -161,7 +161,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1chunk
|
||||
PIN_LONG_ARRAY(ENVONLY, dims, theArray, &isCopy, "H5Pget_chunk: input dims not pinned");
|
||||
|
||||
if (NULL == (da = (hsize_t *) HDmalloc((size_t)max_ndims * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_chunk: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_chunk: memory allocation failed");
|
||||
|
||||
if ((status = H5Pget_chunk((hid_t)plist, (int)max_ndims, da)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -595,7 +595,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1filter
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Pget_filter: cd_values is NULL");
|
||||
|
||||
if (NULL == (filter = (char *) HDmalloc(sizeof(char) * (size_t)namelen)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_filter: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_filter: memory allocation failed");
|
||||
|
||||
PIN_INT_ARRAY(ENVONLY, flags, flagsArray, &isCopy, "H5Pget_filter: flags array not pinned");
|
||||
PIN_LONG_ARRAY(ENVONLY, cd_nelmts, cd_nelmtsArray, &isCopy, "H5Pget_filter: nelmts array not pinned");
|
||||
@ -620,7 +620,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1filter
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, filter))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_filter: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_filter: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, name, 0, (jobject)str);
|
||||
@ -632,7 +632,7 @@ done:
|
||||
if (cd_nelmtsArray)
|
||||
UNPIN_LONG_ARRAY(ENVONLY, cd_nelmts, cd_nelmtsArray, (status < 0) ? JNI_ABORT : 0);
|
||||
if (flagsArray)
|
||||
UNPIN_INT_ARRAY(ENVONLY, flags, flagsArray, (status < 0) ? JNI_ABORT : 0)
|
||||
UNPIN_INT_ARRAY(ENVONLY, flags, flagsArray, (status < 0) ? JNI_ABORT : 0);
|
||||
if (filter)
|
||||
HDfree(filter);
|
||||
|
||||
@ -671,7 +671,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1filter2
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Pget_filter2: filter_config is NULL");
|
||||
|
||||
if (NULL == (filter = (char *) HDmalloc(sizeof(char) * (size_t)namelen)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_filter2: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_filter2: memory allocation failed");
|
||||
|
||||
PIN_INT_ARRAY(ENVONLY, flags, flagsArray, &isCopy, "H5Pget_filter2: flags array not pinned");
|
||||
PIN_LONG_ARRAY(ENVONLY, cd_nelmts, cd_nelmtsArray, &isCopy, "H5Pget_filter2: nelmts array not pinned");
|
||||
@ -715,7 +715,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1filter2
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, filter))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_filter2: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_filter2: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, name, 0, (jobject)str);
|
||||
@ -772,7 +772,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1filter_1by_1id
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Pget_filter_by_id: name is NULL");
|
||||
|
||||
if (NULL == (aName = (char *) HDmalloc(sizeof(char) * (size_t)bs)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_filter_by_id: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_filter_by_id: memory allocation failed");
|
||||
|
||||
PIN_INT_ARRAY(ENVONLY, flags, flagsArray, &isCopy, "H5Pget_filter_by_id: flags not pinned");
|
||||
PIN_LONG_ARRAY(ENVONLY, cd_nelmts, cd_nelmtsArray, &isCopy, "H5Pget_filter_by_id: cd_nelms not pinned");
|
||||
@ -801,7 +801,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1filter_1by_1id
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, aName))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_filter_by_id: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_filter_by_id: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, name, 0, (jobject)str);
|
||||
@ -858,7 +858,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1filter_1by_1id2
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Pget_filter_by_id2: filter_config is NULL");
|
||||
|
||||
if (NULL == (aName = (char *) HDmalloc(sizeof(char) * (size_t)bs)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_filter_by_id2: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_filter_by_id2: memory allocation failed");
|
||||
|
||||
PIN_INT_ARRAY(ENVONLY, flags, flagsArray, &isCopy, "H5Pget_filter_by_id2: flags not pinned");
|
||||
PIN_LONG_ARRAY(ENVONLY, cd_nelmts, cd_nelmtsArray, &isCopy, "H5Pget_filter_by_id2: cd_nelms not pinned");
|
||||
@ -882,7 +882,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1filter_1by_1id2
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, aName))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_filter_by_id2: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_filter_by_id2: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, name, 0, (jobject)str);
|
||||
@ -1122,7 +1122,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1external
|
||||
|
||||
if (name_size > 0)
|
||||
if (NULL == (file = (char *) HDmalloc(sizeof(char) * (size_t)name_size)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_external: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_external: memory allocation failed");
|
||||
|
||||
if ((status = H5Pget_external((hid_t) plist, (unsigned)idx, (size_t)name_size,
|
||||
file, (off_t *)&o, (hsize_t *)&s)) < 0)
|
||||
@ -1140,7 +1140,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1external
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, file))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_external: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_external: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, name, 0, (jobject)str);
|
||||
@ -1250,7 +1250,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1virtual_1dsetname
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (dname = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_virtual_dsetname: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_virtual_dsetname: memory allocation failed");
|
||||
|
||||
if (H5Pget_virtual_dsetname((hid_t)dcpl_id, (size_t)index, dname, (size_t)buf_size + 1) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1258,7 +1258,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1virtual_1dsetname
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, dname))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_virtual_dsetname: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_virtual_dsetname: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
done:
|
||||
@ -1288,7 +1288,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1virtual_1filename
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (fname = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_virtual_filename: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_virtual_filename: memory allocation failed");
|
||||
|
||||
if (H5Pget_virtual_filename((hid_t)dcpl_id, (size_t)index, fname, (size_t)buf_size + 1) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1296,7 +1296,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1virtual_1filename
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, fname))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_virtual_filename: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_virtual_filename: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
done:
|
||||
@ -1392,7 +1392,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1virtual_1prefix
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (pre = (char *) HDmalloc(sizeof(char) * (size_t) prefix_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_virtual_prefix: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_virtual_prefix: memory allocation failed");
|
||||
|
||||
if (H5Pget_virtual_prefix((hid_t)dapl_id, (char *)pre, (size_t) prefix_size + 1) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1400,7 +1400,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1virtual_1prefix
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, pre))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_virtual_prefix: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_virtual_prefix: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
done:
|
||||
|
@ -310,7 +310,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1data_1transform
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (express = (char *) HDmalloc(sizeof(char) * (size_t)express_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_data_transform: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_data_transform: memory allocation failed");
|
||||
|
||||
if (H5Pget_data_transform((hid_t)plist_id, express, (size_t)express_size + 1) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -318,7 +318,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1data_1transform
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, express))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_data_transform: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_data_transform: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, expression, 0, str);
|
||||
|
@ -308,7 +308,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1fapl_1family
|
||||
}
|
||||
|
||||
if (NULL == (sa = (hsize_t *) HDmalloc((size_t) rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_family: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_family: memory allocation failed");
|
||||
|
||||
PIN_LONG_ARRAY(ENVONLY, memb_plist, plistArray, &isCopy, "H5Pget_family: plistArray not pinned");
|
||||
|
||||
@ -398,7 +398,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1fapl_1hdfs
|
||||
if (NULL != fa.namenode_name) {
|
||||
if (NULL == (j_namenode_name = ENVPTR->NewStringUTF(ENVONLY, fa.namenode_name))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_fapl_hdfs: out of memory - can't create namenode_name string");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_fapl_hdfs: out of memory - can't create namenode_name string");
|
||||
}
|
||||
}
|
||||
args[0].l = j_namenode_name;
|
||||
@ -408,7 +408,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1fapl_1hdfs
|
||||
if (NULL != fa.user_name) {
|
||||
if (NULL == (j_user_name = ENVPTR->NewStringUTF(ENVONLY, fa.user_name))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_fapl_hdfs: out of memory - can't create user_name string");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_fapl_hdfs: out of memory - can't create user_name string");
|
||||
}
|
||||
}
|
||||
args[2].l = j_user_name;
|
||||
@ -416,7 +416,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1fapl_1hdfs
|
||||
if (NULL != fa.kerberos_ticket_cache) {
|
||||
if (NULL == (j_kerb_cache_path = ENVPTR->NewStringUTF(ENVONLY, fa.kerberos_ticket_cache))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_fapl_hdfs: out of memory - can't create kerberos_ticket_cache string");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_fapl_hdfs: out of memory - can't create kerberos_ticket_cache string");
|
||||
}
|
||||
}
|
||||
args[3].l = j_kerb_cache_path;
|
||||
@ -651,7 +651,7 @@ Java_hdf_hdf5lib_H5_H5Pset_1fapl_1multi
|
||||
str_len = HDstrlen(utf8);
|
||||
|
||||
if (NULL == (member_name[i] = (char *) HDmalloc(str_len + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pset_fapl_multi: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pset_fapl_multi: memory allocation failed");
|
||||
|
||||
HDstrncpy(member_name[i], utf8, str_len + 1);
|
||||
(member_name[i])[str_len] = '\0';
|
||||
@ -678,7 +678,7 @@ Java_hdf_hdf5lib_H5_H5Pset_1fapl_1multi
|
||||
|
||||
if (NULL == (rstring = ENVPTR->NewStringUTF(ENVONLY, member_name[i]))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pset_fapl_multi: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pset_fapl_multi: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
if (NULL == (o = ENVPTR->GetObjectArrayElement(ENVONLY, memb_name, (jsize) i))) {
|
||||
@ -750,7 +750,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1fapl_1multi
|
||||
PIN_LONG_ARRAY(ENVONLY, memb_addr, theaddrArray, &isCopy, "H5Pget_fapl_multi: memb_addr not pinned");
|
||||
if (memb_name)
|
||||
if (NULL == (mName = (char **) HDcalloc(H5FD_MEM_NTYPES, sizeof(*mName))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_fapl_multi: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_fapl_multi: memory allocation failed");
|
||||
|
||||
if ((status = H5Pget_fapl_multi((hid_t)tid, (H5FD_mem_t *)themapArray, (hid_t *)thefaplArray,
|
||||
mName, (haddr_t *)theaddrArray, (hbool_t *)&relax)) < 0)
|
||||
@ -761,7 +761,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1fapl_1multi
|
||||
if (mName[i]) {
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, mName[i]))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_fapl_multi: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_fapl_multi: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, memb_name, (jsize) i, (jobject)str);
|
||||
@ -823,7 +823,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1fapl_1ros3
|
||||
if (NULL != fa.aws_region) {
|
||||
if (NULL == (j_aws = ENVPTR->NewStringUTF(ENVONLY, fa.aws_region))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_fapl_ros3: out of memory - can't create aws_region string");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_fapl_ros3: out of memory - can't create aws_region string");
|
||||
}
|
||||
}
|
||||
args[0].l = j_aws;
|
||||
@ -831,7 +831,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1fapl_1ros3
|
||||
if (NULL != fa.secret_id) {
|
||||
if (NULL == (j_id = ENVPTR->NewStringUTF(ENVONLY, fa.secret_id))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_fapl_ros3: out of memory - can't create secret_id string");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_fapl_ros3: out of memory - can't create secret_id string");
|
||||
}
|
||||
}
|
||||
args[1].l = j_id;
|
||||
@ -839,7 +839,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1fapl_1ros3
|
||||
if (NULL != fa.secret_key) {
|
||||
if (NULL == (j_key = ENVPTR->NewStringUTF(ENVONLY, fa.secret_key))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_fapl_ros3: out of memory - can't create secret_key string");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_fapl_ros3: out of memory - can't create secret_key string");
|
||||
}
|
||||
}
|
||||
args[2].l = j_key;
|
||||
@ -1688,7 +1688,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1mdc_1config
|
||||
if (NULL != cacheinfo.trace_file_name) {
|
||||
if (NULL == (j_str = ENVPTR->NewStringUTF(ENVONLY, cacheinfo.trace_file_name))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_mdc_config: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_mdc_config: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
}
|
||||
|
||||
@ -1802,7 +1802,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1mdc_1log_1options
|
||||
|
||||
location_size++; /* add extra space for the null terminator */
|
||||
if (NULL == (lname = (char *) HDmalloc(sizeof(char) * location_size)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_mdc_log_options: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_mdc_log_options: memory allocation failed");
|
||||
|
||||
if ((status = H5Pget_mdc_log_options((hid_t)fapl_id, &is_enabled, lname, &location_size, &start_on_access)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1810,7 +1810,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1mdc_1log_1options
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, lname))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_mdc_log_options: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_mdc_log_options: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
mdc_log_options_ptr[0] = (jboolean)is_enabled;
|
||||
|
@ -503,7 +503,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1class_1name
|
||||
|
||||
if (NULL == (j_str = ENVPTR->NewStringUTF(ENVONLY, c_str))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_class_name: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_class_name: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
done:
|
||||
|
@ -134,7 +134,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1elink_1prefix
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (pre = (char *) HDmalloc(sizeof(char) * (size_t) prefix_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_elink_prefix: memory allocation failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_elink_prefix: memory allocation failed");
|
||||
|
||||
if (H5Pget_elink_prefix((hid_t)lapl_id, (char *)pre, (size_t) prefix_size + 1) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -142,7 +142,7 @@ Java_hdf_hdf5lib_H5_H5Pget_1elink_1prefix
|
||||
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, pre))) {
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_TRUE);
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Pget_elink_prefix: out of memory - unable to construct string from UTF characters");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Pget_elink_prefix: out of memory - unable to construct string from UTF characters");
|
||||
}
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, prefix, 0, str);
|
||||
|
@ -226,7 +226,7 @@ Java_hdf_hdf5lib_H5_H5PLget
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (aName = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5PLget: failed to allocate plugin name buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5PLget: failed to allocate plugin name buffer");
|
||||
|
||||
if ((H5PLget((unsigned) index, aName, (size_t)buf_size + 1)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
@ -51,7 +51,7 @@ Java_hdf_hdf5lib_H5_H5Rcreate_1object
|
||||
PIN_JAVA_STRING(ENVONLY, name, refName, NULL, "H5Rcreate_object: reference name not pinned");
|
||||
|
||||
if (NULL == (refBuf = (unsigned char *) HDcalloc((size_t) 1, H5R_REF_BUF_SIZE)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Rcreate_object: failed to allocate reference buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Rcreate_object: failed to allocate reference buffer");
|
||||
|
||||
if ((status = H5Rcreate_object((hid_t)loc_id, refName, (hid_t)aid, (const H5R_ref_t *)refBuf)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -94,7 +94,7 @@ Java_hdf_hdf5lib_H5_H5Rcreate_1region
|
||||
PIN_JAVA_STRING(ENVONLY, name, refName, NULL, "H5Rcreate_region: reference name not pinned");
|
||||
|
||||
if (NULL == (refBuf = (unsigned char *) HDcalloc((size_t) 1, H5R_REF_BUF_SIZE)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Rcreate_region: failed to allocate reference buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Rcreate_region: failed to allocate reference buffer");
|
||||
|
||||
if ((status = H5Rcreate_region((hid_t)loc_id, refName, space_id, (hid_t)aid, (const H5R_ref_t *)refBuf)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -141,7 +141,7 @@ Java_hdf_hdf5lib_H5_H5Rcreate_1attr
|
||||
PIN_JAVA_STRING(ENVONLY, name, refName, NULL, "H5Rcreate_attr: reference name not pinned");
|
||||
|
||||
if (NULL == (refBuf = (unsigned char *) HDcalloc((size_t) 1, H5R_REF_BUF_SIZE)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Rcreate_attr: failed to allocate reference buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Rcreate_attr: failed to allocate reference buffer");
|
||||
|
||||
if ((status = H5Rcreate_attr((hid_t)loc_id, refName, attrName, (hid_t)aid, (const H5R_ref_t *)refBuf)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -315,7 +315,7 @@ Java_hdf_hdf5lib_H5_H5Rcopy
|
||||
PIN_BYTE_ARRAY(ENVONLY, src_ref, src_refBuf, &isCopy, "H5Rcopy: src reference buffer not pinned");
|
||||
|
||||
if (NULL == (dst_refBuf = (unsigned char *) HDcalloc((size_t) 1, H5R_REF_BUF_SIZE)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Rcreate_attr: failed to allocate dst reference buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Rcreate_attr: failed to allocate dst reference buffer");
|
||||
|
||||
if ((status = H5Rcopy((const H5R_ref_t *)src_refBuf, (const H5R_ref_t *)dst_refBuf)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -505,7 +505,7 @@ Java_hdf_hdf5lib_H5_H5Rget_1file_1name
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (namePtr = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Rget_file_name: malloc failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Rget_file_name: malloc failed");
|
||||
|
||||
if ((check_size = H5Rget_file_name((const H5R_ref_t *)refBuf, namePtr, (size_t)buf_size + 1)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -551,7 +551,7 @@ Java_hdf_hdf5lib_H5_H5Rget_1obj_1name
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (namePtr = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Rget_obj_name: malloc failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Rget_obj_name: malloc failed");
|
||||
|
||||
if ((check_size = H5Rget_obj_name((const H5R_ref_t *)refBuf, (hid_t)rapl_id, namePtr, (size_t)buf_size + 1)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -597,7 +597,7 @@ Java_hdf_hdf5lib_H5_H5Rget_1attr_1name
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (namePtr = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Rget_attr_name: malloc failed");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Rget_attr_name: malloc failed");
|
||||
|
||||
if ((check_size = H5Rget_attr_name((const H5R_ref_t *)refBuf, namePtr, (size_t)buf_size + 1)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -645,9 +645,9 @@ Java_hdf_hdf5lib_H5_H5Rcreate
|
||||
}
|
||||
|
||||
if ((H5R_OBJECT == ref_type) && (refBufLen != H5R_OBJ_REF_BUF_SIZE))
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rcreate: reference input array length != H5R_OBJ_REF_BUF_SIZE")
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rcreate: reference input array length != H5R_OBJ_REF_BUF_SIZE");
|
||||
else if ((H5R_DATASET_REGION == ref_type) && (refBufLen != H5R_DSET_REG_REF_BUF_SIZE))
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rcreate: region reference input array length != H5R_DSET_REG_REF_BUF_SIZE")
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rcreate: region reference input array length != H5R_DSET_REG_REF_BUF_SIZE");
|
||||
else if ((H5R_OBJECT != ref_type) && (H5R_DATASET_REGION != ref_type))
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rcreate: unknown reference type");
|
||||
|
||||
@ -692,9 +692,9 @@ Java_hdf_hdf5lib_H5__1H5Rdereference
|
||||
}
|
||||
|
||||
if ((H5R_OBJECT == ref_type) && (refBufLen != H5R_OBJ_REF_BUF_SIZE))
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rdereference: reference input array length != H5R_OBJ_REF_BUF_SIZE")
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rdereference: reference input array length != H5R_OBJ_REF_BUF_SIZE");
|
||||
else if ((H5R_DATASET_REGION == ref_type) && (refBufLen != H5R_DSET_REG_REF_BUF_SIZE))
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rdereference: region reference input array length != H5R_DSET_REG_REF_BUF_SIZE")
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rdereference: region reference input array length != H5R_DSET_REG_REF_BUF_SIZE");
|
||||
else if ((H5R_OBJECT != ref_type) && (H5R_DATASET_REGION != ref_type))
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rdereference: unknown reference type");
|
||||
|
||||
@ -854,16 +854,16 @@ Java_hdf_hdf5lib_H5_H5Rget_1name
|
||||
}
|
||||
|
||||
if ((H5R_OBJECT == ref_type) && (refBufLen != H5R_OBJ_REF_BUF_SIZE))
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rget_name: reference input array length != H5R_OBJ_REF_BUF_SIZE")
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rget_name: reference input array length != H5R_OBJ_REF_BUF_SIZE");
|
||||
else if ((H5R_DATASET_REGION == ref_type) && (refBufLen != H5R_DSET_REG_REF_BUF_SIZE))
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rget_name: region reference input array length != H5R_DSET_REG_REF_BUF_SIZE")
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rget_name: region reference input array length != H5R_DSET_REG_REF_BUF_SIZE");
|
||||
else if ((H5R_OBJECT != ref_type) && (H5R_DATASET_REGION != ref_type))
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Rget_name: unknown reference type");
|
||||
|
||||
PIN_BYTE_ARRAY(ENVONLY, ref, refBuf, &isCopy, "H5Rget_name: reference buffer not pinned");
|
||||
|
||||
if (NULL == (aName = (char *) HDmalloc(sizeof(char) * (size_t)size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Rget_name: failed to allocate referenced object name buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Rget_name: failed to allocate referenced object name buffer");
|
||||
|
||||
if ((ret_val = (jlong)H5Rget_name((hid_t)loc_id, (H5R_type_t)ref_type, refBuf, aName, (size_t)size + 1)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
@ -98,7 +98,7 @@ Java_hdf_hdf5lib_H5__1H5Screate_1simple
|
||||
PIN_LONG_ARRAY(ENVONLY, dims, dimsP, &isCopy, "H5Screate_simple: dims not pinned");
|
||||
|
||||
if (NULL == (sa = lp = (hsize_t *) HDmalloc((size_t)rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Screate_simple: failed to allocate dims buffer")
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Screate_simple: failed to allocate dims buffer");
|
||||
|
||||
jlp = (jlong *) dimsP;
|
||||
for (i = 0; i < rank; i++) {
|
||||
@ -115,7 +115,7 @@ Java_hdf_hdf5lib_H5__1H5Screate_1simple
|
||||
PIN_LONG_ARRAY(ENVONLY, maxdims, maxdimsP, &isCopy, "H5Screate_simple: maxdims not pinned");
|
||||
|
||||
if (NULL == (msa = lp = (hsize_t *) HDmalloc((size_t)rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Screate_simple: failed to allocate maxdims buffer")
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Screate_simple: failed to allocate maxdims buffer");
|
||||
|
||||
jlp = (jlong *) maxdimsP;
|
||||
for (i = 0; i < mrank; i++) {
|
||||
@ -194,7 +194,7 @@ Java_hdf_hdf5lib_H5_H5Sselect_1elements
|
||||
PIN_LONG_ARRAY(ENVONLY, coords, P, &isCopy, "H5Sselect_elements: coords not pinned");
|
||||
|
||||
if (NULL == (sa = (hssize_t *) HDmalloc( (size_t)num_elemn * 2 * sizeof(hssize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sselect_elements: failed to allocate coordinate buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sselect_elements: failed to allocate coordinate buffer");
|
||||
|
||||
for (i = 0; i < (num_elemn * 2); i++) {
|
||||
sa[i] = P[i];
|
||||
@ -247,7 +247,7 @@ Java_hdf_hdf5lib_H5_H5Sselect_1elements
|
||||
nlongs = (int)((size_t)size / sizeof(jlong));
|
||||
|
||||
if (NULL == (lp = (hsize_t *) HDmalloc((size_t)nlongs * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sselect_elements: failed to allocate coordinate buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sselect_elements: failed to allocate coordinate buffer");
|
||||
|
||||
jlp = (jlong *) P;
|
||||
llp = lp;
|
||||
@ -444,7 +444,7 @@ Java_hdf_hdf5lib_H5_H5Sget_1simple_1extent_1dims
|
||||
}
|
||||
|
||||
if (NULL == (sa = (hsize_t *) HDmalloc((size_t)rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sget_simple_extent_dims: failed to allocate dimension buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sget_simple_extent_dims: failed to allocate dimension buffer");
|
||||
}
|
||||
|
||||
if (NULL == maxdims) {
|
||||
@ -462,10 +462,10 @@ Java_hdf_hdf5lib_H5_H5Sget_1simple_1extent_1dims
|
||||
if (rank < 0)
|
||||
rank = mrank;
|
||||
else if (mrank != rank)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sget_simple_extent_dims: maxdims rank not same as dims");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Sget_simple_extent_dims: maxdims rank not same as dims");
|
||||
|
||||
if (NULL == (msa = (hsize_t *) HDmalloc((size_t)rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sget_simple_extent_dims: failed to allocate maximum dimension buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sget_simple_extent_dims: failed to allocate maximum dimension buffer");
|
||||
}
|
||||
|
||||
if ((status = H5Sget_simple_extent_dims(space_id, (hsize_t *)sa, (hsize_t *)msa)) < 0)
|
||||
@ -564,7 +564,7 @@ Java_hdf_hdf5lib_H5_H5Sset_1extent_1simple
|
||||
PIN_LONG_ARRAY(ENVONLY, dims, dimsP, &isCopy, "H5Sset_extent_simple: dims not pinned");
|
||||
|
||||
if (NULL == (sa = lp = (hsize_t *) HDmalloc((size_t)rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sset_extent_simple: failed to allocate dimension buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sset_extent_simple: failed to allocate dimension buffer");
|
||||
|
||||
jlp = (jlong *) dimsP;
|
||||
for (i = 0; i < rank; i++) {
|
||||
@ -581,7 +581,7 @@ Java_hdf_hdf5lib_H5_H5Sset_1extent_1simple
|
||||
PIN_LONG_ARRAY(ENVONLY, maxdims, maxdimsP, &isCopy, "H5Sset_extent_simple: maxdims not pinned");
|
||||
|
||||
if (NULL == (msa = lp = (hsize_t *) HDmalloc((size_t)rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sset_extent_simple: failed to allocate maximum dimension buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sset_extent_simple: failed to allocate maximum dimension buffer");
|
||||
|
||||
jlp = (jlong *) maxdimsP;
|
||||
for (i = 0; i < rank; i++) {
|
||||
@ -660,7 +660,7 @@ Java_hdf_hdf5lib_H5_H5Soffset_1simple
|
||||
rank = (size_t) i / sizeof(jlong);
|
||||
|
||||
if (NULL == (sa = lp = (hssize_t *) HDmalloc((size_t)rank * sizeof(hssize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Soffset_simple: failed to allocate offset buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Soffset_simple: failed to allocate offset buffer");
|
||||
|
||||
jlp = (jlong *) P;
|
||||
for (i = 0; (size_t) i < rank; i++) {
|
||||
@ -788,7 +788,7 @@ Java_hdf_hdf5lib_H5_H5Sselect_1hyperslab
|
||||
PIN_LONG_ARRAY(ENVONLY, start, startP, &isCopy, "H5Sselect_hyperslab: start not pinned");
|
||||
|
||||
if (NULL == (strt = lp = (hsize_t *) HDmalloc((size_t)start_rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sselect_hyperslab: failed to allocate start buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sselect_hyperslab: failed to allocate start buffer");
|
||||
|
||||
jlp = (jlong *) startP;
|
||||
for (i = 0; i < start_rank; i++) {
|
||||
@ -800,7 +800,7 @@ Java_hdf_hdf5lib_H5_H5Sselect_1hyperslab
|
||||
PIN_LONG_ARRAY(ENVONLY, count, countP, &isCopy, "H5Sselect_hyperslab: count not pinned");
|
||||
|
||||
if (NULL == (cnt = lp = (hsize_t *) HDmalloc((size_t)count_rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sselect_hyperslab: failed to allocate count buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sselect_hyperslab: failed to allocate count buffer");
|
||||
|
||||
jlp = (jlong *) countP;
|
||||
for (i = 0; i < count_rank; i++) {
|
||||
@ -825,7 +825,7 @@ Java_hdf_hdf5lib_H5_H5Sselect_1hyperslab
|
||||
PIN_LONG_ARRAY(ENVONLY, stride, strideP, &isCopy, "H5Sselect_hyperslab: stride not pinned");
|
||||
|
||||
if (NULL == (strd = lp = (hsize_t *) HDmalloc((size_t)stride_rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sselect_hyperslab: failed to allocate stride buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sselect_hyperslab: failed to allocate stride buffer");
|
||||
|
||||
jlp = (jlong *) strideP;
|
||||
for (i = 0; i < stride_rank; i++) {
|
||||
@ -851,7 +851,7 @@ Java_hdf_hdf5lib_H5_H5Sselect_1hyperslab
|
||||
PIN_LONG_ARRAY(ENVONLY, block, blockP, &isCopy, "H5Sselect_hyperslab: block not pinned");
|
||||
|
||||
if (NULL == (blk = lp = (hsize_t *) HDmalloc((size_t)block_rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sselect_hyperslab: failed to allocate block buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sselect_hyperslab: failed to allocate block buffer");
|
||||
|
||||
jlp = (jlong *) blockP;
|
||||
for (i = 0; i < block_rank; i++) {
|
||||
@ -988,7 +988,7 @@ Java_hdf_hdf5lib_H5_H5Sget_1select_1hyper_1blocklist
|
||||
|
||||
buf_size = (size_t) numblocks * (size_t) 2 * (size_t) rank * sizeof(hsize_t);
|
||||
if (NULL == (ba = (hsize_t *) HDmalloc(buf_size)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sget_select_hyper_blocklist: failed to allocate block list buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sget_select_hyper_blocklist: failed to allocate block list buffer");
|
||||
|
||||
if ((status = H5Sget_select_hyper_blocklist((hid_t)spaceid, (hsize_t) startblock, (hsize_t) numblocks, (hsize_t *)ba)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1044,7 +1044,7 @@ Java_hdf_hdf5lib_H5_H5Sget_1select_1elem_1pointlist
|
||||
PIN_LONG_ARRAY(ENVONLY, buf, bufP, &isCopy, "H5Sget_select_elem_pointlist: buffer not pinned");
|
||||
|
||||
if (NULL == (ba = (hsize_t *) HDmalloc(((size_t)numpoints * (size_t)rank) * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sget_select_elem_pointlist: failed to allocate point list buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sget_select_elem_pointlist: failed to allocate point list buffer");
|
||||
|
||||
if ((status = H5Sget_select_elem_pointlist((hid_t)spaceid, (hsize_t)startpoint, (hsize_t)numpoints, (hsize_t *)ba)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1094,12 +1094,12 @@ Java_hdf_hdf5lib_H5_H5Sget_1select_1bounds
|
||||
}
|
||||
|
||||
if (NULL == (strt = (hsize_t *) HDmalloc((size_t)rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sget_select_bounds: failed to allocate start buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sget_select_bounds: failed to allocate start buffer");
|
||||
|
||||
PIN_LONG_ARRAY(ENVONLY, end, endP, &isCopy, "H5Sget_select_bounds: end not pinned");
|
||||
|
||||
if (NULL == (en = (hsize_t *) HDmalloc((size_t)rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sget_select_bounds: failed to allocate end buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sget_select_bounds: failed to allocate end buffer");
|
||||
|
||||
if ((status = H5Sget_select_bounds((hid_t) spaceid, (hsize_t *) strt, (hsize_t *) en)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1148,7 +1148,7 @@ Java_hdf_hdf5lib_H5_H5Sencode
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Sencode: buf_size = 0");
|
||||
|
||||
if (NULL == (bufPtr = (unsigned char *) HDcalloc((size_t) 1, buf_size)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sencode: failed to allocate encoding buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sencode: failed to allocate encoding buffer");
|
||||
|
||||
if ((status = H5Sencode2((hid_t) obj_id, bufPtr, &buf_size, H5P_DEFAULT)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1258,7 +1258,7 @@ Java_hdf_hdf5lib_H5_H5Sget_1regular_1hyperslab
|
||||
PIN_LONG_ARRAY(ENVONLY, start, startP, &isCopy, "H5Sget_regular_hyperslab: start not pinned");
|
||||
|
||||
if (NULL == (strt = (hsize_t *) HDmalloc((size_t)start_rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sget_regular_hyperslab: failed to allocate start buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sget_regular_hyperslab: failed to allocate start buffer");
|
||||
}
|
||||
|
||||
if (NULL == stride) {
|
||||
@ -1277,7 +1277,7 @@ Java_hdf_hdf5lib_H5_H5Sget_1regular_1hyperslab
|
||||
PIN_LONG_ARRAY(ENVONLY, stride, strideP, &isCopy, "H5Sget_regular_hyperslab: stride not pinned");
|
||||
|
||||
if (NULL == (strd = (hsize_t *) HDmalloc((size_t)stride_rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sget_regular_hyperslab: failed to allocate stride buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sget_regular_hyperslab: failed to allocate stride buffer");
|
||||
}
|
||||
|
||||
if (NULL == count) {
|
||||
@ -1296,7 +1296,7 @@ Java_hdf_hdf5lib_H5_H5Sget_1regular_1hyperslab
|
||||
PIN_LONG_ARRAY(ENVONLY, count, countP, &isCopy, "H5Sget_regular_hyperslab: count not pinned");
|
||||
|
||||
if (NULL == (cnt = (hsize_t *) HDmalloc((size_t)count_rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sget_regular_hyperslab: failed to allocate count buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sget_regular_hyperslab: failed to allocate count buffer");
|
||||
}
|
||||
|
||||
if (NULL == block) {
|
||||
@ -1315,7 +1315,7 @@ Java_hdf_hdf5lib_H5_H5Sget_1regular_1hyperslab
|
||||
PIN_LONG_ARRAY(ENVONLY, block, blockP, &isCopy, "H5Sget_regular_hyperslab: block not pinned");
|
||||
|
||||
if (NULL == (blk = (hsize_t *) HDmalloc((size_t)block_rank * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Sget_regular_hyperslab: failed to allocate block buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Sget_regular_hyperslab: failed to allocate block buffer");
|
||||
}
|
||||
|
||||
if ((status = H5Sget_regular_hyperslab(space_id, (hsize_t *) strt, (hsize_t *) strd, (hsize_t *) cnt, (hsize_t *) blk)) < 0)
|
||||
|
@ -1239,7 +1239,7 @@ Java_hdf_hdf5lib_H5_H5Tenum_1nameof_1int
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Tenum_nameof_int: name size < 0");
|
||||
|
||||
if (NULL == (nameP = (char *) HDmalloc(sizeof(char) * (size_t)size)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Tenum_nameof_int: failed to allocate name buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Tenum_nameof_int: failed to allocate name buffer");
|
||||
|
||||
PIN_INT_ARRAY(ENVONLY, value, intP, &isCopy, "H5Tenum_nameof_int: value not pinned");
|
||||
|
||||
@ -1285,7 +1285,7 @@ Java_hdf_hdf5lib_H5_H5Tenum_1nameof
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Tenum_nameof: value is NULL");
|
||||
|
||||
if (NULL == (nameP = (char *) HDmalloc(sizeof(char) * (size_t)size)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Tenum_nameof: failed to allocate name buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Tenum_nameof: failed to allocate name buffer");
|
||||
|
||||
PIN_BYTE_ARRAY(ENVONLY, value, byteP, &isCopy, "H5Tenum_nameof: value not pinned");
|
||||
|
||||
@ -1485,7 +1485,7 @@ Java_hdf_hdf5lib_H5_H5Tget_1array_1dims
|
||||
}
|
||||
|
||||
if (NULL == (cdims = (hsize_t *) HDmalloc((size_t)dlen * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Tget_array_dims: failed to allocate dimension buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Tget_array_dims: failed to allocate dimension buffer");
|
||||
|
||||
if ((ndims = H5Tget_array_dims2((hid_t)type_id, cdims)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1626,10 +1626,10 @@ Java_hdf_hdf5lib_H5__1H5Tarray_1create2
|
||||
}
|
||||
|
||||
if (dlen != rank)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Tarray_create: dimension array length != array rank");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "H5Tarray_create: dimension array length != array rank");
|
||||
|
||||
if (NULL == (cdims = (hsize_t *) HDmalloc((size_t)dlen * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Tarray_create: failed to allocate dimension buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Tarray_create: failed to allocate dimension buffer");
|
||||
|
||||
for (i = 0; i < (size_t) dlen; i++) {
|
||||
cdims[i] = (hsize_t)dimsP[i];
|
||||
@ -1676,7 +1676,7 @@ Java_hdf_hdf5lib_H5_H5Tget_1array_1dims2
|
||||
}
|
||||
|
||||
if (NULL == (cdims = (hsize_t *) HDmalloc((size_t)dlen * sizeof(hsize_t))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Tarray_get_dims2: failed to allocate dimension buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Tarray_get_dims2: failed to allocate dimension buffer");
|
||||
|
||||
if ((ndims = H5Tget_array_dims2((hid_t)type_id, (hsize_t*)cdims)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
@ -515,7 +515,7 @@ h5str_convert
|
||||
total_elmts *= dims[i];
|
||||
|
||||
if (NULL == (cptr = (char *) HDcalloc((size_t)total_elmts, baseTypeSize)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_convert: failed to allocate array buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_convert: failed to allocate array buffer");
|
||||
|
||||
for (i = 0; i < total_elmts; i++) {
|
||||
if (!(h5str_convert(ENVONLY, &this_str, container, mtid, out_buf, i * baseTypeSize))) {
|
||||
@ -556,7 +556,7 @@ h5str_convert
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (vl_buf->p = HDmalloc(baseTypeSize)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_convert: failed to allocate vlen buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_convert: failed to allocate vlen buffer");
|
||||
vl_buf->len = 1;
|
||||
|
||||
/* Skip whitespace and vlen indicators */
|
||||
@ -570,7 +570,7 @@ h5str_convert
|
||||
char *tmp_realloc;
|
||||
|
||||
if (NULL == (tmp_realloc = (char *) HDrealloc(vl_buf->p, vl_buf->len * 2 * baseTypeSize)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_convert: failed to reallocate vlen buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_convert: failed to reallocate vlen buffer");
|
||||
vl_buf->len *= 2;
|
||||
vl_buf->p = tmp_realloc;
|
||||
}
|
||||
@ -733,9 +733,9 @@ h5str_sprintf
|
||||
/* Build default formats for long long types */
|
||||
if (!fmt_llong[0]) {
|
||||
if (HDsnprintf(fmt_llong, sizeof(fmt_llong), "%%%sd", H5_PRINTF_LL_WIDTH) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: sprintf failure");
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsnprintf failure");
|
||||
if (HDsnprintf(fmt_ullong, sizeof(fmt_ullong), "%%%su", H5_PRINTF_LL_WIDTH) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: sprintf failure");
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsnprintf failure");
|
||||
} /* end if */
|
||||
|
||||
switch (tclass) {
|
||||
@ -749,7 +749,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_float, cptr, sizeof(float));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(25)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, "%g", tmp_float) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -764,7 +764,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_double, cptr, sizeof(double));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(25)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, "%g", tmp_double) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -779,7 +779,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_ldouble, cptr, sizeof(long double));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(27)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, "%Lf", tmp_ldouble) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -819,13 +819,13 @@ h5str_sprintf
|
||||
/* Check for NULL pointer for string */
|
||||
if (!tmp_str) {
|
||||
if (NULL == (this_str = (char *) HDmalloc(5)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
HDstrncpy(this_str, "NULL", 5);
|
||||
}
|
||||
else {
|
||||
if (typeSize > 0) {
|
||||
if (NULL == (this_str = (char *) HDmalloc(typeSize + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
HDstrncpy(this_str, tmp_str, typeSize);
|
||||
this_str[typeSize] = '\0';
|
||||
@ -851,7 +851,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_uchar, cptr, sizeof(unsigned char));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(7)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, "%hhu", tmp_uchar) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -860,7 +860,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_char, cptr, sizeof(char));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(7)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, "%hhd", tmp_char) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -878,7 +878,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_ushort, cptr, sizeof(unsigned short));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(9)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, "%hu", tmp_ushort) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -887,7 +887,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_short, cptr, sizeof(short));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(9)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, "%hd", tmp_short) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -905,7 +905,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_uint, cptr, sizeof(unsigned int));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(14)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, "%u", tmp_uint) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -914,7 +914,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_int, cptr, sizeof(int));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(14)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, "%d", tmp_int) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -932,7 +932,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_ulong, cptr, sizeof(unsigned long));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(23)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, "%lu", tmp_ulong) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -941,7 +941,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_long, cptr, sizeof(long));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(23)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, "%ld", tmp_long) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -960,7 +960,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_ullong, cptr, sizeof(unsigned long long));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(25)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, fmt_ullong, tmp_ullong) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -969,7 +969,7 @@ h5str_sprintf
|
||||
HDmemcpy(&tmp_llong, cptr, sizeof(long long));
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(25)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (HDsprintf(this_str, fmt_llong, tmp_llong) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
@ -1034,7 +1034,7 @@ h5str_sprintf
|
||||
size_t i;
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(4 * (typeSize + 1))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (1 == typeSize) {
|
||||
if (HDsprintf(this_str, "%#02x", ucptr[0]) < 0)
|
||||
@ -1069,10 +1069,10 @@ h5str_sprintf
|
||||
case H5R_OBJECT1:
|
||||
{
|
||||
/* Object references -- show the type and OID of the referenced object. */
|
||||
H5O_info_t oi;
|
||||
H5O_info2_t oi;
|
||||
|
||||
if((obj = H5Ropen_object(ref_vp, H5P_DEFAULT, H5P_DEFAULT)) >= 0) {
|
||||
H5Oget_info2(obj, &oi, H5O_INFO_BASIC);
|
||||
H5Oget_info3(obj, &oi, H5O_INFO_BASIC);
|
||||
if(H5Oclose(obj) < 0)
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
}
|
||||
@ -1080,7 +1080,7 @@ h5str_sprintf
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(14)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
if (HDsprintf(this_str, "%u-", (unsigned) oi.type) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
if (!h5str_append(out_str, this_str))
|
||||
@ -1114,10 +1114,19 @@ h5str_sprintf
|
||||
h5str_sprint_reference(ENVONLY, out_str, container, ref_vp);
|
||||
|
||||
/* Print OID */
|
||||
if (NULL == (this_str = (char *) HDmalloc(64)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
if (HDsprintf(this_str, "%lu:"H5_PRINTF_HADDR_FMT" ", oi.fileno, oi.addr) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
{
|
||||
char *token_str;
|
||||
|
||||
H5Otoken_to_str(tid, &oi.token, &token_str);
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(64 + strlen(token_str) + 1)))
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
if (HDsprintf(this_str, "%lu:%s", oi.fileno, token_str) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: HDsprintf failure");
|
||||
|
||||
H5free_memory(token_str);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
break;
|
||||
@ -1273,7 +1282,7 @@ h5str_sprintf
|
||||
/* All other types get printed as hexadecimal */
|
||||
|
||||
if (NULL == (this_str = (char *) HDmalloc(4 * (typeSize + 1))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_sprintf: failed to allocate string buffer");
|
||||
|
||||
if (1 == typeSize) {
|
||||
if (HDsprintf(this_str, "%#02x", ucptr[0]) < 0)
|
||||
@ -1346,7 +1355,7 @@ h5str_print_region_data_blocks
|
||||
|
||||
/* Allocate space for the dimension array */
|
||||
if (NULL == (dims1 = (hsize_t *) HDmalloc(sizeof(hsize_t) * (size_t)ndims)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_print_region_data_blocks: failed to allocate dimension array buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_print_region_data_blocks: failed to allocate dimension array buffer");
|
||||
|
||||
/* Find the dimensions of each data space from the block coordinates */
|
||||
for (jndx = 0, numelem = 1; jndx < (size_t) ndims; jndx++) {
|
||||
@ -1362,15 +1371,15 @@ h5str_print_region_data_blocks
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (region_buf = HDmalloc(type_size * (size_t)numelem)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_print_region_data_blocks: failed to allocate region buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_print_region_data_blocks: failed to allocate region buffer");
|
||||
|
||||
/* Select (x , x , ..., x ) x (y , y , ..., y ) hyperslab for reading memory dataset */
|
||||
/* 1 2 n 1 2 n */
|
||||
if (NULL == (start = (hsize_t *) HDmalloc(sizeof(hsize_t) * (size_t)ndims)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_print_region_data_blocks: failed to allocate hyperslab start buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_print_region_data_blocks: failed to allocate hyperslab start buffer");
|
||||
|
||||
if (NULL == (count = (hsize_t *) HDmalloc(sizeof(hsize_t) * (size_t)ndims)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_print_region_data_blocks: failed to allocate hyperslab count buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_print_region_data_blocks: failed to allocate hyperslab count buffer");
|
||||
|
||||
for (blkndx = 0; blkndx < (hsize_t) nblocks; blkndx++) {
|
||||
for (indx = 0; indx < (unsigned) ndims; indx++) {
|
||||
@ -1445,7 +1454,7 @@ h5str_dump_region_blocks_data
|
||||
alloc_size = (hsize_t)nblocks * (hsize_t)ndims * 2 * (hsize_t)sizeof(ptdata[0]);
|
||||
if (alloc_size == (hsize_t)((size_t) alloc_size)) {
|
||||
if (NULL == (ptdata = (hsize_t *) HDmalloc((size_t) alloc_size)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_dump_region_blocks_data: failed to allocate region block buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_dump_region_blocks_data: failed to allocate region block buffer");
|
||||
|
||||
if (H5Sget_select_hyper_blocklist(region, (hsize_t) 0, (hsize_t) nblocks, ptdata) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1505,7 +1514,7 @@ h5str_dump_region_blocks
|
||||
int i;
|
||||
|
||||
if (NULL == (ptdata = (hsize_t *) HDmalloc((size_t) alloc_size)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_dump_region_blocks: failed to allocate region block buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_dump_region_blocks: failed to allocate region block buffer");
|
||||
|
||||
if (H5Sget_select_hyper_blocklist(region, (hsize_t) 0, (hsize_t) nblocks, ptdata) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1590,7 +1599,7 @@ h5str_print_region_data_points
|
||||
|
||||
/* Allocate space for the dimension array */
|
||||
if (NULL == (dims1 = (hsize_t *) HDmalloc(sizeof(hsize_t) * (size_t)ndims)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_print_region_data_points: failed to allocate dimension array buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_print_region_data_points: failed to allocate dimension array buffer");
|
||||
|
||||
dims1[0] = (hsize_t)npoints;
|
||||
|
||||
@ -1602,7 +1611,7 @@ h5str_print_region_data_points
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
if (NULL == (region_buf = HDmalloc(type_size * (size_t)npoints)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_print_region_data_points: failed to allocate region buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_print_region_data_points: failed to allocate region buffer");
|
||||
|
||||
if (H5Dread(region_id, type_id, mem_space, region_space, H5P_DEFAULT, region_buf) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1662,7 +1671,7 @@ h5str_dump_region_points_data
|
||||
alloc_size = (hsize_t)npoints * (hsize_t)ndims * (hsize_t)sizeof(ptdata[0]);
|
||||
if (alloc_size == (hsize_t)((size_t) alloc_size)) {
|
||||
if (NULL == (ptdata = (hsize_t *) HDmalloc((size_t) alloc_size)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_dump_region_points_data: failed to allocate region point data buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_dump_region_points_data: failed to allocate region point data buffer");
|
||||
|
||||
if (H5Sget_select_elem_pointlist(region, (hsize_t) 0, (hsize_t) npoints, ptdata) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -1725,7 +1734,7 @@ h5str_dump_region_points
|
||||
alloc_size = (hsize_t)npoints * (hsize_t)ndims * (hsize_t)sizeof(ptdata[0]);
|
||||
if (alloc_size == (hsize_t)((size_t) alloc_size)) {
|
||||
if (NULL == (ptdata = (hsize_t *) HDmalloc((size_t) alloc_size)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_dump_region_points: failed to allocate region point buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_dump_region_points: failed to allocate region point buffer");
|
||||
|
||||
if (H5Sget_select_elem_pointlist(region, (hsize_t) 0, (hsize_t) npoints, ptdata) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -2833,7 +2842,7 @@ h5str_dump_simple_dset
|
||||
|
||||
if (sm_nbytes > 0) {
|
||||
if (NULL == (sm_buf = (unsigned char *) HDmalloc((size_t)sm_nbytes)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5str_dump_simple_dset: failed to allocate sm_buf");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5str_dump_simple_dset: failed to allocate sm_buf");
|
||||
|
||||
sm_nelmts = sm_nbytes / p_type_nbytes;
|
||||
|
||||
@ -2964,7 +2973,7 @@ h5tools_dump_simple_data
|
||||
h5str_new(&buffer, 32 * size);
|
||||
|
||||
if (!buffer.s)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "h5tools_dump_simple_data: failed to allocate buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "h5tools_dump_simple_data: failed to allocate buffer");
|
||||
|
||||
if (!(bytes_in = h5str_sprintf(ENVONLY, &buffer, container, type, memref, 0, 1)))
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
@ -3035,7 +3044,7 @@ Java_hdf_hdf5lib_H5_H5AreadComplex
|
||||
}
|
||||
|
||||
if (NULL == (readBuf = (char *) HDmalloc((size_t)n * size)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5AreadComplex: failed to allocate read buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5AreadComplex: failed to allocate read buffer");
|
||||
|
||||
if ((status = H5Aread(attr_id, mem_type_id, readBuf)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -3043,7 +3052,7 @@ Java_hdf_hdf5lib_H5_H5AreadComplex
|
||||
h5str_new(&h5str, 4 * size);
|
||||
|
||||
if (!h5str.s)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5AreadComplex: failed to allocate string buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5AreadComplex: failed to allocate string buffer");
|
||||
|
||||
for (i = 0; i < (size_t) n; i++) {
|
||||
h5str.s[0] = '\0';
|
||||
@ -3104,7 +3113,7 @@ Java_hdf_hdf5lib_H5_H5Acopy
|
||||
total_size = (hsize_t)npoints * (hsize_t)type_size;
|
||||
|
||||
if (NULL == (buf = (jbyte *) HDmalloc((size_t)total_size * sizeof(jbyte))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Acopy: failed to allocate buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Acopy: failed to allocate buffer");
|
||||
|
||||
if ((retVal = H5Aread((hid_t)src_id, tid, buf)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -3151,7 +3160,7 @@ Java_hdf_hdf5lib_H5_H5Dcopy
|
||||
UNUSED(clss);
|
||||
|
||||
if (!(total_allocated_size = H5Dget_storage_size((hid_t)src_id)))
|
||||
return 0; // nothing to write
|
||||
return 0; /* nothing to write */
|
||||
|
||||
if ((sid = H5Dget_space((hid_t)src_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -3166,7 +3175,7 @@ Java_hdf_hdf5lib_H5_H5Dcopy
|
||||
total_size = (hsize_t)npoints * (hsize_t)type_size;
|
||||
|
||||
if (NULL == (buf = (jbyte *) HDmalloc((size_t)total_size * sizeof(jbyte))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Dcopy: failed to allocate buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Dcopy: failed to allocate buffer");
|
||||
|
||||
if ((retVal = H5Dread((hid_t)src_id, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
@ -3204,15 +3213,15 @@ done:
|
||||
*/
|
||||
|
||||
#ifdef __cplusplus
|
||||
herr_t obj_info_all(hid_t g_id, const char *name, const H5L_info_t *linfo, void *op_data);
|
||||
herr_t obj_info_max(hid_t g_id, const char *name, const H5L_info_t *linfo, void *op_data);
|
||||
int H5Gget_obj_info_max(hid_t, char **, int *, int *, unsigned long *, long);
|
||||
int H5Gget_obj_info_full( hid_t loc_id, char **objname, int *otype, int *ltype, unsigned long *fno, unsigned long *objno, int indexType, int indexOrder);
|
||||
herr_t obj_info_all(hid_t g_id, const char *name, const H5L_info2_t *linfo, void *op_data);
|
||||
herr_t obj_info_max(hid_t g_id, const char *name, const H5L_info2_t *linfo, void *op_data);
|
||||
int H5Gget_obj_info_max(hid_t, char **, int *, int *, H5O_token_t *, long);
|
||||
int H5Gget_obj_info_full( hid_t loc_id, char **objname, int *otype, int *ltype, unsigned long *fno, H5O_token_t *obj_token, int indexType, int indexOrder);
|
||||
#else
|
||||
static herr_t obj_info_all(hid_t g_id, const char *name, const H5L_info_t *linfo, void *op_data);
|
||||
static herr_t obj_info_max(hid_t g_id, const char *name, const H5L_info_t *linfo, void *op_data);
|
||||
static int H5Gget_obj_info_max(hid_t, char **, int *, int *, unsigned long *, long);
|
||||
static int H5Gget_obj_info_full( hid_t loc_id, char **objname, int *otype, int *ltype, unsigned long *fno, unsigned long *objno, int indexType, int indexOrder);
|
||||
static herr_t obj_info_all(hid_t g_id, const char *name, const H5L_info2_t *linfo, void *op_data);
|
||||
static herr_t obj_info_max(hid_t g_id, const char *name, const H5L_info2_t *linfo, void *op_data);
|
||||
static int H5Gget_obj_info_max(hid_t, char **, int *, int *, H5O_token_t *, long);
|
||||
static int H5Gget_obj_info_full( hid_t loc_id, char **objname, int *otype, int *ltype, unsigned long *fno, H5O_token_t *obj_token, int indexType, int indexOrder);
|
||||
#endif
|
||||
|
||||
typedef struct info_all
|
||||
@ -3220,7 +3229,7 @@ typedef struct info_all
|
||||
char **objname;
|
||||
int *otype;
|
||||
int *ltype;
|
||||
unsigned long *objno;
|
||||
H5O_token_t *obj_token;
|
||||
unsigned long *fno;
|
||||
unsigned long idxnum;
|
||||
int count;
|
||||
@ -3241,17 +3250,17 @@ JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Gget_1obj_1info_1full
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jstring group_name,
|
||||
jobjectArray objName, jintArray oType, jintArray lType, jlongArray fNo,
|
||||
jlongArray oRef, jint n, jint indx_type, jint indx_order)
|
||||
jobjectArray oToken, jint n, jint indx_type, jint indx_order)
|
||||
{
|
||||
unsigned long *refs = NULL;
|
||||
unsigned long *fnos = NULL;
|
||||
H5O_token_t *tokens = NULL;
|
||||
const char *gName = NULL;
|
||||
char **oName = NULL;
|
||||
jboolean isCopy;
|
||||
jstring str;
|
||||
jobject token;
|
||||
jint *otarr = NULL;
|
||||
jint *ltarr = NULL;
|
||||
jlong *refP = NULL;
|
||||
jlong *fnoP = NULL;
|
||||
hid_t gid = (hid_t)loc_id;
|
||||
int i;
|
||||
@ -3265,24 +3274,23 @@ Java_hdf_hdf5lib_H5_H5Gget_1obj_1info_1full
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Gget_obj_info_full: oType is NULL");
|
||||
if (NULL == lType)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Gget_obj_info_full: lType is NULL");
|
||||
if (NULL == oRef)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Gget_obj_info_full: oRef is NULL");
|
||||
if (NULL == oToken)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Gget_obj_info_full: oToken is NULL");
|
||||
if (NULL == fNo)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Gget_obj_info_full: fNo is NULL");
|
||||
|
||||
PIN_INT_ARRAY(ENVONLY, oType, otarr, &isCopy, "H5Gget_obj_info_full: oType not pinned");
|
||||
PIN_INT_ARRAY(ENVONLY, lType, ltarr, &isCopy, "H5Gget_obj_info_full: lType not pinned");
|
||||
PIN_LONG_ARRAY(ENVONLY, oRef, refP, &isCopy, "H5Gget_obj_info_full: oRef not pinned");
|
||||
PIN_LONG_ARRAY(ENVONLY, fNo, fnoP, &isCopy, "H5Gget_obj_info_full: fNo not pinned");
|
||||
|
||||
if (NULL == (oName = (char **) HDcalloc((size_t)n, sizeof(*oName))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Gget_obj_info_full: failed to allocate buffer for object name");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Gget_obj_info_full: failed to allocate buffer for object name");
|
||||
|
||||
if (NULL == (refs = (unsigned long *) HDcalloc((size_t)n, sizeof(unsigned long))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Gget_obj_info_full: failed to allocate buffer for ref. info");
|
||||
if (NULL == (tokens = (H5O_token_t *) HDcalloc((size_t)n, sizeof(H5O_token_t))))
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Gget_obj_info_full: failed to allocate buffer for object tokens");
|
||||
|
||||
if (NULL == (fnos = (unsigned long *) HDcalloc((size_t)n, sizeof(unsigned long))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Gget_obj_info_full: failed to allocate buffer for file number info");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Gget_obj_info_full: failed to allocate buffer for file number info");
|
||||
|
||||
if (group_name) {
|
||||
PIN_JAVA_STRING(ENVONLY, group_name, gName, &isCopy, "H5Gget_obj_info_full: group_name not pinned");
|
||||
@ -3291,11 +3299,10 @@ Java_hdf_hdf5lib_H5_H5Gget_1obj_1info_1full
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
}
|
||||
|
||||
if ((ret_val = H5Gget_obj_info_full(gid, oName, (int *)otarr, (int *)ltarr, fnos, refs, indexType, indexOrder)) < 0)
|
||||
if ((ret_val = H5Gget_obj_info_full(gid, oName, (int *)otarr, (int *)ltarr, fnos, tokens, indexType, indexOrder)) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Gget_obj_info_full: retrieval of object info failed");
|
||||
|
||||
for (i = 0; i < n; i++) {
|
||||
refP[i] = (jlong)refs[i];
|
||||
fnoP[i] = (jlong)fnos[i];
|
||||
|
||||
if (oName[i]) {
|
||||
@ -3307,6 +3314,15 @@ Java_hdf_hdf5lib_H5_H5Gget_1obj_1info_1full
|
||||
|
||||
ENVPTR->DeleteLocalRef(ENVONLY, str);
|
||||
} /* end if */
|
||||
|
||||
/* Create an H5O_token_t object */
|
||||
if (NULL == (token = create_H5O_token_t(ENVONLY, &tokens[i], TRUE)))
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, oToken, i, token);
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
ENVPTR->DeleteLocalRef(ENVONLY, token);
|
||||
}
|
||||
|
||||
done:
|
||||
@ -3316,14 +3332,12 @@ done:
|
||||
}
|
||||
if (fnos)
|
||||
HDfree(fnos);
|
||||
if (refs)
|
||||
HDfree(refs);
|
||||
if (tokens)
|
||||
HDfree(tokens);
|
||||
if (oName)
|
||||
h5str_array_free(oName, (size_t)n);
|
||||
if (fnoP)
|
||||
UNPIN_LONG_ARRAY(ENVONLY, fNo, fnoP, (ret_val < 0) ? JNI_ABORT : 0);
|
||||
if (refP)
|
||||
UNPIN_LONG_ARRAY(ENVONLY, oRef, refP, (ret_val < 0) ? JNI_ABORT : 0);
|
||||
if (ltarr)
|
||||
UNPIN_INT_ARRAY(ENVONLY, lType, ltarr, (ret_val < 0) ? JNI_ABORT : 0);
|
||||
if (otarr)
|
||||
@ -3345,17 +3359,17 @@ done:
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Gget_1obj_1info_1max
|
||||
(JNIEnv *env, jclass clss, jlong loc_id, jobjectArray objName,
|
||||
jintArray oType, jintArray lType, jlongArray oRef, jlong maxnum, jint n)
|
||||
jintArray oType, jintArray lType, jobjectArray oToken, jlong maxnum, jint n)
|
||||
{
|
||||
unsigned long *refs = NULL;
|
||||
jboolean isCopy;
|
||||
jstring str;
|
||||
jlong *refP = NULL;
|
||||
char **oName = NULL;
|
||||
jint *otarr = NULL;
|
||||
jint *ltarr = NULL;
|
||||
int i;
|
||||
herr_t ret_val = FAIL;
|
||||
H5O_token_t *tokens = NULL;
|
||||
jboolean isCopy;
|
||||
jstring str;
|
||||
jobject token;
|
||||
char **oName = NULL;
|
||||
jint *otarr = NULL;
|
||||
jint *ltarr = NULL;
|
||||
int i;
|
||||
herr_t ret_val = FAIL;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
@ -3363,25 +3377,22 @@ Java_hdf_hdf5lib_H5_H5Gget_1obj_1info_1max
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Gget_obj_info_max: oType is NULL");
|
||||
if (NULL == lType)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Gget_obj_info_max: lType is NULL");
|
||||
if (NULL == oRef)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Gget_obj_info_max: oRef is NULL");
|
||||
if (NULL == oToken)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5Gget_obj_info_max: oToken is NULL");
|
||||
|
||||
PIN_INT_ARRAY(ENVONLY, oType, otarr, &isCopy, "H5Gget_obj_info_max: oType not pinned");
|
||||
PIN_INT_ARRAY(ENVONLY, lType, ltarr, &isCopy, "H5Gget_obj_info_max: lType not pinned");
|
||||
PIN_LONG_ARRAY(ENVONLY, oRef, refP, &isCopy, "H5Gget_obj_info_max: oRef not pinned");
|
||||
|
||||
if (NULL == (oName = (char **) HDcalloc((size_t)n, sizeof(*oName))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Gget_obj_info_max: failed to allocate buffer for object name");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Gget_obj_info_max: failed to allocate buffer for object name");
|
||||
|
||||
if (NULL == (refs = (unsigned long *) HDcalloc((size_t)n, sizeof(unsigned long))))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Gget_obj_info_max: failed to allocate buffer for ref. info");
|
||||
if (NULL == (tokens = (H5O_token_t *) HDcalloc((size_t)n, sizeof(H5O_token_t))))
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5Gget_obj_info_max: failed to allocate buffer for object tokens");
|
||||
|
||||
if ((ret_val = H5Gget_obj_info_max((hid_t)loc_id, oName, (int *)otarr, (int *)ltarr, refs, maxnum)) < 0)
|
||||
if ((ret_val = H5Gget_obj_info_max((hid_t)loc_id, oName, (int *)otarr, (int *)ltarr, tokens, maxnum)) < 0)
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5Gget_obj_info_max: retrieval of object info failed");
|
||||
|
||||
for (i = 0; i < n; i++) {
|
||||
refP[i] = (jlong) refs[i];
|
||||
|
||||
if (oName[i]) {
|
||||
if (NULL == (str = ENVPTR->NewStringUTF(ENVONLY, oName[i])))
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
@ -3391,15 +3402,22 @@ Java_hdf_hdf5lib_H5_H5Gget_1obj_1info_1max
|
||||
|
||||
ENVPTR->DeleteLocalRef(ENVONLY, str);
|
||||
}
|
||||
|
||||
/* Create an H5O_token_t object */
|
||||
if (NULL == (token = create_H5O_token_t(ENVONLY, &tokens[i], TRUE)))
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
ENVPTR->SetObjectArrayElement(ENVONLY, oToken, i, token);
|
||||
CHECK_JNI_EXCEPTION(ENVONLY, JNI_FALSE);
|
||||
|
||||
ENVPTR->DeleteLocalRef(ENVONLY, token);
|
||||
} /* end for */
|
||||
|
||||
done:
|
||||
if (refs)
|
||||
HDfree(refs);
|
||||
if (tokens)
|
||||
HDfree(tokens);
|
||||
if (oName)
|
||||
h5str_array_free(oName, (size_t)n);
|
||||
if (refP)
|
||||
UNPIN_LONG_ARRAY(ENVONLY, oRef, refP, (ret_val < 0) ? JNI_ABORT : 0);
|
||||
if (ltarr)
|
||||
UNPIN_INT_ARRAY(ENVONLY, lType, ltarr, (ret_val < 0) ? JNI_ABORT : 0);
|
||||
if (otarr)
|
||||
@ -3410,7 +3428,7 @@ done:
|
||||
|
||||
int
|
||||
H5Gget_obj_info_full
|
||||
(hid_t loc_id, char **objname, int *otype, int *ltype, unsigned long *fno, unsigned long *objno, int indexType, int indexOrder)
|
||||
(hid_t loc_id, char **objname, int *otype, int *ltype, unsigned long *fno, H5O_token_t *obj_token, int indexType, int indexOrder)
|
||||
{
|
||||
info_all_t info;
|
||||
|
||||
@ -3419,10 +3437,10 @@ H5Gget_obj_info_full
|
||||
info.ltype = ltype;
|
||||
info.idxnum = 0;
|
||||
info.fno = fno;
|
||||
info.objno = objno;
|
||||
info.obj_token = obj_token;
|
||||
info.count = 0;
|
||||
|
||||
if (H5Literate(loc_id, (H5_index_t)indexType, (H5_iter_order_t)indexOrder, NULL, obj_info_all, (void *)&info) < 0) {
|
||||
if (H5Literate2(loc_id, (H5_index_t)indexType, (H5_iter_order_t)indexOrder, NULL, obj_info_all, (void *)&info) < 0) {
|
||||
/*
|
||||
* Reset info stats; most importantly, reset the count.
|
||||
*/
|
||||
@ -3431,11 +3449,11 @@ H5Gget_obj_info_full
|
||||
info.ltype = ltype;
|
||||
info.idxnum = 0;
|
||||
info.fno = fno;
|
||||
info.objno = objno;
|
||||
info.obj_token = obj_token;
|
||||
info.count = 0;
|
||||
|
||||
/* Iteration failed, try normal alphabetical order */
|
||||
if (H5Literate(loc_id, H5_INDEX_NAME, H5_ITER_INC, NULL, obj_info_all, (void *)&info) < 0)
|
||||
if (H5Literate2(loc_id, H5_INDEX_NAME, H5_ITER_INC, NULL, obj_info_all, (void *)&info) < 0)
|
||||
return -1;
|
||||
}
|
||||
|
||||
@ -3444,7 +3462,7 @@ H5Gget_obj_info_full
|
||||
|
||||
int
|
||||
H5Gget_obj_info_max
|
||||
(hid_t loc_id, char **objname, int *otype, int *ltype, unsigned long *objno, long maxnum)
|
||||
(hid_t loc_id, char **objname, int *otype, int *ltype, H5O_token_t *obj_token, long maxnum)
|
||||
{
|
||||
info_all_t info;
|
||||
|
||||
@ -3452,10 +3470,10 @@ H5Gget_obj_info_max
|
||||
info.otype = otype;
|
||||
info.ltype = ltype;
|
||||
info.idxnum = (unsigned long)maxnum;
|
||||
info.objno = objno;
|
||||
info.obj_token = obj_token;
|
||||
info.count = 0;
|
||||
|
||||
if (H5Lvisit(loc_id, H5_INDEX_NAME, H5_ITER_NATIVE, obj_info_max, (void *)&info) < 0)
|
||||
if (H5Lvisit2(loc_id, H5_INDEX_NAME, H5_ITER_NATIVE, obj_info_max, (void *)&info) < 0)
|
||||
return -1;
|
||||
|
||||
return info.count;
|
||||
@ -3463,16 +3481,16 @@ H5Gget_obj_info_max
|
||||
|
||||
herr_t
|
||||
obj_info_all
|
||||
(hid_t loc_id, const char *name, const H5L_info_t *info, void *op_data)
|
||||
(hid_t loc_id, const char *name, const H5L_info2_t *info, void *op_data)
|
||||
{
|
||||
info_all_t *datainfo = (info_all_t *)op_data;
|
||||
H5O_info_t object_info;
|
||||
htri_t object_exists;
|
||||
size_t str_len;
|
||||
info_all_t *datainfo = (info_all_t *)op_data;
|
||||
H5O_info2_t object_info;
|
||||
htri_t object_exists;
|
||||
size_t str_len;
|
||||
|
||||
datainfo->otype[datainfo->count] = -1;
|
||||
datainfo->ltype[datainfo->count] = -1;
|
||||
datainfo->objno[datainfo->count] = (unsigned long)-1;
|
||||
datainfo->obj_token[datainfo->count] = H5O_TOKEN_UNDEF;
|
||||
|
||||
str_len = HDstrlen(name);
|
||||
if (NULL == (datainfo->objname[datainfo->count] = (char *) HDmalloc(str_len + 1)))
|
||||
@ -3485,21 +3503,15 @@ obj_info_all
|
||||
goto done;
|
||||
|
||||
if (object_exists) {
|
||||
if (H5Oget_info_by_name2(loc_id, name, &object_info, H5O_INFO_ALL, H5P_DEFAULT) < 0)
|
||||
if (H5Oget_info_by_name3(loc_id, name, &object_info, H5O_INFO_ALL, H5P_DEFAULT) < 0)
|
||||
goto done;
|
||||
|
||||
datainfo->otype[datainfo->count] = object_info.type;
|
||||
datainfo->ltype[datainfo->count] = info->type;
|
||||
datainfo->fno[datainfo->count] = object_info.fileno;
|
||||
datainfo->objno[datainfo->count] = (unsigned long)object_info.addr;
|
||||
}
|
||||
|
||||
/*
|
||||
if (info->type == H5L_TYPE_HARD)
|
||||
datainfo->objno[datainfo->count] = (unsigned long)info->u.address;
|
||||
else
|
||||
datainfo->objno[datainfo->count] = info->u.val_size;
|
||||
*/
|
||||
HDmemcpy(&datainfo->obj_token[datainfo->count], &object_info.token, sizeof(object_info.token));
|
||||
}
|
||||
|
||||
done:
|
||||
datainfo->count++;
|
||||
@ -3509,16 +3521,16 @@ done:
|
||||
|
||||
herr_t
|
||||
obj_info_max
|
||||
(hid_t loc_id, const char *name, const H5L_info_t *info, void *op_data)
|
||||
(hid_t loc_id, const char *name, const H5L_info2_t *info, void *op_data)
|
||||
{
|
||||
info_all_t *datainfo = (info_all_t *)op_data;
|
||||
H5O_info_t object_info;
|
||||
size_t str_len;
|
||||
info_all_t *datainfo = (info_all_t *)op_data;
|
||||
H5O_info2_t object_info;
|
||||
size_t str_len;
|
||||
|
||||
datainfo->otype[datainfo->count] = -1;
|
||||
datainfo->ltype[datainfo->count] = -1;
|
||||
datainfo->objname[datainfo->count] = NULL;
|
||||
datainfo->objno[datainfo->count] = (unsigned long)-1;
|
||||
datainfo->obj_token[datainfo->count] = H5O_TOKEN_UNDEF;
|
||||
|
||||
/* This will be freed by h5str_array_free(oName, n) */
|
||||
str_len = HDstrlen(name);
|
||||
@ -3528,16 +3540,13 @@ obj_info_max
|
||||
HDstrncpy(datainfo->objname[datainfo->count], name, str_len);
|
||||
(datainfo->objname[datainfo->count])[str_len] = '\0';
|
||||
|
||||
if (H5Oget_info2(loc_id, &object_info, H5O_INFO_ALL) < 0)
|
||||
if (H5Oget_info3(loc_id, &object_info, H5O_INFO_ALL) < 0)
|
||||
goto done;
|
||||
|
||||
datainfo->otype[datainfo->count] = object_info.type;
|
||||
datainfo->ltype[datainfo->count] = info->type;
|
||||
|
||||
if (info->type == H5L_TYPE_HARD)
|
||||
datainfo->objno[datainfo->count] = (unsigned long)info->u.address;
|
||||
else
|
||||
datainfo->objno[datainfo->count] = info->u.val_size;
|
||||
HDmemcpy(&datainfo->obj_token[datainfo->count], &object_info.token, sizeof(object_info.token));
|
||||
|
||||
done:
|
||||
datainfo->count++;
|
||||
|
@ -96,7 +96,7 @@ Java_hdf_hdf5lib_H5_H5Dcopy
|
||||
*/
|
||||
JNIEXPORT jint JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5Gget_1obj_1info_1full
|
||||
(JNIEnv*, jclass, jlong, jstring, jobjectArray, jintArray, jintArray, jlongArray, jlongArray, jint, jint, jint);
|
||||
(JNIEnv*, jclass, jlong, jstring, jobjectArray, jintArray, jintArray, jlongArray, jobjectArray, jint, jint, jint);
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
|
@ -110,10 +110,30 @@ done:
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: H5VLget_connector_id
|
||||
* Signature: (Ljava/lang/String;)J
|
||||
* Signature: (J)J
|
||||
*/
|
||||
JNIEXPORT jlong JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5VLget_1connector_1id
|
||||
(JNIEnv *env, jclass clss, jlong obj_id)
|
||||
{
|
||||
hid_t status = H5I_INVALID_HID;
|
||||
|
||||
UNUSED(clss);
|
||||
|
||||
if ((status = H5VLget_connector_id((hid_t)obj_id)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
done:
|
||||
return (jlong)status;
|
||||
} /* end Java_hdf_hdf5lib_H5_H5VLget_1connector_1id */
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: H5VLget_connector_id_by_name
|
||||
* Signature: (Ljava/lang/String;)J
|
||||
*/
|
||||
JNIEXPORT jlong JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5VLget_1connector_1id_1by_1name
|
||||
(JNIEnv *env, jclass clss, jobject connector_name)
|
||||
{
|
||||
const char *volName = NULL;
|
||||
@ -122,11 +142,11 @@ Java_hdf_hdf5lib_H5_H5VLget_1connector_1id
|
||||
UNUSED(clss);
|
||||
|
||||
if (NULL == connector_name)
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5VLget_connector_id: VOL connector name is NULL");
|
||||
H5_NULL_ARGUMENT_ERROR(ENVONLY, "H5VLget_connector_id_by_name: VOL connector name is NULL");
|
||||
|
||||
PIN_JAVA_STRING(ENVONLY, connector_name, volName, NULL, "H5VLget_connector_id: VOL connector name not pinned");
|
||||
PIN_JAVA_STRING(ENVONLY, connector_name, volName, NULL, "H5VLget_connector_id_by_name: VOL connector name not pinned");
|
||||
|
||||
if ((status = H5VLget_connector_id(volName)) < 0)
|
||||
if ((status = H5VLget_connector_id_by_name(volName)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
||||
done:
|
||||
@ -134,7 +154,7 @@ done:
|
||||
UNPIN_JAVA_STRING(ENVONLY, connector_name, volName);
|
||||
|
||||
return (jlong)status;
|
||||
} /* end Java_hdf_hdf5lib_H5_H5VLget_1connector_1id */
|
||||
} /* end Java_hdf_hdf5lib_H5_H5VLget_1connector_1id_1by_1name */
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
@ -158,7 +178,7 @@ Java_hdf_hdf5lib_H5_H5VLget_1connector_1name
|
||||
|
||||
if (buf_size > 0) {
|
||||
if (NULL == (volName = (char *) HDmalloc(sizeof(char) * (size_t)buf_size + 1)))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "H5VLget_connector_name: failed to allocated VOL connector name buffer");
|
||||
H5_OUT_OF_MEMORY_ERROR(ENVONLY, "H5VLget_connector_name: failed to allocated VOL connector name buffer");
|
||||
|
||||
if ((status = H5VLget_connector_name((hid_t)object_id, volName, (size_t)buf_size + 1)) < 0)
|
||||
H5_LIBRARY_ERROR(ENVONLY);
|
||||
|
@ -50,10 +50,19 @@ Java_hdf_hdf5lib_H5_H5VLis_1connector_1registered
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: H5VLget_connector_id
|
||||
* Signature: (Ljava/lang/String;)J
|
||||
* Signature: (J)J
|
||||
*/
|
||||
JNIEXPORT jlong JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5VLget_1connector_1id
|
||||
(JNIEnv *, jclass, jlong);
|
||||
|
||||
/*
|
||||
* Class: hdf_hdf5lib_H5
|
||||
* Method: H5VLget_connector_id_by_name
|
||||
* Signature: (Ljava/lang/String;)J
|
||||
*/
|
||||
JNIEXPORT jlong JNICALL
|
||||
Java_hdf_hdf5lib_H5_H5VLget_1connector_1id_1by_1name
|
||||
(JNIEnv *, jclass, jobject);
|
||||
|
||||
/*
|
||||
|
@ -327,7 +327,7 @@ Java_hdf_hdf5lib_HDFNativeData_byteToInt__II_3B
|
||||
}
|
||||
|
||||
if ((start < 0) || ((int)(start + (len * (int)sizeof(jint))) > blen))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "byteToInt: start < 0 or len exceeded buffer length");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "byteToInt: start < 0 or len exceeded buffer length");
|
||||
|
||||
bp = (char *)barr + start;
|
||||
|
||||
@ -379,7 +379,7 @@ Java_hdf_hdf5lib_HDFNativeData_byteToShort__II_3B
|
||||
}
|
||||
|
||||
if ((start < 0) || ((int)(start + (len * (int)sizeof(jshort))) > blen))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "byteToShort: start < 0 or len exceeded buffer length");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "byteToShort: start < 0 or len exceeded buffer length");
|
||||
|
||||
bp = (char *)barr + start;
|
||||
|
||||
@ -431,7 +431,7 @@ Java_hdf_hdf5lib_HDFNativeData_byteToFloat__II_3B
|
||||
}
|
||||
|
||||
if ((start < 0) || ((int)(start + (len * (int)sizeof(jfloat))) > blen))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "byteToFloat: start < 0 or len exceeded buffer length");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "byteToFloat: start < 0 or len exceeded buffer length");
|
||||
|
||||
bp = (char *)barr + start;
|
||||
|
||||
@ -483,7 +483,7 @@ Java_hdf_hdf5lib_HDFNativeData_byteToLong__II_3B
|
||||
}
|
||||
|
||||
if ((start < 0) || ((int)(start + (len * (int)sizeof(jlong))) > blen))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "byteToLong: start < 0 or len exceeded buffer length");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "byteToLong: start < 0 or len exceeded buffer length");
|
||||
|
||||
bp = (char *)barr + start;
|
||||
|
||||
@ -535,7 +535,7 @@ Java_hdf_hdf5lib_HDFNativeData_byteToDouble__II_3B
|
||||
}
|
||||
|
||||
if ((start < 0) || ((int)(start + (len * (int)sizeof(jdouble))) > blen))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "byteToDouble: start < 0 or len exceeded buffer length");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "byteToDouble: start < 0 or len exceeded buffer length");
|
||||
|
||||
bp = (char *)barr + start;
|
||||
|
||||
@ -593,7 +593,7 @@ Java_hdf_hdf5lib_HDFNativeData_intToByte__II_3I
|
||||
}
|
||||
|
||||
if ((start < 0) || (((start + len)) > ilen))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "intToByte: start < 0 or len exceeded buffer length");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "intToByte: start < 0 or len exceeded buffer length");
|
||||
|
||||
ip = iarr + start;
|
||||
|
||||
@ -655,7 +655,7 @@ Java_hdf_hdf5lib_HDFNativeData_shortToByte__II_3S
|
||||
}
|
||||
|
||||
if ((start < 0) || (((start + len)) > ilen))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "shortToByte: start < 0 or len exceeded buffer length");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "shortToByte: start < 0 or len exceeded buffer length");
|
||||
|
||||
ip = sarr + start;
|
||||
|
||||
@ -717,7 +717,7 @@ Java_hdf_hdf5lib_HDFNativeData_floatToByte__II_3F
|
||||
}
|
||||
|
||||
if ((start < 0) || (((start + len)) > ilen))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "floatToByte: start < 0 or len exceeded buffer length");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "floatToByte: start < 0 or len exceeded buffer length");
|
||||
|
||||
ip = farr + start;
|
||||
|
||||
@ -779,7 +779,7 @@ Java_hdf_hdf5lib_HDFNativeData_doubleToByte__II_3D
|
||||
}
|
||||
|
||||
if ((start < 0) || (((start + len)) > ilen))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "doubleToByte: start < 0 or len exceeded buffer length");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "doubleToByte: start < 0 or len exceeded buffer length");
|
||||
|
||||
ip = darr + start;
|
||||
|
||||
@ -841,7 +841,7 @@ Java_hdf_hdf5lib_HDFNativeData_longToByte__II_3J
|
||||
}
|
||||
|
||||
if ((start < 0) || (((start + len)) > ilen))
|
||||
H5_JNI_FATAL_ERROR(ENVONLY, "longToByte: start < 0 or len exceeded buffer length");
|
||||
H5_BAD_ARGUMENT_ERROR(ENVONLY, "longToByte: start < 0 or len exceeded buffer length");
|
||||
|
||||
ip = larr + start;
|
||||
|
||||
|
@ -74,7 +74,6 @@ public class TestH5E {
|
||||
|
||||
@Test
|
||||
public void testH5Eget_msg_major() {
|
||||
|
||||
try {
|
||||
H5.H5Fopen("test", HDF5Constants.H5F_ACC_RDWR, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
@ -90,8 +89,17 @@ public class TestH5E {
|
||||
fail("H5.H5Eget_msg(Throwable): " + err);
|
||||
}
|
||||
assertNotNull("H5.H5Eget_msg: " + msg, msg);
|
||||
assertEquals("H5.H5Eget_msg: ", "File accessibility", msg);
|
||||
assertEquals("H5.H5Eget_msg: ", HDF5Constants.H5E_MAJOR, error_msg_type[0]);
|
||||
|
||||
/*
|
||||
* If HDF5_VOL_CONNECTOR is set, this might not be the
|
||||
* native connector and the error string might be different.
|
||||
* Only check for the specific error message if the native
|
||||
* connector is being used.
|
||||
*/
|
||||
String connector = System.getenv("HDF5_VOL_CONNECTOR");
|
||||
if (connector == null)
|
||||
assertEquals("H5.H5Eget_msg: ", "File accessibility", msg);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
@ -116,8 +124,17 @@ public class TestH5E {
|
||||
fail("H5.H5Eget_msg: " + err);
|
||||
}
|
||||
assertNotNull("H5.H5Eget_msg: " + msg, msg);
|
||||
assertEquals("H5.H5Eget_msg: ", "Unable to open file", msg);
|
||||
assertEquals("H5.H5Eget_msg: ", HDF5Constants.H5E_MINOR, error_msg_type[0]);
|
||||
|
||||
/*
|
||||
* If HDF5_VOL_CONNECTOR is set, this might not be the
|
||||
* native connector and the error string might be different.
|
||||
* Only check for the specific error message if the native
|
||||
* connector is being used.
|
||||
*/
|
||||
String connector = System.getenv("HDF5_VOL_CONNECTOR");
|
||||
if (connector == null)
|
||||
assertEquals("H5.H5Eget_msg: ", "Unable to open file", msg);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
|
@ -24,6 +24,7 @@ import org.junit.After;
|
||||
import org.junit.Before;
|
||||
import org.junit.Rule;
|
||||
import org.junit.Test;
|
||||
import org.junit.Ignore;
|
||||
import org.junit.rules.TestName;
|
||||
|
||||
public class TestH5Edefault {
|
||||
@ -55,20 +56,29 @@ public class TestH5Edefault {
|
||||
H5.H5Eprint2(-1, null);
|
||||
}
|
||||
|
||||
@Test
|
||||
@Ignore
|
||||
public void testH5Eprint() {
|
||||
try {
|
||||
H5.H5Fopen("test", HDF5Constants.H5F_ACC_RDWR, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
}
|
||||
try {
|
||||
H5.H5Eprint2(HDF5Constants.H5E_DEFAULT, null);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Eprint: " + err);
|
||||
}
|
||||
/*
|
||||
* If HDF5_VOL_CONNECTOR is set, this might not be the
|
||||
* native connector and the error stack might be different.
|
||||
* Only check for the specific error stack if the native
|
||||
* connector is being used.
|
||||
*/
|
||||
String connector = System.getenv("HDF5_VOL_CONNECTOR");
|
||||
if (connector == null) {
|
||||
try {
|
||||
H5.H5Fopen("test", HDF5Constants.H5F_ACC_RDWR, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
}
|
||||
try {
|
||||
H5.H5Eprint2(HDF5Constants.H5E_DEFAULT, null);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Eprint: " + err);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -427,20 +437,29 @@ public class TestH5Edefault {
|
||||
H5.H5Eprint2(-1, null);
|
||||
}
|
||||
|
||||
@Test
|
||||
@Ignore
|
||||
public void testH5EprintInt() {
|
||||
try {
|
||||
H5.H5Fopen("test", HDF5Constants.H5F_ACC_RDWR, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
}
|
||||
try {
|
||||
H5.H5Eprint2(HDF5Constants.H5E_DEFAULT, null);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5EprintInt: " + err);
|
||||
}
|
||||
/*
|
||||
* If HDF5_VOL_CONNECTOR is set, this might not be the
|
||||
* native connector and the error stack might be different.
|
||||
* Only check for the specific error stack if the native
|
||||
* connector is being used.
|
||||
*/
|
||||
String connector = System.getenv("HDF5_VOL_CONNECTOR");
|
||||
if (connector == null) {
|
||||
try {
|
||||
H5.H5Fopen("test", HDF5Constants.H5F_ACC_RDWR, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
}
|
||||
try {
|
||||
H5.H5Eprint2(HDF5Constants.H5E_DEFAULT, null);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5EprintInt: " + err);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -24,6 +24,7 @@ import hdf.hdf5lib.H5;
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
import hdf.hdf5lib.exceptions.HDF5LibraryException;
|
||||
import hdf.hdf5lib.structs.H5G_info_t;
|
||||
import hdf.hdf5lib.structs.H5O_token_t;
|
||||
|
||||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
@ -286,12 +287,12 @@ public class TestH5G {
|
||||
String objNames[] = new String[(int) info.nlinks];
|
||||
int objTypes[] = new int[(int) info.nlinks];
|
||||
int lnkTypes[] = new int[(int) info.nlinks];
|
||||
long objRefs[] = new long[(int) info.nlinks];
|
||||
H5O_token_t objTokens[] = new H5O_token_t[(int) info.nlinks];
|
||||
|
||||
int names_found = 0;
|
||||
try {
|
||||
names_found = H5.H5Gget_obj_info_all(H5fid, GROUPS[0], objNames,
|
||||
objTypes, lnkTypes, objRefs, HDF5Constants.H5_INDEX_NAME);
|
||||
objTypes, lnkTypes, objTokens, HDF5Constants.H5_INDEX_NAME);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
@ -317,14 +318,14 @@ public class TestH5G {
|
||||
assertNotNull("TestH5G.testH5Gget_obj_info_all_gid: ", info);
|
||||
assertTrue("TestH5G.testH5Gget_obj_info_all_gid: number of links is empty", info.nlinks > 0);
|
||||
String objNames[] = new String[(int) info.nlinks];
|
||||
long objRefs[] = new long[(int) info.nlinks];
|
||||
H5O_token_t objTokens[] = new H5O_token_t[(int) info.nlinks];
|
||||
int lnkTypes[] = new int[(int) info.nlinks];
|
||||
int objTypes[] = new int[(int) info.nlinks];
|
||||
|
||||
int names_found = 0;
|
||||
try {
|
||||
names_found = H5.H5Gget_obj_info_all(gid, null, objNames, objTypes, lnkTypes,
|
||||
objRefs, HDF5Constants.H5_INDEX_NAME);
|
||||
objTokens, HDF5Constants.H5_INDEX_NAME);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
@ -358,14 +359,14 @@ public class TestH5G {
|
||||
assertNotNull("TestH5G.testH5Gget_obj_info_all_gid2: ", info);
|
||||
assertTrue("TestH5G.testH5Gget_obj_info_all_gid2: number of links is empty", info.nlinks > 0);
|
||||
String objNames[] = new String[(int) info.nlinks];
|
||||
long objRefs[] = new long[(int) info.nlinks];
|
||||
H5O_token_t objTokens[] = new H5O_token_t[(int) info.nlinks];
|
||||
int lnkTypes[] = new int[(int) info.nlinks];
|
||||
int objTypes[] = new int[(int) info.nlinks];
|
||||
|
||||
int names_found = 0;
|
||||
try {
|
||||
names_found = H5.H5Gget_obj_info_all(gid, null, objNames, objTypes, lnkTypes,
|
||||
objRefs, HDF5Constants.H5_INDEX_NAME);
|
||||
objTokens, HDF5Constants.H5_INDEX_NAME);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
@ -395,12 +396,12 @@ public class TestH5G {
|
||||
String objNames[] = new String[(int)groups_max_size];
|
||||
int objTypes[] = new int[(int)groups_max_size];
|
||||
int lnkTypes[] = new int[(int)groups_max_size];
|
||||
long objRefs[] = new long[(int)groups_max_size];
|
||||
H5O_token_t objTokens[] = new H5O_token_t[(int)groups_max_size];
|
||||
|
||||
int names_found = 0;
|
||||
try {
|
||||
names_found = H5.H5Gget_obj_info_max(gid, objNames, objTypes, lnkTypes,
|
||||
objRefs, groups_max_size);
|
||||
objTokens, groups_max_size);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
@ -426,12 +427,12 @@ public class TestH5G {
|
||||
String objNames[] = new String[(int)groups_max_size];
|
||||
int objTypes[] = new int[(int)groups_max_size];
|
||||
int lnkTypes[] = new int[(int)groups_max_size];
|
||||
long objRefs[] = new long[(int)groups_max_size];
|
||||
H5O_token_t objTokens[] = new H5O_token_t[(int)groups_max_size];
|
||||
|
||||
int names_found = 0;
|
||||
try {
|
||||
names_found = H5.H5Gget_obj_info_max(gid, objNames, objTypes, lnkTypes,
|
||||
objRefs, groups_max_size);
|
||||
objTokens, groups_max_size);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
@ -471,11 +472,11 @@ public class TestH5G {
|
||||
String objNames[] = new String[(int) info.nlinks];
|
||||
int objTypes[] = new int[(int) info.nlinks];
|
||||
int lnkTypes[] = new int[(int) info.nlinks];
|
||||
long objRefs[] = new long[(int) info.nlinks];
|
||||
H5O_token_t objTokens[] = new H5O_token_t[(int) info.nlinks];
|
||||
|
||||
try {
|
||||
H5.H5Gget_obj_info_all(H5fid2, GROUPS2[0], objNames,
|
||||
objTypes, lnkTypes, objRefs, HDF5Constants.H5_INDEX_CRT_ORDER);
|
||||
objTypes, lnkTypes, objTokens, HDF5Constants.H5_INDEX_CRT_ORDER);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
@ -488,7 +489,7 @@ public class TestH5G {
|
||||
|
||||
try {
|
||||
H5.H5Gget_obj_info_all(H5fid2, GROUPS2[0], objNames,
|
||||
objTypes, lnkTypes, objRefs, HDF5Constants.H5_INDEX_NAME);
|
||||
objTypes, lnkTypes, objTokens, HDF5Constants.H5_INDEX_NAME);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
|
@ -20,6 +20,7 @@ import hdf.hdf5lib.H5;
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
import hdf.hdf5lib.exceptions.HDF5LibraryException;
|
||||
import hdf.hdf5lib.structs.H5G_info_t;
|
||||
import hdf.hdf5lib.structs.H5O_token_t;
|
||||
|
||||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
@ -93,12 +94,12 @@ public class TestH5Giterate {
|
||||
String objNames[] = new String[(int) info.nlinks];
|
||||
int objTypes[] = new int[(int) info.nlinks];
|
||||
int lnkTypes[] = new int[(int) info.nlinks];
|
||||
long objRefs[] = new long[(int) info.nlinks];
|
||||
H5O_token_t objTokens[] = new H5O_token_t[(int) info.nlinks];
|
||||
|
||||
int names_found = 0;
|
||||
try {
|
||||
names_found = H5.H5Gget_obj_info_all(H5fid, "/", objNames,
|
||||
objTypes, lnkTypes, objRefs, HDF5Constants.H5_INDEX_NAME);
|
||||
objTypes, lnkTypes, objTokens, HDF5Constants.H5_INDEX_NAME);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
|
@ -21,8 +21,8 @@ import java.util.ArrayList;
|
||||
|
||||
import hdf.hdf5lib.H5;
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_cb;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_t;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_opdata_t;
|
||||
import hdf.hdf5lib.exceptions.HDF5LibraryException;
|
||||
import hdf.hdf5lib.structs.H5L_info_t;
|
||||
|
||||
@ -119,9 +119,8 @@ public class TestH5Lbasic {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Lget_info: " + err);
|
||||
}
|
||||
assertFalse("H5Lget_info ",link_info==null);
|
||||
assertFalse("H5Lget_info",link_info==null);
|
||||
assertTrue("H5Lget_info link type",link_info.type==HDF5Constants.H5L_TYPE_HARD);
|
||||
assertTrue("Link Address ",link_info.address_val_size>0);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
@ -155,7 +154,7 @@ public class TestH5Lbasic {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Lget_info_by_idx: " + err);
|
||||
}
|
||||
assertFalse("H5Lget_info_by_idx ",link_info==null);
|
||||
assertFalse("H5Lget_info_by_idx",link_info==null);
|
||||
assertTrue("H5Lget_info_by_idx link type",link_info.type==HDF5Constants.H5L_TYPE_HARD);
|
||||
try {
|
||||
link_info2 = H5.H5Lget_info(H5fid, "DS1", HDF5Constants.H5P_DEFAULT);
|
||||
@ -164,7 +163,7 @@ public class TestH5Lbasic {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Lget_info: " + err);
|
||||
}
|
||||
assertTrue("Link Address ",link_info.address_val_size==link_info2.address_val_size);
|
||||
assertTrue("Link Value Size", link_info.val_size == link_info2.val_size);
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -178,7 +177,7 @@ public class TestH5Lbasic {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Lget_info_by_idx: " + err);
|
||||
}
|
||||
assertFalse("H5Lget_info_by_idx ",link_info==null);
|
||||
assertFalse("H5Lget_info_by_idx",link_info==null);
|
||||
assertTrue("H5Lget_info_by_idx link type",link_info.type==HDF5Constants.H5L_TYPE_HARD);
|
||||
try {
|
||||
link_info2 = H5.H5Lget_info(H5fid, "L1", HDF5Constants.H5P_DEFAULT);
|
||||
@ -187,7 +186,7 @@ public class TestH5Lbasic {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Lget_info: " + err);
|
||||
}
|
||||
assertTrue("Link Address ",link_info.address_val_size==link_info2.address_val_size);
|
||||
assertTrue("Link Value Size", link_info.val_size == link_info2.val_size);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
@ -233,18 +232,18 @@ public class TestH5Lbasic {
|
||||
this.link_type = type;
|
||||
}
|
||||
}
|
||||
class H5L_iter_data implements H5L_iterate_t {
|
||||
class H5L_iter_data implements H5L_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
H5L_iterate_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_cb {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_t op_data) {
|
||||
H5L_iterate_opdata_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_t {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_opdata_t op_data) {
|
||||
idata id = new idata(name, info.type);
|
||||
((H5L_iter_data)op_data).iterdata.add(id);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
H5L_iterate_cb iter_cb = new H5L_iter_callback();
|
||||
H5L_iterate_t iter_cb = new H5L_iter_callback();
|
||||
try {
|
||||
H5.H5Lvisit(H5fid, HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, iter_cb, iter_data);
|
||||
}
|
||||
@ -271,18 +270,18 @@ public class TestH5Lbasic {
|
||||
this.link_type = type;
|
||||
}
|
||||
}
|
||||
class H5L_iter_data implements H5L_iterate_t {
|
||||
class H5L_iter_data implements H5L_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
H5L_iterate_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_cb {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_t op_data) {
|
||||
H5L_iterate_opdata_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_t {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_opdata_t op_data) {
|
||||
idata id = new idata(name, info.type);
|
||||
((H5L_iter_data)op_data).iterdata.add(id);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
H5L_iterate_cb iter_cb = new H5L_iter_callback();
|
||||
H5L_iterate_t iter_cb = new H5L_iter_callback();
|
||||
try {
|
||||
H5.H5Lvisit_by_name(H5fid, "G1", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, iter_cb, iter_data, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
@ -305,18 +304,18 @@ public class TestH5Lbasic {
|
||||
this.link_type = type;
|
||||
}
|
||||
}
|
||||
class H5L_iter_data implements H5L_iterate_t {
|
||||
class H5L_iter_data implements H5L_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
H5L_iterate_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_cb {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_t op_data) {
|
||||
H5L_iterate_opdata_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_t {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_opdata_t op_data) {
|
||||
idata id = new idata(name, info.type);
|
||||
((H5L_iter_data)op_data).iterdata.add(id);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
H5L_iterate_cb iter_cb = new H5L_iter_callback();
|
||||
H5L_iterate_t iter_cb = new H5L_iter_callback();
|
||||
try {
|
||||
H5.H5Literate(H5fid, HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 0L, iter_cb, iter_data);
|
||||
}
|
||||
@ -342,18 +341,18 @@ public class TestH5Lbasic {
|
||||
this.link_type = type;
|
||||
}
|
||||
}
|
||||
class H5L_iter_data implements H5L_iterate_t {
|
||||
class H5L_iter_data implements H5L_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
H5L_iterate_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_cb {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_t op_data) {
|
||||
H5L_iterate_opdata_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_t {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_opdata_t op_data) {
|
||||
idata id = new idata(name, info.type);
|
||||
((H5L_iter_data)op_data).iterdata.add(id);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
H5L_iterate_cb iter_cb = new H5L_iter_callback();
|
||||
H5L_iterate_t iter_cb = new H5L_iter_callback();
|
||||
try {
|
||||
H5.H5Literate_by_name(H5fid, "G1", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 0L, iter_cb, iter_data, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
|
@ -22,8 +22,8 @@ import java.util.ArrayList;
|
||||
|
||||
import hdf.hdf5lib.H5;
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_cb;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_t;
|
||||
import hdf.hdf5lib.callbacks.H5L_iterate_opdata_t;
|
||||
import hdf.hdf5lib.exceptions.HDF5Exception;
|
||||
import hdf.hdf5lib.exceptions.HDF5LibraryException;
|
||||
import hdf.hdf5lib.structs.H5L_info_t;
|
||||
@ -320,9 +320,9 @@ public class TestH5Lcreate {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Lget_info: " + err);
|
||||
}
|
||||
assertFalse("H5Lget_info ", link_info==null);
|
||||
assertFalse("H5Lget_info", link_info==null);
|
||||
assertTrue("H5Lget_info link type", link_info.type==HDF5Constants.H5L_TYPE_SOFT);
|
||||
assertTrue("Link Address ", link_info.address_val_size>0);
|
||||
assertTrue("Link Value Size", link_info.val_size > 0);
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -383,9 +383,9 @@ public class TestH5Lcreate {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Lget_info: " + err);
|
||||
}
|
||||
assertFalse("H5Lget_info ", link_info==null);
|
||||
assertFalse("H5Lget_info", link_info==null);
|
||||
assertTrue("H5Lget_info link type", link_info.type==HDF5Constants.H5L_TYPE_SOFT);
|
||||
assertTrue("Link Address ", link_info.address_val_size>0);
|
||||
assertTrue("Link Value Size", link_info.val_size > 0);
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -431,9 +431,9 @@ public class TestH5Lcreate {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Lget_info: " + err);
|
||||
}
|
||||
assertFalse("H5Lget_info ", link_info==null);
|
||||
assertFalse("H5Lget_info", link_info==null);
|
||||
assertTrue("H5Lget_info link type", link_info.type==HDF5Constants.H5L_TYPE_EXTERNAL);
|
||||
assertTrue("Link Address ", link_info.address_val_size>0);
|
||||
assertTrue("Link Value Size", link_info.val_size > 0);
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -740,18 +740,18 @@ public class TestH5Lcreate {
|
||||
this.link_type = type;
|
||||
}
|
||||
}
|
||||
class H5L_iter_data implements H5L_iterate_t {
|
||||
class H5L_iter_data implements H5L_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
H5L_iterate_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_cb {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_t op_data) {
|
||||
H5L_iterate_opdata_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_t {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_opdata_t op_data) {
|
||||
idata id = new idata(name, info.type);
|
||||
((H5L_iter_data)op_data).iterdata.add(id);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
H5L_iterate_cb iter_cb = new H5L_iter_callback();
|
||||
H5L_iterate_t iter_cb = new H5L_iter_callback();
|
||||
try {
|
||||
H5.H5Lvisit(H5fid, HDF5Constants.H5_INDEX_CRT_ORDER, HDF5Constants.H5_ITER_INC, iter_cb, iter_data);
|
||||
}
|
||||
@ -792,18 +792,18 @@ public class TestH5Lcreate {
|
||||
this.link_type = type;
|
||||
}
|
||||
}
|
||||
class H5L_iter_data implements H5L_iterate_t {
|
||||
class H5L_iter_data implements H5L_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
H5L_iterate_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_cb {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_t op_data) {
|
||||
H5L_iterate_opdata_t iter_data = new H5L_iter_data();
|
||||
class H5L_iter_callback implements H5L_iterate_t {
|
||||
public int callback(long group, String name, H5L_info_t info, H5L_iterate_opdata_t op_data) {
|
||||
idata id = new idata(name, info.type);
|
||||
((H5L_iter_data)op_data).iterdata.add(id);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
H5L_iterate_cb iter_cb = new H5L_iter_callback();
|
||||
H5L_iterate_t iter_cb = new H5L_iter_callback();
|
||||
try {
|
||||
H5.H5Literate(H5fid, HDF5Constants.H5_INDEX_CRT_ORDER, HDF5Constants.H5_ITER_INC, 0, iter_cb, iter_data);
|
||||
}
|
||||
|
@ -21,10 +21,14 @@ import java.util.ArrayList;
|
||||
|
||||
import hdf.hdf5lib.H5;
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_cb;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_t;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_opdata_t;
|
||||
import hdf.hdf5lib.exceptions.HDF5LibraryException;
|
||||
import hdf.hdf5lib.structs.H5O_info_t;
|
||||
import hdf.hdf5lib.structs.H5O_native_info_t;
|
||||
import hdf.hdf5lib.structs.H5O_token_t;
|
||||
import hdf.hdf5lib.structs.H5O_hdr_info_t;
|
||||
import hdf.hdf5lib.structs.H5_ih_info_t;
|
||||
|
||||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
@ -35,10 +39,8 @@ import org.junit.rules.TestName;
|
||||
public class TestH5Obasic {
|
||||
@Rule public TestName testname = new TestName();
|
||||
private static final String H5_FILE = "h5ex_g_iterateO1.hdf";
|
||||
private static long H5la_ds1 = -1;
|
||||
private static long H5la_l1 = -1;
|
||||
private static long H5la_dt1 = -1;
|
||||
private static long H5la_g1 = -1;
|
||||
private static H5O_token_t H5la_ds1 = null;
|
||||
private static H5O_token_t H5la_l1 = null;
|
||||
long H5fid = -1;
|
||||
|
||||
@Before
|
||||
@ -242,7 +244,7 @@ public class TestH5Obasic {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oget_info_by_idx_n0:H5.H5Oget_info: " + err);
|
||||
}
|
||||
H5la_ds1 = obj_info.addr;
|
||||
H5la_ds1 = obj_info.token;
|
||||
try {H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
try {
|
||||
obj_info = H5.H5Oget_info_by_idx(H5fid, "/", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 0, HDF5Constants.H5P_DEFAULT);
|
||||
@ -253,7 +255,7 @@ public class TestH5Obasic {
|
||||
}
|
||||
assertFalse("testH5Oget_info_by_idx_n0:H5Oget_info_by_idx ",obj_info==null);
|
||||
assertTrue("testH5Oget_info_by_idx_n0:H5Oget_info_by_idx link type",obj_info.type==HDF5Constants.H5O_TYPE_DATASET);
|
||||
assertTrue("testH5Oget_info_by_idx_n0:Link Address ",obj_info.addr==H5la_ds1);
|
||||
assertTrue("testH5Oget_info_by_idx_n0:Link Object token", obj_info.token.equals(H5la_ds1));
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -268,7 +270,7 @@ public class TestH5Obasic {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oget_info_by_idx_n3:H5.H5Oget_info: " + err);
|
||||
}
|
||||
H5la_l1 = obj_info.addr;
|
||||
H5la_l1 = obj_info.token;
|
||||
try {H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
try {
|
||||
obj_info = H5.H5Oget_info_by_idx(H5fid, "/", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 3, HDF5Constants.H5P_DEFAULT);
|
||||
@ -279,7 +281,263 @@ public class TestH5Obasic {
|
||||
}
|
||||
assertFalse("testH5Oget_info_by_idx_n3:H5Oget_info_by_idx ",obj_info==null);
|
||||
assertTrue("testH5Oget_info_by_idx_n3:H5Oget_info_by_idx link type",obj_info.type==HDF5Constants.H5O_TYPE_DATASET);
|
||||
assertTrue("testH5Oget_info_by_idx_n3:Link Address ",obj_info.addr==H5la_l1);
|
||||
assertTrue("testH5Oget_info_by_idx_n3:Link Object Token", obj_info.token.equals(H5la_l1));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oget_native_info_dataset() {
|
||||
long oid = -1;
|
||||
H5O_native_info_t native_info = null;
|
||||
|
||||
try {
|
||||
oid = H5.H5Oopen(H5fid, "DS1", HDF5Constants.H5P_DEFAULT);
|
||||
native_info = H5.H5Oget_native_info(oid);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Oget_native_info: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_native_info ", native_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.hdr_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.obj_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.attr_info == null);
|
||||
try {H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oget_native_info_hardlink() {
|
||||
long oid = -1;
|
||||
H5O_native_info_t native_info = null;
|
||||
|
||||
try {
|
||||
oid = H5.H5Oopen(H5fid, "L1", HDF5Constants.H5P_DEFAULT);
|
||||
native_info = H5.H5Oget_native_info(oid);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Oget_native_info: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_native_info ", native_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.hdr_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.obj_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.attr_info == null);
|
||||
try {H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oget_native_info_group() {
|
||||
long oid = -1;
|
||||
H5O_native_info_t native_info = null;
|
||||
|
||||
try {
|
||||
oid = H5.H5Oopen(H5fid, "G1", HDF5Constants.H5P_DEFAULT);
|
||||
native_info = H5.H5Oget_native_info(oid);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Oget_native_info: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_native_info ", native_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.hdr_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.obj_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.attr_info == null);
|
||||
try {H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oget_native_info_datatype() {
|
||||
long oid = -1;
|
||||
H5O_native_info_t native_info = null;
|
||||
|
||||
try {
|
||||
oid = H5.H5Oopen(H5fid, "DT1", HDF5Constants.H5P_DEFAULT);
|
||||
native_info = H5.H5Oget_native_info(oid);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Oget_native_info: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_native_info ", native_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.hdr_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.obj_info == null);
|
||||
assertFalse("H5Oget_native_info ", native_info.attr_info == null);
|
||||
try {H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
public void testH5Oget_native_info_by_name_not_exist_name() throws Throwable {
|
||||
H5.H5Oget_native_info_by_name(H5fid, "None", HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
public void testH5Oget_native_info_by_name_not_exists() throws Throwable {
|
||||
H5.H5Oget_native_info_by_name(H5fid, "Bogus", HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oget_native_info_by_name_dataset() {
|
||||
H5O_native_info_t native_info = null;
|
||||
|
||||
try {
|
||||
native_info = H5.H5Oget_native_info_by_name(H5fid, "DS1", HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Oget_native_info_by_name: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.hdr_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.obj_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.attr_info == null);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oget_native_info_by_name_hardlink() {
|
||||
H5O_native_info_t native_info = null;
|
||||
|
||||
try {
|
||||
native_info = H5.H5Oget_native_info_by_name(H5fid, "L1", HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Oget_native_info_by_name: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.hdr_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.obj_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.attr_info == null);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oget_native_info_by_name_group() {
|
||||
H5O_native_info_t native_info = null;
|
||||
|
||||
try {
|
||||
native_info = H5.H5Oget_native_info_by_name(H5fid, "G1", HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Oget_native_info_by_name: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.hdr_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.obj_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.attr_info == null);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oget_native_info_by_name_datatype() {
|
||||
H5O_native_info_t native_info = null;
|
||||
|
||||
try {
|
||||
native_info = H5.H5Oget_native_info_by_name(H5fid, "DT1", HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Oget_native_info_by_name: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.hdr_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.obj_info == null);
|
||||
assertFalse("H5Oget_native_info_by_name ", native_info.attr_info == null);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
public void testH5Oget_native_info_by_idx_name_not_exist_name() throws Throwable {
|
||||
H5.H5Oget_native_info_by_idx(H5fid, "None", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 0, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
public void testH5Oget_native_info_by_idx_name_not_exist_create() throws Throwable {
|
||||
H5.H5Oget_native_info_by_idx(H5fid, "None", HDF5Constants.H5_INDEX_CRT_ORDER, HDF5Constants.H5_ITER_INC, 0, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
public void testH5Oget_native_info_by_idx_not_exist_name() throws Throwable {
|
||||
H5.H5Oget_native_info_by_idx(H5fid, "/", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 5, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
public void testH5Oget_native_info_by_idx_not_exist_create() throws Throwable {
|
||||
H5.H5Oget_native_info_by_idx(H5fid, "/", HDF5Constants.H5_INDEX_CRT_ORDER, HDF5Constants.H5_ITER_INC, 5, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oget_native_info_by_idx_n0() {
|
||||
long oid = -1;
|
||||
H5O_native_info_t native_info = null;
|
||||
H5O_hdr_info_t ohdr;
|
||||
H5_ih_info_t oinfo;
|
||||
H5_ih_info_t ainfo;
|
||||
|
||||
try {
|
||||
oid = H5.H5Oopen(H5fid, "DS1", HDF5Constants.H5P_DEFAULT);
|
||||
native_info = H5.H5Oget_native_info(oid);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oget_native_info_by_idx_n0:H5.H5Oget_native_info: " + err);
|
||||
}
|
||||
|
||||
ohdr = native_info.hdr_info;
|
||||
oinfo = native_info.obj_info;
|
||||
ainfo = native_info.attr_info;
|
||||
|
||||
try {H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
|
||||
try {
|
||||
native_info = H5.H5Oget_native_info_by_idx(H5fid, "/", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 0, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oget_native_info_by_idx_n0:H5.H5Oget_native_info_by_idx: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_native_info_by_idx ", native_info == null);
|
||||
assertFalse("H5Oget_native_info_by_idx ", native_info.hdr_info == null);
|
||||
assertFalse("H5Oget_native_info_by_idx ", native_info.obj_info == null);
|
||||
assertFalse("H5Oget_native_info_by_idx ", native_info.attr_info == null);
|
||||
assertTrue("testH5Oget_native_info_by_idx_n0:Object Header Info", native_info.hdr_info.equals(ohdr));
|
||||
assertTrue("testH5Oget_native_info_by_idx_n0:Object Info", native_info.obj_info.equals(oinfo));
|
||||
assertTrue("testH5Oget_native_info_by_idx_n0:Attribute Info", native_info.attr_info.equals(ainfo));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oget_native_info_by_idx_n3() {
|
||||
long oid = -1;
|
||||
H5O_native_info_t native_info = null;
|
||||
H5O_hdr_info_t ohdr;
|
||||
H5_ih_info_t oinfo;
|
||||
H5_ih_info_t ainfo;
|
||||
|
||||
try {
|
||||
oid = H5.H5Oopen(H5fid, "L1", HDF5Constants.H5P_DEFAULT);
|
||||
native_info = H5.H5Oget_native_info(oid);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oget_native_info_by_idx_n3:H5.H5Oget_native_info: " + err);
|
||||
}
|
||||
|
||||
ohdr = native_info.hdr_info;
|
||||
oinfo = native_info.obj_info;
|
||||
ainfo = native_info.attr_info;
|
||||
|
||||
try {H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
|
||||
try {
|
||||
native_info = H5.H5Oget_native_info_by_idx(H5fid, "/", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 3, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oget_native_info_by_idx_n3:H5.H5Oget_native_info_by_idx: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_native_info_by_idx ", native_info == null);
|
||||
assertFalse("H5Oget_native_info_by_idx ", native_info.hdr_info == null);
|
||||
assertFalse("H5Oget_native_info_by_idx ", native_info.obj_info == null);
|
||||
assertFalse("H5Oget_native_info_by_idx ", native_info.attr_info == null);
|
||||
assertTrue("testH5Oget_native_info_by_idx_n3:Object Header Info", native_info.hdr_info.equals(ohdr));
|
||||
assertTrue("testH5Oget_native_info_by_idx_n3:Object Info", native_info.obj_info.equals(oinfo));
|
||||
assertTrue("testH5Oget_native_info_by_idx_n3:Attribute Info", native_info.attr_info.equals(ainfo));
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -292,18 +550,18 @@ public class TestH5Obasic {
|
||||
this.link_type = type;
|
||||
}
|
||||
}
|
||||
class H5O_iter_data implements H5O_iterate_t {
|
||||
class H5O_iter_data implements H5O_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
H5O_iterate_t iter_data = new H5O_iter_data();
|
||||
class H5O_iter_callback implements H5O_iterate_cb {
|
||||
public int callback(long group, String name, H5O_info_t info, H5O_iterate_t op_data) {
|
||||
H5O_iterate_opdata_t iter_data = new H5O_iter_data();
|
||||
class H5O_iter_callback implements H5O_iterate_t {
|
||||
public int callback(long group, String name, H5O_info_t info, H5O_iterate_opdata_t op_data) {
|
||||
idata id = new idata(name, info.type);
|
||||
((H5O_iter_data)op_data).iterdata.add(id);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
H5O_iterate_cb iter_cb = new H5O_iter_callback();
|
||||
H5O_iterate_t iter_cb = new H5O_iter_callback();
|
||||
try {
|
||||
H5.H5Ovisit(H5fid, HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, iter_cb, iter_data);
|
||||
}
|
||||
@ -331,18 +589,18 @@ public class TestH5Obasic {
|
||||
this.link_type = type;
|
||||
}
|
||||
}
|
||||
class H5O_iter_data implements H5O_iterate_t {
|
||||
class H5O_iter_data implements H5O_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
H5O_iterate_t iter_data = new H5O_iter_data();
|
||||
class H5O_iter_callback implements H5O_iterate_cb {
|
||||
public int callback(long group, String name, H5O_info_t info, H5O_iterate_t op_data) {
|
||||
H5O_iterate_opdata_t iter_data = new H5O_iter_data();
|
||||
class H5O_iter_callback implements H5O_iterate_t {
|
||||
public int callback(long group, String name, H5O_info_t info, H5O_iterate_opdata_t op_data) {
|
||||
idata id = new idata(name, info.type);
|
||||
((H5O_iter_data)op_data).iterdata.add(id);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
H5O_iterate_cb iter_cb = new H5O_iter_callback();
|
||||
H5O_iterate_t iter_cb = new H5O_iter_callback();
|
||||
try {
|
||||
H5.H5Ovisit_by_name(H5fid, "G1", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, iter_cb, iter_data, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
@ -371,7 +629,7 @@ public class TestH5Obasic {
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oopen_by_addr() {
|
||||
public void testH5Oopen_by_token() {
|
||||
long oid = -1;
|
||||
H5O_info_t obj_info = null;
|
||||
try {
|
||||
@ -381,32 +639,32 @@ public class TestH5Obasic {
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oopen_by_addr: H5.H5Oget_info: " + err);
|
||||
fail("testH5Oopen_by_token: H5.H5Oget_info: " + err);
|
||||
}
|
||||
H5la_ds1 = obj_info.addr;
|
||||
H5la_ds1 = obj_info.token;
|
||||
try {H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
try {
|
||||
oid = H5.H5Oopen_by_addr(H5fid, H5la_ds1);
|
||||
oid = H5.H5Oopen_by_token(H5fid, H5la_ds1);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oopen_by_addr: H5.H5Oopen_by_addr: " + err);
|
||||
fail("testH5Oopen_by_token: H5.H5Oopen_by_token: " + err);
|
||||
}
|
||||
try {
|
||||
obj_info = H5.H5Oget_info(oid);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oopen_by_addr: H5.H5Oget_info: " + err);
|
||||
fail("testH5Oopen_by_token: H5.H5Oget_info: " + err);
|
||||
}
|
||||
assertFalse("testH5Oopen_by_addr: H5Oget_info ",obj_info==null);
|
||||
assertTrue("testH5Oopen_by_addr: H5Oget_info link type",obj_info.type==HDF5Constants.H5O_TYPE_DATASET);
|
||||
assertTrue("testH5Oopen_by_addr: Link Address ",obj_info.addr==H5la_ds1);
|
||||
assertFalse("testH5Oopen_by_token: H5Oget_info ",obj_info==null);
|
||||
assertTrue("testH5Oopen_by_token: H5Oget_info link type",obj_info.type==HDF5Constants.H5O_TYPE_DATASET);
|
||||
assertTrue("testH5Oopen_by_token: Link Object Token", obj_info.token.equals(H5la_ds1));
|
||||
}
|
||||
finally {
|
||||
try{H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5Oopen_by_idx_n0() {
|
||||
@ -421,14 +679,14 @@ public class TestH5Obasic {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oopen_by_idx_n0: H5.H5Oget_info: " + err);
|
||||
}
|
||||
H5la_ds1 = obj_info.addr;
|
||||
H5la_ds1 = obj_info.token;
|
||||
try {H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
try {
|
||||
oid = H5.H5Oopen_by_idx(H5fid, "/", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 0, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oopen_by_addr: H5.H5Oopen_by_addr: " + err);
|
||||
fail("testH5Oopen_by_idx_n0: H5.H5Oopen_by_idx: " + err);
|
||||
}
|
||||
try {
|
||||
obj_info = H5.H5Oget_info(oid);
|
||||
@ -439,7 +697,7 @@ public class TestH5Obasic {
|
||||
}
|
||||
assertFalse("testH5Oopen_by_idx_n0: H5Oget_info_by_idx ",obj_info==null);
|
||||
assertTrue("testH5Oopen_by_idx_n0: H5Oget_info_by_idx link type",obj_info.type==HDF5Constants.H5O_TYPE_DATASET);
|
||||
assertTrue("testH5Oopen_by_idx_n0: Link Address ",obj_info.addr==H5la_ds1);
|
||||
assertTrue("testH5Oopen_by_idx_n0: Link Object Token", obj_info.token.equals(H5la_ds1));
|
||||
}
|
||||
finally {
|
||||
try{H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
@ -459,14 +717,14 @@ public class TestH5Obasic {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oopen_by_idx_n3:H5.H5Oget_info: " + err);
|
||||
}
|
||||
H5la_l1 = obj_info.addr;
|
||||
H5la_l1 = obj_info.token;
|
||||
try {H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
try {
|
||||
oid = H5.H5Oopen_by_idx(H5fid, "/", HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_INC, 3, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("testH5Oopen_by_addr: H5.H5Oopen_by_addr: " + err);
|
||||
fail("testH5Oopen_by_idx_n3: H5.H5Oopen_by_idx: " + err);
|
||||
}
|
||||
try {
|
||||
obj_info = H5.H5Oget_info(oid);
|
||||
@ -477,7 +735,7 @@ public class TestH5Obasic {
|
||||
}
|
||||
assertFalse("testH5Oopen_by_idx_n3:H5Oget_info_by_idx ",obj_info==null);
|
||||
assertTrue("testH5Oopen_by_idx_n3:H5Oget_info_by_idx link type",obj_info.type==HDF5Constants.H5O_TYPE_DATASET);
|
||||
assertTrue("testH5Oopen_by_idx_n3:Link Address ",obj_info.addr==H5la_l1);
|
||||
assertTrue("testH5Oopen_by_idx_n3:Link Object Token", obj_info.token.equals(H5la_l1));
|
||||
}
|
||||
finally {
|
||||
try{H5.H5Oclose(oid);} catch (Exception ex) {}
|
||||
|
@ -22,8 +22,8 @@ import java.util.ArrayList;
|
||||
|
||||
import hdf.hdf5lib.H5;
|
||||
import hdf.hdf5lib.HDF5Constants;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_cb;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_t;
|
||||
import hdf.hdf5lib.callbacks.H5O_iterate_opdata_t;
|
||||
import hdf.hdf5lib.exceptions.HDF5Exception;
|
||||
import hdf.hdf5lib.exceptions.HDF5LibraryException;
|
||||
import hdf.hdf5lib.structs.H5O_info_t;
|
||||
@ -264,9 +264,9 @@ public class TestH5Ocreate {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Oget_info: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_info ", obj_info==null);
|
||||
assertFalse("H5Oget_info", obj_info==null);
|
||||
assertTrue("H5Oget_info link type", obj_info.type==HDF5Constants.H5O_TYPE_DATASET);
|
||||
assertTrue("Link Address ", obj_info.addr>0);
|
||||
assertTrue("Link Object Token", obj_info.token != null);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
@ -286,9 +286,9 @@ public class TestH5Ocreate {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5Oget_info: " + err);
|
||||
}
|
||||
assertFalse("H5Oget_info ", obj_info==null);
|
||||
assertFalse("H5Oget_info", obj_info==null);
|
||||
assertTrue("H5Oget_info link type", obj_info.type==HDF5Constants.H5O_TYPE_NAMED_DATATYPE);
|
||||
assertTrue("Link Address ", obj_info.addr>0);
|
||||
assertTrue("Link Object Token", obj_info.token != null);
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -351,18 +351,18 @@ public class TestH5Ocreate {
|
||||
this.link_type = type;
|
||||
}
|
||||
}
|
||||
class H5O_iter_data implements H5O_iterate_t {
|
||||
class H5O_iter_data implements H5O_iterate_opdata_t {
|
||||
public ArrayList<idata> iterdata = new ArrayList<idata>();
|
||||
}
|
||||
H5O_iterate_t iter_data = new H5O_iter_data();
|
||||
class H5O_iter_callback implements H5O_iterate_cb {
|
||||
public int callback(long group, String name, H5O_info_t info, H5O_iterate_t op_data) {
|
||||
H5O_iterate_opdata_t iter_data = new H5O_iter_data();
|
||||
class H5O_iter_callback implements H5O_iterate_t {
|
||||
public int callback(long group, String name, H5O_info_t info, H5O_iterate_opdata_t op_data) {
|
||||
idata id = new idata(name, info.type);
|
||||
((H5O_iter_data)op_data).iterdata.add(id);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
H5O_iterate_cb iter_cb = new H5O_iter_callback();
|
||||
H5O_iterate_t iter_cb = new H5O_iter_callback();
|
||||
try {
|
||||
H5.H5Ovisit(H5fid, HDF5Constants.H5_INDEX_CRT_ORDER, HDF5Constants.H5_ITER_INC, iter_cb, iter_data);
|
||||
}
|
||||
|
@ -94,6 +94,31 @@ public class TestH5Oparams {
|
||||
H5.H5Oget_info_by_idx(-1, null, 0, 0, 0L, 0, 0);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
public void testH5Oget_native_info_invalid() throws Throwable {
|
||||
H5.H5Oget_native_info(-1, 0);
|
||||
}
|
||||
|
||||
@Test(expected = NullPointerException.class)
|
||||
public void testH5Oget_native_info_by_name_null() throws Throwable {
|
||||
H5.H5Oget_native_info_by_name(-1, null, 0, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
public void testH5Oget_native_info_by_name_invalid() throws Throwable {
|
||||
H5.H5Oget_native_info_by_name(-1, "/testH5Gcreate", 0, HDF5Constants.H5P_DEFAULT);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
public void testH5Oget_native_info_by_idx_invalid() throws Throwable {
|
||||
H5.H5Oget_native_info_by_idx(-1, "Bogus", -1, -1, -1L, 0, -1);
|
||||
}
|
||||
|
||||
@Test(expected = NullPointerException.class)
|
||||
public void testH5Oget_native_info_by_idx_null() throws Throwable {
|
||||
H5.H5Oget_native_info_by_idx(-1, null, 0, 0, 0L, 0, 0);
|
||||
}
|
||||
|
||||
@Test(expected = HDF5LibraryException.class)
|
||||
public void testH5Olink_invalid() throws Throwable {
|
||||
H5.H5Olink(-1, -1, "Bogus", -1, -1);
|
||||
|
@ -69,14 +69,46 @@ public class TestH5VL {
|
||||
|
||||
@Test
|
||||
public void testH5VLget_connector_id() {
|
||||
String H5_FILE = "testFvl.h5";
|
||||
|
||||
long H5fid = H5.H5Fcreate(H5_FILE, HDF5Constants.H5F_ACC_TRUNC,
|
||||
HDF5Constants.H5P_DEFAULT, HDF5Constants.H5P_DEFAULT);
|
||||
|
||||
try {
|
||||
long native_id = H5.H5VLget_connector_id(H5fid);
|
||||
assertTrue("H5.H5VLget_connector_id", native_id >= 0);
|
||||
|
||||
/*
|
||||
* If HDF5_VOL_CONNECTOR is set, this might not be the
|
||||
* native connector. Only check for the native connector
|
||||
* if this isn't set.
|
||||
*/
|
||||
String connector = System.getenv("HDF5_VOL_CONNECTOR");
|
||||
if (connector == null)
|
||||
assertEquals(HDF5Constants.H5VL_NATIVE, native_id);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5VLget_connector_id " + err);
|
||||
}
|
||||
finally {
|
||||
if (H5fid > 0) {
|
||||
try {H5.H5Fclose(H5fid);} catch (Exception ex) {}
|
||||
}
|
||||
_deleteFile(H5_FILE);
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testH5VLget_connector_id_by_name() {
|
||||
try {
|
||||
long native_id = H5.H5VLget_connector_id(HDF5Constants.H5VL_NATIVE_NAME);
|
||||
assertTrue("H5.H5VLget_connector_id H5VL_NATIVE_NAME", native_id >= 0);
|
||||
long native_id = H5.H5VLget_connector_id_by_name(HDF5Constants.H5VL_NATIVE_NAME);
|
||||
assertTrue("H5.H5VLget_connector_id_by_name H5VL_NATIVE_NAME", native_id >= 0);
|
||||
assertEquals(HDF5Constants.H5VL_NATIVE, native_id);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
fail("H5.H5VLget_connector_id " + err);
|
||||
fail("H5.H5VLget_connector_id_by_name " + err);
|
||||
}
|
||||
}
|
||||
|
||||
@ -90,7 +122,15 @@ public class TestH5VL {
|
||||
|
||||
try {
|
||||
String native_name = H5.H5VLget_connector_name(H5fid);
|
||||
assertTrue("H5.H5VLget_connector_name H5VL_NATIVE", native_name.compareToIgnoreCase(HDF5Constants.H5VL_NATIVE_NAME)==0);
|
||||
|
||||
/*
|
||||
* If HDF5_VOL_CONNECTOR is set, this might not be the
|
||||
* native connector. Only check for the native connector
|
||||
* if this isn't set.
|
||||
*/
|
||||
String connector = System.getenv("HDF5_VOL_CONNECTOR");
|
||||
if (connector == null)
|
||||
assertTrue("H5.H5VLget_connector_name H5VL_NATIVE", native_name.compareToIgnoreCase(HDF5Constants.H5VL_NATIVE_NAME)==0);
|
||||
}
|
||||
catch (Throwable err) {
|
||||
err.printStackTrace();
|
||||
|
@ -1,10 +1,8 @@
|
||||
JUnit version 4.11
|
||||
.testH5EprintInt
|
||||
.testH5Eset_current_stack_invalid_stkid
|
||||
.testH5Eset_current_stack
|
||||
.testH5Eget_num
|
||||
.testH5Eclear
|
||||
.testH5Eprint
|
||||
.testH5Epush_null_name
|
||||
.testH5Eget_num_with_msg
|
||||
.testH5Eclear2_with_msg
|
||||
@ -30,49 +28,5 @@ JUnit version 4.11
|
||||
|
||||
Time: XXXX
|
||||
|
||||
OK (28 tests)
|
||||
OK (26 tests)
|
||||
|
||||
HDF5-DIAG: Error detected in HDF5 (version (number)) thread (IDs):
|
||||
#000: (file name) line (number) in H5Fopen(): unable to open file
|
||||
major: File accessibility
|
||||
minor: Unable to open file
|
||||
#001: (file name) line (number) in H5VL_file_open(): open failed
|
||||
major: Virtual Object Layer
|
||||
minor: Can't open object
|
||||
#002: (file name) line (number) in H5VL__file_open(): open failed
|
||||
major: Virtual Object Layer
|
||||
minor: Can't open object
|
||||
#003: (file name) line (number) in H5VL__native_file_open(): unable to open file
|
||||
major: File accessibility
|
||||
minor: Unable to open file
|
||||
#004: (file name) line (number) in H5F_open(): unable to open file: name = 'test', tent_flags = 1
|
||||
major: File accessibility
|
||||
minor: Unable to open file
|
||||
#005: (file name) line (number) in H5FD_open(): open failed
|
||||
major: Virtual File Layer
|
||||
minor: Unable to initialize object
|
||||
#006: (file name) line (number) in H5FD_sec2_open(): unable to open file: name = 'test', errno = 2, error message = 'No such file or directory', flags = 1, o_flags = 2
|
||||
major: File accessibility
|
||||
minor: Unable to open file
|
||||
HDF5-DIAG: Error detected in HDF5 (version (number)) thread (IDs):
|
||||
#000: (file name) line (number) in H5Fopen(): unable to open file
|
||||
major: File accessibility
|
||||
minor: Unable to open file
|
||||
#001: (file name) line (number) in H5VL_file_open(): open failed
|
||||
major: Virtual Object Layer
|
||||
minor: Can't open object
|
||||
#002: (file name) line (number) in H5VL__file_open(): open failed
|
||||
major: Virtual Object Layer
|
||||
minor: Can't open object
|
||||
#003: (file name) line (number) in H5VL__native_file_open(): unable to open file
|
||||
major: File accessibility
|
||||
minor: Unable to open file
|
||||
#004: (file name) line (number) in H5F_open(): unable to open file: name = 'test', tent_flags = 1
|
||||
major: File accessibility
|
||||
minor: Unable to open file
|
||||
#005: (file name) line (number) in H5FD_open(): open failed
|
||||
major: Virtual File Layer
|
||||
minor: Unable to initialize object
|
||||
#006: (file name) line (number) in H5FD_sec2_open(): unable to open file: name = 'test', errno = 2, error message = 'No such file or directory', flags = 1, o_flags = 2
|
||||
major: File accessibility
|
||||
minor: Unable to open file
|
||||
|
@ -1,29 +1,45 @@
|
||||
JUnit version 4.11
|
||||
.testH5Oexists_by_name
|
||||
.testH5Oget_native_info_dataset
|
||||
.testH5Oopen_by_token
|
||||
.testH5Oget_info_by_idx_n0
|
||||
.testH5Oget_info_by_idx_n3
|
||||
.testH5Oget_native_info_datatype
|
||||
.testH5Oget_info_by_name_not_exist_name
|
||||
.testH5Ovisit_by_name
|
||||
.testH5Oget_native_info_by_name_datatype
|
||||
.testH5Oget_info_by_idx_name_not_exist_name
|
||||
.testH5Oget_info_datatype
|
||||
.testH5Oget_info_by_idx_not_exist_name
|
||||
.testH5Oopen_by_idx_n0
|
||||
.testH5Oopen_by_idx_n3
|
||||
.testH5Oget_native_info_by_name_not_exist_name
|
||||
.testH5Oopen_not_exists
|
||||
.testH5Ovisit
|
||||
.testH5Oget_info_by_idx_not_exist_create
|
||||
.testH5Oget_native_info_by_idx_not_exist_name
|
||||
.testH5Oget_info_by_name_hardlink
|
||||
.testH5Oget_info_by_name_group
|
||||
.testH5Oopen_by_addr
|
||||
.testH5Oget_info_by_name_not_exists
|
||||
.testH5Oget_native_info_by_idx_not_exist_create
|
||||
.testH5Oget_info_by_name_dataset
|
||||
.testH5Oget_info_group
|
||||
.testH5Oget_native_info_hardlink
|
||||
.testH5Oget_native_info_by_name_hardlink
|
||||
.testH5Oget_native_info_by_idx_name_not_exist_name
|
||||
.testH5Oget_info_by_name_datatype
|
||||
.testH5Oget_info_hardlink
|
||||
.testH5Oget_native_info_group
|
||||
.testH5Oget_native_info_by_name_not_exists
|
||||
.testH5Oget_native_info_by_name_dataset
|
||||
.testH5Oget_info_by_idx_name_not_exist_create
|
||||
.testH5Oget_native_info_by_idx_n0
|
||||
.testH5Oget_native_info_by_idx_n3
|
||||
.testH5Oget_info_dataset
|
||||
.testH5Oget_native_info_by_name_group
|
||||
.testH5Oget_native_info_by_idx_name_not_exist_create
|
||||
|
||||
Time: XXXX
|
||||
|
||||
OK (23 tests)
|
||||
OK (39 tests)
|
||||
|
||||
|
@ -1,22 +1,27 @@
|
||||
JUnit version 4.11
|
||||
.testH5Oget_comment_by_name_null
|
||||
.testH5Oget_native_info_by_name_invalid
|
||||
.testH5Ovisit_by_name_nullname
|
||||
.testH5Oget_info_invalid
|
||||
.testH5Ovisit_by_name_null
|
||||
.testH5Odisable_mdc_flushes
|
||||
.testH5Oget_comment_invalid
|
||||
.testH5Oget_native_info_invalid
|
||||
.testH5Oset_comment_by_name_invalid
|
||||
.testH5Oare_mdc_flushes_disabled
|
||||
.testH5Oopen_null
|
||||
.testH5Oclose_invalid
|
||||
.testH5Oflush_invalid
|
||||
.testH5Oget_native_info_by_name_null
|
||||
.testH5Oget_comment_by_name_invalid
|
||||
.testH5Orefresh_invalid
|
||||
.testH5Ocopy_null_dest
|
||||
.testH5Oget_native_info_by_idx_null
|
||||
.testH5Olink_invalid
|
||||
.testH5Oget_info_by_idx_invalid
|
||||
.testH5Oget_info_by_idx_null
|
||||
.testH5Olink_null_dest
|
||||
.testH5Oget_native_info_by_idx_invalid
|
||||
.testH5Oget_info_by_name_invalid
|
||||
.testH5Oget_info_by_name_null
|
||||
.testH5Ocopy_invalid
|
||||
@ -29,5 +34,5 @@ JUnit version 4.11
|
||||
|
||||
Time: XXXX
|
||||
|
||||
OK (27 tests)
|
||||
OK (32 tests)
|
||||
|
||||
|
@ -1,4 +1,5 @@
|
||||
JUnit version 4.11
|
||||
.testH5VLget_connector_id_by_name
|
||||
.testH5VLget_connector_id
|
||||
.testH5VLnative_init
|
||||
.testH5VLget_connector_name
|
||||
@ -7,5 +8,5 @@ JUnit version 4.11
|
||||
|
||||
Time: XXXX
|
||||
|
||||
OK (5 tests)
|
||||
OK (6 tests)
|
||||
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user