summaryrefslogtreecommitdiffstats
path: root/fortran
diff options
context:
space:
mode:
authorLarry Knox <lrknox@hdfgroup.org>2023-05-02 21:06:16 (GMT)
committerGitHub <noreply@github.com>2023-05-02 21:06:16 (GMT)
commit271b0fbb8c7525c9e33fddc53a1d594352a4b569 (patch)
treebae9fafe6061f3dba6a2ca8dc640e65b69b91ac7 /fortran
parent6eb021b68a8b46bbc89844713f014e6ba729ca7d (diff)
downloadhdf5-271b0fbb8c7525c9e33fddc53a1d594352a4b569.zip
hdf5-271b0fbb8c7525c9e33fddc53a1d594352a4b569.tar.gz
hdf5-271b0fbb8c7525c9e33fddc53a1d594352a4b569.tar.bz2
Sync 2 new develop prs to hdf5_1_14 (#2879)
* Add bin directory to make distclean (#2872) This allows h5cc to be cleaned up * Fixed test failure for when REAL is promoted via a compiler flag (#2873) --------- Co-authored-by: Dana Robinson <43805+derobins@users.noreply.github.com> Co-authored-by: Scot Breitenfeld <brtnfld@hdfgroup.org>
Diffstat (limited to 'fortran')
-rw-r--r--fortran/test/fortranlib_test.F902
-rw-r--r--fortran/test/tH5P.F9025
2 files changed, 14 insertions, 13 deletions
diff --git a/fortran/test/fortranlib_test.F90 b/fortran/test/fortranlib_test.F90
index ec0dcec..eb587a9 100644
--- a/fortran/test/fortranlib_test.F90
+++ b/fortran/test/fortranlib_test.F90
@@ -204,7 +204,7 @@ PROGRAM fortranlibtest
CALL write_test_status(ret_total_error, ' Dataset chunk cache configuration', total_error)
ret_total_error = 0
- CALL test_misc_properties(cleanup, ret_total_error)
+ CALL test_misc_properties(ret_total_error)
CALL write_test_status(ret_total_error, ' Miscellaneous properties', total_error)
ret_total_error = 0
diff --git a/fortran/test/tH5P.F90 b/fortran/test/tH5P.F90
index 37ecdac..57320df 100644
--- a/fortran/test/tH5P.F90
+++ b/fortran/test/tH5P.F90
@@ -777,10 +777,9 @@ END SUBROUTINE test_chunk_cache
!
!-------------------------------------------------------------------------
!
-SUBROUTINE test_misc_properties(cleanup, total_error)
+SUBROUTINE test_misc_properties(total_error)
IMPLICIT NONE
- LOGICAL, INTENT(IN) :: cleanup
INTEGER, INTENT(INOUT) :: total_error
INTEGER(hid_t) :: fapl_id = -1 ! Local fapl
@@ -872,18 +871,17 @@ SUBROUTINE test_in_place_conversion(cleanup, total_error)
INTEGER(HSIZE_T), DIMENSION(1) :: dims = (/array_len/) ! Dataset dimensions
INTEGER :: rank = 1 ! Dataset rank
- REAL(KIND=Fortran_DOUBLE), DIMENSION(1:array_len), TARGET :: wbuf_d
- REAL(KIND=Fortran_DOUBLE), DIMENSION(1:array_len) :: wbuf_d_org
- REAL(KIND=Fortran_REAL) , DIMENSION(1:array_len), TARGET :: rbuf
+ REAL(KIND=C_DOUBLE), DIMENSION(1:array_len), TARGET :: wbuf_d
+ REAL(KIND=C_DOUBLE), DIMENSION(1:array_len) :: wbuf_d_org
+ REAL(KIND=C_FLOAT), DIMENSION(1:array_len), TARGET :: rbuf
INTEGER :: i
TYPE(C_PTR) :: f_ptr
! create the data
DO i = 1, array_len
- wbuf_d(i) = 1_Fortran_DOUBLE + 0.123456789123456_Fortran_DOUBLE
+ wbuf_d(i) = 1.0_C_DOUBLE + 0.123456789123456_C_DOUBLE
wbuf_d_org(i) = wbuf_d(i)
ENDDO
-
!
!Create file "inplace_conv.h5" using default properties.
!
@@ -917,22 +915,22 @@ SUBROUTINE test_in_place_conversion(cleanup, total_error)
CALL check("h5pget_modify_write_buf_f", error, total_error)
CALL VERIFY("h5pget_modify_write_buf_f", modify_write_buf, .TRUE., total_error)
- CALL h5dcreate_f(file_id, dsetname, H5T_NATIVE_REAL, dspace_id, dset_id, error)
+ CALL h5dcreate_f(file_id, dsetname, h5kind_to_type(KIND(rbuf(1)), H5_REAL_KIND), dspace_id, dset_id, error)
CALL check("h5dcreate_f", error, total_error)
- f_ptr = C_LOC(wbuf_d)
- CALL h5dwrite_f(dset_id, H5T_NATIVE_DOUBLE, f_ptr, error, H5S_ALL_F, H5S_ALL_F, xfer_prp=plist_id)
+ f_ptr = C_LOC(wbuf_d(1))
+ CALL h5dwrite_f(dset_id, h5kind_to_type(KIND(wbuf_d(1)), H5_REAL_KIND), f_ptr, error, H5S_ALL_F, H5S_ALL_F, xfer_prp=plist_id)
CALL check("h5dwrite_f", error, total_error)
! Should not be equal for in-place buffer use
CALL VERIFY("h5dwrite_f -- in-place", wbuf_d(1), wbuf_d_org(1), total_error, .FALSE.)
f_ptr = C_LOC(rbuf)
- CALL h5dread_f(dset_id, H5T_NATIVE_REAL, f_ptr, error)
+ CALL h5dread_f(dset_id, h5kind_to_type(KIND(rbuf(1)), H5_REAL_KIND), f_ptr, error)
CALL check("h5dread_f", error, total_error)
DO i = 1, array_len
- CALL VERIFY("h5dwrite_f -- in-place", rbuf(i), REAL(wbuf_d_org(i), Fortran_REAL), total_error)
+ CALL VERIFY("h5dwrite_f -- in-place", rbuf(i), REAL(wbuf_d_org(i), C_FLOAT), total_error)
ENDDO
!
@@ -954,6 +952,9 @@ SUBROUTINE test_in_place_conversion(cleanup, total_error)
CALL h5pclose_f(plist_id, error)
CALL check("h5pclose_f", error, total_error)
+ IF(cleanup) CALL h5_cleanup_f(fix_filename, H5P_DEFAULT_F, error)
+ CALL check("h5_cleanup_f", error, total_error)
+
END SUBROUTINE test_in_place_conversion
END MODULE TH5P