Please, help us to better serve our user community by answering the following short survey: https://www.hdfgroup.org/website-survey/
HDF5 2.0.0.50d6458
API Reference
Loading...
Searching...
No Matches
Release Software Changes for HDF5 1.10

Software Changes from Release to Release in HDF5 1.10

For a description of the major new features that were introduced, please see New Features in HDF5 Release 1.10.

This page provides information on the changes that a maintenance developer needs to be aware of between successive releases of HDF5, such as:

  • New or changed features or tools
  • Syntax and behavioral changes in the existing application programming interface (API)
  • Certain types of changes in configuration or build processes

Note that bug fixes and performance enhancements in the C library are automatically picked up by the C++, Fortran, and Java libraries.

The following information is included below.

See [API Compatibility Reports for 1.10]() for information regarding compatibility with previous releases.

Compatibility and Performance Issues

Not all HDF5-1.10 releases are compatible. Users should NOT be using 1.10 releases prior to HDF5-1.10.3. See the compatibility matrix below for details on compatibility between 1.10 releases:

Release1.10.5+1.10.41.10.31.10.21.10.11.10.0-patch11.10.0
1.10.5+.YesYesNoNoNoNo
1.10.4Yes.YesNoNoNoNo
1.10.3YesYes.NoNoNoNo
1.10.2NoNoNo.NoNoNo

The following images show how performance has changed from release to release.

td
td

The release notes also list changes made to the library, but these notes tend to be more at a more detail-oriented level. The release notes may include new features, bugs fixed, supported configuration features, platforms on which the library has been tested, and known problems. The release note files are listed below and can be found at the top level of the HDF5 source code tree in the release_docs directory.

FilenameDescription
Release NotesTechnical notes regarding the current release of the HDF5 library (RELEASE.txt in the source code)
HISTORY-1_10.txtRelease information for all HDF5-1.10 releases
HISTORY-1_8_0-1_10_0.txtDevelopment history between the HDF5-1.8.0 and HDF5-1.10.0 releases
HISTORY-1_8.txtRelease information for HDF5-1.8.0 through HDF5-1.8.21 releases
HISTORY-1_0-1_8_0_rc3.txtTechnical notes starting with HDF5-1.0.0 and ending with HDF5-1.8.0-rc3 (the state of the code prior to the HDF5-1.8.0 release)

Release 1.10.9 versus 1.10.8

New and Changed Functions, Classes, Subroutines, Wrappers, and Macros

In the Java API

One Java wrapper was added:

  • H5.H5export_dataset

Compatibility Notes and Reports

See the [API compatibility report between 1.10.8 and 1.10.9]() for information regarding compatibility with the previous release.

Release 1.10.8 versus 1.10.7

New and Changed Functions, Classes, Subroutines, Wrappers, and Macros

In the C++ API

One C++ wrapper was added:

  • DataSet::operator=

Compatibility Notes and Reports

See the [API compatibility report between 1.10.7 and 1.10.8]() for information regarding compatibility with the previous release.

Release 1.10.7 versus 1.10.6

New and Changed Functions, Classes, Subroutines, Wrappers, and Macros

In the C Interface (main library)

The following are new C functions in this release:

In the C++ API

The following C++ wrappers were added:

Compatibility Notes and Reports

See the [API compatibility report between 1.10.7 and 1.10.8]() for information regarding compatibility with the previous release.

Release 1.10.6 versus 1.10.5

New and Changed Functions, Classes, Subroutines, Wrappers, and Macros

In the C Interface (main library)

The following are new C functions in this release:

In the C++ API

The following C++ wrappers were added:

Compatibility Notes and Reports

See the [API compatibility report between 1.10.7 and 1.10.8]() for information regarding compatibility with the previous release.

Release 1.10.5 versus 1.10.4

New and Changed Functions, Classes, Subroutines, Wrappers, and Macros

In the C Interface (main library)

The following are new C functions in this release:

The following changed in this release:

