]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR fortran/40743 (ICE when compiling iso_varying_string.f95 at revision 149591)
authorJanus Weil <janus@gcc.gnu.org>
Wed, 15 Jul 2009 08:41:29 +0000 (10:41 +0200)
committerJanus Weil <janus@gcc.gnu.org>
Wed, 15 Jul 2009 08:41:29 +0000 (10:41 +0200)
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-15  Janus Weil  <janus@gcc.gnu.org>

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

From-SVN: r149662

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

index aaf2c882dc16cc55e74e3f19dab8f1e23eb70ae8..d83acc7314234da9ea69558963cd2ac75e77d35e 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 880dfd0e886c13455f0435fe93365dab2b603b70..5b4fc2d69493ebf0ab743e0942b34ebb9e9158f7 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 6f30aef5fccf162a216253221f9ea032191d270d..4dc0801291933c95dea36550de0f257d170a3405 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
+