annotate gcc/testsuite/gfortran.dg/bind_c_usage_18.f90 @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900 (2018-10-24)
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 ! { dg-options "-Wc-binding-type" }
kono
parents:
diff changeset
3 !
kono
parents:
diff changeset
4 ! PR fortran/38160
kono
parents:
diff changeset
5 !
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 subroutine foo(x,y,z,a) bind(c) ! { dg-warning "but may not be C interoperable" }
kono
parents:
diff changeset
8 use iso_c_binding
kono
parents:
diff changeset
9 implicit none
kono
parents:
diff changeset
10 integer(4) :: x
kono
parents:
diff changeset
11 integer(c_float) :: y ! { dg-warning "C kind type parameter is for type REAL" }
kono
parents:
diff changeset
12 complex(c_float) :: z ! OK, c_float == c_float_complex
kono
parents:
diff changeset
13 real(c_float_complex) :: a ! OK, c_float == c_float_complex
kono
parents:
diff changeset
14 end subroutine foo
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 use iso_c_binding
kono
parents:
diff changeset
17 implicit none
kono
parents:
diff changeset
18 integer, parameter :: it = c_int
kono
parents:
diff changeset
19 integer, parameter :: dt = c_double
kono
parents:
diff changeset
20 complex(c_int), target :: z1 ! { dg-warning "C kind type parameter is for type INTEGER" }
kono
parents:
diff changeset
21 complex(it), target :: z2 ! { dg-warning "C kind type parameter is for type INTEGER" }
kono
parents:
diff changeset
22 complex(c_double), target :: z3 ! OK
kono
parents:
diff changeset
23 complex(dt), target :: z4 ! OK
kono
parents:
diff changeset
24 type(c_ptr) :: ptr
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 ptr = c_loc(z1)
kono
parents:
diff changeset
27 ptr = c_loc(z2)
kono
parents:
diff changeset
28 ptr = c_loc(z3)
kono
parents:
diff changeset
29 ptr = c_loc(z4)
kono
parents:
diff changeset
30 end