File: pointer02.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 (53 lines) | stat: -rw-r--r-- 1,866 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
51
52
53
! RUN: %python %S/test_errors.py %s %flang_fc1
recursive subroutine sub(dp, dpp)
  procedure(inner) dp
  procedure(inner), pointer :: dpp
  procedure(inner) ext
  procedure(sub), pointer :: p1 => sub ! ok
  procedure(inner), pointer :: p2 => ext ! ok
  !ERROR: Procedure pointer 'p3' initializer 'inner' is neither an external nor a module procedure
  procedure(inner), pointer :: p3 => inner
  !ERROR: Procedure pointer 'p4' initializer 'dp' is neither an external nor a module procedure
  procedure(inner), pointer :: p4 => dp
  !ERROR: Procedure pointer 'p5' initializer 'dpp' is neither an external nor a module procedure
  procedure(inner), pointer :: p5 => dpp
  generic :: generic => ext
  !ERROR: 'generic' must be an abstract interface or a procedure with an explicit interface
  procedure(generic), pointer :: p6 ! => generic
 contains
  subroutine inner
  end
end
recursive function fun() result(res)
  procedure(fun), pointer :: p1 => fun ! ok
  !ERROR: Procedure pointer 'p2' initializer 'inner' is neither an external nor a module procedure
  procedure(inner), pointer :: p2 => inner
  res = 0.
 contains
  function inner()
    inner = 0.
  end
end
module m
  procedure(msub), pointer :: ps1 => msub ! ok
  procedure(mfun), pointer :: pf1 => mfun ! ok
 contains
  recursive subroutine msub
    procedure(msub), pointer :: ps2 => msub ! ok
    !ERROR: Procedure pointer 'ps3' initializer 'inner' is neither an external nor a module procedure
    procedure(inner), pointer :: ps3 => inner
   contains
    subroutine inner
    end
  end
  recursive function mfun() result(res)
    procedure(mfun), pointer :: pf2 => mfun ! ok
    !ERROR: Procedure pointer 'pf3' initializer 'inner' is neither an external nor a module procedure
    procedure(inner), pointer :: pf3 => inner
    res = 0.
   contains
    function inner()
      inner = 0.
    end
  end
end