Summary:
With current model, there are issues with cxx range loop. It looks like
it comes from std::vector::size model.
example of such FP:
```
int t = vec.size();
for(auto& elem : vec) {
auto x = elem
}
```
Reviewed By: jvillard
Differential Revision: D5545914
fbshipit-source-id: fbe55b3
master
parent
7a3decf7f7
commit
c473f21f81
@ -0,0 +1,43 @@
|
||||
/*
|
||||
* Copyright (c) 2017 - present Facebook, Inc.
|
||||
* All rights reserved.
|
||||
*
|
||||
* This source code is licensed under the BSD style license found in the
|
||||
* LICENSE file in the root directory of this source tree. An additional grant
|
||||
* of patent rights can be found in the PATENTS file in the same directory.
|
||||
*/
|
||||
#include <vector>
|
||||
|
||||
void foreach_access_ok(std::vector<int>& vec) {
|
||||
if (vec.empty()) {
|
||||
// do nothing
|
||||
}
|
||||
for (const auto& elem : vec) {
|
||||
auto r = elem;
|
||||
}
|
||||
}
|
||||
|
||||
void iterator_for_access_ok(std::vector<int>& vec) {
|
||||
if (vec.empty()) {
|
||||
// do nothing
|
||||
}
|
||||
for (auto it = vec.begin(); it != vec.end(); ++it) {
|
||||
auto r = *it;
|
||||
}
|
||||
}
|
||||
|
||||
void empty_vector_loop_ok() {
|
||||
std::vector<int> vec;
|
||||
int* ptr = nullptr;
|
||||
for (const auto& elem : vec) {
|
||||
*ptr = elem; // this is unreachable
|
||||
}
|
||||
}
|
||||
|
||||
void non_empty_vector_loop_bad(std::vector<int>& vec) {
|
||||
std::vector<int> x;
|
||||
int* ptr = nullptr;
|
||||
for (const auto& elem : vec) {
|
||||
*ptr = elem; // this is reachable
|
||||
}
|
||||
}
|
||||
Loading…
Reference in new issue