annotate gcc/testsuite/gfortran.dg/c_loc_tests_14.f90 @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +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