aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/cp/ChangeLog5
-rw-r--r--gcc/cp/decl.c7
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/template/error37.C12
4 files changed, 29 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 4b23d31..57ae757 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,8 @@
+2009-01-15 Andrew Pinski <andrew_pinski@playstation.sony.com>
+
+ PR C++/29388
+ * decl.c (grokdeclarator): Check for a non namespace/class context.
+
2009-01-15 Jason Merrill <jason@redhat.com>
PR c++/36334
diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c
index c6ed22d..8476959 100644
--- a/gcc/cp/decl.c
+++ b/gcc/cp/decl.c
@@ -9285,6 +9285,13 @@ grokdeclarator (const cp_declarator *declarator,
"declared out of global scope", name);
}
+ if (ctype != NULL_TREE
+ && TREE_CODE (ctype) != NAMESPACE_DECL && !MAYBE_CLASS_TYPE_P (ctype))
+ {
+ error ("%q#T is not a class or a namespace", ctype);
+ ctype = NULL_TREE;
+ }
+
if (ctype == NULL_TREE)
{
if (virtualp)
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 198ba97..3e46d1f 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2009-01-15 Andrew Pinski <andrew_pinski@playstation.sony.com>
+
+ PR C++/29388
+ * g++.dg/template/error37.C: New testcase.
+
2009-01-15 Jason Merrill <jason@redhat.com>
PR c++/36334
diff --git a/gcc/testsuite/g++.dg/template/error37.C b/gcc/testsuite/g++.dg/template/error37.C
new file mode 100644
index 0000000..7f1f9ed
--- /dev/null
+++ b/gcc/testsuite/g++.dg/template/error37.C
@@ -0,0 +1,12 @@
+// { dg-do compile }
+// PR C++/29388
+// We used to ICE in is_ancestor because we would use int as the context of foo
+// but that is invalid.
+
+template<int> struct A
+{
+ typedef int T;
+ void foo();
+};
+
+template<int N> void A<N>::T::foo() {} // { dg-error "" }