diff options
author | Ted Kremenek <kremenek@apple.com> | 2011-01-21 19:41:46 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2011-01-21 19:41:46 +0000 |
commit | fbb178a0b47fca1b0fb78c5d41198614cf52aa70 (patch) | |
tree | 2a0a57bcdb1bc86f9fef21acfd318939d26a5c1d /lib/Sema/AnalysisBasedWarnings.cpp | |
parent | 94b1b4d785bc0f09f6af4be394e59d51f35dda60 (diff) |
Add basic fixits for -Wuninitialized-experimental
to suggest initializations for pointer and
ObjC pointer types.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@123995 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/AnalysisBasedWarnings.cpp')
-rw-r--r-- | lib/Sema/AnalysisBasedWarnings.cpp | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/lib/Sema/AnalysisBasedWarnings.cpp b/lib/Sema/AnalysisBasedWarnings.cpp index 67ddbf5bf9..91f95a762a 100644 --- a/lib/Sema/AnalysisBasedWarnings.cpp +++ b/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; |