summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/nested_modules_2.f90
blob: 5bfdaddaac2b900b89345c5d8f990252c92b19a3 (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
! { dg-do run }
! This tests the patch for PR16861.
!
! Contributed by Paul Thomas <pault@gcc.gnu.org>
!
module foo
INTEGER :: i
end module foo

module bar
contains
subroutine sub1 (j)
  use foo
  integer, dimension(i) :: j
  j = 42
end subroutine sub1
subroutine sub2 (k)
  use foo
  integer, dimension(i) :: k
  k = 84
end subroutine sub2
end module bar

module foobar
  use foo                      !This used to cause an ICE
  use bar
end module foobar

program testfoobar
  use foobar
  integer, dimension(3)  :: l = 0
  i = 2
  call sub1 (l)
  i = 1
  call sub2 (l)
  if (all (l.ne.(/84,42,0/))) call abort ()
end program testfoobar

! { dg-final { cleanup-modules "foo bar foobar" } }