[PATCH] D78289: [analyzer] Stability improvements for IteratorModeling functions
Denys Petrov via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Thu Apr 23 07:32:16 PDT 2020
ASDenysPetrov updated this revision to Diff 259561.
ASDenysPetrov edited the summary of this revision.
ASDenysPetrov added a comment.
I decided not to add changes of what I cannot cover by tests. So I removed them.
@NoQ @baloghadamsoftware
please, review my changes.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D78289/new/
https://reviews.llvm.org/D78289
Files:
clang/lib/StaticAnalyzer/Checkers/IteratorModeling.cpp
clang/test/Analysis/iterator-range.cpp
Index: clang/test/Analysis/iterator-range.cpp
===================================================================
--- clang/test/Analysis/iterator-range.cpp
+++ clang/test/Analysis/iterator-range.cpp
@@ -810,6 +810,19 @@
auto j = std::prev(i, 0); // no-warning
}
+// std::prev() with int* for checking Loc value argument
+namespace std {
+template <typename T>
+T prev(T, int *);
+}
+
+void prev_loc_value(const std::vector<int> &V, int o) {
+
+ auto i = return_any_iterator(V.begin());
+ int *offset = &o;
+ auto j = std::prev(i, offset); // no-warning
+}
+
//
// Structure member dereference operators
//
Index: clang/lib/StaticAnalyzer/Checkers/IteratorModeling.cpp
===================================================================
--- clang/lib/StaticAnalyzer/Checkers/IteratorModeling.cpp
+++ clang/lib/StaticAnalyzer/Checkers/IteratorModeling.cpp
@@ -402,7 +402,7 @@
if (!Cont)
return;
- // At least one of the iterators have recorded positions. If one of them has
+ // At least one of the iterators has recorded positions. If one of them does
// not then create a new symbol for the offset.
SymbolRef Sym;
if (!LPos || !RPos) {
@@ -422,7 +422,7 @@
RPos = getIteratorPosition(State, RVal);
}
- // We cannot make assumpotions on `UnknownVal`. Let us conjure a symbol
+ // We cannot make assumptions on `UnknownVal`. Let us conjure a symbol
// instead.
if (RetVal.isUnknown()) {
auto &SymMgr = C.getSymbolManager();
@@ -532,8 +532,9 @@
return;
const auto *value = &RHS;
+ SVal val;
if (auto loc = RHS.getAs<Loc>()) {
- const auto val = State->getRawSVal(*loc);
+ val = State->getRawSVal(*loc);
value = &val;
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D78289.259561.patch
Type: text/x-patch
Size: 1702 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20200423/4c27caab/attachment-0001.bin>
More information about the cfe-commits
mailing list