OSDN Git Service

2007-12-06 Paul Thomas <pault@gcc.gnu.org>
authorpault <pault@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 6 Dec 2007 06:11:01 +0000 (06:11 +0000)
committerpault <pault@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 6 Dec 2007 06:11:01 +0000 (06:11 +0000)
PR fortran/34435
* module.c (find_symbol): Do not return symtrees with unique
names, which shows that they are private.

2007-12-06  Paul Thomas  <pault@gcc.gnu.org>

PR fortran/34435
* gfortran.dg/used_types_19.f90: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@130642 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/fortran/ChangeLog
gcc/fortran/module.c
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/used_types_19.f90 [new file with mode: 0644]

index 3b290ac..5d59c89 100644 (file)
@@ -1,3 +1,9 @@
+2007-12-06  Paul Thomas  <pault@gcc.gnu.org>
+
+       PR fortran/34435
+       * module.c (find_symbol): Do not return symtrees with unique
+       names, which shows that they are private.
+
 2007-12-05  Jakub Jelinek  <jakub@redhat.com>
 
        PR debug/33739
index af81c3a..c48bc68 100644 (file)
@@ -3153,7 +3153,8 @@ find_symbol (gfc_symtree *st, const char *name,
 
   c = strcmp (name, st->n.sym->name);
   if (c == 0 && st->n.sym->module
-            && strcmp (module, st->n.sym->module) == 0)
+            && strcmp (module, st->n.sym->module) == 0
+            && !check_unique_name (st->name))
     {
       if ((!generic && !st->n.sym->attr.generic)
             || (generic && st->n.sym->attr.generic))
index f2fcadb..b19a448 100644 (file)
@@ -1,3 +1,8 @@
+2007-12-06  Paul Thomas  <pault@gcc.gnu.org>
+
+       PR fortran/34435
+       * gfortran.dg/used_types_19.f90: New test.
+
 2007-12-06  Kaz Kojima  <kkojima@gcc.gnu.org>
 
        * gfortran.dg/nan_2.f90: Add -mieee for sh.
diff --git a/gcc/testsuite/gfortran.dg/used_types_19.f90 b/gcc/testsuite/gfortran.dg/used_types_19.f90
new file mode 100644 (file)
index 0000000..dbec8dc
--- /dev/null
@@ -0,0 +1,26 @@
+! { dg-do compile }
+! Tests the fix for PR34335 a regression in which the PRIVATE attribute
+! of type(a) in module b would be ignored and would prevent it being
+! loaded in the main program.
+!
+! Contributed by Janus Weil <jaydub66@gmail.com>
+!
+module A
+  type A_type
+    real comp
+  end type
+end module A
+
+module B
+  use A
+  private
+  type(A_type) :: B_var
+  public:: B_var
+end module B
+
+program C
+  use B
+  use A
+  type(A_type):: A_var
+end program C
+! { dg-final { cleanup-modules "a b" } }