+2014-06-05 Richard Biener <rguenther@suse.de>
+ Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/56961
+ * cp-gimplify.c (cp_gimplify_expr, [MODIFY_EXPR]): Rework
+ handling of empty classes.
+
2014-06-04 Jason Merrill <jason@redhat.com>
* parser.c (cp_parser_diagnose_invalid_type_name): Give helpful note
Also drop volatile variables on the RHS to avoid infinite
recursion from gimplify_expr trying to load the value. */
- if (!TREE_SIDE_EFFECTS (op1)
- || (DECL_P (op1) && TREE_THIS_VOLATILE (op1)))
+ if (!TREE_SIDE_EFFECTS (op1))
*expr_p = op0;
- else if (TREE_CODE (op1) == MEM_REF
- && TREE_THIS_VOLATILE (op1))
- {
- /* Similarly for volatile MEM_REFs on the RHS. */
- if (!TREE_SIDE_EFFECTS (TREE_OPERAND (op1, 0)))
- *expr_p = op0;
- else
- *expr_p = build2 (COMPOUND_EXPR, TREE_TYPE (*expr_p),
- TREE_OPERAND (op1, 0), op0);
- }
+ else if (TREE_THIS_VOLATILE (op1)
+ && (REFERENCE_CLASS_P (op1) || DECL_P (op1)))
+ *expr_p = build2 (COMPOUND_EXPR, TREE_TYPE (*expr_p),
+ build_fold_addr_expr (op1), op0);
else
*expr_p = build2 (COMPOUND_EXPR, TREE_TYPE (*expr_p),
op0, op1);
+2014-06-05 Richard Biener <rguenther@suse.de>
+ Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/56961
+ * g++.dg/parse/pr56961.C: New.
+
2014-06-05 Kai Tietz <ktietz@redhat.com>
PR target/46219