]> granicus.if.org Git - clang/commitdiff
Let Expr::HasSideEffects() return false for NULL, bool literals, this, and nullptr.
authorNico Weber <nicolasweber@gmx.de>
Fri, 20 Jul 2012 03:39:05 +0000 (03:39 +0000)
committerNico Weber <nicolasweber@gmx.de>
Fri, 20 Jul 2012 03:39:05 +0000 (03:39 +0000)
Fixes PR13413, -Wunused-private-field now warns on unused fields initialized to NULL.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@160541 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/ExprConstant.cpp
test/ARCMT/cxx-rewrite.mm.result
test/SemaCXX/warn-unused-private-field.cpp

index f88206cee717258d8bf9c947d6e212a3d5661486..cbcd5e8f74b9100a969dfd6cd3e2505a4575cc40 100644 (file)
@@ -2340,6 +2340,12 @@ public:
     return Visit(E->getSubExpr());
   }
   bool VisitUnaryOperator(const UnaryOperator *E) { return Visit(E->getSubExpr()); }
+  bool VisitGNUNullExpr(const GNUNullExpr *E) { return false; }
+  bool VisitCXXBoolLiteralExpr(const CXXBoolLiteralExpr *E) { return false; }
+  bool VisitCXXThisExpr(const CXXThisExpr *E) { return false; }
+  bool VisitCXXNullPtrLiteralExpr(const CXXNullPtrLiteralExpr *E) {
+    return false;
+  }
     
   // Has side effects if any element does.
   bool VisitInitListExpr(const InitListExpr *E) {
index a2dc9a51f006ced2368a4927b71ef20fb95f1262..7c944d5f240a412affc959f2f66bf7f71bf97e40 100644 (file)
@@ -16,7 +16,7 @@ struct foo {
             [NSString string];
         }
     }
-    ~foo(){ s; }
+    ~foo(){  }
 private:
     foo(foo const &);
     foo &operator=(foo const &);
index 6a7922e8e55d2365af406e9ba82dc478e9f37c45..640a9b9a69d9d73b4a37f057a7e9ec30fae36061 100644 (file)
@@ -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}}
+};
+}