forked from OSchip/llvm-project
[analyzer] Migrate AttrNonNullChecker to CheckerV2.
llvm-svn: 126623
This commit is contained in:
parent
4f7745a3b1
commit
6fff2e3d36
|
@ -12,33 +12,27 @@
|
|||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "InternalChecks.h"
|
||||
#include "ClangSACheckers.h"
|
||||
#include "clang/StaticAnalyzer/Core/CheckerV2.h"
|
||||
#include "clang/StaticAnalyzer/Core/CheckerManager.h"
|
||||
#include "clang/StaticAnalyzer/Core/PathSensitive/CheckerContext.h"
|
||||
#include "clang/StaticAnalyzer/Core/BugReporter/BugType.h"
|
||||
#include "clang/StaticAnalyzer/Core/PathSensitive/CheckerVisitor.h"
|
||||
|
||||
using namespace clang;
|
||||
using namespace ento;
|
||||
|
||||
namespace {
|
||||
class AttrNonNullChecker
|
||||
: public CheckerVisitor<AttrNonNullChecker> {
|
||||
BugType *BT;
|
||||
: public CheckerV2< check::PreStmt<CallExpr> > {
|
||||
mutable llvm::OwningPtr<BugType> BT;
|
||||
public:
|
||||
AttrNonNullChecker() : BT(0) {}
|
||||
static void *getTag() {
|
||||
static int x = 0;
|
||||
return &x;
|
||||
}
|
||||
void PreVisitCallExpr(CheckerContext &C, const CallExpr *CE);
|
||||
|
||||
void checkPreStmt(const CallExpr *CE, CheckerContext &C) const;
|
||||
};
|
||||
} // end anonymous namespace
|
||||
|
||||
void ento::RegisterAttrNonNullChecker(ExprEngine &Eng) {
|
||||
Eng.registerCheck(new AttrNonNullChecker());
|
||||
}
|
||||
|
||||
void AttrNonNullChecker::PreVisitCallExpr(CheckerContext &C,
|
||||
const CallExpr *CE) {
|
||||
void AttrNonNullChecker::checkPreStmt(const CallExpr *CE,
|
||||
CheckerContext &C) const {
|
||||
const GRState *state = C.getState();
|
||||
|
||||
// Check if the callee has a 'nonnull' attribute.
|
||||
|
@ -103,8 +97,8 @@ void AttrNonNullChecker::PreVisitCallExpr(CheckerContext &C,
|
|||
// created. Ownership is transferred to the BugReporter object once
|
||||
// the BugReport is passed to 'EmitWarning'.
|
||||
if (!BT)
|
||||
BT = new BugType("Argument with 'nonnull' attribute passed null",
|
||||
"API");
|
||||
BT.reset(new BugType("Argument with 'nonnull' attribute passed null",
|
||||
"API"));
|
||||
|
||||
EnhancedBugReport *R =
|
||||
new EnhancedBugReport(*BT,
|
||||
|
@ -134,3 +128,7 @@ void AttrNonNullChecker::PreVisitCallExpr(CheckerContext &C,
|
|||
// If 'state' has been updated generated a new node.
|
||||
C.addTransition(state);
|
||||
}
|
||||
|
||||
void ento::registerAttrNonNullChecker(CheckerManager &mgr) {
|
||||
mgr.registerChecker<AttrNonNullChecker>();
|
||||
}
|
||||
|
|
|
@ -75,6 +75,10 @@ def ObjCUnusedIvarsChecker : Checker<"UnusedIvars">,
|
|||
|
||||
let ParentPackage = Core in {
|
||||
|
||||
def AttrNonNullChecker : Checker<"AttrNonNull">,
|
||||
HelpText<"Check for arguments declared to have nonnull attribute">,
|
||||
DescFile<"AttrNonNullChecker.cpp">;
|
||||
|
||||
def VLASizeChecker : Checker<"VLASize">,
|
||||
HelpText<"Check for declarations of VLA of undefined or zero size">,
|
||||
DescFile<"VLASizeChecker.cpp">;
|
||||
|
|
|
@ -323,7 +323,6 @@ static void RegisterInternalChecks(ExprEngine &Eng) {
|
|||
// CallAndMessageChecker should be registered before AttrNonNullChecker,
|
||||
// where we assume arguments are not undefined.
|
||||
RegisterCallAndMessageChecker(Eng);
|
||||
RegisterAttrNonNullChecker(Eng);
|
||||
RegisterDereferenceChecker(Eng);
|
||||
}
|
||||
|
||||
|
|
|
@ -23,7 +23,6 @@ class ExprEngine;
|
|||
|
||||
// Foundational checks that handle basic semantics.
|
||||
void RegisterAdjustedReturnValueChecker(ExprEngine &Eng);
|
||||
void RegisterAttrNonNullChecker(ExprEngine &Eng);
|
||||
void RegisterCallAndMessageChecker(ExprEngine &Eng);
|
||||
void RegisterDereferenceChecker(ExprEngine &Eng);
|
||||
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
// RUN: %clang_cc1 -triple i386-apple-darwin10 -analyze -analyzer-checker=core.experimental -std=gnu99 -analyzer-check-objc-mem -verify %s -analyzer-constraints=basic -analyzer-store=basic -Wreturn-type
|
||||
// RUN: %clang_cc1 -triple i386-apple-darwin10 -analyze -analyzer-checker=core.experimental -std=gnu99 -analyzer-check-objc-mem -verify %s -analyzer-constraints=range -analyzer-store=basic -Wreturn-type
|
||||
// RUN: %clang_cc1 -triple i386-apple-darwin10 -analyze -analyzer-checker=core.experimental -std=gnu99 -analyzer-check-objc-mem -analyzer-store=region -analyzer-constraints=range -analyzer-no-purge-dead -verify %s -Wreturn-type
|
||||
// RUN: %clang_cc1 -triple i386-apple-darwin10 -analyze -analyzer-checker=core.experimental -std=gnu99 -analyzer-check-objc-mem -analyzer-store=region -analyzer-constraints=range -verify %s -Wreturn-type
|
||||
// RUN: %clang_cc1 -triple i386-apple-darwin10 -analyze -analyzer-checker=core,core.experimental -std=gnu99 -analyzer-check-objc-mem -verify %s -analyzer-constraints=basic -analyzer-store=basic -Wreturn-type
|
||||
// RUN: %clang_cc1 -triple i386-apple-darwin10 -analyze -analyzer-checker=core,core.experimental -std=gnu99 -analyzer-check-objc-mem -verify %s -analyzer-constraints=range -analyzer-store=basic -Wreturn-type
|
||||
// RUN: %clang_cc1 -triple i386-apple-darwin10 -analyze -analyzer-checker=core,core.experimental -std=gnu99 -analyzer-check-objc-mem -analyzer-store=region -analyzer-constraints=range -analyzer-no-purge-dead -verify %s -Wreturn-type
|
||||
// RUN: %clang_cc1 -triple i386-apple-darwin10 -analyze -analyzer-checker=core,core.experimental -std=gnu99 -analyzer-check-objc-mem -analyzer-store=region -analyzer-constraints=range -verify %s -Wreturn-type
|
||||
|
||||
typedef unsigned uintptr_t;
|
||||
|
||||
|
|
Loading…
Reference in New Issue