Improve -Wuninitialized to catch const classes being used in their own copy
constructors.
llvm-svn: 215471
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp
index 77285ed..e676466 100644
--- a/clang/lib/Sema/SemaDeclCXX.cpp
+++ b/clang/lib/Sema/SemaDeclCXX.cpp
@@ -2314,12 +2314,18 @@
}
void VisitCXXConstructExpr(CXXConstructExpr *E) {
- if (E->getConstructor()->isCopyConstructor())
- if (ImplicitCastExpr* ICE = dyn_cast<ImplicitCastExpr>(E->getArg(0)))
- if (ICE->getCastKind() == CK_NoOp)
- if (MemberExpr *ME = dyn_cast<MemberExpr>(ICE->getSubExpr()))
- HandleMemberExpr(ME, false /*CheckReferenceOnly*/);
-
+ if (E->getConstructor()->isCopyConstructor()) {
+ Expr *ArgExpr = E->getArg(0);
+ if (ImplicitCastExpr* ICE = dyn_cast<ImplicitCastExpr>(ArgExpr)) {
+ if (ICE->getCastKind() == CK_NoOp) {
+ ArgExpr = ICE->getSubExpr();
+ }
+ }
+
+ if (MemberExpr *ME = dyn_cast<MemberExpr>(ArgExpr)) {
+ HandleMemberExpr(ME, false /*CheckReferenceOnly*/);
+ }
+ }
Inherited::VisitCXXConstructExpr(E);
}