aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaolo Carlini <paolo.carlini@oracle.com>2018-02-20 09:02:12 +0000
committerPaolo Carlini <paolo@gcc.gnu.org>2018-02-20 09:02:12 +0000
commit0b2513e292a70d715affbe4a9b5af6672fcf99b3 (patch)
tree71703ff66974d7a3c883c1170d86827cc4b1b189
parent393d9df7b33313418ae8921cdb587537bd641c1c (diff)
downloadgcc-0b2513e292a70d715affbe4a9b5af6672fcf99b3.zip
gcc-0b2513e292a70d715affbe4a9b5af6672fcf99b3.tar.gz
gcc-0b2513e292a70d715affbe4a9b5af6672fcf99b3.tar.bz2
re PR c++/84446 (ICE with broken lambda)
/cp 2018-02-20 Paolo Carlini <paolo.carlini@oracle.com> PR c++/84446 * parser.c (cp_parser_init_declarator): Don't call start_lambda_scope on error_mark_node. /testsuite 2018-02-20 Paolo Carlini <paolo.carlini@oracle.com> PR c++/84446 * g++.dg/cpp0x/lambda/lambda-ice27.C: New. From-SVN: r257841
-rw-r--r--gcc/cp/ChangeLog6
-rw-r--r--gcc/cp/parser.c4
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/lambda/lambda-ice27.C8
4 files changed, 21 insertions, 2 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 1e0f9eb..f2bcce9 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,9 @@
+2018-02-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/84446
+ * parser.c (cp_parser_init_declarator): Don't call start_lambda_scope
+ on error_mark_node.
+
2018-02-20 Jakub Jelinek <jakub@redhat.com>
PR c++/84445
diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c
index d8d7880..2bb0d2d 100644
--- a/gcc/cp/parser.c
+++ b/gcc/cp/parser.c
@@ -19650,12 +19650,12 @@ cp_parser_init_declarator (cp_parser* parser,
member templates. The former involves deferring
parsing of the initializer until end of class as with default
arguments. So right here we only handle the latter. */
- if (!member_p && processing_template_decl)
+ if (!member_p && processing_template_decl && decl != error_mark_node)
start_lambda_scope (decl);
initializer = cp_parser_initializer (parser,
&is_direct_init,
&is_non_constant_init);
- if (!member_p && processing_template_decl)
+ if (!member_p && processing_template_decl && decl != error_mark_node)
finish_lambda_scope ();
if (initializer == error_mark_node)
cp_parser_skip_to_end_of_statement (parser);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 29157ac..6a0c3bd 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2018-02-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/84446
+ * g++.dg/cpp0x/lambda/lambda-ice27.C: New.
+
2018-02-20 Jakub Jelinek <jakub@redhat.com>
PR c++/84445
diff --git a/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-ice27.C b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-ice27.C
new file mode 100644
index 0000000..04c44a3
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-ice27.C
@@ -0,0 +1,8 @@
+// PR c++/84446
+// { dg-do compile { target c++11 } }
+
+template<int> void foo()
+{
+ int i,
+ i = [] { virtual }(); // { dg-error "redeclaration|expected" }
+}