+2006-04-02 Erik Edelmann <eedelman@gcc.gnu.org>
+
+ * trans-array.c (gfc_trans_dealloc_allocated): Take a
+ tree representation of the array to be deallocated as argument
+ instead of its gfc_symbol.
+ (gfc_trans_deferred_array): Update call to
+ gfc_trans_dealloc_allocated.
+ * trans-array.h (gfc_trans_dealloc_allocated): Update
+ prototype.
+ * trans-expr.c (gfc_conv_function_call): Update call to
+ gfc_trans_dealloc_allocated, get indirect reference to dummy
+ arguments.
+
2006-04-01 Roger Sayle <roger@eyesopen.com>
PR fortran/25270
}
-/* Generate code to deallocate the symbol 'sym', if it is allocated. */
+/* Generate code to deallocate an array, if it is allocated. */
tree
-gfc_trans_dealloc_allocated (gfc_symbol * sym)
+gfc_trans_dealloc_allocated (tree descriptor)
{
tree tmp;
- tree descriptor;
tree deallocate;
stmtblock_t block;
- gcc_assert (sym->attr.allocatable);
-
gfc_start_block (&block);
- descriptor = sym->backend_decl;
deallocate = gfc_array_deallocate (descriptor, null_pointer_node);
tmp = gfc_conv_descriptor_data_get (descriptor);
/* Allocatable arrays need to be freed when they go out of scope. */
if (sym->attr.allocatable)
{
- tmp = gfc_trans_dealloc_allocated (sym);
+ tmp = gfc_trans_dealloc_allocated (sym->backend_decl);
gfc_add_expr_to_block (&fnblock, tmp);
}
tree gfc_trans_dummy_array_bias (gfc_symbol *, tree, tree);
/* Generate entry and exit code for g77 calling convention arrays. */
tree gfc_trans_g77_array (gfc_symbol *, tree);
-/* Generate code to deallocate the symbol 'sym', if it is allocated. */
-tree gfc_trans_dealloc_allocated (gfc_symbol * sym);
+/* Generate code to deallocate an array, if it is allocated. */
+tree gfc_trans_dealloc_allocated (tree);
/* Add initialization for deferred arrays. */
tree gfc_trans_deferred_array (gfc_symbol *, tree);
/* Generate an initializer for a static pointer or allocatable array. */
if (formal && formal->sym->attr.allocatable
&& formal->sym->attr.intent == INTENT_OUT)
{
- tmp = gfc_trans_dealloc_allocated (arg->expr->symtree->n.sym);
+ tmp = arg->expr->symtree->n.sym->backend_decl;
+ if (arg->expr->symtree->n.sym->attr.dummy)
+ tmp = build_fold_indirect_ref (tmp);
+ tmp = gfc_trans_dealloc_allocated (tmp);
gfc_add_expr_to_block (&se->pre, tmp);
}
+2006-04-02 Erik Edelmann <eedelman@gcc.gnu.org>
+
+ * gfortran.dg/allocatable_dummy_1.f90: Also check that allocatable
+ dummy arguments work when the actual argument is itself a dummy
+ argument of the caller.
+
2006-04-01 Eric Botcazou <ebotcazou@libertysurf.fr>
PR libfortran/24685
integer, allocatable, intent(in) :: x(:)
integer, allocatable, intent(out) :: y(:)
if (allocated(y)) call abort()
- allocate (y(3))
+ call init(y)
y = x
end subroutine useit