File: implicit15.f90

package info (click to toggle)
llvm-toolchain-20 1%3A20.1.8-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 2,111,696 kB
  • sloc: cpp: 7,438,781; ansic: 1,393,871; asm: 1,012,926; python: 241,771; f90: 86,635; objc: 75,411; lisp: 42,144; pascal: 17,286; sh: 8,596; ml: 5,082; perl: 4,730; makefile: 3,591; awk: 3,523; javascript: 2,251; xml: 892; fortran: 672
file content (50 lines) | stat: -rw-r--r-- 1,122 bytes parent folder | download | duplicates (5)
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
!RUN: %flang_fc1 -fdebug-unparse  %s  2>&1 | FileCheck %s
!Test inheritance of implicit rules in submodules and separate module
!procedures.

module m
  implicit integer(1)(a-z)
  interface
    module subroutine mp(da) ! integer(2)
      implicit integer(2)(a-z)
    end
  end interface
  save :: mv ! integer(1)
end

submodule(m) sm1
  implicit integer(8)(a-z)
  save :: sm1v ! integer(8)
  interface
    module subroutine sm1p(da) ! default real
    end
  end interface
end

submodule(m:sm1) sm2
  implicit integer(2)(a-c,e-z)
  save :: sm2v ! integer(2)
 contains
  module subroutine sm1p(da) ! default real
    save :: sm1pv ! inherited integer(2)
    !CHECK: PRINT *, 1_4, 8_4, 2_4, 4_4, 2_4
    print *, kind(mv), kind(sm1v), kind(sm2v), kind(da), kind(sm1pv)
  end
end

submodule(m:sm2) sm3
  implicit integer(8)(a-z)
  save :: sm3v ! integer(8)
 contains
  module procedure mp
    save :: mpv ! inherited integer(8)
    call sm1p(1.)
    !CHECK: PRINT *, 1_4, 8_4, 2_4, 8_4, 2_4, 8_4
    print *, kind(mv), kind(sm1v), kind(sm2v), kind(sm3v), kind(da), kind(mpv)
  end
end

program main
  use m
  call mp(1_2)
end