Commit 93d6838a authored by Feng Xiao's avatar Feng Xiao

Call copy() only if there is something to copy.

RepeatedField::begin()/end() will return NULL when the content is empty.
Passing these NULL values to std::copy() will result in runtime complains
from some compilers (e.g., vs2010).
parent 5a9be2c6
...@@ -1125,7 +1125,9 @@ template <typename Element> ...@@ -1125,7 +1125,9 @@ template <typename Element>
inline typename RepeatedField<Element>::iterator RepeatedField<Element>::erase( inline typename RepeatedField<Element>::iterator RepeatedField<Element>::erase(
const_iterator first, const_iterator last) { const_iterator first, const_iterator last) {
size_type first_offset = first - cbegin(); size_type first_offset = first - cbegin();
if (first != last) {
Truncate(std::copy(last, cend(), begin() + first_offset) - cbegin()); Truncate(std::copy(last, cend(), begin() + first_offset) - cbegin());
}
return begin() + first_offset; return begin() + first_offset;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment