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
|
! { dg-do compile }
module x
use iso_c_binding
bind(c) :: test, sub1 ! { dg-error "only be used for variables or common blocks" }
bind(c) :: sub2 ! { dg-error "only be used for variables or common blocks" }
contains
function foo() bind(c,name="xx")
integer(c_int),bind(c,name="xy") :: foo ! { dg-error "only be used for variables or common blocks" }
! NAG f95: "BIND(C) for non-variable FOO"
! g95: "Duplicate BIND attribute specified"
! gfortran: Accepted
foo = 5_c_int
end function foo
function test()
integer(c_int) :: test
bind(c,name="kk") :: test ! { dg-error "only be used for variables or common blocks" }
! NAG f95: "BIND(C) for non-variable TEST"
! gfortran, g95: Accepted
test = 5_c_int
end function test
function bar() bind(c)
integer(c_int) :: bar
bind(c,name="zx") :: bar ! { dg-error "only be used for variables or common blocks" }
bar = 5_c_int
end function bar
subroutine sub0() bind(c)
bind(c) :: sub0 ! { dg-error "only be used for variables or common blocks" }
end subroutine sub0
subroutine sub1(i) bind(c)
use, intrinsic :: iso_c_binding, only: c_int
integer(c_int), value :: i
end subroutine sub1
subroutine sub2(i)
use, intrinsic :: iso_c_binding, only: c_int
integer(c_int), value :: i
end subroutine sub2
subroutine sub3(i)
use, intrinsic :: iso_c_binding, only: c_int
integer(c_int), value :: i
bind(c) :: sub3 ! { dg-error "only be used for variables or common blocks" }
end subroutine sub3
end module x
|