summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/import5.f90
blob: 0106c4ec121442e4c5992ff24a4c3111c3128a19 (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
! { dg-do compile }
! Test for import in interfaces PR fortran/30922
!
! Contributed by Tobias Burnus <burnus@gcc.gnu.org>
!
module test_import
  implicit none

  type :: my_type
     integer :: data
  end type my_type
  integer, parameter :: n = 20

  interface
     integer function func1(param)
       import
       type(my_type) :: param(n)
     end function func1

     integer function func2(param)
       import :: my_type
       type(my_type), value :: param
     end function func2
  end interface

contains

  subroutine sub1 ()

    interface
      integer function func3(param)
        import
        type(my_type), dimension (n) :: param
      end function func3

      integer function func4(param)
        import :: my_type, n
        type(my_type), dimension (n) :: param
      end function func4
    end interface

  end subroutine sub1
end module test_import
! { dg-final { cleanup-modules "test_import" } }