From: Tobias Burnus Date: Wed, 13 Jun 2012 11:56:08 +0000 (+0200) Subject: re PR fortran/53597 (F95/F2003 constraint no longer triggers: un-SAVED default-initia... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=d1f6dfe6fb26ad5bc8d7b7cd34199bd5a9cfe59a;p=gcc.git re PR fortran/53597 (F95/F2003 constraint no longer triggers: un-SAVED default-initialized module variable) 2012-06-13 Tobias Burnus PR fortran/53597 * decl.c (match_attr_spec): Only mark module variables as SAVE_IMPLICIT for Fortran 2008 and later. 2012-06-13 Tobias Burnus PR fortran/53597 * gfortran.dg/save_4.f90: New. From-SVN: r188506 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 02b644544a6..ffe1254a193 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2012-06-13 Tobias Burnus + + PR fortran/53597 + * decl.c (match_attr_spec): Only mark module variables + as SAVE_IMPLICIT for Fortran 2008 and later. + 2012-06-08 Janus Weil PR fortran/52552 diff --git a/gcc/fortran/decl.c b/gcc/fortran/decl.c index a760331eeba..26b5059cd9f 100644 --- a/gcc/fortran/decl.c +++ b/gcc/fortran/decl.c @@ -3810,8 +3810,9 @@ match_attr_spec (void) } } - /* Module variables implicitly have the SAVE attribute. */ - if (gfc_current_state () == COMP_MODULE && !current_attr.save) + /* Since Fortran 2008 module variables implicitly have the SAVE attribute. */ + if (gfc_current_state () == COMP_MODULE && !current_attr.save + && (gfc_option.allow_std & GFC_STD_F2008) != 0) current_attr.save = SAVE_IMPLICIT; colon_seen = 1; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index cdeb722d27b..3649dcfd8b5 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2012-06-13 Tobias Burnus + + PR fortran/53597 + * gfortran.dg/save_4.f90: New. + 2012-06-12 Jakub Jelinek PR c/53532 diff --git a/gcc/testsuite/gfortran.dg/save_4.f90 b/gcc/testsuite/gfortran.dg/save_4.f90 new file mode 100644 index 00000000000..74ea6e83531 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/save_4.f90 @@ -0,0 +1,13 @@ +! { dg-do compile } +! { dg-options "-std=f2003" } +! +! PR fortran/53597 +! +MODULE somemodule + IMPLICIT NONE + TYPE sometype + INTEGER :: i + DOUBLE PRECISION, POINTER, DIMENSION(:,:) :: coef => NULL() + END TYPE sometype + TYPE(sometype) :: somevariable ! { dg-error "Fortran 2008: Implied SAVE for module variable 'somevariable' at .1., needed due to the default initialization" } +END MODULE somemodule