* trans-array.c (gfc_build_null_descriptor): New function.
(gfc_trans_static_array_pointer): Use it.
* trans-array.h (gfc_build_null_descriptor): Add prototype.
* trans-expr.c (gfc_conv_structure): Handle array pointers.
testsuite/
* gfortran.fortran-torture/execute/der_init_5.f90: Enable more tests.
From-SVN: r84477
+2004-07-10 Paul Brook <paul@codesourcery.com>
+
+ * trans-array.c (gfc_build_null_descriptor): New function.
+ (gfc_trans_static_array_pointer): Use it.
+ * trans-array.h (gfc_build_null_descriptor): Add prototype.
+ * trans-expr.c (gfc_conv_structure): Handle array pointers.
+
2004-07-10 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
PR fortran/16336
}
-/* Generate an initializer for a static pointer or allocatable array. */
+/* Build an null array descriptor constructor. */
-void
-gfc_trans_static_array_pointer (gfc_symbol * sym)
+tree
+gfc_build_null_descriptor (tree type)
{
- tree tmp;
tree field;
- tree type;
+ tree tmp;
- assert (TREE_STATIC (sym->backend_decl));
- /* Just zero the data member. */
- type = TREE_TYPE (sym->backend_decl);
assert (GFC_DESCRIPTOR_TYPE_P (type));
assert (DATA_FIELD == 0);
field = TYPE_FIELDS (type);
+ /* Set a NULL data pointer. */
tmp = tree_cons (field, null_pointer_node, NULL_TREE);
tmp = build1 (CONSTRUCTOR, type, tmp);
TREE_CONSTANT (tmp) = 1;
TREE_INVARIANT (tmp) = 1;
- DECL_INITIAL (sym->backend_decl) = tmp;
+ /* All other fields are ignored. */
+
+ return tmp;
}
}
+/* Generate an initializer for a static pointer or allocatable array. */
+
+void
+gfc_trans_static_array_pointer (gfc_symbol * sym)
+{
+ tree type;
+
+ assert (TREE_STATIC (sym->backend_decl));
+ /* Just zero the data member. */
+ type = TREE_TYPE (sym->backend_decl);
+ DECL_INITIAL (sym->backend_decl) =gfc_build_null_descriptor (type);
+}
+
+
/* Generate code to allocate an array temporary, or create a variable to
hold the data. */
void gfc_conv_loop_setup (gfc_loopinfo *);
/* Resolve array assignment dependencies. */
void gfc_conv_resolve_dependencies (gfc_loopinfo *, gfc_ss *, gfc_ss *);
+/* Build an null array descriptor constructor. */
+tree gfc_build_null_descriptor (tree);
/* Get a single array element. */
void gfc_conv_array_ref (gfc_se *, gfc_array_ref *);
tree val;
gfc_se cse;
tree type;
- tree arraytype;
assert (expr->expr_type == EXPR_STRUCTURE || expr->expr_type == EXPR_NULL);
type = gfc_typenode_for_spec (&expr->ts);
/* Evaluate the expression for this component. */
if (init)
{
- if (!cm->pointer)
+ if (cm->dimension)
{
- /* Initializing a non-pointer element. */
- if (cm->dimension)
- {
- arraytype = TREE_TYPE (cm->backend_decl);
- cse.expr = gfc_conv_array_initializer (arraytype, c->expr);
- }
- else if (cm->ts.type == BT_DERIVED)
- gfc_conv_structure (&cse, c->expr, 1);
- else
- gfc_conv_expr (&cse, c->expr);
+ tree arraytype;
+ arraytype = TREE_TYPE (cm->backend_decl);
+ /* Arrays need special handling. */
+ if (cm->pointer)
+ cse.expr = gfc_build_null_descriptor (arraytype);
+ else
+ cse.expr = gfc_conv_array_initializer (arraytype, c->expr);
}
- else
+ else if (cm->pointer)
{
- /* Pointer components may only be initialized to
- NULL. This should have been enforced by the frontend. */
- if (cm->dimension)
- {
- gfc_todo_error ("Initialization of pointer members");
- }
- else
- cse.expr = fold_convert (TREE_TYPE (cm->backend_decl),
- null_pointer_node);
+ /* Pointer components may only be initialized to NULL. */
+ assert (c->expr->expr_type == EXPR_NULL);
+ cse.expr = fold_convert (TREE_TYPE (cm->backend_decl),
+ null_pointer_node);
}
+ else if (cm->ts.type == BT_DERIVED)
+ gfc_conv_structure (&cse, c->expr, 1);
+ else
+ gfc_conv_expr (&cse, c->expr);
}
else
{
+2004-07-10 Paul Brook <paul@codesourcery.com>
+
+ * gfortran.fortran-torture/execute/der_init_5.f90: Enable more tests.
+
2004-07-10 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
PR fortran/15969
type t
type(t), pointer :: a => NULL()
real, pointer :: b => NULL()
-! character, pointer :: c => NULL()
-! integer, pointer, dimension(:) :: d => NULL()
+ character, pointer :: c => NULL()
+ integer, pointer, dimension(:) :: d => NULL()
end type t
type (t) :: p
if (associated(p%a)) call abort()
if (associated(p%b)) call abort()
! if (associated(p%c)) call abort()
-! if (associated(p%d)) call abort()
+ if (associated(p%d)) call abort()
end