Files
clang-p2996/flang/test/Semantics/call02.f90
Peter Klausler 33c27f28d1 [flang] Warn about undefined function results (#99533)
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.
2024-07-30 09:41:46 -07:00

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