In 1.10.3 the original functions were versioned to H5Oget_info*1 and H5Ovisit*1 and the macros H5Oget_info* and H5Ovisit* were created. This broke the API compatibility for a maintenance release. In HDF5-1.10.5, the macros introduced in HDF5-1.10.3 were removed. The H5Oget_info*1 and H5Ovisit*1 APIs were copied to H5Oget_Info* and H5Ovisit*. As an example, H5Oget_info and H5Oget_info1 are identical in this release.

In the C++ API

The following C++ wrapper was added:

  • H5Object::visit() - Wrapper for the C API H5Ovisit2. Recursively visit elements reachable from an HDF5 object and perform a common set of operations across all of those elements.

In the Fortran API

The following Fortran wrappers were added or changed:

The following Fortran utility function was added:

  • h5lib.h5gmtime - converts (C) time_t structure to Fortran DATE AND TIME storage format

A new Fortran derived type was added:

  • c_h5o_info_t - This is interoperable with C's h5o_info_t. This is needed for callback functions which pass C's h5o_info_t data type definition.

In the Java wrapper

The following Java wrappers were added or changed:

Compatibility Notes and Reports

See the [API compatibility report between 1.10.5 and 1.10.2/1.10.3/1.10.4]() for details.

Release 1.10.4 versus 1.10.3

See the [API compatibility report between 1.10.4 and 1.10.3]() for details.

Release 1.10.3 versus 1.10.2

New and Changed Functions, Classes, Subroutines, Wrappers, and Macros

In the C Interface (main library)

The following are new C functions in this release:

In the C High Level Interface

The following C functions were deprecated in this release:

In the C++ API

Several C++ wrappers were added or modified to provide additional support. See the API Compatibility Report for details.

Compatibility Notes and Report

See the [API compatibility report between 1.10.4 and 1.10.3]() for details.

Release 1.10.2 versus 1.10.1

This section lists interface-level changes and other user-visible changes in behavior in the transition from HDF5 Release 1.10.1 to Release 1.10.2.

New and Changed Functions, Classes, Subroutines, Wrappers, and Macros

In the C Interface (main library)

The following are new C functions in this release:

The following C functions changed in this release:

  • H5Pset_libver_bounds - HDF5-1.10 was added to the range of versions
  • H5Pset_virtual - A change was made to the method of searching for VDS source files
  • H5PL* - The parameters for many of the H5PL APIs were renamed

In the C High Level Interface

The following new C function was added to this release:

  • H5DOread_chunk - Reads a raw data chunk directly from a dataset in a file

In the C++ API

The following C++ wrappers were added:

  • H5Lcreate_soft - Creates a soft link from link_name to target_name
  • H5Lcreate_hard - Creates a hard link from new_name to curr_name
  • H5Lcopy - Copy an object from a group of file
  • H5Lmove - Rename an object in a group or file
  • H5Ldelete - Removes the specified link from this location
  • H5Tencode - Creates a binary object description of this datatype
  • H5Tdecode - Returns the decoded type from the binary object description
  • H5Lget_info - Returns the information of the named link

These were also added:

  • Class LinkCreatPropList for link create property list

Overloaded functions:

  • H5Location::createGroup to take a link creation property list

See the API Compatibility report for complete details.

In the Java API

The following Java wrappers were added:

  • H5Pset_evict_on_close - Controls the library's behavior of evicting metadata associated with a closed object
  • H5Pget_evict_on_close - Retrieves the file access property list setting that determines whether an HDF5 object will be evicted from the library's metadata cache when closed
  • H5Pset_chunk_opts - Sets the edge chunk option in a dataset creation property list
  • H5Pget_chunk_opts - Retrieves the edge chunk option setting from a dataset creation property list
  • H5Pset_efile_prefix - Sets the external dataset storage file prefix in the dataset access property list
  • H5Pget_efile_prefix - Retrieves the prefix for external raw data storage files as set in the dataset access property list
  • H5Pset_virtual_prefix - Sets prefix to be applied to VDS source file paths
  • H5Pget_virtual_prefix - Retrieves prefix applied to VDS source file paths

See the Release.txt file for details.

Tools

New options were added to the h5clear utility:

  • –filesize - Print the file's EOA and EOF
  • –increment=C - Set the file's EOA to the maximum of (EOA, EOF) + C for the file C is >= 0; C is optional and will default to 1M when not set

