aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/trans-expr.c
diff options
context:
space:
mode:
authorPaul Brook <paul@codesourcery.com>2004-07-10 22:55:40 +0000
committerPaul Brook <pbrook@gcc.gnu.org>2004-07-10 22:55:40 +0000
commit331c72f3db58cd93b1863aef4844a2ef883ae63a (patch)
tree034a0384236929485e40eb708eba4ee38fc03fdb /gcc/fortran/trans-expr.c
parent53814b8fe83f2f579f213e919b40c2793e824892 (diff)
downloadgcc-331c72f3db58cd93b1863aef4844a2ef883ae63a.zip
gcc-331c72f3db58cd93b1863aef4844a2ef883ae63a.tar.gz
gcc-331c72f3db58cd93b1863aef4844a2ef883ae63a.tar.bz2
trans-array.c (gfc_build_null_descriptor): New function.
* 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
Diffstat (limited to 'gcc/fortran/trans-expr.c')
-rw-r--r--gcc/fortran/trans-expr.c39
1 files changed, 17 insertions, 22 deletions
diff --git a/gcc/fortran/trans-expr.c b/gcc/fortran/trans-expr.c
index 5c62234..a8412bd 100644
--- a/gcc/fortran/trans-expr.c
+++ b/gcc/fortran/trans-expr.c
@@ -1379,7 +1379,6 @@ gfc_conv_structure (gfc_se * se, gfc_expr * expr, int init)
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);
@@ -1397,32 +1396,28 @@ gfc_conv_structure (gfc_se * se, gfc_expr * expr, int init)
/* 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
{