blob: b8b669f640d82db1fca7efea3802a572e3806c52 [file] [log] [blame]
! { dg-do compile }
! { dg-options "-Wrealloc-lhs-all -Wrealloc-lhs" }
!
! PR fortran/52196
!
implicit none
type t
integer :: x
end type t
integer, allocatable :: a(:), b
real, allocatable :: r(:)
type(t), allocatable :: c(:)
character(len=:), allocatable :: str
character(len=:), allocatable :: astr(:)
allocate(a(2), b, c(1))
b = 4 ! { dg-warning "Code for reallocating the allocatable variable" }
a = [b,b] ! { dg-warning "Code for reallocating the allocatable array" }
c = [t(4)] ! { dg-warning "Code for reallocating the allocatable variable" }
a = 5 ! no realloc
c = t(5) ! no realloc
str = 'abc' ! { dg-warning "Code for reallocating the allocatable variable" }
astr = 'abc' ! no realloc
astr = ['abc'] ! { dg-warning "Code for reallocating the allocatable array" }
a = reshape(a,shape(a)) ! { dg-warning "Code for reallocating the allocatable array" }
r = sin(r)
r = sin(r(1)) ! no realloc
b = sin(r(1)) ! { dg-warning "Code for reallocating the allocatable variable" }
a = nar() ! { dg-warning "Code for reallocating the allocatable array" }
a = nar2() ! { dg-warning "Code for reallocating the allocatable array" }
contains
function nar()
integer,allocatable :: nar(:)
end function
function nar2()
integer :: nar2(8)
end function
end