From: Victor Leikehman Date: Fri, 14 May 2004 22:52:04 +0000 (+0300) Subject: decl.c (variable_decl): Always apply default initializer. X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=cb44ab824bd0902002bbf1caa66c05b56829630c;p=platform%2Fupstream%2Fgcc.git decl.c (variable_decl): Always apply default initializer. fortran/ * decl.c (variable_decl): Always apply default initializer. libgfortran/ * gfortran.fortran-torture/execute/def_init_3.f90: New test. From-SVN: r81865 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 605a572..19a66ce 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,7 @@ +2004-05-14 Victor Leikehman + + * decl.c (variable_decl): Always apply default initializer. + 2004-05-08 Tobias Schlüter PR fortran/15206 diff --git a/gcc/fortran/decl.c b/gcc/fortran/decl.c index 9d6bf94..2aed9b2 100644 --- a/gcc/fortran/decl.c +++ b/gcc/fortran/decl.c @@ -619,10 +619,11 @@ variable_decl (void) if (m != MATCH_YES) goto cleanup; } - else if (current_ts.type == BT_DERIVED) - { - initializer = default_initializer (); - } + } + + if (current_ts.type == BT_DERIVED && !initializer) + { + initializer = default_initializer (); } /* Add the initializer. Note that it is fine if &initializer is diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 77a80ba..7e14671 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2004-05-14 Victor Leikehman + + * gfortran.fortran-torture/execute/def_init_3.f90: New test. + 2004-05-14 Jeff Law * gcc.dg/tree-ssa/20040514-2.c: New test. diff --git a/gcc/testsuite/gfortran.fortran-torture/execute/der_init_3.f90 b/gcc/testsuite/gfortran.fortran-torture/execute/der_init_3.f90 new file mode 100644 index 0000000..16f203a --- /dev/null +++ b/gcc/testsuite/gfortran.fortran-torture/execute/der_init_3.f90 @@ -0,0 +1,12 @@ +! PR15365 +! Default initializers were being missed +program main + type xyz + integer :: x = 123 + end + + type (xyz) :: a !! ok + type (xyz) b !!! not initialized !!! + if (a%x.ne.123) call abort + if (b%x.ne.123) call abort +end