File: functions_40.f90

package info (click to toggle)
lfortran 0.60.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 58,412 kB
  • sloc: cpp: 173,406; f90: 80,491; python: 17,586; ansic: 9,610; yacc: 2,356; sh: 1,401; fortran: 895; makefile: 37; javascript: 15
file content (37 lines) | stat: -rw-r--r-- 1,061 bytes parent folder | download
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
module mod1_functions_40_integers
  integer(4) :: n
end module mod1_functions_40_integers

module mod2_functions_40_interfaces
  interface 
     subroutine some_routine(a)
       use mod1_functions_40_integers
       ! symbol present in dimension, hence in FunctionType ASR node
       real(8), dimension(n:,:) ::  a
     end subroutine some_routine
  end interface
end module mod2_functions_40_interfaces

program functions_40
  use mod2_functions_40_interfaces
  use mod1_functions_40_integers
  implicit none
  real(8), allocatable:: a(:,:)
  n = 42
  allocate(a(n:n+1,2))
  call some_routine(a)
end program functions_40

subroutine some_routine(a)
  use mod1_functions_40_integers
  real(8), dimension(n:,:) ::  a
  print *, "lbound(a, 1): ", lbound(a, 1)
  if (lbound(a, 1) /= 42) error stop
  print *, "lbound(a, 2): ", lbound(a, 2)
  if (lbound(a, 2) /= 1) error stop

  print *, "ubound(a, 1): ", ubound(a, 1)
  if (ubound(a, 1) /= 43) error stop
  print *, "ubound(a, 2): ", ubound(a, 2)
  if (ubound(a, 2) /= 2) error stop
end subroutine some_routine