Exactly what it says on the tin! I decided not to merge this with the patch that changes all these to a CallDescriptionMap object, so the patch is that much more trivial.
Details
Diff Detail
Event Timeline
Fantastic, thanks!!
clang/include/clang/StaticAnalyzer/Core/PathSensitive/CallEvent.h | ||
---|---|---|
259 | I don't fully understand how does overload resolution work in this case, maybe rename the original function? | |
clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp | ||
1006 | The FD->getKind() != Decl::Function part is super mega redundant here. |
clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp | ||
---|---|---|
1006 | Sorry for jumping in from nowhere. AFAIK, this is the only way to detect free vs member functions. It looks like this wants to discard member functions. Are you sure it's redundant? |
clang/include/clang/StaticAnalyzer/Core/PathSensitive/CallEvent.h | ||
---|---|---|
259 | Well, isCalled may now have an arbitrary number of arguments. The single argument version is this function, and the n-argument ones call this n times: isCalled(A, B, C) -> isCalled(A) || isCalled(B) || isCalled(B). I guess I could rename the other one to isAnyCalled, but I think its fine. | |
clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp | ||
1006 | Please do! Though I have a suspicion that if this isn't redundant, such a check should be done in CallDescription. |
clang/include/clang/StaticAnalyzer/Core/PathSensitive/CallEvent.h | ||
---|---|---|
259 | But that would be super ugly imo :/ I think the current implementation is intuitive enough, but I'm happy to change it if you disagree. | |
clang/lib/StaticAnalyzer/Checkers/MallocChecker.cpp | ||
1006 | I agree that it should be removed, since we explicitly support functions annotated to return a dynamically allocated memory region, even if it is a member function. |
clang/include/clang/StaticAnalyzer/Core/PathSensitive/CallEvent.h | ||
---|---|---|
259 | Ok, so, maybe in such cases we should add a flag to our CallDescriptionMap and then write code like if (CDM.lookup(Call)->hasFlag) { ... } ? (or, maybe, make a separate map if these calls are never present in the rest of the code... do we want CallDescriptionSet for this purpose?) |
clang/include/clang/StaticAnalyzer/Core/PathSensitive/CallEvent.h | ||
---|---|---|
259 | Well, the followup patch where the map is deployed uses nothing fancy. Lets wait until we actually need such a thing. What do you mean under "calls that are never present in the code"? |
I don't fully understand how does overload resolution work in this case, maybe rename the original function?