================
@@ -1165,7 +1165,7 @@ ProgramStateRef 
StdLibraryFunctionsChecker::NotNullConstraint::apply(
   return State->assume(L, CannotBeNull);
 }
 
-void StdLibraryFunctionsChecker::NotNullConstraint::describe(
+void StdLibraryFunctionsChecker::NullnessConstraint::describe(
     DescriptionKind DK, const CallEvent &Call, ProgramStateRef State,
     const Summary &Summary, llvm::raw_ostream &Out) const {
   assert(CannotBeNull &&
----------------
balazske wrote:

Currently the `NotNullConstraint` is used in two ways:

- Argument preconditions where only a non-null condition is used. When 
`describe` is called here the `CannotBeNull` should be true. The 
`describeArgumentValue` is called on the negated version of it when 
`CannotBeNull` is false.
- Return value conditions at "cases" where it can be null or non-null. Here 
always a custom description text is used and `describe` or 
`describeArgumentValue` is not called. 

Purpose of the assertion seems to be only to make a simplification (not 
implement `describe` in the null and `describeArgumentValue` in the non-null 
case). The assertion could be extended with something like `getArgNo() != Ret 
&&` (verify the first use case above).

https://github.com/llvm/llvm-project/pull/131374
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to