re PR fortran/85603 (ICE with character array substring assignment)
2018-09-22 Paul Thomas <pault@gcc.gnu.org> PR fortran/85603 * trans-array.c (gfc_alloc_allocatable_for_assignment): Test the charlen backend_decl before using the VAR_P macro. 2018-09-22 Paul Thomas <pault@gcc.gnu.org> PR fortran/85603 * gfortran.dg/deferred_character_23.f90 : New test. From-SVN: r264502
This commit is contained in:
parent
0e569a3c7e
commit
204d463084
4 changed files with 35 additions and 1 deletions
|
@ -1,3 +1,9 @@
|
|||
2018-09-22 Paul Thomas <pault@gcc.gnu.org>
|
||||
|
||||
PR fortran/85603
|
||||
* trans-array.c (gfc_alloc_allocatable_for_assignment): Test
|
||||
the charlen backend_decl before using the VAR_P macro.
|
||||
|
||||
2018-09-21 Paul Thomas <pault@gcc.gnu.org>
|
||||
|
||||
PR fortran/77325
|
||||
|
|
|
@ -9950,7 +9950,8 @@ gfc_alloc_allocatable_for_assignment (gfc_loopinfo *loop,
|
|||
{
|
||||
if (expr2->ts.deferred)
|
||||
{
|
||||
if (VAR_P (expr2->ts.u.cl->backend_decl))
|
||||
if (expr2->ts.u.cl->backend_decl
|
||||
&& VAR_P (expr2->ts.u.cl->backend_decl))
|
||||
tmp = expr2->ts.u.cl->backend_decl;
|
||||
else
|
||||
tmp = rss->info->string_length;
|
||||
|
|
|
@ -1,3 +1,8 @@
|
|||
2018-09-22 Paul Thomas <pault@gcc.gnu.org>
|
||||
|
||||
PR fortran/85603
|
||||
* gfortran.dg/deferred_character_23.f90 : New test.
|
||||
|
||||
2018-09-21 Jeff Law <law@redhat.com>
|
||||
|
||||
* gcc.dg/tree-ssa/vrp113.c: Disable EVRP.
|
||||
|
|
22
gcc/testsuite/gfortran.dg/deferred_character_23.f90
Normal file
22
gcc/testsuite/gfortran.dg/deferred_character_23.f90
Normal file
|
@ -0,0 +1,22 @@
|
|||
! { dg-do run }
|
||||
!
|
||||
! Tests the fix for PR85603.
|
||||
!
|
||||
! Contributed by Walt Spector <w6ws@earthlink.net>
|
||||
!
|
||||
program strlen_bug
|
||||
implicit none
|
||||
|
||||
character(:), allocatable :: strings(:)
|
||||
integer :: maxlen
|
||||
|
||||
strings = [ character(32) :: &
|
||||
'short', &
|
||||
'somewhat longer' ]
|
||||
maxlen = maxval (len_trim (strings))
|
||||
if (maxlen .ne. 15) stop 1
|
||||
strings = strings(:)(:maxlen) ! Used to ICE
|
||||
if (any (strings .ne. ['short ','somewhat longer'])) stop 2
|
||||
|
||||
deallocate (strings) ! To check for memory leaks
|
||||
end program
|
Loading…
Add table
Reference in a new issue