trans-expr.c (get_proc_ptr_comp): Restore initial expression type before calling...
authorMikael Morin <mikael@gcc.gnu.org>
Wed, 6 Oct 2010 16:05:41 +0000 (16:05 +0000)
committerMikael Morin <mikael@gcc.gnu.org>
Wed, 6 Oct 2010 16:05:41 +0000 (16:05 +0000)
2010-10-06  Mikael Morin  <mikael@gcc.gnu.org>

* trans-expr.c (get_proc_ptr_comp): Restore initial expression type
before calling gfc_free_expr.

From-SVN: r165047

gcc/fortran/ChangeLog
gcc/fortran/trans-expr.c

index 4c8cec4..dc0bfbb 100644 (file)
@@ -1,5 +1,10 @@
 2010-10-06  Mikael Morin  <mikael@gcc.gnu.org>
 
+       * trans-expr.c (get_proc_ptr_comp): Restore initial expression type
+       before calling gfc_free_expr.
+
+2010-10-06  Mikael Morin  <mikael@gcc.gnu.org>
+
        * trans-array.c (gfc_conv_tmp_array_ref): Add factorized call to
        gfc_advance_se_ss_chain.
        * trans-expr.c (gfc_conv_subref_array_ref, gfc_conv_procedure_call,
index d662d20..c1588f8 100644 (file)
@@ -1612,10 +1612,17 @@ get_proc_ptr_comp (gfc_expr *e)
 {
   gfc_se comp_se;
   gfc_expr *e2;
+  expr_t old_type;
+
   gfc_init_se (&comp_se, NULL);
   e2 = gfc_copy_expr (e);
+  /* We have to restore the expr type later so that gfc_free_expr frees
+     the exact same thing that was allocated.
+     TODO: This is ugly.  */
+  old_type = e2->expr_type;
   e2->expr_type = EXPR_VARIABLE;
   gfc_conv_expr (&comp_se, e2);
+  e2->expr_type = old_type;
   gfc_free_expr (e2);
   return build_fold_addr_expr_loc (input_location, comp_se.expr);
 }