http://gcc.gnu.org/bugzilla/show_bug.cgi?id=55907



--- Comment #4 from janus at gcc dot gnu.org 2013-02-08 22:02:09 UTC ---

The following, which is a partial revert of r183180, fixes the ICE:



Index: gcc/fortran/resolve.c

===================================================================

--- gcc/fortran/resolve.c    (revision 195813)

+++ gcc/fortran/resolve.c    (working copy)

@@ -10981,26 +10981,6 @@ build_default_init_expr (gfc_symbol *sym)

       gfc_free_expr (init_expr);

       init_expr = NULL;

     }

-      if (!init_expr && gfc_option.flag_init_character ==

GFC_INIT_CHARACTER_ON

-      && sym->ts.u.cl->length)

-    {

-      gfc_actual_arglist *arg;

-      init_expr = gfc_get_expr ();

-      init_expr->where = sym->declared_at;

-      init_expr->ts = sym->ts;

-      init_expr->expr_type = EXPR_FUNCTION;

-      init_expr->value.function.isym =

-        gfc_intrinsic_function_by_id (GFC_ISYM_REPEAT);

-      init_expr->value.function.name = "repeat";

-      arg = gfc_get_actual_arglist ();

-      arg->expr = gfc_get_character_expr (sym->ts.kind, &sym->declared_at,

-                          NULL, 1);

-      arg->expr->value.character.string[0]

-        = gfc_option.flag_init_character_value;

-      arg->next = gfc_get_actual_arglist ();

-      arg->next->expr = gfc_copy_expr (sym->ts.u.cl->length);

-      init_expr->value.function.actual = arg;

-    }

       break;



     default:

Reply via email to