blob: e866dd89c07ab6e0105ab95f6f79daf5a1f67ebe [file] [log] [blame]
! RUN: %python %S/test_errors.py %s %flang_fc1
! More coarray error tests.
module m1
integer :: local[*] ! ok in module
end
program main
use iso_fortran_env
!ERROR: Coarray 'namedconst' may not be a named constant
!ERROR: Local coarray must have the SAVE or ALLOCATABLE attribute
integer, parameter :: namedConst = 123
codimension namedConst[*]
!ERROR: Coarray 'coarr1' may not be in COMMON block '//'
real :: coarr1[*]
common//coarr1
!ERROR: Variable 'event' with EVENT_TYPE or LOCK_TYPE must be a coarray
type(event_type) event
!ERROR: Variable 'lock' with EVENT_TYPE or LOCK_TYPE must be a coarray
type(lock_type) lock
!ERROR: Variable 'notify' with NOTIFY_TYPE must be a coarray
type(notify_type) notify
integer :: local[*] ! ok in main
end
function func1()
!ERROR: Function result may not be a coarray
integer :: func1[*]
!ERROR: Local coarray must have the SAVE or ALLOCATABLE attribute
integer :: local[*]
integer, save :: saved[*] ! ok
integer :: inited[*] = 1 ! ok
func = 1
end
function func2()
type t
real, allocatable :: comp[:]
end type
type t2
!ERROR: Allocatable or array component 'allo' may not have a coarray ultimate component '%comp'
type(t), allocatable :: allo
!ERROR: Allocatable or array component 'arr' may not have a coarray ultimate component '%comp'
type(t) :: arr(1)
end type
!ERROR: Function result 'func2' may not have a coarray potential component '%comp'
type(t) func2
!ERROR: Pointer 'ptr' may not have a coarray potential component '%comp'
type(t), pointer :: ptr
!ERROR: Coarray 'coarr' may not have a coarray potential component '%comp'
type(t), save :: coarr[*]
!ERROR: Local variable 'local' without the SAVE or ALLOCATABLE attribute may not have a coarray potential subobject component '%comp'
type(t) :: local
end
module m2
type t0
integer n
end type
type t1
class(t0), allocatable :: a
end type
type t2
type(t1) c
end type
contains
subroutine test(x)
type(t2), intent(in) :: x[*]
!ERROR: The base of a polymorphic object may not be coindexed
call sub1(x[1]%c%a)
!ERROR: A coindexed designator may not have a type with the polymorphic potential subobject component '%a'
call sub2(x[1]%c)
end
subroutine sub1(x)
type(t0), intent(in) :: x
end
subroutine sub2(x)
type(t1), intent(in) :: x
end
end
module m3
type t
real, allocatable :: a(:)
real, pointer :: p(:)
real arr(2)
end type
contains
subroutine sub(ca)
real, intent(in) :: ca(:)[*]
end
subroutine test(cat)
type(t), intent(in) :: cat[*]
call sub(cat%arr(1:2)) ! ok
!ERROR: Actual argument associated with coarray dummy argument 'ca=' must be a coarray
call sub(cat%arr([1]))
!ERROR: Actual argument associated with coarray dummy argument 'ca=' must be a coarray
call sub(cat%a)
!ERROR: Actual argument associated with coarray dummy argument 'ca=' must be a coarray
call sub(cat%p)
end
end
subroutine s4
type t
real, allocatable :: a(:)[:]
end type
type t2
!ERROR: Allocatable or array component 'bad1' may not have a coarray ultimate component '%a'
type(t), allocatable :: bad1
!ERROR: Pointer 'bad2' may not have a coarray potential component '%a'
type(t), pointer :: bad2
!ERROR: Allocatable or array component 'bad3' may not have a coarray ultimate component '%a'
type(t) :: bad3(2)
!ERROR: Component 'bad4' is a coarray and must have the ALLOCATABLE attribute and have a deferred coshape
!ERROR: Coarray 'bad4' may not have a coarray potential component '%a'
type(t) :: bad4[*]
end type
type(t), save :: ta(2)
!ERROR: 'a' has corank 1, but coindexed reference has 2 cosubscripts
print *, ta(1)%a(1)[1,2]
!ERROR: An allocatable or pointer component reference must be applied to a scalar base
print *, ta(:)%a(1)[1]
!ERROR: Subscripts must appear in a coindexed reference when its base is an array
print *, ta(1)%a[1]
end
subroutine s5(a, notify, res)
use iso_fortran_env
type t
type(notify_type) :: a
end type
real, intent(in) :: a[*]
type(event_type), intent(in) :: notify[*]
!ERROR: An INTENT(OUT) dummy argument may not be, or contain, NOTIFY_TYPE
type(notify_type), intent(out) :: res[*]
!ERROR: Variable 'bad' with NOTIFY_TYPE potential component '%a' must be a coarray
type(t) :: bad
!ERROR: NOTIFY= specifier must have type NOTIFY_TYPE from ISO_FORTRAN_ENV
print *, a[1, NOTIFY=notify]
end