Unverified Commit 3e1bd5b8 authored by Joshua Haberman's avatar Joshua Haberman Committed by GitHub

Merge pull request #5014 from Kwizatz/iterator-deprecation-fix

Updating Iterators to be compatible with C++17 in MSVC
parents f2ef7970 b0f332ba
...@@ -2280,23 +2280,14 @@ namespace internal { ...@@ -2280,23 +2280,14 @@ namespace internal {
// This code based on net/proto/proto-array-internal.h by Jeffrey Yasskin // This code based on net/proto/proto-array-internal.h by Jeffrey Yasskin
// (jyasskin@google.com). // (jyasskin@google.com).
template<typename Element> template<typename Element>
class RepeatedPtrIterator class RepeatedPtrIterator {
: public std::iterator<
std::random_access_iterator_tag, Element> {
public: public:
typedef RepeatedPtrIterator<Element> iterator; typedef RepeatedPtrIterator<Element> iterator;
typedef std::iterator< typedef std::random_access_iterator_tag iterator_category;
std::random_access_iterator_tag, Element> superclass;
// Shadow the value_type in std::iterator<> because const_iterator::value_type
// needs to be T, not const T.
typedef typename std::remove_const<Element>::type value_type; typedef typename std::remove_const<Element>::type value_type;
typedef std::ptrdiff_t difference_type;
// Let the compiler know that these are type names, so we don't have to typedef Element* pointer;
// write "typename" in front of them everywhere. typedef Element& reference;
typedef typename superclass::reference reference;
typedef typename superclass::pointer pointer;
typedef typename superclass::difference_type difference_type;
RepeatedPtrIterator() : it_(NULL) {} RepeatedPtrIterator() : it_(NULL) {}
explicit RepeatedPtrIterator(void* const* it) : it_(it) {} explicit RepeatedPtrIterator(void* const* it) : it_(it) {}
...@@ -2376,21 +2367,14 @@ class RepeatedPtrIterator ...@@ -2376,21 +2367,14 @@ class RepeatedPtrIterator
// referenced by the iterator. It should either be "void *" for a mutable // referenced by the iterator. It should either be "void *" for a mutable
// iterator, or "const void* const" for a constant iterator. // iterator, or "const void* const" for a constant iterator.
template <typename Element, typename VoidPtr> template <typename Element, typename VoidPtr>
class RepeatedPtrOverPtrsIterator class RepeatedPtrOverPtrsIterator {
: public std::iterator<std::random_access_iterator_tag, Element> {
public: public:
typedef RepeatedPtrOverPtrsIterator<Element, VoidPtr> iterator; typedef RepeatedPtrOverPtrsIterator<Element, VoidPtr> iterator;
typedef std::iterator<std::random_access_iterator_tag, Element> superclass; typedef std::random_access_iterator_tag iterator_category;
// Shadow the value_type in std::iterator<> because const_iterator::value_type
// needs to be T, not const T.
typedef typename std::remove_const<Element>::type value_type; typedef typename std::remove_const<Element>::type value_type;
typedef std::ptrdiff_t difference_type;
// Let the compiler know that these are type names, so we don't have to typedef Element* pointer;
// write "typename" in front of them everywhere. typedef Element& reference;
typedef typename superclass::reference reference;
typedef typename superclass::pointer pointer;
typedef typename superclass::difference_type difference_type;
RepeatedPtrOverPtrsIterator() : it_(NULL) {} RepeatedPtrOverPtrsIterator() : it_(NULL) {}
explicit RepeatedPtrOverPtrsIterator(VoidPtr* it) : it_(it) {} explicit RepeatedPtrOverPtrsIterator(VoidPtr* it) : it_(it) {}
......
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