From: Janus Weil Date: Mon, 13 Dec 2010 19:17:46 +0000 (+0100) Subject: re PR fortran/46201 ([F03] ICE on procedure pointer component call) X-Git-Tag: releases/gcc-4.6.0~1939 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=c58bb30d66b333fc184a6b53ae9479e4aaeae8c4;p=thirdparty%2Fgcc.git re PR fortran/46201 ([F03] ICE on procedure pointer component call) 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/46201 * gfortran.dg/proc_ptr_comp_27.f90: New. From-SVN: r167767 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index ae78f9f330da..eddfceb4e800 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 6681a6ab3dfa..cf2cdb6005a8 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 405f4a6930f1..165be16f4c40 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 000000000000..d966648fc30b --- /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