From: Jerry DeLisle Date: Sat, 22 Dec 2007 01:57:07 +0000 (+0000) Subject: re PR libfortran/34540 (cshift, eoshift, kind=1 and kind=2 arguments...) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=565e50452f91d43f2e5846855e1f030f5b6f4cd9;p=gcc.git re PR libfortran/34540 (cshift, eoshift, kind=1 and kind=2 arguments...) 2007-12-21 Jerry DeLisle PR fortran/34540 * iresolve.c (gfc_resolve_cshift): Take optional dim path only if the argument is an optional itself. * iresolve.c (gfc_resolve_eoshift): Same. From-SVN: r131133 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index f90a0778812..c67dca5f837 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,10 @@ +2007-12-21 Jerry DeLisle + + PR fortran/34540 + * iresolve.c (gfc_resolve_cshift): Take optional dim path + only if the argument is an optional itself. + * iresolve.c (gfc_resolve_eoshift): Same. + 2007-12-21 Paul Thomas PR fortran/34438 diff --git a/gcc/fortran/iresolve.c b/gcc/fortran/iresolve.c index a68e42e0aff..cdc4ac176dd 100644 --- a/gcc/fortran/iresolve.c +++ b/gcc/fortran/iresolve.c @@ -590,7 +590,7 @@ gfc_resolve_cshift (gfc_expr *f, gfc_expr *array, gfc_expr *shift, if (dim != NULL) { - if (dim->expr_type != EXPR_CONSTANT) + if (dim->expr_type != EXPR_CONSTANT && dim->symtree->n.sym->attr.optional) { /* Mark this for later setting the type in gfc_conv_missing_dummy. */ dim->representation.length = shift->ts.kind; @@ -728,7 +728,7 @@ gfc_resolve_eoshift (gfc_expr *f, gfc_expr *array, gfc_expr *shift, if (dim != NULL) { - if (dim->expr_type != EXPR_CONSTANT) + if (dim->expr_type != EXPR_CONSTANT && dim->symtree->n.sym->attr.optional) { /* Mark this for later setting the type in gfc_conv_missing_dummy. */ dim->representation.length = shift->ts.kind;