diff options
author | Ted Kremenek <kremenek@apple.com> | 2011-01-25 19:13:48 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2011-01-25 19:13:48 +0000 |
commit | a8c17a5babab35f2db26bf218e7571d1af4afedf (patch) | |
tree | ba2d1e33c9fbe93b088bf9fdf632e7537f38a215 /lib/Sema/AnalysisBasedWarnings.cpp | |
parent | 937596fc25bba3ac7519e9ffff3e4fab2c97863e (diff) |
Teach -Wuninitialized-experimental to also warn
about uninitialized variables captured by blocks.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@124213 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/AnalysisBasedWarnings.cpp')
-rw-r--r-- | lib/Sema/AnalysisBasedWarnings.cpp | 27 |
1 files changed, 17 insertions, 10 deletions
diff --git a/lib/Sema/AnalysisBasedWarnings.cpp b/lib/Sema/AnalysisBasedWarnings.cpp index 38284f6627..4866c8fb3d 100644 --- a/lib/Sema/AnalysisBasedWarnings.cpp +++ b/lib/Sema/AnalysisBasedWarnings.cpp @@ -366,7 +366,7 @@ static void CheckFallThroughForBody(Sema &S, const Decl *D, const Stmt *Body, namespace { struct SLocSort { - bool operator()(const DeclRefExpr *a, const DeclRefExpr *b) { + bool operator()(const Expr *a, const Expr *b) { SourceLocation aLoc = a->getLocStart(); SourceLocation bLoc = b->getLocStart(); return aLoc.getRawEncoding() < bLoc.getRawEncoding(); @@ -375,7 +375,7 @@ struct SLocSort { class UninitValsDiagReporter : public UninitVariablesHandler { Sema &S; - typedef llvm::SmallVector<const DeclRefExpr *, 2> UsesVec; + typedef llvm::SmallVector<const Expr *, 2> UsesVec; typedef llvm::DenseMap<const VarDecl *, UsesVec*> UsesMap; UsesMap *uses; @@ -385,7 +385,7 @@ public: flushDiagnostics(); } - void handleUseOfUninitVariable(const DeclRefExpr *dr, const VarDecl *vd) { + void handleUseOfUninitVariable(const Expr *ex, const VarDecl *vd) { if (!uses) uses = new UsesMap(); @@ -393,7 +393,7 @@ public: if (!vec) vec = new UsesVec(); - vec->push_back(dr); + vec->push_back(ex); } void flushDiagnostics() { @@ -404,7 +404,7 @@ public: const VarDecl *vd = i->first; UsesVec *vec = i->second; - S.Diag(vd->getLocStart(), diag::warn_var_is_uninit) + S.Diag(vd->getLocStart(), diag::warn_uninit_var) << vd->getDeclName() << vd->getSourceRange(); // Sort the uses by their SourceLocations. While not strictly @@ -414,9 +414,15 @@ public: for (UsesVec::iterator vi = vec->begin(), ve = vec->end(); vi != ve; ++vi) { - const DeclRefExpr *dr = *vi; - S.Diag(dr->getLocStart(), diag::note_var_is_uninit) - << vd->getDeclName() << dr->getSourceRange(); + if (const DeclRefExpr *dr = dyn_cast<DeclRefExpr>(*vi)) { + S.Diag(dr->getLocStart(), diag::note_uninit_var) + << vd->getDeclName() << dr->getSourceRange(); + } + else { + const BlockExpr *be = cast<BlockExpr>(*vi); + S.Diag(be->getLocStart(), diag::note_uninit_var_captured_by_block) + << vd->getDeclName(); + } } // Suggest possible initialization (if any). @@ -514,11 +520,12 @@ AnalysisBasedWarnings::IssueWarnings(sema::AnalysisBasedWarnings::Policy P, if (P.enableCheckUnreachable) CheckUnreachable(S, AC); - if (Diags.getDiagnosticLevel(diag::warn_var_is_uninit, D->getLocStart()) + if (Diags.getDiagnosticLevel(diag::warn_uninit_var, D->getLocStart()) != Diagnostic::Ignored) { if (CFG *cfg = AC.getCFG()) { UninitValsDiagReporter reporter(S); - runUninitializedVariablesAnalysis(*cast<DeclContext>(D), *cfg, reporter); + runUninitializedVariablesAnalysis(*cast<DeclContext>(D), *cfg, AC, + reporter); } } } |