aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2017-02-21 19:00:35 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2017-02-21 19:00:35 +0100
commitb7280ac2708e2a36337347de3c27e8fda914683e (patch)
tree2fb263f2ae604a84bb90c1499aca21471c380c7c /gcc
parent5c3f1d7b10ab48d50e80359eb18c0edc1e3ed402 (diff)
downloadgcc-b7280ac2708e2a36337347de3c27e8fda914683e.zip
gcc-b7280ac2708e2a36337347de3c27e8fda914683e.tar.gz
gcc-b7280ac2708e2a36337347de3c27e8fda914683e.tar.bz2
re PR c++/79654 (ICE on invalid c++ code in register_dtor_fn in cp/decl.c:7877)
PR c++/79654 * decl.c (cp_finish_decomp): Don't set decl's type to error_mark_node on error. * pt.c (tsubst_decomp_names): Return error_mark_node if the first decl after the decomposition artificial decl has error_mark_node. * decl2.c (prune_vars_needing_no_initialization): Use error_operand_p instead of just == error_mark_node comparison. * g++.dg/cpp1z/decomp26.C: New test. Co-Authored-By: Paolo Carlini <paolo.carlini@oracle.com> From-SVN: r245639
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog11
-rw-r--r--gcc/cp/decl.c1
-rw-r--r--gcc/cp/decl2.c2
-rw-r--r--gcc/cp/pt.c5
-rw-r--r--gcc/testsuite/ChangeLog3
-rw-r--r--gcc/testsuite/g++.dg/cpp1z/decomp26.C6
6 files changed, 26 insertions, 2 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index a63eb4b..8222541 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,4 +1,15 @@
2017-02-21 Jakub Jelinek <jakub@redhat.com>
+ Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/79654
+ * decl.c (cp_finish_decomp): Don't set decl's type to error_mark_node
+ on error.
+ * pt.c (tsubst_decomp_names): Return error_mark_node if the first
+ decl after the decomposition artificial decl has error_mark_node.
+ * decl2.c (prune_vars_needing_no_initialization): Use error_operand_p
+ instead of just == error_mark_node comparison.
+
+2017-02-21 Jakub Jelinek <jakub@redhat.com>
PR sanitizer/79589
* decl.c: Include gimplify.h.
diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c
index 5ab9a20..fa1d645 100644
--- a/gcc/cp/decl.c
+++ b/gcc/cp/decl.c
@@ -7386,7 +7386,6 @@ cp_finish_decomp (tree decl, tree first, unsigned int count)
}
first = DECL_CHAIN (first);
}
- TREE_TYPE (decl) = error_mark_node;
if (DECL_P (decl) && DECL_NAMESPACE_SCOPE_P (decl))
SET_DECL_ASSEMBLER_NAME (decl, get_identifier ("<decomp>"));
return;
diff --git a/gcc/cp/decl2.c b/gcc/cp/decl2.c
index d2e57ff..b50fadf 100644
--- a/gcc/cp/decl2.c
+++ b/gcc/cp/decl2.c
@@ -3879,7 +3879,7 @@ prune_vars_needing_no_initialization (tree *vars)
tree init = TREE_PURPOSE (t);
/* Deal gracefully with error. */
- if (decl == error_mark_node)
+ if (error_operand_p (decl))
{
var = &TREE_CHAIN (t);
continue;
diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c
index 2cac24f..c29e691 100644
--- a/gcc/cp/pt.c
+++ b/gcc/cp/pt.c
@@ -15610,6 +15610,11 @@ tsubst_decomp_names (tree decl, tree pattern_decl, tree args,
&& DECL_NAME (decl2);
decl2 = DECL_CHAIN (decl2))
{
+ if (TREE_TYPE (decl2) == error_mark_node && *cnt == 0)
+ {
+ gcc_assert (errorcount);
+ return error_mark_node;
+ }
(*cnt)++;
gcc_assert (DECL_HAS_VALUE_EXPR_P (decl2));
tree v = DECL_VALUE_EXPR (decl2);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index abefa2d..1262b2e 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,8 @@
2017-02-21 Jakub Jelinek <jakub@redhat.com>
+ PR c++/79654
+ * g++.dg/cpp1z/decomp26.C: New test.
+
PR sanitizer/79589
* g++.dg/ubsan/pr79589.C: New test.
diff --git a/gcc/testsuite/g++.dg/cpp1z/decomp26.C b/gcc/testsuite/g++.dg/cpp1z/decomp26.C
new file mode 100644
index 0000000..f413920
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp1z/decomp26.C
@@ -0,0 +1,6 @@
+// PR c++/79654
+// { dg-do compile { target c++11 } }
+// { dg-options "" }
+
+template<typename T> T &make(); // { dg-warning "decomposition declaration only available with" "" { target c++14_down } .+1 }
+auto [d1, d2] = make<int>(); // { dg-error "cannot decompose non-array non-class type" }