/cp
authorpaolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4>
Sat, 19 Nov 2011 23:17:12 +0000 (23:17 +0000)
committerpaolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4>
Sat, 19 Nov 2011 23:17:12 +0000 (23:17 +0000)
2011-11-19  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/51216
* semantics.c (potential_constant_expression_1): Handle IF_STMT,
DO_STMT, FOR_STMT, and WHILE_STMT.

/testsuite
2011-11-19  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/51216
* g++.dg/cpp0x/pr51216.C: New.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@181517 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/semantics.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/cpp0x/pr51216.C [new file with mode: 0644]

index fa8e1e2..3d0f356 100644 (file)
@@ -1,3 +1,9 @@
+2011-11-19  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/51216
+       * semantics.c (potential_constant_expression_1): Handle IF_STMT,
+       DO_STMT, FOR_STMT, and WHILE_STMT.
+
 2011-11-18  Fabien ChĂȘne  <fabien@gcc.gnu.org>
 
        PR c++/51188
index f70bdb3..fe685fa 100644 (file)
@@ -8178,6 +8178,10 @@ potential_constant_expression_1 (tree t, bool want_rval, tsubst_flags_t flags)
     case EXPR_STMT:
     case BIND_EXPR:
     case TRANSACTION_EXPR:
+    case IF_STMT:
+    case DO_STMT:
+    case FOR_STMT:
+    case WHILE_STMT:
       if (flags & tf_error)
         error ("expression %qE is not a constant-expression", t);
       return false;
index 5b579e0..861f36c 100644 (file)
@@ -1,3 +1,8 @@
+2011-11-19  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/51216
+       * g++.dg/cpp0x/pr51216.C: New.
+
 2011-11-19  Eric Botcazou  <ebotcazou@adacore.com>
 
        * gcc.dg/delay-slot-2.c: New test.
diff --git a/gcc/testsuite/g++.dg/cpp0x/pr51216.C b/gcc/testsuite/g++.dg/cpp0x/pr51216.C
new file mode 100644 (file)
index 0000000..4bdd071
--- /dev/null
@@ -0,0 +1,10 @@
+// PR c++/51216
+// { dg-options "-std=c++0x" }
+
+void foo()
+{
+  int i = ({ if (1) ; });           // { dg-error "ignored" }
+  int j = ({ for (;;) ; });         // { dg-error "ignored" }
+  int k = ({ while (1) ; });        // { dg-error "ignored" }
+  int l = ({ do { } while (1); });  // { dg-error "ignored" }
+}