2009-07-15 Janus Weil <janus@gcc.gnu.org>
authorjanus <janus@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 15 Jul 2009 08:41:29 +0000 (08:41 +0000)
committerjanus <janus@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 15 Jul 2009 08:41:29 +0000 (08:41 +0000)
PR fortran/40743
* resolve.c (resolve_symbol): Don't resolve the formal namespace of a
contained procedure.

2009-07-15  Janus Weil  <janus@gcc.gnu.org>

PR fortran/40743
* gfortran.dg/interface_assignment_4.f90: New.

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

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

index aaf2c88..d83acc7 100644 (file)
@@ -1,3 +1,9 @@
+2009-07-15  Janus Weil  <janus@gcc.gnu.org>
+
+       PR fortran/40743
+       * resolve.c (resolve_symbol): Don't resolve the formal namespace of a
+       contained procedure.
+
 2009-07-14  Taras Glek  <tglek@mozilla.com>
            Rafael Espindola  <espindola@google.com>
 
index 880dfd0..5b4fc2d 100644 (file)
@@ -9842,7 +9842,8 @@ resolve_symbol (gfc_symbol *sym)
   formal_arg_flag = 0;
 
   /* Resolve formal namespaces.  */
-  if (sym->formal_ns && sym->formal_ns != gfc_current_ns)
+  if (sym->formal_ns && sym->formal_ns != gfc_current_ns
+      && !sym->attr.contained)
     gfc_resolve (sym->formal_ns);
 
   /* Make sure the formal namespace is present.  */
index 6f30aef..4dc0801 100644 (file)
@@ -1,3 +1,8 @@
+2009-07-15  Janus Weil  <janus@gcc.gnu.org>
+
+       PR fortran/40743
+       * gfortran.dg/interface_assignment_4.f90: New.
+
 2009-07-15  Gerald Pfeifer  <gerald@pfeifer.com>
 
        * gcc.dg/builtins-config.h (HAVE_C99_RUNTIME): Do not define
diff --git a/gcc/testsuite/gfortran.dg/interface_assignment_4.f90 b/gcc/testsuite/gfortran.dg/interface_assignment_4.f90
new file mode 100644 (file)
index 0000000..535e884
--- /dev/null
@@ -0,0 +1,35 @@
+! { dg-do compile }
+!
+! PR 40743: [4.5 Regression] ICE when compiling iso_varying_string.f95 at revision 149591
+!
+! Reduced from http://www.fortran.com/iso_varying_string.f95
+! Contributed by Janus Weil <janus@gcc.gnu.org>
+
+  implicit none
+
+  type :: varying_string
+  end type
+
+  interface assignment(=)
+     procedure op_assign_VS_CH
+  end interface
+
+contains
+
+  subroutine op_assign_VS_CH (var, exp)
+    type(varying_string), intent(out) :: var
+    character(LEN=*), intent(in)      :: exp
+  end subroutine
+
+  subroutine split_VS
+    type(varying_string) :: string
+    call split_CH(string)
+  end subroutine
+
+  subroutine split_CH (string)
+    type(varying_string) :: string
+    string = ""
+  end subroutine
+
+end
+