diff options
Diffstat (limited to 'lib/StaticAnalyzer/Checkers/EnumCastOutOfRangeChecker.cpp')
| -rw-r--r-- | lib/StaticAnalyzer/Checkers/EnumCastOutOfRangeChecker.cpp | 18 | 
1 files changed, 17 insertions, 1 deletions
| diff --git a/lib/StaticAnalyzer/Checkers/EnumCastOutOfRangeChecker.cpp b/lib/StaticAnalyzer/Checkers/EnumCastOutOfRangeChecker.cpp index 736d80ef9ec7..481a5685a71f 100644 --- a/lib/StaticAnalyzer/Checkers/EnumCastOutOfRangeChecker.cpp +++ b/lib/StaticAnalyzer/Checkers/EnumCastOutOfRangeChecker.cpp @@ -83,7 +83,7 @@ void EnumCastOutOfRangeChecker::reportWarning(CheckerContext &C) const {            new BuiltinBug(this, "Enum cast out of range",                           "The value provided to the cast expression is not in "                           "the valid range of values for the enum")); -    C.emitReport(llvm::make_unique<BugReport>( +    C.emitReport(std::make_unique<PathSensitiveBugReport>(          *EnumValueCastOutOfRange, EnumValueCastOutOfRange->getDescription(),          N));    } @@ -91,6 +91,22 @@ void EnumCastOutOfRangeChecker::reportWarning(CheckerContext &C) const {  void EnumCastOutOfRangeChecker::checkPreStmt(const CastExpr *CE,                                               CheckerContext &C) const { + +  // Only perform enum range check on casts where such checks are valid.  For +  // all other cast kinds (where enum range checks are unnecessary or invalid), +  // just return immediately.  TODO: The set of casts whitelisted for enum +  // range checking may be incomplete.  Better to add a missing cast kind to +  // enable a missing check than to generate false negatives and have to remove +  // those later. +  switch (CE->getCastKind()) { +  case CK_IntegralCast: +    break; + +  default: +    return; +    break; +  } +    // Get the value of the expression to cast.    const llvm::Optional<DefinedOrUnknownSVal> ValueToCast =        C.getSVal(CE->getSubExpr()).getAs<DefinedOrUnknownSVal>(); | 
