diff options
author | Jakub Jelinek <jakub@redhat.com> | 2016-10-04 17:34:16 +0200 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2016-10-04 17:34:16 +0200 |
commit | f72da967576271070086b2252a8463bb69f93abd (patch) | |
tree | 2b161d1369bfc1f4e27eaab39000b1f0df64d3ca | |
parent | bfecd57cd46ac368213f55fc4a3ff67c8c59c5ea (diff) | |
download | gcc-f72da967576271070086b2252a8463bb69f93abd.zip gcc-f72da967576271070086b2252a8463bb69f93abd.tar.gz gcc-f72da967576271070086b2252a8463bb69f93abd.tar.bz2 |
re PR c++/77791 (ICE on invalid C++11 code with redefined function parameter: tree check: expected tree that contains ‘decl minimal’ structure, have ‘error_mark’ in cp_parser_lambda_declarator_opt, at cp/parser.c:1011)
PR c++/77791
* parser.c (cp_parser_lambda_declarator_opt): Only pedwarn
for C++11 on decls in the param_list. Test cxx_dialect < cxx14 before
the loop just once.
* g++.dg/cpp0x/lambda/lambda-77791.C: New test.
From-SVN: r240751
-rw-r--r-- | gcc/cp/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/cp/parser.c | 9 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 3 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/cpp0x/lambda/lambda-77791.C | 4 |
4 files changed, 17 insertions, 4 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 48edc6e..637aed4 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,10 @@ 2016-10-04 Jakub Jelinek <jakub@redhat.com> + PR c++/77791 + * parser.c (cp_parser_lambda_declarator_opt): Only pedwarn + for C++11 on decls in the param_list. Test cxx_dialect < cxx14 before + the loop just once. + * cp-tree.h (enum cp_tree_index): Remove CPTI_JAVA_*, CPTI_LANG_NAME_JAVA and CPTI_JCLASS. (java_byte_type_node, java_short_type_node, java_int_type_node, diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c index 16b895c..8581375 100644 --- a/gcc/cp/parser.c +++ b/gcc/cp/parser.c @@ -10114,10 +10114,11 @@ cp_parser_lambda_declarator_opt (cp_parser* parser, tree lambda_expr) /* Default arguments shall not be specified in the parameter-declaration-clause of a lambda-declarator. */ - for (tree t = param_list; t; t = TREE_CHAIN (t)) - if (TREE_PURPOSE (t) && cxx_dialect < cxx14) - pedwarn (DECL_SOURCE_LOCATION (TREE_VALUE (t)), OPT_Wpedantic, - "default argument specified for lambda parameter"); + if (cxx_dialect < cxx14) + for (tree t = param_list; t; t = TREE_CHAIN (t)) + if (TREE_PURPOSE (t) && DECL_P (TREE_VALUE (t))) + pedwarn (DECL_SOURCE_LOCATION (TREE_VALUE (t)), OPT_Wpedantic, + "default argument specified for lambda parameter"); cp_parser_require (parser, CPP_CLOSE_PAREN, RT_CLOSE_PAREN); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index ef45ca1..3b2e14a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,8 @@ 2016-10-04 Jakub Jelinek <jakub@redhat.com> + PR c++/77791 + * g++.dg/cpp0x/lambda/lambda-77791.C: New test. + * g++.dg/other/java3.C: Remove. * g++.dg/other/java1.C: Remove. * g++.dg/other/error12.C: Remove. diff --git a/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-77791.C b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-77791.C new file mode 100644 index 0000000..0475d27 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-77791.C @@ -0,0 +1,4 @@ +// PR c++/77791 +// { dg-do compile { target c++11 } } + +auto a = [] (int i, int i = 0) {}; // { dg-error "redefinition of" } |