diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index ae78f9f330d..eddfceb4e80 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2010-12-13 Janus Weil + + PR fortran/46201 + * trans-expr.c (gfc_conv_procedure_call): Handle procedure pointer + components called on a dimensionful base object. + 2010-12-13 Janus Weil PR fortran/46841 diff --git a/gcc/fortran/trans-expr.c b/gcc/fortran/trans-expr.c index 6681a6ab3df..cf2cdb6005a 100644 --- a/gcc/fortran/trans-expr.c +++ b/gcc/fortran/trans-expr.c @@ -3594,7 +3594,7 @@ gfc_conv_procedure_call (gfc_se * se, gfc_symbol * sym, if (!se->direct_byref) { - if (sym->attr.dimension || (comp && comp->attr.dimension)) + if ((sym->attr.dimension && !comp) || (comp && comp->attr.dimension)) { if (gfc_option.rtcheck & GFC_RTCHECK_BOUNDS) { diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 405f4a6930f..165be16f4c4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-12-13 Janus Weil + + PR fortran/46201 + * gfortran.dg/proc_ptr_comp_27.f90: New. + 2010-12-13 Jakub Jelinek PR debug/46867 diff --git a/gcc/testsuite/gfortran.dg/proc_ptr_comp_27.f90 b/gcc/testsuite/gfortran.dg/proc_ptr_comp_27.f90 new file mode 100644 index 00000000000..d966648fc30 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/proc_ptr_comp_27.f90 @@ -0,0 +1,12 @@ +! { dg-do compile } +! +! PR 46201: [F03] ICE on procedure pointer component call +! +! Contributed by Stephen J. Bespalko + +type t + procedure(character), nopass, pointer :: ppc +end type +type(t),dimension(1) :: v +print *,v(1)%ppc() +end