mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:25:44 +00:00
202b273a2e
- Bug 1175485 part 1 - Allow inner iterator of ReverseIterator deref to any type, and change IntegerIterator, EnumeratedRange, and nsFrameList::Iterator to return value type instead of a reference. r=roc,waldo (83c53e8e8) - Bug 1175485 part 2 - Add static_assert to MakeRange to ensure it is used with integers. r=waldo (2b6fc759a) - Bug 1175485 part 3 - Remove unused operators, typedefs and IteratorTraits. r=waldo (91bc5407d) - Bug 1175485 part 4 - Add unit test for integer range. r=waldo (ec2b7d4c1) - Bug 1188204 - Fix more constructors in MFBT; r=froydnj (099428523) - Bug 1187985 - Make PersistentRooted use rootKind to find its lists; r=sfink (0c223593a) - Bug 1184191 - Assert in release mode if we reenter the garbage collector r=terrence (3207d3631) - Bug 1188124 - Use rootKind to select the right PersistentRooted list head; r=sfink (47009c787) - Bug 1174849 - Remove "serviceworker" from RequestContext; r=smaug,bkelly (138e480ea) - Bug 1174868 - Avoid storing RequestContext inside InternalRequest; r=nsm,bkelly,smaug (779a05075) - Bug 1147668 - Correctly reflect video and track RequestContext values; r=smaug (90f265d5f) - Bug 1148818 - Re-enable the Cache part of test_request_context.html on Android now that it passes (782fe9777) - Bug 1148935 - Correctly reflect worker and sharedworker RequestContext values; r=smaug (fd40e01d8)
169 lines
5.2 KiB
C++
169 lines
5.2 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
/* An iterator that acts like another iterator, but iterating in
|
|
* the negative direction. (Note that not all iterators can iterate
|
|
* in the negative direction.) */
|
|
|
|
#ifndef mozilla_ReverseIterator_h
|
|
#define mozilla_ReverseIterator_h
|
|
|
|
#include "mozilla/Attributes.h"
|
|
#include "mozilla/TypeTraits.h"
|
|
|
|
namespace mozilla {
|
|
|
|
template<typename IteratorT>
|
|
class ReverseIterator
|
|
{
|
|
public:
|
|
template<typename Iterator>
|
|
explicit ReverseIterator(Iterator aIter)
|
|
: mCurrent(aIter) { }
|
|
|
|
template<typename Iterator>
|
|
MOZ_IMPLICIT ReverseIterator(const ReverseIterator<Iterator>& aOther)
|
|
: mCurrent(aOther.mCurrent) { }
|
|
|
|
decltype(*DeclVal<IteratorT>()) operator*() const
|
|
{
|
|
IteratorT tmp = mCurrent;
|
|
return *--tmp;
|
|
}
|
|
|
|
/* Increments and decrements operators */
|
|
|
|
ReverseIterator& operator++() { --mCurrent; return *this; }
|
|
ReverseIterator& operator--() { ++mCurrent; return *this; }
|
|
ReverseIterator operator++(int) { auto ret = *this; mCurrent--; return ret; }
|
|
ReverseIterator operator--(int) { auto ret = *this; mCurrent++; return ret; }
|
|
|
|
/* Comparison operators */
|
|
|
|
template<typename Iterator1, typename Iterator2>
|
|
friend bool operator==(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2);
|
|
template<typename Iterator1, typename Iterator2>
|
|
friend bool operator!=(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2);
|
|
template<typename Iterator1, typename Iterator2>
|
|
friend bool operator<(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2);
|
|
template<typename Iterator1, typename Iterator2>
|
|
friend bool operator<=(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2);
|
|
template<typename Iterator1, typename Iterator2>
|
|
friend bool operator>(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2);
|
|
template<typename Iterator1, typename Iterator2>
|
|
friend bool operator>=(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2);
|
|
|
|
private:
|
|
IteratorT mCurrent;
|
|
};
|
|
|
|
template<typename Iterator1, typename Iterator2>
|
|
bool
|
|
operator==(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2)
|
|
{
|
|
return aIter1.mCurrent == aIter2.mCurrent;
|
|
}
|
|
|
|
template<typename Iterator1, typename Iterator2>
|
|
bool
|
|
operator!=(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2)
|
|
{
|
|
return aIter1.mCurrent != aIter2.mCurrent;
|
|
}
|
|
|
|
template<typename Iterator1, typename Iterator2>
|
|
bool
|
|
operator<(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2)
|
|
{
|
|
return aIter1.mCurrent > aIter2.mCurrent;
|
|
}
|
|
|
|
template<typename Iterator1, typename Iterator2>
|
|
bool
|
|
operator<=(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2)
|
|
{
|
|
return aIter1.mCurrent >= aIter2.mCurrent;
|
|
}
|
|
|
|
template<typename Iterator1, typename Iterator2>
|
|
bool
|
|
operator>(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2)
|
|
{
|
|
return aIter1.mCurrent < aIter2.mCurrent;
|
|
}
|
|
|
|
template<typename Iterator1, typename Iterator2>
|
|
bool
|
|
operator>=(const ReverseIterator<Iterator1>& aIter1,
|
|
const ReverseIterator<Iterator2>& aIter2)
|
|
{
|
|
return aIter1.mCurrent <= aIter2.mCurrent;
|
|
}
|
|
|
|
namespace detail {
|
|
|
|
template<typename IteratorT>
|
|
class IteratorRange
|
|
{
|
|
public:
|
|
typedef IteratorT iterator;
|
|
typedef IteratorT const_iterator;
|
|
typedef ReverseIterator<IteratorT> reverse_iterator;
|
|
typedef ReverseIterator<IteratorT> const_reverse_iterator;
|
|
|
|
template<typename Iterator1, typename Iterator2>
|
|
MOZ_IMPLICIT IteratorRange(Iterator1 aIterBegin, Iterator2 aIterEnd)
|
|
: mIterBegin(aIterBegin), mIterEnd(aIterEnd) { }
|
|
|
|
template<typename Iterator>
|
|
MOZ_IMPLICIT IteratorRange(const IteratorRange<Iterator>& aOther)
|
|
: mIterBegin(aOther.mIterBegin), mIterEnd(aOther.mIterEnd) { }
|
|
|
|
iterator begin() const { return mIterBegin; }
|
|
const_iterator cbegin() const { return begin(); }
|
|
iterator end() const { return mIterEnd; }
|
|
const_iterator cend() const { return end(); }
|
|
reverse_iterator rbegin() const { return reverse_iterator(mIterEnd); }
|
|
const_reverse_iterator crbegin() const { return rbegin(); }
|
|
reverse_iterator rend() const { return reverse_iterator(mIterBegin); }
|
|
const_reverse_iterator crend() const { return rend(); }
|
|
|
|
private:
|
|
IteratorT mIterBegin;
|
|
IteratorT mIterEnd;
|
|
};
|
|
|
|
} // namespace detail
|
|
|
|
template<typename Range>
|
|
detail::IteratorRange<typename Range::reverse_iterator>
|
|
Reversed(Range& aRange)
|
|
{
|
|
return {aRange.rbegin(), aRange.rend()};
|
|
}
|
|
|
|
template<typename Range>
|
|
detail::IteratorRange<typename Range::const_reverse_iterator>
|
|
Reversed(const Range& aRange)
|
|
{
|
|
return {aRange.rbegin(), aRange.rend()};
|
|
}
|
|
|
|
} // namespace mozilla
|
|
|
|
#endif // mozilla_ReverseIterator_h
|