A new option was added to h5diff

  • –enable-error-stack - Enable the error stack

Compatibility Notes and Report

See the [API compatibility report between 1.10.4 and 1.10.3]() for details.

Release 1.10.1 versus 1.10.0

This section lists interface-level changes and other user-visible changes in behavior in the transition from HDF5 Release 1.10.0 (and HDF5-1.10.0-patch1) to Release 1.10.1.

New Features

Several new features are introduced in HDF5 Release 1.10.1.

  • Metadata Cache Image
  • Metadata Cache Evict on Close
  • Paged Aggregation
  • Page Buffering

New Features, including associated C Functions

The following features are described and documented in New Features in HDF5 Release 1.10. Each new feature in 1.10.1 is listed below along with the associated C functions:

New and Changed Functions, Classes, Subroutines, Wrappers, and Macros

In the C Interface (main library)

The following new C functions were added:

In the C++ API

New member functions were added to provide const versions. For example, these methods,

  • ArrayType::getArrayDims ( hsize_t* dims ) const
  • ArrayType::getArrayNDims ( ) const

replace these:

  • ArrayType::getArrayDims(hsize_t* dims)
  • ArrayType::getArrayNDims()

Several functions were moved to other classes. For example, this method,

  • H5Location::openDataSet (char const* name) const

replaces:

  • CommonFG::openDataSet (char const* name) const

PLEASE review the Compatibility report below for complete information on the C++ changes in this release.

Compatibility Report

See the [API compatibility report between 1.10.1 and 1.10.0-patch1]() for details.

Release 1.10.0 versus Release 1.8.16

This section lists interface-level changes and other user-visible changes in behavior in the transition from HDF5 Release 1.8.16 to Release 1.10.0.

Changed Type

  • hid_t - Changed from a 32-bit to a 64-bit value. hid_t is the type is used for all HDF5 identifiers. This change, which is necessary to accommodate the capacities of modern computing systems, therefore affects all HDF5 applications. If an application has been using HDF5's hid_t the type, recompilation will normally be sufficient to take advantage of HDF5 Release 1.10.0. If an application uses an integer type instead of HDF5's hid_t type, those identifiers must be changed to a 64-bit type when the application is ported to the 1.10.x series.

New Features and Feature Sets

Several new features are introduced in HDF5 Release 1.10.0.

  • Single-Writer / Multiple-Reader or SWMR
  • Collective Metadata I/O
  • Fine-tuning the metadata cache
  • File Space Management
  • Virtual Datasets or VDS
  • Partial Edge Chunk Options
  • Relative Pathnames for External Links
  • Property List Encoding and Decoding

More substantial lists follow, including new and modified C functions and Fortran subroutines.

New Features, including associated C Functions and Fortran Wrappers

The following features are described and documented in New Features in HDF5 Release 1.10.0. On this page, we list each feature and its associated C functions and Fortran wrappers.

Single-writer / Multiple-reader, commonly called SWMR:

  • H5Fstart_swmr_write - Enables SWMR writing mode for a file.
  • H5DOappend - Appends data to a dataset along a specified dimension. (This is a high-level API.)
  • H5Pget_append_flush - Retrieves the values of the append property that is set up in the dataset access property list.
  • H5Pset_append_flush - Sets two actions to perform when the size of a dataset's dimension being appended reaches a specified boundary.
  • H5Pget_object_flush_cb - Retrieves the object flush property values from the file access property list.
  • H5Pset_object_flush_cb - Sets a callback function to invoke when an object flush occurs in the file.
  • H5Odisable_mdc_flushes - Prevents metadata entries for an HDF5 object from being flushed from the metadata cache to storage.
  • H5Oenable_mdc_flushes - Returns the cache entries associated with an HDF5 object to the default metadata flush and eviction algorithm.
  • H5Oare_mdc_flushes_disabled - Determines if an HDF5 object (dataset, group, committed datatype) has had flushes of metadata entries disabled.
  • H5Fdisable_mdc_flushes - Globally prevents dirty metadata entries from being flushed from the metadata cache to storage.
  • H5Fenable_mdc_flushes - Returns a file's metadata cache to the standard eviction and flushing algorithm.
  • H5Fare_mdc_flushes_disabled - Determines if flushes have been globally disabled for a file's metadata cache.
  • H5Fget_mdc_flush_disabled_obj_ids - Returns a list of all object identifiers for which flushes have been disabled in a file's metadata cache.

