When the result of a function never appears in a variable definition context, emit a warning. If the function has multiple result variables due to alternate ENTRY statements, any definition will suffice. The implementation of this check is tied to the general variable definability checking utility in semantics. Every variable definition context uses it to ensure that no undefinable variable is being defined. A set of defined variables is maintained in the SemanticsContext and, when the warning is enabled and no fatal error has been reported, the scope tree is traversed and all the function subprograms' results are tested for membership in that set.
159 lines
4.6 KiB
Fortran
159 lines
4.6 KiB
Fortran
! RUN: %python %S/test_errors.py %s %flang_fc1 -pedantic
|
|
! 15.5.1 procedure reference constraints and restrictions
|
|
|
|
subroutine s01(elem, subr)
|
|
interface
|
|
!ERROR: A dummy procedure may not be ELEMENTAL
|
|
elemental real function elem(x)
|
|
real, intent(in), value :: x
|
|
end function
|
|
subroutine subr(dummy)
|
|
!PORTABILITY: A dummy procedure should not have an ELEMENTAL intrinsic as its interface
|
|
procedure(sin) :: dummy
|
|
end subroutine
|
|
subroutine badsubr(dummy)
|
|
import :: elem
|
|
!ERROR: A dummy procedure may not be ELEMENTAL
|
|
procedure(elem) :: dummy
|
|
end subroutine
|
|
subroutine optionalsubr(dummy)
|
|
!PORTABILITY: A dummy procedure should not have an ELEMENTAL intrinsic as its interface
|
|
procedure(sin), optional :: dummy
|
|
end subroutine
|
|
subroutine ptrsubr(dummy)
|
|
!PORTABILITY: A dummy procedure should not have an ELEMENTAL intrinsic as its interface
|
|
procedure(sin), pointer, intent(in) :: dummy
|
|
end subroutine
|
|
end interface
|
|
intrinsic :: cos
|
|
call subr(cos) ! not an error
|
|
!ERROR: Non-intrinsic ELEMENTAL procedure 'elem' may not be passed as an actual argument
|
|
call subr(elem) ! C1533
|
|
!ERROR: Actual argument associated with procedure dummy argument 'dummy=' is a null pointer
|
|
call subr(null())
|
|
call optionalsubr(null()) ! ok
|
|
call ptrsubr(null()) ! ok
|
|
!ERROR: Actual argument associated with procedure dummy argument 'dummy=' is typeless
|
|
call subr(B"1010")
|
|
end subroutine
|
|
|
|
subroutine s02
|
|
!ERROR: Non-intrinsic ELEMENTAL procedure 'elem' may not be passed as an actual argument
|
|
call sub(elem)
|
|
contains
|
|
elemental integer function elem()
|
|
elem = 1
|
|
end function
|
|
end
|
|
|
|
subroutine s03
|
|
interface
|
|
subroutine sub1(p)
|
|
procedure(real) :: p
|
|
end subroutine
|
|
end interface
|
|
sf(x) = x + 1.
|
|
!ERROR: Statement function 'sf' may not be passed as an actual argument
|
|
call sub1(sf)
|
|
!ERROR: Statement function 'sf' may not be passed as an actual argument
|
|
call sub2(sf)
|
|
end
|
|
|
|
module m01
|
|
procedure(sin) :: elem01
|
|
interface
|
|
elemental real function elem02(x)
|
|
real, value :: x
|
|
end function
|
|
subroutine callme(f)
|
|
external f
|
|
end subroutine
|
|
end interface
|
|
contains
|
|
elemental real function elem03(x)
|
|
real, value :: x
|
|
elem03 = 0.
|
|
end function
|
|
subroutine test
|
|
intrinsic :: cos
|
|
call callme(cos) ! not an error
|
|
!ERROR: Non-intrinsic ELEMENTAL procedure 'elem01' may not be passed as an actual argument
|
|
call callme(elem01) ! C1533
|
|
!ERROR: Non-intrinsic ELEMENTAL procedure 'elem02' may not be passed as an actual argument
|
|
call callme(elem02) ! C1533
|
|
!ERROR: Non-intrinsic ELEMENTAL procedure 'elem03' may not be passed as an actual argument
|
|
call callme(elem03) ! C1533
|
|
!ERROR: Non-intrinsic ELEMENTAL procedure 'elem04' may not be passed as an actual argument
|
|
call callme(elem04) ! C1533
|
|
contains
|
|
elemental real function elem04(x)
|
|
real, value :: x
|
|
elem04 = 0.
|
|
end function
|
|
end subroutine
|
|
end module
|
|
|
|
module m02
|
|
type :: t
|
|
integer, pointer :: ptr
|
|
end type
|
|
type(t) :: coarray[*]
|
|
contains
|
|
subroutine callee(x)
|
|
type(t), intent(in) :: x
|
|
end subroutine
|
|
subroutine test
|
|
!ERROR: Coindexed object 'coarray' with POINTER ultimate component '%ptr' cannot be associated with dummy argument 'x='
|
|
call callee(coarray[1]) ! C1537
|
|
end subroutine
|
|
end module
|
|
|
|
module m03
|
|
contains
|
|
subroutine test
|
|
!ERROR: Non-intrinsic ELEMENTAL procedure 'elem' may not be passed as an actual argument
|
|
call sub(elem)
|
|
contains
|
|
elemental integer function elem()
|
|
elem = 1
|
|
end function
|
|
end
|
|
end
|
|
|
|
program p03
|
|
logical :: l
|
|
call s1(index)
|
|
l = index .eq. 0 ! index is an object entity, not an intrinsic
|
|
call s2(sin)
|
|
!ERROR: Actual argument associated with procedure dummy argument 'p=' is not a procedure
|
|
call s3(cos)
|
|
contains
|
|
subroutine s2(x)
|
|
real :: x
|
|
end
|
|
subroutine s3(p)
|
|
procedure(real) :: p
|
|
end
|
|
end
|
|
|
|
subroutine p04
|
|
implicit none
|
|
!ERROR: No explicit type declared for 'index'
|
|
call s1(index)
|
|
end
|
|
|
|
subroutine p05
|
|
integer :: a1(2), a2, a3
|
|
!ERROR: In an elemental procedure reference with at least one array argument, actual argument a2 that corresponds to an INTENT(OUT) or INTENT(INOUT) dummy argument must be an array
|
|
!ERROR: In an elemental procedure reference with at least one array argument, actual argument a3 that corresponds to an INTENT(OUT) or INTENT(INOUT) dummy argument must be an array
|
|
call s1(a1, a2, a3)
|
|
contains
|
|
elemental subroutine s1(a, b, c)
|
|
integer, intent(in) :: a
|
|
integer, intent(out) :: b
|
|
integer, intent(inout) :: c
|
|
b = a
|
|
c = a
|
|
end
|
|
end
|