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 | 2959fdd087e763cdedc48a02fbb2636f1ddb1592 (patch) | |
| tree | b9f7baa809c6ce4220eea73c12875a0a49368410 /clang/lib/Sema/AnalysisBasedWarnings.cpp | |
| parent | 39fa05634287190fa5898715dc66ac68ce5028ef (diff) | |
| download | bcm5719-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.cpp | 21 |
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; |

