aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorPaolo Carlini <paolo.carlini@oracle.com>2017-06-01 10:20:27 +0000
committerPaolo Carlini <paolo@gcc.gnu.org>2017-06-01 10:20:27 +0000
commitac853c9071ab9a8df483c26fe8672732546c51ab (patch)
tree840e9172b123a07168d915101b1f9441c3c29348 /gcc
parent7841f13c8064c7d8f4eb13acd396bd0455e12c26 (diff)
downloadgcc-ac853c9071ab9a8df483c26fe8672732546c51ab.zip
gcc-ac853c9071ab9a8df483c26fe8672732546c51ab.tar.gz
gcc-ac853c9071ab9a8df483c26fe8672732546c51ab.tar.bz2
re PR c++/80896 ([[nodiscard]] is ignored for functions returning references)
/cp 2017-06-01 Paolo Carlini <paolo.carlini@oracle.com> PR c++/80896 * cvt.c (convert_to_void): Possibly call maybe_warn_nodiscard for case INDIRECT_REF too in the main switch. /testsuite 2017-06-01 Paolo Carlini <paolo.carlini@oracle.com> PR c++/80896 * g++.dg/cpp1z/nodiscard5.C: New. From-SVN: r248784
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog6
-rw-r--r--gcc/cp/cvt.c2
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/cpp1z/nodiscard5.C7
4 files changed, 20 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index bbb6a53..60fe1a5 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,9 @@
+2017-06-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/80896
+ * cvt.c (convert_to_void): Possibly call maybe_warn_nodiscard
+ for case INDIRECT_REF too in the main switch.
+
2017-05-31 Jason Merrill <jason@redhat.com>
PR c++/80840 - ICE with constexpr and reference
diff --git a/gcc/cp/cvt.c b/gcc/cp/cvt.c
index e8a7ee2..6b28ef6 100644
--- a/gcc/cp/cvt.c
+++ b/gcc/cp/cvt.c
@@ -1296,6 +1296,8 @@ convert_to_void (tree expr, impl_conv_void implicit, tsubst_flags_t complain)
&& !is_reference)
warning_at (loc, OPT_Wunused_value, "value computed is not used");
expr = TREE_OPERAND (expr, 0);
+ if (TREE_CODE (expr) == CALL_EXPR)
+ maybe_warn_nodiscard (expr, implicit);
}
break;
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 952bc93..a1212f2 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2017-06-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/80896
+ * g++.dg/cpp1z/nodiscard5.C: New.
+
2017-06-01 Claudiu Zissulescu <claziss@synopsys.com>
* gcc.target/arc/pr9001195952.c: New test.
diff --git a/gcc/testsuite/g++.dg/cpp1z/nodiscard5.C b/gcc/testsuite/g++.dg/cpp1z/nodiscard5.C
new file mode 100644
index 0000000..fa9a974
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp1z/nodiscard5.C
@@ -0,0 +1,7 @@
+// PR c++/80896
+// { dg-do compile { target c++11 } }
+
+int x = 42;
+[[nodiscard]] int& func() { return x; }
+
+int main() { func(); } // { dg-warning "ignoring return value" }