H5Pinsert is a macro that is mapped to either
      H5Pinsert1 or
      H5Pinsert2,
      depending on the needs of the application.
      Such macros are provided to facilitate application compatibility. For example:
H5Pinsert macro 
              will be mapped to H5Pinsert1 and 
              will use the H5Pinsert1 syntax 
              (first signature above)
              if an application is coded for HDF5 Release 1.6.x.
          H5Pinsert macro 
              mapped to H5Pinsert2 and 
              will use the H5Pinsert2 syntax 
              (second signature above)
              if an application is coded for HDF5 Release 1.8.x.
      
      When both the HDF5 Library and the application are built and 
      installed with no specific compatibility flags, 
      H5Pinsert is mapped to the most recent version of
      the function, currently 
      H5Pinsert2.
      If the library and/or application is compiled for Release 1.6
      emulation, H5Pinsert will be mapped to 
      H5Pinsert1.
      Function-specific flags are available to override these settings 
      on a function-by-function basis when the application is compiled. 
      
Specific compile-time compatibility flags and the resulting mappings are as follows:
| Compatibility setting | H5Pinsertmapping | 
|---|---|
| Global settings | |
| No compatibility flag | H5Pinsert2 | 
| Enable deprecated symbols | H5Pinsert2 | 
| Disable deprecated symbols | H5Pinsert2 | 
| Emulate Release 1.6 interface | H5Pinsert1 | 
| Function-level macros | |
| H5Pinsert_vers = 2     | H5Pinsert2 | 
| H5Pinsert_vers = 1 | H5Pinsert1 | 
For more information on macro use and mappings, see the “API Compatibility Macros in HDF5” document.
H5Pinsert interface
        and the only interface available prior to HDF5 Release 1.8.0.
        This signature and the corresponding function are now deprecated 
        but will remain directly callable as 
        H5Pinsert1.
        
        Signature [2] above was introduced with HDF5 Release 1.8.0
        and is the recommended and default interface.
        It is directly callable as
        H5Pinsert2.
        
See “API Compatibility Macros in HDF5” for circumstances under which either of these functions might not be available in an installed instance of the HDF5 Library.
If a C routine that takes a function pointer as an argument is called from within C++ code, the C routine should be returned from normally.
Examples of this kind of routine include callbacks such as 
      H5Pset_elink_cb and H5Pset_type_conv_cb 
      and functions such as H5Tconvert and 
      H5Ewalk2.
Exiting the routine in its normal fashion allows the HDF5 C Library to clean up its work properly. In other words, if the C++ application jumps out of the routine back to the C++ “catch” statement, the library is not given the opportunity to close any temporary data structures that were set up when the routine was called. The C++ application should save some state as the routine is started so that any problem that occurs might be diagnosed.
| Release | Change | 
| 1.8.8 | Fortran updated to Fortran2003. | 
| 1.8.0 | The function 
            C function H5Pinsertrenamed toH5Pinsert1and deprecated in this release.C macro H5Pinsertand the C functionH5Pinsert2introduced in this release. |