PR c++/34619
authorjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 3 Jan 2008 10:28:30 +0000 (10:28 +0000)
committerjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 3 Jan 2008 10:28:30 +0000 (10:28 +0000)
* cgraphunit.c (cgraph_build_static_cdtor): set_cfun back to NULL
before returning.

* testsuite/libmudflap.c++/pass61-frag.cxx: New test.

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

gcc/ChangeLog
gcc/cgraphunit.c
libmudflap/ChangeLog
libmudflap/testsuite/libmudflap.c++/pass61-frag.cxx [new file with mode: 0644]

index e7098d0..952d851 100644 (file)
@@ -1,5 +1,9 @@
 2008-01-03  Jakub Jelinek  <jakub@redhat.com>
 
+       PR c++/34619
+       * cgraphunit.c (cgraph_build_static_cdtor): set_cfun back to NULL
+       before returning.
+
        PR tree-optimization/29484
        * tree-inline.c (inline_forbidden_p_2): New function.
        (inline_forbidden_p): Disallow inlining if some static var
index 7215f1a..5d81f56 100644 (file)
@@ -1,5 +1,6 @@
 /* Callgraph based interprocedural optimizations.
-   Copyright (C) 2003, 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
+   Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008
+   Free Software Foundation, Inc.
    Contributed by Jan Hubicka
 
 This file is part of GCC.
@@ -1515,6 +1516,7 @@ cgraph_build_static_cdtor (char which, tree body, int priority)
 
   cgraph_add_new_function (decl, false);
   cgraph_mark_needed_node (cgraph_node (decl));
+  set_cfun (NULL);
 }
 
 void
index 081f14c..1c7313a 100644 (file)
@@ -1,3 +1,8 @@
+2008-01-03  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/34619
+       * testsuite/libmudflap.c++/pass61-frag.cxx: New test.
+
 2008-01-01  Volker Reichelt  <v.reichelt@netcologne.de>
 
        PR libmudflap/26442
diff --git a/libmudflap/testsuite/libmudflap.c++/pass61-frag.cxx b/libmudflap/testsuite/libmudflap.c++/pass61-frag.cxx
new file mode 100644 (file)
index 0000000..0304611
--- /dev/null
@@ -0,0 +1,20 @@
+// PR c++/34619
+// { dg-do compile }
+
+template <typename> struct A
+{
+  typedef int X;
+  static const int N = 1;
+};
+
+template <typename T> struct B
+{
+  typedef typename A <int [A <T>::N]>::X Y;
+  template <typename U> B (Y, U) {}
+};
+
+int main ()
+{
+}
+
+B <int>b (0, 0);