c++: Handle COMPOUND_EXPRs in ocp_convert [PR94339]
authorJakub Jelinek <jakub@redhat.com>
Fri, 27 Mar 2020 09:00:47 +0000 (10:00 +0100)
committerJakub Jelinek <jakub@redhat.com>
Fri, 27 Mar 2020 09:00:47 +0000 (10:00 +0100)
My recent change to get_narrower/warnings_for_convert_and_check broke
the following testcase, warnings_for_convert_and_check is upset that
expr is a COMPOUND_EXPR with INTEGER_CST at the rightmost operand, while
result is a COMPOUND_EXPR with a NOP_EXPR of INTEGER_CST at the rightmost
operand, it expects such conversions to be simplified.

The easiest fix seems to be to handle COMPOUND_EXPRs in ocp_convert too,
by converting the rightmost operand and recreating COMPOUND_EXPR(s) if that
changed.

The attr-copy-2.C change is a workaround for PR94346, where we now ICE on
the testcase, while previously we'd ICE only if it contained a comma
expression at the outer level rather than cast of a COMPOUND_EXPR to
something.  I'll defer that to Martin.

2020-03-27  Jakub Jelinek  <jakub@redhat.com>

PR c++/94339
* cvt.c (ocp_convert): Handle COMPOUND_EXPR by recursion on the second
operand and creating a new COMPOUND_EXPR if anything changed.

* g++.dg/other/pr94339.C: New test.
* g++.dg/ext/attr-copy-2.C: Comment out failing tests due to PR94346.

gcc/cp/ChangeLog
gcc/cp/cvt.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/ext/attr-copy-2.C
gcc/testsuite/g++.dg/other/pr94339.C [new file with mode: 0644]

index 6ac6a67933a5fb2a5db2740f0532f5f73301f6c0..46208b2d7561b374653681067de1b9343b665d7b 100644 (file)
@@ -1,3 +1,9 @@
+2020-03-27  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/94339
+       * cvt.c (ocp_convert): Handle COMPOUND_EXPR by recursion on the second
+       operand and creating a new COMPOUND_EXPR if anything changed.
+
 2020-03-26  Marek Polacek  <polacek@redhat.com>
 
        PR c++/94336 - template keyword accepted before destructor names.
index 22a72c08c4545d0730c24ebf3c61f0a7c692cbd1..a3b80968b334882176f7faa55b19e1d8ed711af5 100644 (file)
@@ -697,6 +697,17 @@ ocp_convert (tree type, tree expr, int convtype, int flags,
   if (error_operand_p (e) || type == error_mark_node)
     return error_mark_node;
 
+  if (TREE_CODE (e) == COMPOUND_EXPR)
+    {
+      e = ocp_convert (type, TREE_OPERAND (e, 1), convtype, flags, complain);
+      if (e == error_mark_node)
+       return error_mark_node;
+      if (e == TREE_OPERAND (expr, 1))
+       return expr;
+      return build2_loc (EXPR_LOCATION (expr), COMPOUND_EXPR, TREE_TYPE (e),
+                        TREE_OPERAND (expr, 0), e);
+    }
+
   complete_type (type);
   complete_type (TREE_TYPE (expr));
 
index 98f090721d161c1b1e93ef71e3e3a0b81035c5d4..f0b1b5f006b41aa48de097c224188ad399e8155c 100644 (file)
@@ -1,3 +1,9 @@
+2020-03-27  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/94339
+       * g++.dg/other/pr94339.C: New test.
+       * g++.dg/ext/attr-copy-2.C: Comment out failing tests due to PR94346.
+
 2020-03-27  Roman Zhuykov  <zhroma@ispras.ru>
 
        * gcc.c-torture/execute/pr70127-debug-sms.c: New test.
index 7776959d9f6baf5da52c13c6de49dd269bdfd476..7c47a1554c489c1f15a8a602f9b5360162a1f06a 100644 (file)
@@ -36,8 +36,8 @@ typedef struct C
   ATTR (copy (*(struct A *)(0, 1))) long m_xpa_0_1;
 
   ATTR (copy (((struct A *)0)[0])) short m_arpa_0;
-  ATTR (copy (((struct A *)(1, 0))[0])) int m_arpa_1_0;
-  ATTR (copy (((struct A *)(0, 1))[0])) long m_arpa_0_1;
+//  ATTR (copy (((struct A *)(1, 0))[0])) int m_arpa_1_0;
+//  ATTR (copy (((struct A *)(0, 1))[0])) long m_arpa_0_1;
 
   ATTR (copy (a)) short m_a;
   ATTR (copy (b.a)) int m_b_a;
@@ -86,8 +86,8 @@ static_assert (__builtin_has_attribute (((C*)0)->m_xpa_0_1, packed));
 static_assert (__builtin_has_attribute (((C*)0)->m_ra, packed));
 
 static_assert (__builtin_has_attribute (((C*)0)->m_arpa_0, packed));
-static_assert (__builtin_has_attribute (((C*)0)->m_arpa_1_0, packed));
-static_assert (__builtin_has_attribute (((C*)0)->m_arpa_0_1, packed));
+//static_assert (__builtin_has_attribute (((C*)0)->m_arpa_1_0, packed));
+//static_assert (__builtin_has_attribute (((C*)0)->m_arpa_0_1, packed));
 
 static_assert (__builtin_has_attribute (((C*)0)->m_a, packed));
 static_assert (__builtin_has_attribute (((C*)0)->m_b_a, packed));
diff --git a/gcc/testsuite/g++.dg/other/pr94339.C b/gcc/testsuite/g++.dg/other/pr94339.C
new file mode 100644 (file)
index 0000000..3892d78
--- /dev/null
@@ -0,0 +1,11 @@
+// PR c++/94339
+// { dg-do compile }
+
+unsigned a;
+void bar ();
+
+unsigned
+foo (bool x)
+{
+  return x ? bar (), -1 : a;
+}