Check for end iterator before using iterator

If it == end, then sequence_length(it) will be called which will attempt to dereference the it iterator. This is normally harmless, because the get_sequence_x() functions each check to see whether it == end. However, some runtime libraries (MSVC CRT debug build in particular) check the validity of every iterator dereference, and a runtime check will be triggered inside sequence_length() if it is at the end.
This commit is contained in:
Greg Hewgill 2016-09-28 13:32:08 +13:00
parent b4c761dbe9
commit 9d52bc19dc
1 changed files with 3 additions and 0 deletions

View File

@ -222,6 +222,9 @@ namespace internal
template <typename octet_iterator> template <typename octet_iterator>
utf_error validate_next(octet_iterator& it, octet_iterator end, uint32_t& code_point) utf_error validate_next(octet_iterator& it, octet_iterator end, uint32_t& code_point)
{ {
if (it == end)
return NOT_ENOUGH_ROOM;
// Save the original value of it so we can go back in case of failure // Save the original value of it so we can go back in case of failure
// Of course, it does not make much sense with i.e. stream iterators // Of course, it does not make much sense with i.e. stream iterators
octet_iterator original_it = it; octet_iterator original_it = it;