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).
This commit is contained in:
parent
5a9be2c6f6
commit
93d6838ab5
1 changed files with 3 additions and 1 deletions
|
@ -1125,7 +1125,9 @@ template <typename Element>
|
|||
inline typename RepeatedField<Element>::iterator RepeatedField<Element>::erase(
|
||||
const_iterator first, const_iterator last) {
|
||||
size_type first_offset = first - cbegin();
|
||||
Truncate(std::copy(last, cend(), begin() + first_offset) - cbegin());
|
||||
if (first != last) {
|
||||
Truncate(std::copy(last, cend(), begin() + first_offset) - cbegin());
|
||||
}
|
||||
return begin() + first_offset;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue