diff options
author | Fritz Reese <fritzoreese@gmail.com> | 2016-05-14 15:29:13 +0000 |
---|---|---|
committer | Steven G. Kargl <kargl@gcc.gnu.org> | 2016-05-14 15:29:13 +0000 |
commit | e75eb64fdf7296fa333f49f0186f1e219fed16ad (patch) | |
tree | c0e35f95a24b7dfb90378e63c97ad2c70611d844 /gcc/fortran/expr.c | |
parent | 3a65d8d709ae9c42d15dc258d34cb8ec4b9ea122 (diff) | |
download | gcc-e75eb64fdf7296fa333f49f0186f1e219fed16ad.zip gcc-e75eb64fdf7296fa333f49f0186f1e219fed16ad.tar.gz gcc-e75eb64fdf7296fa333f49f0186f1e219fed16ad.tar.bz2 |
re PR fortran/71047 (Allocatable component of INTENT(OUT) dummy not set correctly)
2016-05-14 Fritz Reese <fritzoreese@gmail.com>
PR fortran/71047
* expr.c (gfc_default_initializer): Avoid extra component refs in
constructors for derived types and classes.
2016-05-14 Fritz Reese <fritzoreese@gmail.com>
PR fortran/71047
* gfortran.dg/pr71047.f08: New test.
From-SVN: r236241
Diffstat (limited to 'gcc/fortran/expr.c')
-rw-r--r-- | gcc/fortran/expr.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/gcc/fortran/expr.c b/gcc/fortran/expr.c index 6ebe08b..d1258cd 100644 --- a/gcc/fortran/expr.c +++ b/gcc/fortran/expr.c @@ -3975,7 +3975,10 @@ gfc_default_initializer (gfc_typespec *ts) if (comp->initializer) { - ctor->n.component = comp; + /* Save the component ref for STRUCTUREs and UNIONs. */ + if (ts->u.derived->attr.flavor == FL_STRUCT + || ts->u.derived->attr.flavor == FL_UNION) + ctor->n.component = comp; ctor->expr = gfc_copy_expr (comp->initializer); if ((comp->ts.type != comp->initializer->ts.type || comp->ts.kind != comp->initializer->ts.kind) |