-
-
Notifications
You must be signed in to change notification settings - Fork 269
/
Copy pathh5ex_t_objref_F03.F90
141 lines (136 loc) · 4.15 KB
/
h5ex_t_objref_F03.F90
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
!************************************************************
!
! This example shows how to read and write object references
! to a dataset. The program first creates objects in the
! file and writes references to those objects to a dataset
! with a dataspace of DIM0, then closes the file. Next, it
! reopens the file, dereferences the references, and outputs
! the names of their targets to the screen.
!
! This file is intended for use with HDF5 Library version 1.8
! with --enable-fortran2003
!
!************************************************************
PROGRAM main
USE HDF5
USE ISO_C_BINDING
IMPLICIT NONE
CHARACTER(LEN=20), PARAMETER :: filename = "h5ex_t_objref_F03.h5"
CHARACTER(LEN=3) , PARAMETER :: dataset = "DS1"
INTEGER , PARAMETER :: dim0 = 2
INTEGER(HID_T) :: file, space, dset, obj ! Handles
INTEGER :: hdferr
INTEGER(hsize_t), DIMENSION(1:1) :: dims = (/dim0/)
TYPE(hobj_ref_t_f), DIMENSION(1:dim0), TARGET :: wdata ! Write buffer
TYPE(hobj_ref_t_f), DIMENSION(:), ALLOCATABLE, TARGET :: rdata ! Read buffer
INTEGER :: objtype
INTEGER(SIZE_T) :: name_size
CHARACTER(LEN=80) :: name
INTEGER(HSIZE_T), DIMENSION(1:1) :: maxdims
INTEGER :: i
TYPE(C_PTR) :: f_ptr
!
! Initialize FORTRAN interface.
!
CALL h5open_f(hdferr)
!
! Create a new file using the default properties.
!
CALL h5fcreate_f(filename, H5F_ACC_TRUNC_F, file, hdferr)
!
! Create a dataset with a null dataspace.
!
CALL h5screate_f(H5S_NULL_F,space,hdferr)
CALL h5dcreate_f(file, "DS2", H5T_STD_I32LE, space, obj, hdferr)
!
CALL h5dclose_f(obj , hdferr)
CALL h5sclose_f(space, hdferr)
!
! Create a group.
!
CALL h5gcreate_f(file, "G1", obj, hdferr)
CALL h5gclose_f(obj, hdferr)
!
! Create references to the previously created objects. note, space_id
! is not needed for object references.
!
f_ptr = C_LOC(wdata(1))
CALL H5Rcreate_f(file, "G1", H5R_OBJECT_F, f_ptr, hdferr)
f_ptr = C_LOC(wdata(2))
CALL H5Rcreate_f(file, "DS2", H5R_OBJECT_F, f_ptr, hdferr)
!
! Create dataspace. Setting maximum size to be the current size.
!
CALL h5screate_simple_f(1, dims, space, hdferr)
!
! Create the dataset and write the object references to it.
!
CALL h5dcreate_f(file, dataset, H5T_STD_REF_OBJ, space, dset, hdferr)
f_ptr = C_LOC(wdata(1))
CALL h5dwrite_f(dset, H5T_STD_REF_OBJ, f_ptr, hdferr)
!
! Close and release resources.
!
CALL h5dclose_f(dset, hdferr)
CALL h5sclose_f(space, hdferr)
CALL h5fclose_f(file, hdferr)
!
! Now we begin the read section of this example.
!
! Open file and dataset.
!
CALL h5fopen_f(filename, H5F_ACC_RDONLY_F, file, hdferr)
CALL h5dopen_f(file, dataset, dset, hdferr)
!
! Get dataspace and allocate memory for read buffer.
!
CALL h5dget_space_f(dset, space, hdferr)
CALL h5sget_simple_extent_dims_f(space, dims, maxdims, hdferr)
ALLOCATE(rdata(1:maxdims(1)))
!
! Read the data.
!
f_ptr = C_LOC(rdata(1))
CALL h5dread_f(dset, H5T_STD_REF_OBJ, f_ptr, hdferr)
!
! Output the data to the screen.
!
DO i = 1, maxdims(1)
WRITE(*,'(A,"[",i1,"]:",/,2X,"->")', ADVANCE='NO') dataset, i-1
!
! Open the referenced object, get its name and type.
!
f_ptr = C_LOC(rdata(i))
CALL H5Rdereference_f(dset, H5R_OBJECT_F, f_ptr, obj, hdferr)
CALL H5Rget_obj_type_f(dset, H5R_OBJECT_F, f_ptr, objtype, hdferr)
!
! Get the length of the name and name
!
CALL H5Iget_name_f(obj, name, 80_size_t, name_size, hdferr)
!
! Print the object type and close the object.
!
IF(objtype.EQ.H5G_GROUP_F)THEN
WRITE(*,'("Group")', ADVANCE="NO")
ELSE IF(objtype.EQ.H5G_DATASET_F)THEN
WRITE(*,'("Dataset")', ADVANCE="NO")
ELSE IF(objtype.EQ.H5G_TYPE_F)THEN
WRITE(*,'("Named Datatype")', ADVANCE="NO")
ELSE
WRITE(*,'("Unknown")', ADVANCE="NO")
ENDIF
CALL h5oclose_f(obj, hdferr)
!
! Print the name.
!
WRITE(*,'(": ",A)') name(1:name_size)
END DO
!
! Close and release resources.
!
DEALLOCATE(rdata)
CALL h5dclose_f(dset , hdferr)
CALL h5sclose_f(space, hdferr)
CALL h5fclose_f(file , hdferr)
!
END PROGRAM main