[Bug c/46921] Lost side effect when struct initializer expression uses comma operator

jsm28 at gcc dot gnu.org gcc-bugzilla@gcc.gnu.org
Tue Mar 13 18:10:00 GMT 2018


https://gcc.gnu.org/bugzilla/show_bug.cgi?id=46921

--- Comment #5 from Joseph S. Myers <jsm28 at gcc dot gnu.org> ---
Author: jsm28
Date: Tue Mar 13 18:10:09 2018
New Revision: 258497

URL: https://gcc.gnu.org/viewcvs?rev=258497&root=gcc&view=rev
Log:
PR c/46921 Lost side effect when struct initializer expression uses comma
operator

This patch fixes improper handling of comma operator expression in a
struct field initializer as described in:

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=46921

Currently, function output_init_element () does not evaluate the left
hand expression in a comma operator that's used for a struct
initializer field if the right hand side is zero-sized. However, the
left hand expression must be evaluated if it's found to have side
effects (for example, a function call).

Patch was successfully bootstrapped and tested on x86_64-linux.

gcc/c:
2018-03-13  David Pagan  <dave.pagan@oracle.com>

        PR c/46921
        * c-typeck.c (output_init_element): Ensure field initializer
        expression is always evaluated if there are side effects.

gcc/testsuite:
2018-03-13  David Pagan  <dave.pagan@oracle.com>

        PR c/46921
        * gcc.dg/pr46921.c: New test.

Added:
    trunk/gcc/testsuite/gcc.dg/pr46921.c
Modified:
    trunk/gcc/c/ChangeLog
    trunk/gcc/c/c-typeck.c
    trunk/gcc/testsuite/ChangeLog


More information about the Gcc-bugs mailing list