summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCXX/warn-unused-private-field.cpp
diff options
context:
space:
mode:
authorNico Weber <nicolasweber@gmx.de>2012-07-20 03:39:05 +0000
committerNico Weber <nicolasweber@gmx.de>2012-07-20 03:39:05 +0000
commit90359514099ca55e7ab564b705e7ad3213ff9bad (patch)
tree386230aefc9a90c1e4a0956f3d8718ca103d3726 /clang/test/SemaCXX/warn-unused-private-field.cpp
parent3a8bdb5677e0c6f66d367b71d75189270073bd98 (diff)
downloadbcm5719-llvm-90359514099ca55e7ab564b705e7ad3213ff9bad.tar.gz
bcm5719-llvm-90359514099ca55e7ab564b705e7ad3213ff9bad.zip
Let Expr::HasSideEffects() return false for NULL, bool literals, this, and nullptr.
Fixes PR13413, -Wunused-private-field now warns on unused fields initialized to NULL. llvm-svn: 160541
Diffstat (limited to 'clang/test/SemaCXX/warn-unused-private-field.cpp')
-rw-r--r--clang/test/SemaCXX/warn-unused-private-field.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/warn-unused-private-field.cpp b/clang/test/SemaCXX/warn-unused-private-field.cpp
index 6a7922e8e55..640a9b9a69d 100644
--- a/clang/test/SemaCXX/warn-unused-private-field.cpp
+++ b/clang/test/SemaCXX/warn-unused-private-field.cpp
@@ -209,3 +209,13 @@ union S {
unsigned char Data[8];
};
} // namespace anonymous_structs_unions
+
+namespace pr13413 {
+class A {
+ A() : p_(__null), b_(false), a_(this), p2_(nullptr) {}
+ void* p_; // expected-warning{{private field 'p_' is not used}}
+ bool b_; // expected-warning{{private field 'b_' is not used}}
+ A* a_; // expected-warning{{private field 'a_' is not used}}
+ void* p2_; // expected-warning{{private field 'p2_' is not used}}
+};
+}
OpenPOWER on IntegriCloud