29 if (std::optional<Loc> LV = Cond.
getAs<
Loc>()) {
30 SValBuilder &SVB = State->getStateManager().getSValBuilder();
33 if (
const TypedRegion *TR = dyn_cast_or_null<TypedRegion>(MR))
34 T = TR->getLocationType();
45 NonLoc Cond,
bool Assumption) {
46 State = assumeAux(State, Cond, Assumption);
65 switch (Cond.getKind()) {
67 llvm_unreachable(
"'Assume' not implemented for this NonLoc");
69 case nonloc::SymbolValKind: {
70 nonloc::SymbolVal SV = Cond.castAs<nonloc::SymbolVal>();
76 case nonloc::ConcreteIntKind: {
77 bool b = *Cond.castAs<nonloc::ConcreteInt>().getValue() != 0;
78 bool isFeasible =
b ? Assumption : !Assumption;
79 return isFeasible ? State :
nullptr;
82 case nonloc::PointerToMemberKind: {
83 bool IsNull = !Cond.castAs<nonloc::PointerToMember>().isNullMemberPointer();
84 bool IsFeasible =
IsNull ? Assumption : !Assumption;
85 return IsFeasible ? State :
nullptr;
88 case nonloc::LocAsIntegerKind:
89 return assumeInternal(State, Cond.castAs<nonloc::LocAsInteger>().getLoc(),
96 const llvm::APSInt &To,
bool InRange) {
98 assert(From.isUnsigned() == To.isUnsigned() &&
99 From.getBitWidth() == To.getBitWidth() &&
100 "Values should have same types!");
111 llvm_unreachable(
"'assumeInclusiveRange' is not implemented"
114 case nonloc::LocAsIntegerKind:
115 case nonloc::SymbolValKind: {
121 case nonloc::ConcreteIntKind: {
123 bool IsInRange = IntVal >= From && IntVal <= To;
124 bool isFeasible = (IsInRange == InRange);
125 return isFeasible ? State :
nullptr;
A (possibly-)qualified type.
virtual bool canReasonAbout(SVal X) const =0
canReasonAbout - Not all ConstraintManagers can accurately reason about all SVal values.
ProgramStateRef processAssume(ProgramStateRef state, SVal cond, bool assumption)
evalAssume - Callback function invoked by the ConstraintManager when making assumptions about state v...
MemRegion - The root abstract class for all memory regions.
ASTContext & getContext()
SVal evalCast(SVal V, QualType CastTy, QualType OriginalTy)
Cast a given SVal to another SVal using given QualType's.
std::optional< T > getAs() const
Convert to the specified SVal type, returning std::nullopt if this SVal is not of the desired type.
T castAs() const
Convert to the specified SVal type, asserting that this SVal is of the desired type.
ProgramStateRef assumeInclusiveRangeInternal(ProgramStateRef State, NonLoc Value, const llvm::APSInt &From, const llvm::APSInt &To, bool InRange) override
virtual ProgramStateRef assumeSym(ProgramStateRef State, SymbolRef Sym, bool Assumption)=0
Given a symbolic expression that can be reasoned about, assume that it is true/false and generate the...
~SimpleConstraintManager() override
virtual ProgramStateRef assumeSymUnsupported(ProgramStateRef State, SymbolRef Sym, bool Assumption)=0
Given a symbolic expression that cannot be reasoned about, assume that it is zero/nonzero and add it ...
virtual ProgramStateRef assumeSymInclusiveRange(ProgramStateRef State, SymbolRef Sym, const llvm::APSInt &From, const llvm::APSInt &To, bool InRange)=0
Given a symbolic expression within the range [From, To], assume that it is true/false and generate th...
ProgramStateRef assumeInternal(ProgramStateRef State, DefinedSVal Cond, bool Assumption) override
Ensures that the DefinedSVal conditional is expressed as a NonLoc by creating boolean casts to handle...
TypedRegion - An abstract class representing regions that are typed.
Value representing integer constant.
IntrusiveRefCntPtr< const ProgramState > ProgramStateRef
const SymExpr * SymbolRef
The JSON file list parser is used to communicate input to InstallAPI.
const FunctionProtoType * T