summaryrefslogtreecommitdiff
path: root/flang/test/Semantics/procinterface04.f90
blob: fb48c4b17b41972fb0648af42ffd5196e729c514 (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
! RUN: %python %S/test_errors.py %s %flang_fc1 -pedantic
subroutine test(dp1, dp2)
  intrinsic sin
  interface
    elemental real function elemental(x)
      real, intent(in) :: x
    end
    pure real function nonelemental(x)
      real, intent(in) :: x
    end
  end interface
  !PORTABILITY: A dummy procedure should not have an ELEMENTAL intrinsic as its interface [-Wportability]
  procedure(sin) :: dp1
  !ERROR: A dummy procedure may not be ELEMENTAL
  procedure(elemental) :: dp2
  !PORTABILITY: Procedure pointer 'pp1' should not have an ELEMENTAL intrinsic as its interface [-Wportability]
  procedure(sin), pointer :: pp1
  !ERROR: Procedure pointer 'pp2' may not be ELEMENTAL
  procedure(elemental), pointer :: pp2
  procedure(elemental) :: pp3 ! ok, external
  procedure(nonelemental), pointer :: pp4 => sin ! ok, special case
  !ERROR: Procedure pointer 'pp5' cannot be initialized with the elemental procedure 'elemental'
  procedure(nonelemental), pointer :: pp5 => elemental
end