aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSteven G. Kargl <kargl@gcc.gnu.org>2006-02-03 19:11:27 +0000
committerSteven G. Kargl <kargl@gcc.gnu.org>2006-02-03 19:11:27 +0000
commit219fa8c3bd143161ed37bf6197cb83c7c87e9b6f (patch)
tree50c12e62ea4c706beae0f2e06912b333f9904b99
parentc57bf6210beafda78650af0e0e1647833f42d174 (diff)
downloadgcc-219fa8c3bd143161ed37bf6197cb83c7c87e9b6f.zip
gcc-219fa8c3bd143161ed37bf6197cb83c7c87e9b6f.tar.gz
gcc-219fa8c3bd143161ed37bf6197cb83c7c87e9b6f.tar.bz2
[multiple changes]
2006-02-03 Steven G. Kargl <kargls@comcast.net> Paul Thomas <pault@gcc.gnu.org> * resolve.c (resolve_symbol): Default initialization of derived type component reguires the SAVE attribute. 2006-02-03 Steven G. Kargl <kargls@comcast.net> * gfortran.dg/char_result_11.f90: Add SAVE. * gfortran.dg/der_pointer_4.f90: Ditto. * gfortran.dg/default_initialization.f90: New test. From-SVN: r110554
-rw-r--r--gcc/fortran/ChangeLog6
-rw-r--r--gcc/fortran/resolve.c31
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/gfortran.dg/char_result_11.f902
-rw-r--r--gcc/testsuite/gfortran.dg/default_initialization.f9018
-rw-r--r--gcc/testsuite/gfortran.dg/der_pointer_4.f902
6 files changed, 58 insertions, 7 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 80a453d..a9a610e 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,9 @@
+2006-02-03 Steven G. Kargl <kargls@comcast>
+ Paul Thomas <pault@gcc.gnu.org>
+
+ * resolve.c (resolve_symbol): Default initialization of derived type
+ component reguires the SAVE attribute.
+
2006-02-02 Steven G. Kargl <kargls@comcast>
PR fortran/24958
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c
index ca89f88..3767992 100644
--- a/gcc/fortran/resolve.c
+++ b/gcc/fortran/resolve.c
@@ -4511,11 +4511,12 @@ resolve_symbol (gfc_symbol * sym)
int formal_ns_save, check_constant, mp_flag;
int i, flag;
gfc_namelist *nl;
- gfc_symtree * symtree;
- gfc_symtree * this_symtree;
- gfc_namespace * ns;
- gfc_component * c;
- gfc_formal_arglist * arg;
+ gfc_symtree *symtree;
+ gfc_symtree *this_symtree;
+ gfc_namespace *ns;
+ gfc_component *c;
+ gfc_formal_arglist *arg;
+ gfc_expr *constructor_expr;
if (sym->attr.flavor == FL_UNKNOWN)
{
@@ -4857,6 +4858,26 @@ resolve_symbol (gfc_symbol * sym)
return;
}
+ /* 4th constraint in section 11.3: "If an object of a type for which
+ component-initialization is specified (R429) appears in the
+ specification-part of a module and does not have the ALLOCATABLE
+ or POINTER attribute, the object shall have the SAVE attribute." */
+
+ if (sym->ts.type == BT_DERIVED && !(sym->value || flag))
+ constructor_expr = gfc_default_initializer (&sym->ts);
+
+ if (sym->ns->proc_name
+ && sym->ns->proc_name->attr.flavor == FL_MODULE
+ && constructor_expr
+ && !sym->ns->save_all && !sym->attr.save
+ && !sym->attr.pointer && !sym->attr.allocatable)
+ {
+ gfc_error("Object '%s' at %L must have the SAVE attribute %s",
+ sym->name, &sym->declared_at,
+ "for default initialization of a component");
+ return;
+ }
+
/* Assign default initializer. */
if (sym->ts.type == BT_DERIVED && !(sym->value || flag)
&& !sym->attr.pointer)
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 416187f..5dc5b19 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,9 @@
+2006-02-03 Steven G. Kargl <kargls@comcast.net>
+
+ * gfortran.dg/char_result_11.f90: Add SAVE.
+ * gfortran.dg/der_pointer_4.f90: Ditto.
+ * gfortran.dg/default_initialization.f90: New test.
+
2006-02-03 Jeff Law <law@redhat.com>
* lib/gcc-dg.exp (cleanup-rtl-dump): Fix dump file regexp to
diff --git a/gcc/testsuite/gfortran.dg/char_result_11.f90 b/gcc/testsuite/gfortran.dg/char_result_11.f90
index 19a5c96..c37b20e 100644
--- a/gcc/testsuite/gfortran.dg/char_result_11.f90
+++ b/gcc/testsuite/gfortran.dg/char_result_11.f90
@@ -16,7 +16,7 @@ module cutils
integer(1) :: n1 = 3, n2 = 3, n3 = 3, n4 = 3, n6 = 3, n8 = 3
character(10) :: s = "abcdefghij"
integer :: x(4) = (/ 30, 40, 50, 60 /)
- type(t) :: tt1(5), tt2(5)
+ type(t), save :: tt1(5), tt2(5)
public :: IntToChar1, IntToChar2, IntToChar3, IntToChar4, IntToChar5, &
IntToChar6, IntToChar7, IntToChar8
diff --git a/gcc/testsuite/gfortran.dg/default_initialization.f90 b/gcc/testsuite/gfortran.dg/default_initialization.f90
new file mode 100644
index 0000000..4064784
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/default_initialization.f90
@@ -0,0 +1,18 @@
+!
+! { dg-do compile }
+! PR 20845
+!
+! In ISO/IEC 1539-1:1997(E), 4th constraint in section 11.3:
+!
+! If an object of a type for which component-initialization is specified
+! (R429) appears in the specification-part of a module and does not have
+! the ALLOCATABLE or POINTER attribute, the object shall have the SAVE
+! attribute.
+!
+module bad
+ implicit none
+ type default_initialization
+ integer :: x = 42
+ end type default_initialization
+ type (default_initialization) t ! { dg-error "default initialization" }
+end module bad
diff --git a/gcc/testsuite/gfortran.dg/der_pointer_4.f90 b/gcc/testsuite/gfortran.dg/der_pointer_4.f90
index 6bc499d..c08b846 100644
--- a/gcc/testsuite/gfortran.dg/der_pointer_4.f90
+++ b/gcc/testsuite/gfortran.dg/der_pointer_4.f90
@@ -7,5 +7,5 @@ module crash
integer :: i = 0
type (foo), pointer :: next
end type foo
- type (foo) :: bar
+ type (foo), save :: bar
end module crash