summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/bind_c_usage_10.f03
blob: 4f2268aee6dbb7150f7bffffa6884714aad078c1 (plain)
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
! { dg-do run }
! { dg-additional-sources bind_c_usage_10_c.c }
!
! PR fortran/34079
!
! Check BIND(C) for ENTRY
!
module mod
 use iso_c_binding
 implicit none
contains
  subroutine sub1(j) bind(c, name="mySub1")
    integer(c_int) :: j
    real(c_float)  :: x
    j = 5
    return
   entry sub1ent(x)
     x = 55.0
  end subroutine sub1
  subroutine sub2(j)
    integer(c_int) :: j
    real(c_float)  :: x
    j = 6
    return
   entry sub2ent(x) bind(c, name="mySubEnt2")
    x = 66.0
  end subroutine sub2
  subroutine sub3(j) bind(c, name="mySub3")
    integer(c_int) :: j
    real(c_float)  :: x
    j = 7
    return
   entry sub3ent(x) bind(c, name="mySubEnt3")
     x = 77.0
  end subroutine sub3
  subroutine sub4(j)
    integer(c_int) :: j
    real(c_float)  :: x
    j = 8
    return
   entry sub4ent(x) bind(c)
     x = 88.0
  end subroutine sub4

  integer(c_int) function func1() bind(c, name="myFunc1")
    real(c_float) :: func1ent
    func1 = -5
    return
   entry func1ent()
    func1ent = -55.0
  end function func1
  integer(c_int) function func2()
    real(c_float) :: func2ent
    func2 = -6
    return
   entry func2ent() bind(c, name="myFuncEnt2")
    func2ent = -66.0
  end function func2
  integer(c_int) function func3() bind(c, name="myFunc3")
    real(c_float) :: func3ent
    func3 = -7
    return
   entry func3ent() bind(c, name="myFuncEnt3")
    func3ent = -77.0
  end function func3
  integer(c_int) function func4()
    real(c_float) :: func4ent
    func4 = -8
    return
   entry func4ent() bind(c)
    func4ent = -88.0
  end function func4
end module mod

! { dg-final { cleanup-modules "mod" } }