aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2014-10-09 14:05:29 -0400
committerJason Merrill <jason@gcc.gnu.org>2014-10-09 14:05:29 -0400
commitea4e4e6e2f85186ddff69ced0b8647fac67d68ae (patch)
treef21f7dbe8cfd281fd8ad88b0fd2ea707f065a5ab /gcc
parent5d4fffb822d1370d3e8efb694dbc9dc35d003de8 (diff)
downloadgcc-ea4e4e6e2f85186ddff69ced0b8647fac67d68ae.zip
gcc-ea4e4e6e2f85186ddff69ced0b8647fac67d68ae.tar.gz
gcc-ea4e4e6e2f85186ddff69ced0b8647fac67d68ae.tar.bz2
re PR c++/63309 (internal compiler error: Segmentation fault)
PR c++/63309 * parser.c (cp_parser_class_head): push_template_decl for members of templates, too. From-SVN: r216044
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog4
-rw-r--r--gcc/cp/parser.c4
-rw-r--r--gcc/testsuite/g++.dg/template/nested6.C19
3 files changed, 24 insertions, 3 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 09aad7d..cf04f0d 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,5 +1,9 @@
2014-10-09 Jason Merrill <jason@redhat.com>
+ PR c++/63309
+ * parser.c (cp_parser_class_head): push_template_decl for members
+ of templates, too.
+
PR c++/63415
* pt.c (value_dependent_expression_p) [CONSTRUCTOR]: Check the type.
(iterative_hash_template_arg): Likewise.
diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c
index bc992b2..a9edcd5 100644
--- a/gcc/cp/parser.c
+++ b/gcc/cp/parser.c
@@ -20222,9 +20222,7 @@ cp_parser_class_head (cp_parser* parser,
template either from the template headers or the type we're
defining, so that we diagnose both extra and missing headers. */
if ((PROCESSING_REAL_TEMPLATE_DECL_P ()
- || (CLASSTYPE_TEMPLATE_INFO (TREE_TYPE (type))
- && PRIMARY_TEMPLATE_P (CLASSTYPE_TI_TEMPLATE
- (TREE_TYPE (type)))))
+ || CLASSTYPE_TEMPLATE_INFO (TREE_TYPE (type)))
&& !CLASSTYPE_TEMPLATE_SPECIALIZATION (TREE_TYPE (type)))
{
type = push_template_decl (type);
diff --git a/gcc/testsuite/g++.dg/template/nested6.C b/gcc/testsuite/g++.dg/template/nested6.C
new file mode 100644
index 0000000..f5b8054
--- /dev/null
+++ b/gcc/testsuite/g++.dg/template/nested6.C
@@ -0,0 +1,19 @@
+// PR c++/63309
+
+template <class T>
+class A
+{
+public:
+ class B;
+};
+
+template <class T, class I>
+class A<T>::B // { dg-error "template parameters|required" }
+{
+};
+
+int main()
+{
+ A<int>::B myB; // { dg-prune-output "incomplete type" }
+ return 0;
+}