aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaolo Carlini <paolo.carlini@oracle.com>2011-02-23 00:37:43 +0000
committerPaolo Carlini <paolo@gcc.gnu.org>2011-02-23 00:37:43 +0000
commita26e0b8113f3a58fde9b98041140b301c4407c00 (patch)
tree6f191d30d0d11b9693f93644a9ab60e272be6665
parentb152a6158e401ee9e3752b4403deadd91aec2418 (diff)
downloadgcc-a26e0b8113f3a58fde9b98041140b301c4407c00.zip
gcc-a26e0b8113f3a58fde9b98041140b301c4407c00.tar.gz
gcc-a26e0b8113f3a58fde9b98041140b301c4407c00.tar.bz2
re PR c++/47242 ([C++0x] ICE: tree check: expected field_decl, have error_mark in build_lambda_object, at cp/semantics.c:7604 on invalid lambda function)
/cp 2011-02-22 Paolo Carlini <paolo.carlini@oracle.com> PR c++/47242 * semantics.c (build_lambda_object): Bail out if a field is error_mark_node. /testsuite 2011-02-22 Paolo Carlini <paolo.carlini@oracle.com> PR c++/47242 * g++.dg/cpp0x/lambda/lambda-ice4.C: New. From-SVN: r170423
-rw-r--r--gcc/cp/ChangeLog6
-rw-r--r--gcc/cp/semantics.c7
-rw-r--r--gcc/testsuite/ChangeLog7
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/lambda/lambda-ice4.C14
4 files changed, 33 insertions, 1 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index b532371..291f09b 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,9 @@
+2011-02-22 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/47242
+ * semantics.c (build_lambda_object): Bail out if a field is
+ error_mark_node.
+
2011-02-22 Dodji Seketeli <dodji@redhat.com>
PR c++/47666
diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c
index 6a9c6a0..4af007d 100644
--- a/gcc/cp/semantics.c
+++ b/gcc/cp/semantics.c
@@ -7795,6 +7795,12 @@ build_lambda_object (tree lambda_expr)
tree field = TREE_PURPOSE (node);
tree val = TREE_VALUE (node);
+ if (field == error_mark_node)
+ {
+ expr = error_mark_node;
+ goto out;
+ }
+
if (DECL_P (val))
mark_used (val);
@@ -7830,6 +7836,7 @@ build_lambda_object (tree lambda_expr)
expr = finish_compound_literal (type, expr);
CLASSTYPE_NON_AGGREGATE (type) = 1;
+ out:
input_location = saved_loc;
return expr;
}
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index aa53085..f64735e 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2011-02-22 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/47242
+ * g++.dg/cpp0x/lambda/lambda-ice4.C: New.
+
2011-02-23 Jie Zhang <jie@codesourcery.com>
PR rtl-optimization/47763
@@ -154,7 +159,7 @@
PR objc/47784
* objc.dg/property/dotsyntax-22.m: New.
* obj-c++.dg/property/dotsyntax-22.mm: New.
-
+
2011-02-20 Dodji Seketeli <dodji@redhat.com>
PR c++/46394
diff --git a/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-ice4.C b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-ice4.C
new file mode 100644
index 0000000..77c773b
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-ice4.C
@@ -0,0 +1,14 @@
+// PR c++/47242
+// { dg-options "-std=c++0x" }
+
+template < typename > void
+bar ()
+{
+ [i]{}; // { dg-error "declared|invalid" }
+}
+
+void
+foo ()
+{
+ bar<int>();
+}