Command-line Tools:

  • h5watch - Allows users to output new records appended to a dataset under SWMR access as it grows. The functionality is similar to the Unix user command tail with the follow option, which outputs appended data as the file grows.
  • h5format_convert - This tool allows users to convert the indexing type of a chunked dataset made with a 1.10.x version of the HDF5 Library when the latest file format is used to the 1.8.x version 1 B-tree indexing type. For example, datasets created using SWMR access, can be converted to be accessed by the HDF5 1.18 library and tools. The tool does not rewrite raw data, but it does rewrite HDF5 metadata.

Collective Metadata I/O:

Fine-tuning the Metadata Cache:

  • H5Fget_metadata_read_retry_info - Retrieves the collection of read retries for metadata items with checksum.
  • H5Pget_metadata_read_attempts - Retrieves the number of read attempts from a file access property list.
  • H5Pset_metadata_read_attempts - Sets the number of read attempts in a file access property list.
  • H5Dflush - Causes all buffers associated with a dataset to be immediately written to disk without removing the data from the cache.
  • H5Drefresh - Causes all buffers associated with a dataset to be cleared and immediately re-loaded with updated contents from disk storage.
  • H5Gflush - Causes all buffers associated with a group to be immediately flushed to disk without removing the data from the cache.
  • H5Grefresh - Causes all buffers associated with a group to be cleared and immediately re-loaded with updated contents from disk storage.
  • H5Oflush - Causes all buffers associated with an object to be immediately flushed to disk without removing the data from the cache.
  • H5Orefresh - Causes all buffers associated with an object to be cleared and immediately re-loaded with updated contents from disk storage.
  • H5Tflush - Causes all buffers associated with a committed datatype to be immediately flushed to disk without removing the data from the cache.
  • H5Trefresh - Causes all buffers associated with a committed datatype to be cleared and immediately re-loaded with updated contents from disk storage.
  • H5Fget_intent - Determines the read/write or read-only status of a file.

Logging APIs:

File Space Management:

  • H5Fget_free_sections - Retrieves free-space section information for a file.
  • H5Fget_freespace - Returns the amount of free space in a file.
  • H5Fget_info2 - Returns global information for a file.
  • H5Pset_file_space - Sets the file space management strategy and/or the free-space section threshold for an HDF5 file.
  • H5Pget_file_space - Retrieves the file space management strategy and/or the free-space section threshold for an HDF5 file.

The following tool has been modified to preserve or modify file freepace information appropriately when processing files employing the VDS feature:

  • h5repack - Repacks HDF5 files with various options, including the ability to change the applied filters. This version of h5repack understands the file free space feature and handles the file and metadata appropriately.

Virtual Dataset or VDS:

Supporting Functions:

Modified Functions:

The following pre-exising functions have been modified to understand virtual datasets.

Partial Edge Chunks:

  • H5Pset_chunk_opts - Sets a partial edge chunk option in a dataset access property list.
  • H5Pget_chunk_opts - Retrieves partial edge chunk option setting from a dataset access property list.

Relative Pathnames for External Links:

These functions enable the user to specify the locations of external files. (These functions are not yet documented as of the time of release for 1.10.0.)

Property List Encoding and Decoding:

Additional New Functions:

The following new functions appear in HDF5 Release 1.10.0 but are not yet documented:

New and Changed Elements of the Packet Table (H5PT) High-level API

In the C Interface

Replacement functions:

  • H5PTcreate - Takes a property list identifier to provide flexibility on creation properties. H5PTcreate_fl has been removed.
  • H5PTfree_vlen_buff - Replaces H5PTfree_vlen_readbuff.

