From: Paul Thomas Date: Sun, 6 May 2007 15:12:01 +0000 (+0000) Subject: re PR fortran/31540 ([Regression 4.2 only] character((constant expression)) for exter... X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=8111a921e9c63612e5b608439f2130276e845e0e;p=platform%2Fupstream%2Fgcc.git re PR fortran/31540 ([Regression 4.2 only] character((constant expression)) for external function) 2007-05-06 Paul Thomas PR fortran/31540 * resolve.c (resolve_fl_procedure): Resolve constant character lengths. 2007-05-06 Paul Thomas PR fortran/31540 * gfortran.dg/char_result_4.f90: New test. From-SVN: r124475 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 9435165..361ffcc 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2007-05-06 Paul Thomas + + PR fortran/31540 + * resolve.c (resolve_fl_procedure): Resolve constant character + lengths. + 2007-05-05 Jerry DeLisle PR fortran/31251 diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c index 55f1390..4ec9a92 100644 --- a/gcc/fortran/resolve.c +++ b/gcc/fortran/resolve.c @@ -5812,6 +5812,11 @@ resolve_fl_procedure (gfc_symbol *sym, int mp_flag) if (sym->ts.type == BT_CHARACTER) { gfc_charlen *cl = sym->ts.cl; + + if (cl && cl->length && gfc_is_constant_expr (cl->length) + && resolve_charlen (cl) == FAILURE) + return FAILURE; + if (!cl || !cl->length || cl->length->expr_type != EXPR_CONSTANT) { if (sym->attr.proc == PROC_ST_FUNCTION) diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index bcec964..2b74f7c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2007-05-06 Paul Thomas + + PR fortran/31540 + * gfortran.dg/char_result_4.f90: New test. + 2007-06-05 Revital Eres PR 30957