summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/AnalysisBasedWarnings.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2011-01-21 19:41:46 +0000
committerTed Kremenek <kremenek@apple.com>2011-01-21 19:41:46 +0000
commit2959fdd087e763cdedc48a02fbb2636f1ddb1592 (patch)
treeb9f7baa809c6ce4220eea73c12875a0a49368410 /clang/lib/Sema/AnalysisBasedWarnings.cpp
parent39fa05634287190fa5898715dc66ac68ce5028ef (diff)
downloadbcm5719-llvm-2959fdd087e763cdedc48a02fbb2636f1ddb1592.tar.gz
bcm5719-llvm-2959fdd087e763cdedc48a02fbb2636f1ddb1592.zip
Add basic fixits for -Wuninitialized-experimental
to suggest initializations for pointer and ObjC pointer types. llvm-svn: 123995
Diffstat (limited to 'clang/lib/Sema/AnalysisBasedWarnings.cpp')
-rw-r--r--clang/lib/Sema/AnalysisBasedWarnings.cpp21
1 files changed, 20 insertions, 1 deletions
diff --git a/clang/lib/Sema/AnalysisBasedWarnings.cpp b/clang/lib/Sema/AnalysisBasedWarnings.cpp
index 67ddbf5bf98..91f95a762ac 100644
--- a/clang/lib/Sema/AnalysisBasedWarnings.cpp
+++ b/clang/lib/Sema/AnalysisBasedWarnings.cpp
@@ -16,6 +16,7 @@
#include "clang/Sema/AnalysisBasedWarnings.h"
#include "clang/Sema/SemaInternal.h"
#include "clang/Basic/SourceManager.h"
+#include "clang/Lex/Preprocessor.h"
#include "clang/AST/DeclObjC.h"
#include "clang/AST/DeclCXX.h"
#include "clang/AST/ExprObjC.h"
@@ -405,7 +406,7 @@ public:
S.Diag(vd->getLocStart(), diag::warn_var_is_uninit)
<< vd->getDeclName() << vd->getSourceRange();
-
+
// Sort the uses by their SourceLocations. While not strictly
// guaranteed to produce them in line/column order, this will provide
// a stable ordering.
@@ -417,6 +418,24 @@ public:
S.Diag(dr->getLocStart(), diag::note_var_is_uninit)
<< vd->getDeclName() << dr->getSourceRange();
}
+
+ // Suggest possible initialization (if any).
+ const char *initialization = 0;
+ QualType vdTy = vd->getType();
+
+ if (vdTy->getAs<ObjCObjectPointerType>()) {
+ initialization = " = nil";
+ }
+ else if (vdTy->getAs<PointerType>()) {
+ initialization = " = 0";
+ }
+
+ if (initialization) {
+ SourceLocation loc = S.PP.getLocForEndOfToken(vd->getLocEnd());
+ S.Diag(loc, diag::note_var_fixit_add_initialization)
+ << FixItHint::CreateInsertion(loc, initialization);
+ }
+
delete vec;
}
delete uses;
OpenPOWER on IntegriCloud