New functions:
Two accessor functions have been added.

  • H5PTget_dataset - Returns the identifier of the dataset associated a packet table.
  • H5PTget_type - Returns the identifier of the datatype used by a packet table.
  • H5PTis_varlen - Determines whether a type is variable-length.

In the C++ Interface

Overloaded constructor
An overloaded constructor has been added.

  • FL_PacketTable - Takes a property list identifier to provide flexibility on creation properties.
  • H5PTfree_vlen_buff - Replaces H5PTfree_vlen_readbuff.

Accessor wrappers
Two accessor wrappers are added to class PacketTable.

  • PacketTable::GetDataset() - Returns the identifier of the dataset associated a packet table.
  • PacketTable::GetDatatype() - Returns the identifier of the datatype used by a packet table.

Other wrappers

  • PacketTable::FreeBuff() - Replaces VL_PacketTable::FreeReadBuff().
  • PacketTable::IsVariableLength() - Replaces VL_PacketTable::IsVariableLength().

Overloaded functions:
Where a member functions has a char* as an argument, an overloaded functions has been added to provide the const char* argument. The existing version will be deprecated in a future release.

Java Interface Changes

  • Integration into Main HDF5 Library - The Java HDF5 JNI library has been integrated into the HDF5 repository.

Configure option:

  • –enable-java

CMake option:

  • -DHDF5_BUILD_JAVA:BOOL=ON

Prior to the 1.10.x series, the HDF5 Java tools were built from an independent repository and were not as fully integrated with HDF5. were built from an independent repository and were not as fully integrated with HDF5.

Package Hierarchy Change

  • The package hierarchy has changed to hdf.hdflib.hdf5.
  • Prior to the 1.10.x series, the hierarchy was ncsa.hdf.hdflib.hdf5.

New Java APIs

A number of new APIs have been added in the Java interface, including APIs for the VDS and SWMR features.

Functions with Changed Behavior

  • H5Lexists - The behavior of this function has changed in this release. When testing the pathname / (a slash representing the root of an HDF5 file) H5Lexists now returns successfully with the value 1 (one). See the entry in the HDF5 Reference Manual for H5Lexists for more information.

API Compatibility

See API Compatibility Macros for details on the following.

New API Compatibility Flag

A new v18 flag was added enabling the building of HDF5 such that the default API is compatible with the HDF5 Release 1.8.x API:

  • –with-default-api-version=v18

New versioned functions and associated compatibility macros

Two functions and a struct have been converted to a versioned form in this release. Compatibility macros have been created for each.

Autotools Configuration and Large File Support

Autotools configuration has been extensively reworked and autotool's handling of large file support has been overhauled in this release.

See the following sections in RELEASE.txt:

  • Autotools Configuration Has Been Extensively Reworked
  • LFS Changes

RELEASE.txt can be found in the release_docs/ subdirectory at the root level of the HDF5 code distribution.

Compatibility Report and Comments

[Compatibility report for Release 1.10.0 versus Release 1.8.16]()

Comments regarding the report

In the C interface, the hid_t change from 32-bit to 64-bit was made in order to address a performance problem that arose when the library "ran out" of valid object identifiers to issue and thus needed to employ an expensive algorithm to find previously issued identifiers that could be re-issued. This problem is avoided by switching the size of the hid_t type to 64-bit integers instead of 32-bit integers in order to make the pool of available integers significantly larger. (H5E_major_t and H5E_minor_t are aliased to hid_t which is why they changed size as well). (An alternate solution to this problem was applied in release HDF5 1.8.5 but this is the cleaner/preferred solution and had to wait until 1.10.0 to be included).

hbool_t will now be defined as a Bool type when configure determines that it's available.

Public structs that have members of type hid_t or hbool_t are affected by the above changes accordingly.

The H5Fget_info function was renamed due to the introduction of a newer version of the function which returns additional information. The H5Rdereference function was renamed due to the introduction of a newer version of the function which allows a data access property list to be passed in. Both changes are accompanied with compatibility macros, so while existing code will need to be recompiled in order to use the newer library version, these functions do not need to be changed in application code using them provided that the API Compatibility Macros are configured appropriately.