1 /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
2 * vim: set ts=8 sts=2 et sw=2 tw=80:
3 * This Source Code Form is subject to the terms of the Mozilla Public
4 * License, v. 2.0. If a copy of the MPL was not distributed with this
5 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
7 #ifndef gc_IteratorUtils_h
8 #define gc_IteratorUtils_h
10 #include "mozilla/Array.h"
11 #include "mozilla/Maybe.h"
13 #include <initializer_list>
18 * Create an iterator that yields the values from IteratorB(a) for all a in
19 * IteratorA(). Equivalent to nested for loops over IteratorA and IteratorB
20 * where IteratorB is constructed with a value from IteratorA.
22 template <typename IteratorA
, typename IteratorB
>
23 class NestedIterator
{
24 using T
= decltype(std::declval
<IteratorB
>().get());
27 mozilla::Maybe
<IteratorB
> b
;
30 template <typename
... Args
>
31 explicit NestedIterator(Args
&&... args
) : a(std::forward
<Args
>(args
)...) {
35 bool done() const { return b
.isNothing(); }
52 const IteratorB
& ref() const { return *b
; }
54 operator T() const { return get(); }
56 T
operator->() const { return get(); }
60 MOZ_ASSERT(b
.isNothing());
73 * An iterator the yields values from each of N of instances of Iterator in
76 template <typename Iterator
, size_t N
>
77 class ChainedIterator
{
78 using T
= decltype(std::declval
<Iterator
>().get());
80 mozilla::Array
<Iterator
, N
> iterators
;
84 template <typename
... Args
>
85 MOZ_IMPLICIT
ChainedIterator(Args
&&... args
)
86 : iterators(Iterator(std::forward
<Args
>(args
))...) {
91 bool done() const { return index
== N
; }
95 iterators
[index
].next();
101 return iterators
[index
].get();
104 operator T() const { return get(); }
105 T
operator->() const { return get(); }
110 while (iterators
[index
].done()) {
121 #endif // gc_IteratorUtils_h