1*2d1272b8SAndroid Build Coastguard Worker /*
2*2d1272b8SAndroid Build Coastguard Worker * Copyright © 2018 Google, Inc.
3*2d1272b8SAndroid Build Coastguard Worker *
4*2d1272b8SAndroid Build Coastguard Worker * This is part of HarfBuzz, a text shaping library.
5*2d1272b8SAndroid Build Coastguard Worker *
6*2d1272b8SAndroid Build Coastguard Worker * Permission is hereby granted, without written agreement and without
7*2d1272b8SAndroid Build Coastguard Worker * license or royalty fees, to use, copy, modify, and distribute this
8*2d1272b8SAndroid Build Coastguard Worker * software and its documentation for any purpose, provided that the
9*2d1272b8SAndroid Build Coastguard Worker * above copyright notice and the following two paragraphs appear in
10*2d1272b8SAndroid Build Coastguard Worker * all copies of this software.
11*2d1272b8SAndroid Build Coastguard Worker *
12*2d1272b8SAndroid Build Coastguard Worker * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
13*2d1272b8SAndroid Build Coastguard Worker * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
14*2d1272b8SAndroid Build Coastguard Worker * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
15*2d1272b8SAndroid Build Coastguard Worker * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
16*2d1272b8SAndroid Build Coastguard Worker * DAMAGE.
17*2d1272b8SAndroid Build Coastguard Worker *
18*2d1272b8SAndroid Build Coastguard Worker * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
19*2d1272b8SAndroid Build Coastguard Worker * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
20*2d1272b8SAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
21*2d1272b8SAndroid Build Coastguard Worker * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
22*2d1272b8SAndroid Build Coastguard Worker * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
23*2d1272b8SAndroid Build Coastguard Worker *
24*2d1272b8SAndroid Build Coastguard Worker * Google Author(s): Behdad Esfahbod
25*2d1272b8SAndroid Build Coastguard Worker */
26*2d1272b8SAndroid Build Coastguard Worker
27*2d1272b8SAndroid Build Coastguard Worker #include "hb.hh"
28*2d1272b8SAndroid Build Coastguard Worker #include "hb-iter.hh"
29*2d1272b8SAndroid Build Coastguard Worker
30*2d1272b8SAndroid Build Coastguard Worker #include "hb-array.hh"
31*2d1272b8SAndroid Build Coastguard Worker #include "hb-set.hh"
32*2d1272b8SAndroid Build Coastguard Worker #include "hb-ot-layout-common.hh"
33*2d1272b8SAndroid Build Coastguard Worker
34*2d1272b8SAndroid Build Coastguard Worker template <typename T>
35*2d1272b8SAndroid Build Coastguard Worker struct array_iter_t : hb_iter_with_fallback_t<array_iter_t<T>, T&>
36*2d1272b8SAndroid Build Coastguard Worker {
array_iter_tarray_iter_t37*2d1272b8SAndroid Build Coastguard Worker array_iter_t (hb_array_t<T> arr_) : arr (arr_) {}
38*2d1272b8SAndroid Build Coastguard Worker
39*2d1272b8SAndroid Build Coastguard Worker typedef T& __item_t__;
40*2d1272b8SAndroid Build Coastguard Worker static constexpr bool is_random_access_iterator = true;
__item_at__array_iter_t41*2d1272b8SAndroid Build Coastguard Worker T& __item_at__ (unsigned i) const { return arr[i]; }
__forward__array_iter_t42*2d1272b8SAndroid Build Coastguard Worker void __forward__ (unsigned n) { arr += n; }
__rewind__array_iter_t43*2d1272b8SAndroid Build Coastguard Worker void __rewind__ (unsigned n) { arr -= n; }
__len__array_iter_t44*2d1272b8SAndroid Build Coastguard Worker unsigned __len__ () const { return arr.length; }
operator !=array_iter_t45*2d1272b8SAndroid Build Coastguard Worker bool operator != (const array_iter_t& o) { return arr != o.arr; }
46*2d1272b8SAndroid Build Coastguard Worker
47*2d1272b8SAndroid Build Coastguard Worker private:
48*2d1272b8SAndroid Build Coastguard Worker hb_array_t<T> arr;
49*2d1272b8SAndroid Build Coastguard Worker };
50*2d1272b8SAndroid Build Coastguard Worker
51*2d1272b8SAndroid Build Coastguard Worker template <typename T>
52*2d1272b8SAndroid Build Coastguard Worker struct some_array_t
53*2d1272b8SAndroid Build Coastguard Worker {
some_array_tsome_array_t54*2d1272b8SAndroid Build Coastguard Worker some_array_t (hb_array_t<T> arr_) : arr (arr_) {}
55*2d1272b8SAndroid Build Coastguard Worker
56*2d1272b8SAndroid Build Coastguard Worker typedef array_iter_t<T> iter_t;
itersome_array_t57*2d1272b8SAndroid Build Coastguard Worker array_iter_t<T> iter () { return array_iter_t<T> (arr); }
operator array_iter_t<T>some_array_t58*2d1272b8SAndroid Build Coastguard Worker operator array_iter_t<T> () { return iter (); }
operator hb_iter_t<array_iter_t<T>>some_array_t59*2d1272b8SAndroid Build Coastguard Worker operator hb_iter_t<array_iter_t<T>> () { return iter (); }
60*2d1272b8SAndroid Build Coastguard Worker
61*2d1272b8SAndroid Build Coastguard Worker private:
62*2d1272b8SAndroid Build Coastguard Worker hb_array_t<T> arr;
63*2d1272b8SAndroid Build Coastguard Worker };
64*2d1272b8SAndroid Build Coastguard Worker
65*2d1272b8SAndroid Build Coastguard Worker
66*2d1272b8SAndroid Build Coastguard Worker template <typename Iter,
67*2d1272b8SAndroid Build Coastguard Worker hb_requires (hb_is_iterator (Iter))>
68*2d1272b8SAndroid Build Coastguard Worker static void
test_iterator_non_default_constructable(Iter it)69*2d1272b8SAndroid Build Coastguard Worker test_iterator_non_default_constructable (Iter it)
70*2d1272b8SAndroid Build Coastguard Worker {
71*2d1272b8SAndroid Build Coastguard Worker /* Iterate over a copy of it. */
72*2d1272b8SAndroid Build Coastguard Worker for (auto c = it.iter (); c; c++)
73*2d1272b8SAndroid Build Coastguard Worker *c;
74*2d1272b8SAndroid Build Coastguard Worker
75*2d1272b8SAndroid Build Coastguard Worker /* Same. */
76*2d1272b8SAndroid Build Coastguard Worker for (auto c = +it; c; c++)
77*2d1272b8SAndroid Build Coastguard Worker *c;
78*2d1272b8SAndroid Build Coastguard Worker
79*2d1272b8SAndroid Build Coastguard Worker /* Range-based for over a copy. */
80*2d1272b8SAndroid Build Coastguard Worker for (auto _ : +it)
81*2d1272b8SAndroid Build Coastguard Worker (void) _;
82*2d1272b8SAndroid Build Coastguard Worker
83*2d1272b8SAndroid Build Coastguard Worker it += it.len ();
84*2d1272b8SAndroid Build Coastguard Worker it = it + 10;
85*2d1272b8SAndroid Build Coastguard Worker it = 10 + it;
86*2d1272b8SAndroid Build Coastguard Worker
87*2d1272b8SAndroid Build Coastguard Worker assert (*it == it[0]);
88*2d1272b8SAndroid Build Coastguard Worker
89*2d1272b8SAndroid Build Coastguard Worker static_assert (true || it.is_random_access_iterator, "");
90*2d1272b8SAndroid Build Coastguard Worker static_assert (true || it.is_sorted_iterator, "");
91*2d1272b8SAndroid Build Coastguard Worker }
92*2d1272b8SAndroid Build Coastguard Worker
93*2d1272b8SAndroid Build Coastguard Worker template <typename Iter,
94*2d1272b8SAndroid Build Coastguard Worker hb_requires (hb_is_iterator (Iter))>
95*2d1272b8SAndroid Build Coastguard Worker static void
test_iterator(Iter it)96*2d1272b8SAndroid Build Coastguard Worker test_iterator (Iter it)
97*2d1272b8SAndroid Build Coastguard Worker {
98*2d1272b8SAndroid Build Coastguard Worker Iter default_constructed;
99*2d1272b8SAndroid Build Coastguard Worker assert (!default_constructed);
100*2d1272b8SAndroid Build Coastguard Worker
101*2d1272b8SAndroid Build Coastguard Worker test_iterator_non_default_constructable (it);
102*2d1272b8SAndroid Build Coastguard Worker }
103*2d1272b8SAndroid Build Coastguard Worker
104*2d1272b8SAndroid Build Coastguard Worker template <typename Iterable,
105*2d1272b8SAndroid Build Coastguard Worker hb_requires (hb_is_iterable (Iterable))>
106*2d1272b8SAndroid Build Coastguard Worker static void
test_iterable(const Iterable & lst=Null (Iterable))107*2d1272b8SAndroid Build Coastguard Worker test_iterable (const Iterable &lst = Null (Iterable))
108*2d1272b8SAndroid Build Coastguard Worker {
109*2d1272b8SAndroid Build Coastguard Worker for (auto _ : lst)
110*2d1272b8SAndroid Build Coastguard Worker (void) _;
111*2d1272b8SAndroid Build Coastguard Worker
112*2d1272b8SAndroid Build Coastguard Worker // Test that can take iterator from.
113*2d1272b8SAndroid Build Coastguard Worker test_iterator (lst.iter ());
114*2d1272b8SAndroid Build Coastguard Worker }
115*2d1272b8SAndroid Build Coastguard Worker
116*2d1272b8SAndroid Build Coastguard Worker template <typename It>
check_sequential(It it)117*2d1272b8SAndroid Build Coastguard Worker static void check_sequential (It it)
118*2d1272b8SAndroid Build Coastguard Worker {
119*2d1272b8SAndroid Build Coastguard Worker int i = 1;
120*2d1272b8SAndroid Build Coastguard Worker for (int v : +it) {
121*2d1272b8SAndroid Build Coastguard Worker assert (v == i++);
122*2d1272b8SAndroid Build Coastguard Worker }
123*2d1272b8SAndroid Build Coastguard Worker }
124*2d1272b8SAndroid Build Coastguard Worker
test_concat()125*2d1272b8SAndroid Build Coastguard Worker static void test_concat ()
126*2d1272b8SAndroid Build Coastguard Worker {
127*2d1272b8SAndroid Build Coastguard Worker hb_vector_t<int> a = {1, 2, 3};
128*2d1272b8SAndroid Build Coastguard Worker hb_vector_t<int> b = {4, 5};
129*2d1272b8SAndroid Build Coastguard Worker
130*2d1272b8SAndroid Build Coastguard Worker hb_vector_t<int> c = {};
131*2d1272b8SAndroid Build Coastguard Worker hb_vector_t<int> d = {1, 2, 3, 4, 5};
132*2d1272b8SAndroid Build Coastguard Worker
133*2d1272b8SAndroid Build Coastguard Worker auto it1 = hb_concat (a, b);
134*2d1272b8SAndroid Build Coastguard Worker assert (it1.len () == 5);
135*2d1272b8SAndroid Build Coastguard Worker assert (it1.is_random_access_iterator);
136*2d1272b8SAndroid Build Coastguard Worker auto it2 = hb_concat (c, d);
137*2d1272b8SAndroid Build Coastguard Worker assert (it2.len () == 5);
138*2d1272b8SAndroid Build Coastguard Worker auto it3 = hb_concat (d, c);
139*2d1272b8SAndroid Build Coastguard Worker assert (it3.len () == 5);
140*2d1272b8SAndroid Build Coastguard Worker for (int i = 0; i < 5; i++) {
141*2d1272b8SAndroid Build Coastguard Worker assert(it1[i] == i + 1);
142*2d1272b8SAndroid Build Coastguard Worker assert(it2[i] == i + 1);
143*2d1272b8SAndroid Build Coastguard Worker assert(it3[i] == i + 1);
144*2d1272b8SAndroid Build Coastguard Worker }
145*2d1272b8SAndroid Build Coastguard Worker
146*2d1272b8SAndroid Build Coastguard Worker check_sequential (it1);
147*2d1272b8SAndroid Build Coastguard Worker check_sequential (it2);
148*2d1272b8SAndroid Build Coastguard Worker check_sequential (it3);
149*2d1272b8SAndroid Build Coastguard Worker
150*2d1272b8SAndroid Build Coastguard Worker auto it4 = +it1;
151*2d1272b8SAndroid Build Coastguard Worker it4 += 0;
152*2d1272b8SAndroid Build Coastguard Worker assert (*it4 == 1);
153*2d1272b8SAndroid Build Coastguard Worker
154*2d1272b8SAndroid Build Coastguard Worker it4 += 2;
155*2d1272b8SAndroid Build Coastguard Worker assert (*it4 == 3);
156*2d1272b8SAndroid Build Coastguard Worker assert (it4);
157*2d1272b8SAndroid Build Coastguard Worker assert (it4.len () == 3);
158*2d1272b8SAndroid Build Coastguard Worker
159*2d1272b8SAndroid Build Coastguard Worker it4 += 2;
160*2d1272b8SAndroid Build Coastguard Worker assert (*it4 == 5);
161*2d1272b8SAndroid Build Coastguard Worker assert (it4);
162*2d1272b8SAndroid Build Coastguard Worker assert (it4.len () == 1);
163*2d1272b8SAndroid Build Coastguard Worker
164*2d1272b8SAndroid Build Coastguard Worker it4++;
165*2d1272b8SAndroid Build Coastguard Worker assert (!it4);
166*2d1272b8SAndroid Build Coastguard Worker assert (it4.len () == 0);
167*2d1272b8SAndroid Build Coastguard Worker
168*2d1272b8SAndroid Build Coastguard Worker auto it5 = +it1;
169*2d1272b8SAndroid Build Coastguard Worker it5 += 3;
170*2d1272b8SAndroid Build Coastguard Worker assert (*it5 == 4);
171*2d1272b8SAndroid Build Coastguard Worker
172*2d1272b8SAndroid Build Coastguard Worker hb_set_t s_a = {1, 2, 3};
173*2d1272b8SAndroid Build Coastguard Worker hb_set_t s_b = {4, 5};
174*2d1272b8SAndroid Build Coastguard Worker auto it6 = hb_concat (s_a, s_b);
175*2d1272b8SAndroid Build Coastguard Worker assert (!it6.is_random_access_iterator);
176*2d1272b8SAndroid Build Coastguard Worker check_sequential (it6);
177*2d1272b8SAndroid Build Coastguard Worker assert (it6.len () == 5);
178*2d1272b8SAndroid Build Coastguard Worker
179*2d1272b8SAndroid Build Coastguard Worker it6 += 0;
180*2d1272b8SAndroid Build Coastguard Worker assert (*it6 == 1);
181*2d1272b8SAndroid Build Coastguard Worker
182*2d1272b8SAndroid Build Coastguard Worker it6 += 3;
183*2d1272b8SAndroid Build Coastguard Worker assert (*it6 == 4);
184*2d1272b8SAndroid Build Coastguard Worker assert (it6);
185*2d1272b8SAndroid Build Coastguard Worker assert (it6.len () == 2);
186*2d1272b8SAndroid Build Coastguard Worker }
187*2d1272b8SAndroid Build Coastguard Worker
188*2d1272b8SAndroid Build Coastguard Worker int
main(int argc,char ** argv)189*2d1272b8SAndroid Build Coastguard Worker main (int argc, char **argv)
190*2d1272b8SAndroid Build Coastguard Worker {
191*2d1272b8SAndroid Build Coastguard Worker const int src[10] = {};
192*2d1272b8SAndroid Build Coastguard Worker int dst[20];
193*2d1272b8SAndroid Build Coastguard Worker hb_vector_t<int> v;
194*2d1272b8SAndroid Build Coastguard Worker
195*2d1272b8SAndroid Build Coastguard Worker array_iter_t<const int> s (src); /* Implicit conversion from static array. */
196*2d1272b8SAndroid Build Coastguard Worker array_iter_t<const int> s2 (v); /* Implicit conversion from vector. */
197*2d1272b8SAndroid Build Coastguard Worker array_iter_t<int> t (dst);
198*2d1272b8SAndroid Build Coastguard Worker
199*2d1272b8SAndroid Build Coastguard Worker static_assert (array_iter_t<int>::is_random_access_iterator, "");
200*2d1272b8SAndroid Build Coastguard Worker
201*2d1272b8SAndroid Build Coastguard Worker some_array_t<const int> a (src);
202*2d1272b8SAndroid Build Coastguard Worker
203*2d1272b8SAndroid Build Coastguard Worker s2 = s;
204*2d1272b8SAndroid Build Coastguard Worker
205*2d1272b8SAndroid Build Coastguard Worker hb_iter (src);
206*2d1272b8SAndroid Build Coastguard Worker hb_iter (src, 2);
207*2d1272b8SAndroid Build Coastguard Worker
208*2d1272b8SAndroid Build Coastguard Worker hb_fill (t, 42);
209*2d1272b8SAndroid Build Coastguard Worker hb_copy (s, t);
210*2d1272b8SAndroid Build Coastguard Worker hb_copy (a.iter (), t);
211*2d1272b8SAndroid Build Coastguard Worker
212*2d1272b8SAndroid Build Coastguard Worker test_iterable (v);
213*2d1272b8SAndroid Build Coastguard Worker hb_set_t st;
214*2d1272b8SAndroid Build Coastguard Worker st << 1 << 15 << 43;
215*2d1272b8SAndroid Build Coastguard Worker test_iterable (st);
216*2d1272b8SAndroid Build Coastguard Worker hb_sorted_array_t<int> sa;
217*2d1272b8SAndroid Build Coastguard Worker (void) static_cast<hb_iter_t<hb_sorted_array_t<int>, hb_sorted_array_t<int>::item_t>&> (sa);
218*2d1272b8SAndroid Build Coastguard Worker (void) static_cast<hb_iter_t<hb_sorted_array_t<int>, hb_sorted_array_t<int>::__item_t__>&> (sa);
219*2d1272b8SAndroid Build Coastguard Worker (void) static_cast<hb_iter_t<hb_sorted_array_t<int>, int&>&>(sa);
220*2d1272b8SAndroid Build Coastguard Worker (void) static_cast<hb_iter_t<hb_sorted_array_t<int>>&>(sa);
221*2d1272b8SAndroid Build Coastguard Worker (void) static_cast<hb_iter_t<hb_array_t<int>, int&>&> (sa);
222*2d1272b8SAndroid Build Coastguard Worker test_iterable (sa);
223*2d1272b8SAndroid Build Coastguard Worker
224*2d1272b8SAndroid Build Coastguard Worker test_iterable<hb_array_t<int>> ();
225*2d1272b8SAndroid Build Coastguard Worker test_iterable<hb_sorted_array_t<const int>> ();
226*2d1272b8SAndroid Build Coastguard Worker test_iterable<hb_vector_t<float>> ();
227*2d1272b8SAndroid Build Coastguard Worker test_iterable<hb_set_t> ();
228*2d1272b8SAndroid Build Coastguard Worker test_iterable<OT::Array16Of<OT::HBUINT16>> ();
229*2d1272b8SAndroid Build Coastguard Worker
230*2d1272b8SAndroid Build Coastguard Worker test_iterator (hb_zip (st, v));
231*2d1272b8SAndroid Build Coastguard Worker test_iterator_non_default_constructable (hb_enumerate (st));
232*2d1272b8SAndroid Build Coastguard Worker test_iterator_non_default_constructable (hb_enumerate (st, -5));
233*2d1272b8SAndroid Build Coastguard Worker test_iterator_non_default_constructable (hb_enumerate (hb_iter (st)));
234*2d1272b8SAndroid Build Coastguard Worker test_iterator_non_default_constructable (hb_enumerate (hb_iter (st) + 1));
235*2d1272b8SAndroid Build Coastguard Worker test_iterator_non_default_constructable (hb_iter (st) | hb_filter ());
236*2d1272b8SAndroid Build Coastguard Worker test_iterator_non_default_constructable (hb_iter (st) | hb_map (hb_lidentity));
237*2d1272b8SAndroid Build Coastguard Worker
238*2d1272b8SAndroid Build Coastguard Worker assert (true == hb_all (st));
239*2d1272b8SAndroid Build Coastguard Worker assert (false == hb_all (st, 42u));
240*2d1272b8SAndroid Build Coastguard Worker assert (true == hb_any (st));
241*2d1272b8SAndroid Build Coastguard Worker assert (false == hb_any (st, 14u));
242*2d1272b8SAndroid Build Coastguard Worker assert (true == hb_any (st, 14u, [] (unsigned _) { return _ - 1u; }));
243*2d1272b8SAndroid Build Coastguard Worker assert (true == hb_any (st, [] (unsigned _) { return _ == 15u; }));
244*2d1272b8SAndroid Build Coastguard Worker assert (true == hb_any (st, 15u));
245*2d1272b8SAndroid Build Coastguard Worker assert (false == hb_none (st));
246*2d1272b8SAndroid Build Coastguard Worker assert (false == hb_none (st, 15u));
247*2d1272b8SAndroid Build Coastguard Worker assert (true == hb_none (st, 17u));
248*2d1272b8SAndroid Build Coastguard Worker
249*2d1272b8SAndroid Build Coastguard Worker hb_array_t<hb_vector_t<int>> pa;
250*2d1272b8SAndroid Build Coastguard Worker pa->as_array ();
251*2d1272b8SAndroid Build Coastguard Worker
252*2d1272b8SAndroid Build Coastguard Worker hb_map_t m;
253*2d1272b8SAndroid Build Coastguard Worker
254*2d1272b8SAndroid Build Coastguard Worker hb_iter (st);
255*2d1272b8SAndroid Build Coastguard Worker hb_iter (&st);
256*2d1272b8SAndroid Build Coastguard Worker
257*2d1272b8SAndroid Build Coastguard Worker + hb_iter (src)
258*2d1272b8SAndroid Build Coastguard Worker | hb_map (m)
259*2d1272b8SAndroid Build Coastguard Worker | hb_map (&m)
260*2d1272b8SAndroid Build Coastguard Worker | hb_filter ()
261*2d1272b8SAndroid Build Coastguard Worker | hb_filter (st)
262*2d1272b8SAndroid Build Coastguard Worker | hb_filter (&st)
263*2d1272b8SAndroid Build Coastguard Worker | hb_filter (hb_bool)
264*2d1272b8SAndroid Build Coastguard Worker | hb_filter (hb_bool, hb_identity)
265*2d1272b8SAndroid Build Coastguard Worker | hb_sink (st)
266*2d1272b8SAndroid Build Coastguard Worker ;
267*2d1272b8SAndroid Build Coastguard Worker
268*2d1272b8SAndroid Build Coastguard Worker + hb_iter (src)
269*2d1272b8SAndroid Build Coastguard Worker | hb_sink (hb_array (dst))
270*2d1272b8SAndroid Build Coastguard Worker ;
271*2d1272b8SAndroid Build Coastguard Worker
272*2d1272b8SAndroid Build Coastguard Worker + hb_iter (src)
273*2d1272b8SAndroid Build Coastguard Worker | hb_apply (&st)
274*2d1272b8SAndroid Build Coastguard Worker ;
275*2d1272b8SAndroid Build Coastguard Worker
276*2d1272b8SAndroid Build Coastguard Worker + hb_iter (src)
277*2d1272b8SAndroid Build Coastguard Worker | hb_map ([] (int i) { return 1; })
278*2d1272b8SAndroid Build Coastguard Worker | hb_reduce ([=] (int acc, int value) { return acc; }, 2)
279*2d1272b8SAndroid Build Coastguard Worker ;
280*2d1272b8SAndroid Build Coastguard Worker
281*2d1272b8SAndroid Build Coastguard Worker using map_pair_t = hb_item_type<hb_map_t>;
282*2d1272b8SAndroid Build Coastguard Worker + hb_iter (m)
283*2d1272b8SAndroid Build Coastguard Worker | hb_map ([] (map_pair_t p) { return p.first * p.second; })
284*2d1272b8SAndroid Build Coastguard Worker ;
285*2d1272b8SAndroid Build Coastguard Worker
286*2d1272b8SAndroid Build Coastguard Worker m.keys ();
287*2d1272b8SAndroid Build Coastguard Worker using map_key_t = decltype (*m.keys());
288*2d1272b8SAndroid Build Coastguard Worker + hb_iter (m.keys ())
289*2d1272b8SAndroid Build Coastguard Worker | hb_filter ([] (map_key_t k) { return k < 42; })
290*2d1272b8SAndroid Build Coastguard Worker | hb_drain
291*2d1272b8SAndroid Build Coastguard Worker ;
292*2d1272b8SAndroid Build Coastguard Worker
293*2d1272b8SAndroid Build Coastguard Worker m.values ();
294*2d1272b8SAndroid Build Coastguard Worker using map_value_t = decltype (*m.values());
295*2d1272b8SAndroid Build Coastguard Worker + hb_iter (m.values ())
296*2d1272b8SAndroid Build Coastguard Worker | hb_filter ([] (map_value_t k) { return k < 42; })
297*2d1272b8SAndroid Build Coastguard Worker | hb_drain
298*2d1272b8SAndroid Build Coastguard Worker ;
299*2d1272b8SAndroid Build Coastguard Worker
300*2d1272b8SAndroid Build Coastguard Worker unsigned int temp1 = 10;
301*2d1272b8SAndroid Build Coastguard Worker unsigned int temp2 = 0;
302*2d1272b8SAndroid Build Coastguard Worker hb_map_t *result =
303*2d1272b8SAndroid Build Coastguard Worker + hb_iter (src)
304*2d1272b8SAndroid Build Coastguard Worker | hb_map ([&] (int i) -> hb_set_t *
305*2d1272b8SAndroid Build Coastguard Worker {
306*2d1272b8SAndroid Build Coastguard Worker hb_set_t *set = hb_set_create ();
307*2d1272b8SAndroid Build Coastguard Worker for (unsigned int i = 0; i < temp1; ++i)
308*2d1272b8SAndroid Build Coastguard Worker hb_set_add (set, i);
309*2d1272b8SAndroid Build Coastguard Worker temp1++;
310*2d1272b8SAndroid Build Coastguard Worker return set;
311*2d1272b8SAndroid Build Coastguard Worker })
312*2d1272b8SAndroid Build Coastguard Worker | hb_reduce ([&] (hb_map_t *acc, hb_set_t *value) -> hb_map_t *
313*2d1272b8SAndroid Build Coastguard Worker {
314*2d1272b8SAndroid Build Coastguard Worker hb_map_set (acc, temp2++, hb_set_get_population (value));
315*2d1272b8SAndroid Build Coastguard Worker /* This is not a memory managed language, take care! */
316*2d1272b8SAndroid Build Coastguard Worker hb_set_destroy (value);
317*2d1272b8SAndroid Build Coastguard Worker return acc;
318*2d1272b8SAndroid Build Coastguard Worker }, hb_map_create ())
319*2d1272b8SAndroid Build Coastguard Worker ;
320*2d1272b8SAndroid Build Coastguard Worker /* The result should be something like 0->10, 1->11, ..., 9->19 */
321*2d1272b8SAndroid Build Coastguard Worker assert (hb_map_get (result, 9) == 19);
322*2d1272b8SAndroid Build Coastguard Worker hb_map_destroy (result);
323*2d1272b8SAndroid Build Coastguard Worker
324*2d1272b8SAndroid Build Coastguard Worker /* Like above, but passing hb_set_t instead of hb_set_t * */
325*2d1272b8SAndroid Build Coastguard Worker temp1 = 10;
326*2d1272b8SAndroid Build Coastguard Worker temp2 = 0;
327*2d1272b8SAndroid Build Coastguard Worker result =
328*2d1272b8SAndroid Build Coastguard Worker + hb_iter (src)
329*2d1272b8SAndroid Build Coastguard Worker | hb_map ([&] (int i) -> hb_set_t
330*2d1272b8SAndroid Build Coastguard Worker {
331*2d1272b8SAndroid Build Coastguard Worker hb_set_t set;
332*2d1272b8SAndroid Build Coastguard Worker for (unsigned int i = 0; i < temp1; ++i)
333*2d1272b8SAndroid Build Coastguard Worker hb_set_add (&set, i);
334*2d1272b8SAndroid Build Coastguard Worker temp1++;
335*2d1272b8SAndroid Build Coastguard Worker return set;
336*2d1272b8SAndroid Build Coastguard Worker })
337*2d1272b8SAndroid Build Coastguard Worker | hb_reduce ([&] (hb_map_t *acc, hb_set_t value) -> hb_map_t *
338*2d1272b8SAndroid Build Coastguard Worker {
339*2d1272b8SAndroid Build Coastguard Worker hb_map_set (acc, temp2++, hb_set_get_population (&value));
340*2d1272b8SAndroid Build Coastguard Worker return acc;
341*2d1272b8SAndroid Build Coastguard Worker }, hb_map_create ())
342*2d1272b8SAndroid Build Coastguard Worker ;
343*2d1272b8SAndroid Build Coastguard Worker /* The result should be something like 0->10, 1->11, ..., 9->19 */
344*2d1272b8SAndroid Build Coastguard Worker assert (hb_map_get (result, 9) == 19);
345*2d1272b8SAndroid Build Coastguard Worker hb_map_destroy (result);
346*2d1272b8SAndroid Build Coastguard Worker
347*2d1272b8SAndroid Build Coastguard Worker unsigned int temp3 = 0;
348*2d1272b8SAndroid Build Coastguard Worker + hb_iter(src)
349*2d1272b8SAndroid Build Coastguard Worker | hb_map([&] (int i) { return ++temp3; })
350*2d1272b8SAndroid Build Coastguard Worker | hb_reduce([&] (float acc, int value) { return acc + value; }, 0)
351*2d1272b8SAndroid Build Coastguard Worker ;
352*2d1272b8SAndroid Build Coastguard Worker
353*2d1272b8SAndroid Build Coastguard Worker + hb_iter (src)
354*2d1272b8SAndroid Build Coastguard Worker | hb_drain
355*2d1272b8SAndroid Build Coastguard Worker ;
356*2d1272b8SAndroid Build Coastguard Worker
357*2d1272b8SAndroid Build Coastguard Worker t << 1;
358*2d1272b8SAndroid Build Coastguard Worker long vl;
359*2d1272b8SAndroid Build Coastguard Worker s >> vl;
360*2d1272b8SAndroid Build Coastguard Worker
361*2d1272b8SAndroid Build Coastguard Worker hb_iota ();
362*2d1272b8SAndroid Build Coastguard Worker hb_iota (3);
363*2d1272b8SAndroid Build Coastguard Worker hb_iota (3, 2);
364*2d1272b8SAndroid Build Coastguard Worker assert ((&vl) + 1 == *++hb_iota (&vl, hb_inc));
365*2d1272b8SAndroid Build Coastguard Worker hb_range ();
366*2d1272b8SAndroid Build Coastguard Worker hb_repeat (7u);
367*2d1272b8SAndroid Build Coastguard Worker hb_repeat (nullptr);
368*2d1272b8SAndroid Build Coastguard Worker hb_repeat (vl) | hb_chop (3);
369*2d1272b8SAndroid Build Coastguard Worker assert (hb_len (hb_range (10) | hb_take (3)) == 3);
370*2d1272b8SAndroid Build Coastguard Worker assert (hb_range (9).len () == 9);
371*2d1272b8SAndroid Build Coastguard Worker assert (hb_range (2, 9).len () == 7);
372*2d1272b8SAndroid Build Coastguard Worker assert (hb_range (2, 9, 3).len () == 3);
373*2d1272b8SAndroid Build Coastguard Worker assert (hb_range (2, 8, 3).len () == 2);
374*2d1272b8SAndroid Build Coastguard Worker assert (hb_range (2, 7, 3).len () == 2);
375*2d1272b8SAndroid Build Coastguard Worker assert (hb_range (-2, -9, -3).len () == 3);
376*2d1272b8SAndroid Build Coastguard Worker assert (hb_range (-2, -8, -3).len () == 2);
377*2d1272b8SAndroid Build Coastguard Worker assert (hb_range (-2, -7, -3).len () == 2);
378*2d1272b8SAndroid Build Coastguard Worker
379*2d1272b8SAndroid Build Coastguard Worker test_concat ();
380*2d1272b8SAndroid Build Coastguard Worker
381*2d1272b8SAndroid Build Coastguard Worker return 0;
382*2d1272b8SAndroid Build Coastguard Worker }
383