re PR fortran/19358 ([gfortran] Segfault with missing upper bound)
2005-09-13 Paul Thomas <pault@gcc.gnu.org> PR fortran/19358 * trans-array.c (gfc_trans_dummy_array_bias): correct the typo which uses dim[i].upper for lbound, rather than dim[i].lower. 2005-09-13 Paul Thomas <pault@gcc.gnu.org> PR fortran/19358 * gfortran.fortran-torture/assumed_dummy_1.f90: New test. From-SVN: r104259
This commit is contained in:
parent
0120daacbe
commit
0df3cf7f04
4 changed files with 58 additions and 1 deletions
|
@ -1,3 +1,9 @@
|
|||
2005-09-14 Paul Thomas <pault@gcc.gnu.org>
|
||||
|
||||
PR fortran/19358
|
||||
* trans-array.c (gfc_trans_dummy_array_bias): correct the typo
|
||||
which uses dim[i].upper for lbound, rather than dim[i].lower.
|
||||
|
||||
2005-09-13 Erik Edelmann <erik.edelmann@iki.fi>
|
||||
|
||||
PR fortran/17740
|
||||
|
|
|
@ -3477,7 +3477,7 @@ gfc_trans_dummy_array_bias (gfc_symbol * sym, tree tmpdesc, tree body)
|
|||
if (!INTEGER_CST_P (lbound))
|
||||
{
|
||||
gfc_init_se (&se, NULL);
|
||||
gfc_conv_expr_type (&se, sym->as->upper[n],
|
||||
gfc_conv_expr_type (&se, sym->as->lower[n],
|
||||
gfc_array_index_type);
|
||||
gfc_add_block_to_block (&block, &se.pre);
|
||||
gfc_add_modify_expr (&block, lbound, se.expr);
|
||||
|
|
|
@ -1,3 +1,8 @@
|
|||
2005-09-13 Paul Thomas <pault@gcc.gnu.org>
|
||||
|
||||
PR fortran/19358
|
||||
* gfortran.fortran-torture/assumed_dummy_1.f90: New test.
|
||||
|
||||
2005-09-13 Josh Conner <jconner@apple.com>
|
||||
|
||||
PR c++/23180
|
||||
|
|
46
gcc/testsuite/gfortran.dg/assumed_dummy_1.f90
Normal file
46
gcc/testsuite/gfortran.dg/assumed_dummy_1.f90
Normal file
|
@ -0,0 +1,46 @@
|
|||
! { dg do-run}
|
||||
! Tests the fix for PRs 19358, 19477, 21211 and 21622.
|
||||
!
|
||||
! Note that this tests only the valid cases with explicit interfaces.
|
||||
!
|
||||
! Contributed by Paul Thomas <pault@gcc.gnu.org>
|
||||
!
|
||||
module global
|
||||
contains
|
||||
SUBROUTINE goo (x, i)
|
||||
REAL, DIMENSION(i:) :: x
|
||||
integer :: i
|
||||
x (3) = 99.0
|
||||
END SUBROUTINE goo
|
||||
end module global
|
||||
|
||||
SUBROUTINE foo (x, i)
|
||||
REAL, DIMENSION(i:) :: x
|
||||
integer :: i
|
||||
x (4) = 42.0
|
||||
END SUBROUTINE foo
|
||||
|
||||
program test
|
||||
use global
|
||||
real, dimension(3) :: y = 0
|
||||
integer :: j = 2
|
||||
|
||||
interface
|
||||
SUBROUTINE foo (x, i)
|
||||
REAL, DIMENSION(i:) :: x
|
||||
integer :: i
|
||||
END SUBROUTINE foo
|
||||
end interface
|
||||
call foo (y, j)
|
||||
call goo (y, j)
|
||||
call roo (y, j)
|
||||
if (any(y.ne.(/21.0, 99.0, 42.0/))) call abort ()
|
||||
contains
|
||||
SUBROUTINE roo (x, i)
|
||||
REAL, DIMENSION(i:) :: x
|
||||
integer :: i
|
||||
x (2) = 21.0
|
||||
END SUBROUTINE roo
|
||||
end program test
|
||||
|
||||
|
Loading…
Add table
Reference in a new issue