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
|
! RUN: %S/test_errors.sh %s %t %flang_fc1
! REQUIRES: shell
! C736 If EXTENDS appears and the type being defined has a coarray ultimate
! component, its parent type shall have a coarray ultimate component.
!
subroutine s()
type coarrayParent
real,allocatable, codimension[:] :: parentField
end type coarrayParent
type, extends(coarrayParent) :: goodChildType
real, allocatable, codimension[:] :: childField
end type goodChildType
type, extends(coarrayParent) :: brotherType
real :: brotherField
end type brotherType
type, extends(brotherType) :: grandChildType
real, allocatable, codimension[:] :: grandChildField
end type grandChildType
type plainParent
end type plainParent
!ERROR: Type 'badchildtype' has a coarray ultimate component so the type at the base of its type extension chain ('plainparent') must be a type that has a coarray ultimate component
type, extends(plainParent) :: badChildType
real, allocatable, codimension[:] :: childField
end type badChildType
type, extends(plainParent) :: plainChild
real :: realField
end type plainChild
!ERROR: Type 'badchildtype2' has a coarray ultimate component so the type at the base of its type extension chain ('plainparent') must be a type that has a coarray ultimate component
type, extends(plainChild) :: badChildType2
real, allocatable, codimension[:] :: childField
end type badChildType2
!ERROR: Type 'badchildtype3' has a coarray ultimate component so the type at the base of its type extension chain ('plainparent') must be a type that has a coarray ultimate component
type, extends(plainParent) :: badChildType3
type(coarrayParent) :: childField
end type badChildType3
end subroutine s
|