summaryrefslogtreecommitdiff
path: root/gcc/testsuite
diff options
context:
space:
mode:
authorjsm28 <jsm28@138bc75d-0d04-0410-961f-82ee72b054a4>2005-08-06 11:31:49 +0000
committerjsm28 <jsm28@138bc75d-0d04-0410-961f-82ee72b054a4>2005-08-06 11:31:49 +0000
commit1c3d3e7cbc93a587d68e8e91bc7e6c07cf205840 (patch)
tree50083463eef147d4518d2138f1a14ce9e8fb18b7 /gcc/testsuite
parentca8cce9fc2a2367248ffe52d526ce0bfbb1ed71b (diff)
downloadgcc-1c3d3e7cbc93a587d68e8e91bc7e6c07cf205840.tar.gz
PR c/23113
* stmt.c (warn_if_unused_value): Check TREE_NO_WARNING at start. Don't handle NOP_EXPR, CONVERT_EXPR and NON_LVALUE_EXPR specially. Check for side effects only for COND_EXPR. * c-typeck.c (c_finish_stmt_expr): Mark statement expression return with TREE_NO_WARNING. testsuite: * gcc.dg/Wunused-value-1.c: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@102805 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/testsuite')
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/Wunused-value-1.c31
2 files changed, 36 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 0097a9d2cfa..6e27aec9c24 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2005-08-06 Joseph S. Myers <joseph@codesourcery.com>
+
+ PR c/23113
+ * gcc.dg/Wunused-value-1.c: New test.
+
2005-08-06 Richard Sandiford <richard@codesourcery.com>
PR rtl-optimization/23233
diff --git a/gcc/testsuite/gcc.dg/Wunused-value-1.c b/gcc/testsuite/gcc.dg/Wunused-value-1.c
new file mode 100644
index 00000000000..0fc7c364ba8
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/Wunused-value-1.c
@@ -0,0 +1,31 @@
+/* Test -Wunused-value. Bug 23113. */
+/* Origin: Joseph Myers <joseph@codesourcery.com> */
+/* { dg-do compile } */
+/* { dg-options "-Wunused-value" } */
+
+int f (void);
+void g (void);
+int *p;
+
+void
+h (void)
+{
+ 1 + f (); /* { dg-warning "value computed is not used" } */
+ f () + f (); /* { dg-warning "value computed is not used" } */
+ f () + f (), f (); /* { dg-warning "value computed is not used" } */
+ (char) f (); /* { dg-warning "value computed is not used" } */
+ g ();
+ f ();
+ (void) f ();
+ *p++; /* { dg-warning "value computed is not used" } */
+ ++*p;
+ (*p ? f() : 0);
+ ({ f(); });
+ /* Statement expressions may be used in macro expansions which like
+ functions return values which may or may not be of use, so don't
+ warn for them but do warn inside them. */
+ ({ f() + 1; });
+ ({ f(); 0; });
+ ({ f() + 1; 0; }); /* { dg-warning "value computed is not used" } */
+ 1 + ({ f(); }); /* { dg-warning "value computed is not used" } */
+}