summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/entry_3.f90
blob: b4473df31bacf3f9309ebdd1ac4bb24eb653ffc0 (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
! { dg-do run }
! Test assumed shape arrays in procedures with multiple entry points.
! Arguments that aren't present in all entry points must be treated like
! optional arguments.
module entry_4
contains
subroutine foo(a)
  integer, dimension(:) :: a
  integer, dimension(:) :: b
  a = (/1, 2/)
  return
entry bar(b)
  b = (/3, 4/)
end subroutine
end module

program entry_4_prog
  use entry_4
  integer :: a(2)
  a = 0
  call foo(a)
  if (any (a .ne. (/1, 2/))) call abort
  call bar(a)
  if (any (a .ne. (/3, 4/))) call abort
end program

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