blob: d6a22475ad1b31e75c89674002d4ba7d6c39f1ab [file] [log] [blame]
! { dg-do run }
! Test for allocatable scalar components and deferred length char arrays.
! Check that fix for pr60357 works.
! Contributed by Antony Lewis <antony@cosmologist.info> and
! Andre Vehreschild <vehre@gmx.de>
!
program test_allocatable_components
Type A
integer :: X
integer, allocatable :: y
character(len=:), allocatable :: c
end type A
Type(A) :: Me
Type(A) :: Ea
Me= A(X= 1, Y= 2, C="correctly allocated")
if (Me%X /= 1) STOP 1
if (.not. allocated(Me%y) .or. Me%y /= 2) STOP 2
if (.not. allocated(Me%c)) STOP 3
if (len(Me%c) /= 19) STOP 4
if (Me%c /= "correctly allocated") STOP 5
! Now check explicitly allocated components.
Ea%X = 9
allocate(Ea%y)
Ea%y = 42
! Implicit allocate on assign in the next line
Ea%c = "13 characters"
if (Ea%X /= 9) STOP 6
if (.not. allocated(Ea%y) .or. Ea%y /= 42) STOP 7
if (.not. allocated(Ea%c)) STOP 8
if (len(Ea%c) /= 13) STOP 9
if (Ea%c /= "13 characters") STOP 10
deallocate(Ea%y)
deallocate(Ea%c)
if (allocated(Ea%y)) STOP 11
if (allocated(Ea%c)) STOP 12
end program
! vim:ts=4:sts=4:sw=4: