diff options
author | Joseph Myers <joseph@codesourcery.com> | 2005-04-28 01:45:48 +0100 |
---|---|---|
committer | Joseph Myers <jsm28@gcc.gnu.org> | 2005-04-28 01:45:48 +0100 |
commit | e14a65404712f3f8b9e4af99336be4f2db65efe5 (patch) | |
tree | e075ef044741bf5e950cddca77ae2825b21e0291 | |
parent | c1bc6ca8a5c0638c567d94f81a687326abd8ed08 (diff) | |
download | gcc-e14a65404712f3f8b9e4af99336be4f2db65efe5.zip gcc-e14a65404712f3f8b9e4af99336be4f2db65efe5.tar.gz gcc-e14a65404712f3f8b9e4af99336be4f2db65efe5.tar.bz2 |
c-typeck.c (build_compound_expr): Correct logic in last change.
* c-typeck.c (build_compound_expr): Correct logic in last change.
testsuite:
* gcc.dg/void-cast-2.c: New test.
From-SVN: r98901
-rw-r--r-- | gcc/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/c-typeck.c | 9 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/void-cast-2.c | 8 |
4 files changed, 21 insertions, 4 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 5da37d4..95fe5f5 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2005-04-28 Joseph S. Myers <joseph@codesourcery.com> + + * c-typeck.c (build_compound_expr): Correct logic in last change. + 2005-04-27 James E. Wilson <wilson@specifixinc.com> * config/ia64/ia64.c (update_set_flags): Delete ppred and pcond diff --git a/gcc/c-typeck.c b/gcc/c-typeck.c index 281d2b0..3a5d11d 100644 --- a/gcc/c-typeck.c +++ b/gcc/c-typeck.c @@ -3108,12 +3108,13 @@ build_compound_expr (tree expr1, tree expr2) /* The left-hand operand of a comma expression is like an expression statement: with -Wextra or -Wunused, we should warn if it doesn't have any side-effects, unless it was explicitly cast to (void). */ - if (warn_unused_value - && !VOID_TYPE_P (TREE_TYPE (expr1))) + if (warn_unused_value) { - if (TREE_CODE (expr1) == CONVERT_EXPR) + if (VOID_TYPE_P (TREE_TYPE (expr1)) + && TREE_CODE (expr1) == CONVERT_EXPR) ; /* (void) a, b */ - else if (TREE_CODE (expr1) == COMPOUND_EXPR + else if (VOID_TYPE_P (TREE_TYPE (expr1)) + && TREE_CODE (expr1) == COMPOUND_EXPR && TREE_CODE (TREE_OPERAND (expr1, 1)) == CONVERT_EXPR) ; /* (void) a, (void) b, c */ else diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index b16bf69..1f7bc01 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2005-04-28 Joseph S. Myers <joseph@codesourcery.com> + + * gcc.dg/void-cast-2.c: New test. + 2005-04-27 Joseph S. Myers <joseph@codesourcery.com> PR c/21159 diff --git a/gcc/testsuite/gcc.dg/void-cast-2.c b/gcc/testsuite/gcc.dg/void-cast-2.c new file mode 100644 index 0000000..c51e91a --- /dev/null +++ b/gcc/testsuite/gcc.dg/void-cast-2.c @@ -0,0 +1,8 @@ +/* Test further cases of warnings for comma expressions, with and + without casts to void. */ +/* Origin: Joseph Myers <joseph@codesourcery.com> */ +/* { dg-do compile } */ +/* { dg-options "-Wall" } */ +int a, b, c, d; +int e(void) { return (char)a, b; } /* { dg-warning "warning: left-hand operand of comma expression has no effect" } */ +int f(void) { return (a ? (void)b : (void)c), d; } /* { dg-warning "warning: left-hand operand of comma expression has no effect" } */ |