diff options
author | Paul Brook <paul@codesourcery.com> | 2004-05-18 00:48:05 +0000 |
---|---|---|
committer | Paul Brook <pbrook@gcc.gnu.org> | 2004-05-18 00:48:05 +0000 |
commit | 54b4ba60f20d3870a79467caa3b604971225d388 (patch) | |
tree | c59d49b2984c03bcf5e5f018b12cc2f44288e7a1 /gcc/fortran/expr.c | |
parent | b7cefb87f053f26b4354d18f94c4e3baa4266645 (diff) | |
download | gcc-54b4ba60f20d3870a79467caa3b604971225d388.zip gcc-54b4ba60f20d3870a79467caa3b604971225d388.tar.gz gcc-54b4ba60f20d3870a79467caa3b604971225d388.tar.bz2 |
re PR fortran/13930 (derived type with intent(in) attribute not accepted)
PR fortran/13930
* decl.c (add_init_expr_to_sym): Remove incorrect check.
(default_initializer): Move to expr.c.
(variable_decl): Don't assign default initializer to variables.
* expr.c (gfc_default_initializer): Move to here.
* gfortran.h (gfc_default_initializer): Add prototype.
* resolve.c (resolve_symbol): Check for illegal initializers.
Assign default initializer.
testsuite/
* gfortran.fortran-torture/execute/der_init_4.f90: New test.
From-SVN: r81966
Diffstat (limited to 'gcc/fortran/expr.c')
-rw-r--r-- | gcc/fortran/expr.c | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/gcc/fortran/expr.c b/gcc/fortran/expr.c index 8b3e391..bb912c7 100644 --- a/gcc/fortran/expr.c +++ b/gcc/fortran/expr.c @@ -1953,3 +1953,46 @@ gfc_check_assign_symbol (gfc_symbol * sym, gfc_expr * rvalue) return r; } + + +/* Get an expression for a default initializer. */ + +gfc_expr * +gfc_default_initializer (gfc_typespec *ts) +{ + gfc_constructor *tail; + gfc_expr *init; + gfc_component *c; + + init = NULL; + + /* See if we have a default initializer. */ + for (c = ts->derived->components; c; c = c->next) + { + if (c->initializer && init == NULL) + init = gfc_get_expr (); + } + + if (init == NULL) + return NULL; + + /* Build the constructor. */ + init->expr_type = EXPR_STRUCTURE; + init->ts = *ts; + init->where = ts->derived->declared_at; + tail = NULL; + for (c = ts->derived->components; c; c = c->next) + { + if (tail == NULL) + init->value.constructor = tail = gfc_get_constructor (); + else + { + tail->next = gfc_get_constructor (); + tail = tail->next; + } + + if (c->initializer) + tail->expr = gfc_copy_expr (c->initializer); + } + return init; +} |