blob: 924dd40bc69578be8b84857e18bdae2d5912f1a8 [file] [log] [blame]
! { 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