[libcxx] [test] D27021: Fix MSVC warning C4389 "signed/unsigned mismatch", part 8/12.
Add static_cast<std::size_t> when comparing distance() to size().
These replacements were performed programmatically with regex_replace():
const vector<pair<regex, string>> reg_fmt = {
{ regex(R"(assert\((\w+)\.size\(\) == std::distance\((\w+, \w+)\)\))"),
"assert($1.size() == static_cast<std::size_t>(std::distance($2)))" },
{ regex(R"(assert\(distance\((\w+\.begin\(\), \w+\.end\(\))\) == (\w+)\.size\(\)\))"),
"assert(static_cast<std::size_t>(distance($1)) == $2.size())" },
{ regex(R"(assert\(std::distance\((\w+\.\w*begin\(\), \w+\.\w*end\(\))\) == (\w+)\.size\(\)\))"),
"assert(static_cast<std::size_t>(std::distance($1)) == $2.size())" },
};
Also, include <cstddef> when it wasn't already being included.
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@288745 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -65,8 +65,8 @@ int main()
|
||||
8
|
||||
};
|
||||
std::set<int> m(ar, ar+sizeof(ar)/sizeof(ar[0]));
|
||||
assert(std::distance(m.begin(), m.end()) == m.size());
|
||||
assert(std::distance(m.rbegin(), m.rend()) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.begin(), m.end())) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.rbegin(), m.rend())) == m.size());
|
||||
std::set<int>::iterator i;
|
||||
i = m.begin();
|
||||
std::set<int>::const_iterator k = i;
|
||||
@@ -104,10 +104,10 @@ int main()
|
||||
8
|
||||
};
|
||||
const std::set<int> m(ar, ar+sizeof(ar)/sizeof(ar[0]));
|
||||
assert(std::distance(m.begin(), m.end()) == m.size());
|
||||
assert(std::distance(m.cbegin(), m.cend()) == m.size());
|
||||
assert(std::distance(m.rbegin(), m.rend()) == m.size());
|
||||
assert(std::distance(m.crbegin(), m.crend()) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.begin(), m.end())) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.cbegin(), m.cend())) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.rbegin(), m.rend())) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.crbegin(), m.crend())) == m.size());
|
||||
std::set<int>::const_iterator i;
|
||||
i = m.begin();
|
||||
for (int j = 1; static_cast<std::size_t>(j) <= m.size(); ++j, ++i)
|
||||
@@ -144,8 +144,8 @@ int main()
|
||||
8
|
||||
};
|
||||
std::set<int, std::less<int>, min_allocator<int>> m(ar, ar+sizeof(ar)/sizeof(ar[0]));
|
||||
assert(std::distance(m.begin(), m.end()) == m.size());
|
||||
assert(std::distance(m.rbegin(), m.rend()) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.begin(), m.end())) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.rbegin(), m.rend())) == m.size());
|
||||
std::set<int, std::less<int>, min_allocator<int>>::iterator i;
|
||||
i = m.begin();
|
||||
std::set<int, std::less<int>, min_allocator<int>>::const_iterator k = i;
|
||||
@@ -183,10 +183,10 @@ int main()
|
||||
8
|
||||
};
|
||||
const std::set<int, std::less<int>, min_allocator<int>> m(ar, ar+sizeof(ar)/sizeof(ar[0]));
|
||||
assert(std::distance(m.begin(), m.end()) == m.size());
|
||||
assert(std::distance(m.cbegin(), m.cend()) == m.size());
|
||||
assert(std::distance(m.rbegin(), m.rend()) == m.size());
|
||||
assert(std::distance(m.crbegin(), m.crend()) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.begin(), m.end())) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.cbegin(), m.cend())) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.rbegin(), m.rend())) == m.size());
|
||||
assert(static_cast<std::size_t>(std::distance(m.crbegin(), m.crend())) == m.size());
|
||||
std::set<int, std::less<int>, min_allocator<int>>::const_iterator i;
|
||||
i = m.begin();
|
||||
for (int j = 1; static_cast<std::size_t>(j) <= m.size(); ++j, ++i)
|
||||
|
||||
Reference in New Issue
Block a user