From a4d60b6de3197d0f5ef5ce653d0f3adce235422c Mon Sep 17 00:00:00 2001 From: Ted Kremenek Date: Thu, 27 Mar 2008 17:17:22 +0000 Subject: [PATCH] Add creation of BasicObjCFoundationChecks when running GRSimpleVals from the driver. llvm-svn: 48886 --- .../Analysis/BasicObjCFoundationChecks.cpp | 10 +++++ .../lib/Analysis/BasicObjCFoundationChecks.h | 39 +++++++++++++++++++ clang/lib/Analysis/GRSimpleVals.cpp | 12 ++++-- 3 files changed, 58 insertions(+), 3 deletions(-) create mode 100644 clang/lib/Analysis/BasicObjCFoundationChecks.h diff --git a/clang/lib/Analysis/BasicObjCFoundationChecks.cpp b/clang/lib/Analysis/BasicObjCFoundationChecks.cpp index 0fae7ddcd38f..4d7a4d99db8b 100644 --- a/clang/lib/Analysis/BasicObjCFoundationChecks.cpp +++ b/clang/lib/Analysis/BasicObjCFoundationChecks.cpp @@ -13,6 +13,8 @@ // //===----------------------------------------------------------------------===// +#include "BasicObjCFoundationChecks.h" + #include "clang/Analysis/PathSensitive/ExplodedGraph.h" #include "clang/Analysis/PathSensitive/GRSimpleAPICheck.h" #include "clang/Analysis/PathSensitive/ValueState.h" @@ -53,6 +55,14 @@ public: } // end anonymous namespace +GRSimpleAPICheck* +clang::CreateBasicObjCFoundationChecks(ASTContext& Ctx, + ValueStateManager* VMgr) { + + return new BasicObjCFoundationChecks(Ctx, VMgr); +} + + bool BasicObjCFoundationChecks::Audit(ExplodedNode* N) { ObjCMessageExpr* ME = diff --git a/clang/lib/Analysis/BasicObjCFoundationChecks.h b/clang/lib/Analysis/BasicObjCFoundationChecks.h new file mode 100644 index 000000000000..df2992b05453 --- /dev/null +++ b/clang/lib/Analysis/BasicObjCFoundationChecks.h @@ -0,0 +1,39 @@ +//== BasicObjCFoundationChecks.h - Simple Apple-Foundation checks -*- C++ -*--// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file defines BasicObjCFoundationChecks, a class that encapsulates +// a set of simple checks to run on Objective-C code using Apple's Foundation +// classes. +// +//===----------------------------------------------------------------------===// + +#include "clang/Analysis/PathSensitive/ExplodedGraph.h" +#include "clang/Analysis/PathSensitive/GRSimpleAPICheck.h" +#include "clang/Analysis/PathSensitive/ValueState.h" +#include "clang/Analysis/PathSensitive/AnnotatedPath.h" +#include "clang/Analysis/PathDiagnostic.h" +#include "clang/AST/Expr.h" +#include "clang/AST/ASTContext.h" +#include "llvm/Support/Compiler.h" + +#ifndef LLVM_CLANG_ANALYSIS_BASICOBJCFOUNDATIONCHECKS +#define LLVM_CLANG_ANALYSIS_BASICOBJCFOUNDATIONCHECKS + +namespace clang { + +class GRSimpleAPICheck; +class ASTContext; +class ValueStateManager; + +GRSimpleAPICheck* CreateBasicObjCFoundationChecks(ASTContext& Ctx, + ValueStateManager* VMgr); + +} // end clang namespace + +#endif diff --git a/clang/lib/Analysis/GRSimpleVals.cpp b/clang/lib/Analysis/GRSimpleVals.cpp index b6e6b5087f1d..520f6246bfef 100644 --- a/clang/lib/Analysis/GRSimpleVals.cpp +++ b/clang/lib/Analysis/GRSimpleVals.cpp @@ -14,6 +14,7 @@ //===----------------------------------------------------------------------===// #include "GRSimpleVals.h" +#include "BasicObjCFoundationChecks.h" #include "clang/Analysis/PathSensitive/ValueState.h" #include "clang/Basic/Diagnostic.h" #include @@ -103,14 +104,19 @@ void EmitWarning(Diagnostic& Diag, SourceManager& SrcMgr, unsigned RunGRSimpleVals(CFG& cfg, Decl& CD, ASTContext& Ctx, Diagnostic& Diag, bool Visualize, bool TrimGraph) { - if (Diag.hasErrorOccurred()) - return 0; - GRCoreEngine Eng(cfg, CD, Ctx); GRExprEngine* CheckerState = &Eng.getCheckerState(); + + // Set base transfer functions. GRSimpleVals GRSV; CheckerState->setTransferFunctions(GRSV); + // Add extra checkers. + llvm::OwningPtr FoundationCheck( + CreateBasicObjCFoundationChecks(Ctx, &CheckerState->getStateManager())); + + CheckerState->AddObjCMessageExprCheck(FoundationCheck.get()); + // Execute the worklist algorithm. Eng.ExecuteWorkList(100000);