annotate gcc/testsuite/gfortran.dg/c_loc_tests_14.f90 @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 ! { dg-do compile }
kono
parents:
diff changeset
2 !
kono
parents:
diff changeset
3 ! PR fortran/38536
kono
parents:
diff changeset
4 ! Accept as argument to C_LOC a subcomponent accessed through a pointer.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 USE ISO_C_BINDING
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 IMPLICIT NONE
kono
parents:
diff changeset
9 TYPE test3
kono
parents:
diff changeset
10 INTEGER, DIMENSION(5) :: b
kono
parents:
diff changeset
11 END TYPE test3
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 TYPE test2
kono
parents:
diff changeset
14 TYPE(test3), DIMENSION(:), POINTER :: a
kono
parents:
diff changeset
15 END TYPE test2
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 TYPE test
kono
parents:
diff changeset
18 TYPE(test2), DIMENSION(2) :: c
kono
parents:
diff changeset
19 END TYPE test
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 TYPE(test) :: chrScalar
kono
parents:
diff changeset
22 TYPE(C_PTR) :: f_ptr
kono
parents:
diff changeset
23 TYPE(test3), TARGET :: d(3)
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 chrScalar%c(1)%a => d
kono
parents:
diff changeset
27 f_ptr = C_LOC(chrScalar%c(1)%a(1)%b(1))
kono
parents:
diff changeset
28 end
kono
parents:
diff changeset
29