]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR c++/54777 ([C++11] Comma operator in constexpr environment can cause ICE)
authorJakub Jelinek <jakub@redhat.com>
Wed, 3 Oct 2012 14:21:20 +0000 (16:21 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Wed, 3 Oct 2012 14:21:20 +0000 (16:21 +0200)
PR c++/54777
* semantics.c (cxx_eval_constant_expression) <case COMPOUND_EXPR>: If
not ignoring the second operand, pass the original second operand
and not one with stripped nops to cxx_eval_constant_expression.

* g++.dg/cpp0x/constexpr-ref4.C: New test.

From-SVN: r192036

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

index f868739be6ef1643e474d93f6e78e1d3ba9426a8..223e42a0d4c9f434ecbdba7935a9f013645cc831 100644 (file)
@@ -1,3 +1,10 @@
+2012-10-03  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/54777
+       * semantics.c (cxx_eval_constant_expression) <case COMPOUND_EXPR>: If
+       not ignoring the second operand, pass the original second operand
+       and not one with stripped nops to cxx_eval_constant_expression.
+
 2012-10-01  Jason Merrill  <jason@redhat.com>
 
        * decl.c (check_initializer): Set DECL_NONTRIVIALLY_INITIALIZED_P
index 1aa5a8b8b561a460f0317ad38c608e01c48d952e..68cbb4ba8c408ac978cbded38a1b975fdc44fbf7 100644 (file)
@@ -7740,6 +7740,7 @@ cxx_eval_constant_expression (const constexpr_call *call, tree t,
            /* Check that the LHS is constant and then discard it.  */
            cxx_eval_constant_expression (call, op0, allow_non_constant,
                                          false, non_constant_p);
+           op1 = TREE_OPERAND (t, 1);
            r = cxx_eval_constant_expression (call, op1, allow_non_constant,
                                              addr, non_constant_p);
          }
index 2120cb4d965dc2d517ddceb1811f25383914e7d5..659fa534d9f5dd34df4561716ca8335d7d9a7fd9 100644 (file)
@@ -1,3 +1,8 @@
+2012-10-03  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/54777
+       * g++.dg/cpp0x/constexpr-ref4.C: New test.
+
 2012-10-02  Janus Weil  <janus@gcc.gnu.org>
 
        PR fortran/54778
diff --git a/gcc/testsuite/g++.dg/cpp0x/constexpr-ref4.C b/gcc/testsuite/g++.dg/cpp0x/constexpr-ref4.C
new file mode 100644 (file)
index 0000000..6ae355a
--- /dev/null
@@ -0,0 +1,18 @@
+// PR c++/54777
+// { dg-options -std=c++0x }
+
+struct S
+{
+  int s[1];
+  constexpr const int &foo (unsigned i) { return (i < 1 ? 0 : throw 1), s[i]; }
+  constexpr const int &bar (unsigned i) { return i < 1 ? s[i] : (throw 0, s[i]); }
+};
+
+int
+main ()
+{
+  constexpr S a {};
+  constexpr int i = a.foo (0);
+  constexpr int j = a.bar (0);
+  static_assert (i == j, "Ouch");
+}