1*2d1272b8SAndroid Build Coastguard Worker /*
2*2d1272b8SAndroid Build Coastguard Worker * Copyright © 2021 Behdad Esfahbod
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
25*2d1272b8SAndroid Build Coastguard Worker #include "hb.hh"
26*2d1272b8SAndroid Build Coastguard Worker #include "hb-set.hh"
27*2d1272b8SAndroid Build Coastguard Worker
28*2d1272b8SAndroid Build Coastguard Worker int
main(int argc,char ** argv)29*2d1272b8SAndroid Build Coastguard Worker main (int argc, char **argv)
30*2d1272b8SAndroid Build Coastguard Worker {
31*2d1272b8SAndroid Build Coastguard Worker
32*2d1272b8SAndroid Build Coastguard Worker /* Test copy constructor. */
33*2d1272b8SAndroid Build Coastguard Worker {
34*2d1272b8SAndroid Build Coastguard Worker hb_set_t v1 {1, 2};
35*2d1272b8SAndroid Build Coastguard Worker hb_set_t v2 {v1};
36*2d1272b8SAndroid Build Coastguard Worker assert (v1.get_population () == 2);
37*2d1272b8SAndroid Build Coastguard Worker assert (hb_len (hb_iter (v1)) == 2);
38*2d1272b8SAndroid Build Coastguard Worker assert (v2.get_population () == 2);
39*2d1272b8SAndroid Build Coastguard Worker }
40*2d1272b8SAndroid Build Coastguard Worker
41*2d1272b8SAndroid Build Coastguard Worker /* Test copy assignment. */
42*2d1272b8SAndroid Build Coastguard Worker {
43*2d1272b8SAndroid Build Coastguard Worker hb_set_t v1 {1, 2};
44*2d1272b8SAndroid Build Coastguard Worker hb_set_t v2;
45*2d1272b8SAndroid Build Coastguard Worker v2 = v1;
46*2d1272b8SAndroid Build Coastguard Worker assert (v1.get_population () == 2);
47*2d1272b8SAndroid Build Coastguard Worker assert (v2.get_population () == 2);
48*2d1272b8SAndroid Build Coastguard Worker }
49*2d1272b8SAndroid Build Coastguard Worker
50*2d1272b8SAndroid Build Coastguard Worker /* Test move constructor. */
51*2d1272b8SAndroid Build Coastguard Worker {
52*2d1272b8SAndroid Build Coastguard Worker hb_set_t s {1, 2};
53*2d1272b8SAndroid Build Coastguard Worker hb_set_t v (std::move (s));
54*2d1272b8SAndroid Build Coastguard Worker assert (s.get_population () == 0);
55*2d1272b8SAndroid Build Coastguard Worker assert (hb_len (hb_iter (s)) == 0);
56*2d1272b8SAndroid Build Coastguard Worker assert (v.get_population () == 2);
57*2d1272b8SAndroid Build Coastguard Worker }
58*2d1272b8SAndroid Build Coastguard Worker
59*2d1272b8SAndroid Build Coastguard Worker /* Test move assignment. */
60*2d1272b8SAndroid Build Coastguard Worker {
61*2d1272b8SAndroid Build Coastguard Worker hb_set_t s = hb_set_t {1, 2};
62*2d1272b8SAndroid Build Coastguard Worker hb_set_t v;
63*2d1272b8SAndroid Build Coastguard Worker v = std::move (s);
64*2d1272b8SAndroid Build Coastguard Worker assert (s.get_population () == 0);
65*2d1272b8SAndroid Build Coastguard Worker assert (v.get_population () == 2);
66*2d1272b8SAndroid Build Coastguard Worker }
67*2d1272b8SAndroid Build Coastguard Worker
68*2d1272b8SAndroid Build Coastguard Worker /* Test initializing from iterable. */
69*2d1272b8SAndroid Build Coastguard Worker {
70*2d1272b8SAndroid Build Coastguard Worker hb_set_t s;
71*2d1272b8SAndroid Build Coastguard Worker
72*2d1272b8SAndroid Build Coastguard Worker s.add (18);
73*2d1272b8SAndroid Build Coastguard Worker s.add (12);
74*2d1272b8SAndroid Build Coastguard Worker
75*2d1272b8SAndroid Build Coastguard Worker hb_vector_t<hb_codepoint_t> v (s);
76*2d1272b8SAndroid Build Coastguard Worker hb_set_t v0 (v);
77*2d1272b8SAndroid Build Coastguard Worker hb_set_t v1 (s);
78*2d1272b8SAndroid Build Coastguard Worker hb_set_t v2 (std::move (s));
79*2d1272b8SAndroid Build Coastguard Worker
80*2d1272b8SAndroid Build Coastguard Worker assert (s.get_population () == 0);
81*2d1272b8SAndroid Build Coastguard Worker assert (v0.get_population () == 2);
82*2d1272b8SAndroid Build Coastguard Worker assert (v1.get_population () == 2);
83*2d1272b8SAndroid Build Coastguard Worker assert (v2.get_population () == 2);
84*2d1272b8SAndroid Build Coastguard Worker }
85*2d1272b8SAndroid Build Coastguard Worker
86*2d1272b8SAndroid Build Coastguard Worker /* Test initializing from iterator. */
87*2d1272b8SAndroid Build Coastguard Worker {
88*2d1272b8SAndroid Build Coastguard Worker hb_set_t s;
89*2d1272b8SAndroid Build Coastguard Worker
90*2d1272b8SAndroid Build Coastguard Worker s.add (18);
91*2d1272b8SAndroid Build Coastguard Worker s << 12;
92*2d1272b8SAndroid Build Coastguard Worker
93*2d1272b8SAndroid Build Coastguard Worker /* Sink a range. */
94*2d1272b8SAndroid Build Coastguard Worker s << hb_codepoint_pair_t {1, 3};
95*2d1272b8SAndroid Build Coastguard Worker
96*2d1272b8SAndroid Build Coastguard Worker hb_set_t v (hb_iter (s));
97*2d1272b8SAndroid Build Coastguard Worker
98*2d1272b8SAndroid Build Coastguard Worker assert (v.get_population () == 5);
99*2d1272b8SAndroid Build Coastguard Worker }
100*2d1272b8SAndroid Build Coastguard Worker
101*2d1272b8SAndroid Build Coastguard Worker /* Test initializing from initializer list and swapping. */
102*2d1272b8SAndroid Build Coastguard Worker {
103*2d1272b8SAndroid Build Coastguard Worker hb_set_t v1 {1, 2, 3};
104*2d1272b8SAndroid Build Coastguard Worker hb_set_t v2 {4, 5};
105*2d1272b8SAndroid Build Coastguard Worker hb_swap (v1, v2);
106*2d1272b8SAndroid Build Coastguard Worker assert (v1.get_population () == 2);
107*2d1272b8SAndroid Build Coastguard Worker assert (v2.get_population () == 3);
108*2d1272b8SAndroid Build Coastguard Worker }
109*2d1272b8SAndroid Build Coastguard Worker
110*2d1272b8SAndroid Build Coastguard Worker /* Test inverted sets. */
111*2d1272b8SAndroid Build Coastguard Worker {
112*2d1272b8SAndroid Build Coastguard Worker hb_set_t s;
113*2d1272b8SAndroid Build Coastguard Worker s.invert();
114*2d1272b8SAndroid Build Coastguard Worker s.del (5);
115*2d1272b8SAndroid Build Coastguard Worker
116*2d1272b8SAndroid Build Coastguard Worker hb_codepoint_t start = HB_SET_VALUE_INVALID, last = HB_SET_VALUE_INVALID;
117*2d1272b8SAndroid Build Coastguard Worker assert (s.next_range (&start, &last));
118*2d1272b8SAndroid Build Coastguard Worker assert (start == 0);
119*2d1272b8SAndroid Build Coastguard Worker assert (last == 4);
120*2d1272b8SAndroid Build Coastguard Worker assert (s.next_range (&start, &last));
121*2d1272b8SAndroid Build Coastguard Worker assert (start == 6);
122*2d1272b8SAndroid Build Coastguard Worker assert (last == HB_SET_VALUE_INVALID - 1);
123*2d1272b8SAndroid Build Coastguard Worker assert (!s.next_range (&start, &last));
124*2d1272b8SAndroid Build Coastguard Worker
125*2d1272b8SAndroid Build Coastguard Worker start = HB_SET_VALUE_INVALID;
126*2d1272b8SAndroid Build Coastguard Worker last = HB_SET_VALUE_INVALID;
127*2d1272b8SAndroid Build Coastguard Worker assert (s.previous_range (&start, &last));
128*2d1272b8SAndroid Build Coastguard Worker assert (start == 6);
129*2d1272b8SAndroid Build Coastguard Worker assert (last == HB_SET_VALUE_INVALID - 1);
130*2d1272b8SAndroid Build Coastguard Worker assert (s.previous_range (&start, &last));
131*2d1272b8SAndroid Build Coastguard Worker assert (start == 0);
132*2d1272b8SAndroid Build Coastguard Worker assert (last == 4);
133*2d1272b8SAndroid Build Coastguard Worker assert (!s.previous_range (&start, &last));
134*2d1272b8SAndroid Build Coastguard Worker
135*2d1272b8SAndroid Build Coastguard Worker assert (s.is_inverted ());
136*2d1272b8SAndroid Build Coastguard Worker /* Inverted set returns true for invalid value; oh well. */
137*2d1272b8SAndroid Build Coastguard Worker assert (s.has (HB_SET_VALUE_INVALID));
138*2d1272b8SAndroid Build Coastguard Worker }
139*2d1272b8SAndroid Build Coastguard Worker
140*2d1272b8SAndroid Build Coastguard Worker /* Adding HB_SET_VALUE_INVALID */
141*2d1272b8SAndroid Build Coastguard Worker {
142*2d1272b8SAndroid Build Coastguard Worker hb_set_t s;
143*2d1272b8SAndroid Build Coastguard Worker
144*2d1272b8SAndroid Build Coastguard Worker s.add(HB_SET_VALUE_INVALID);
145*2d1272b8SAndroid Build Coastguard Worker assert(!s.has(HB_SET_VALUE_INVALID));
146*2d1272b8SAndroid Build Coastguard Worker
147*2d1272b8SAndroid Build Coastguard Worker s.clear();
148*2d1272b8SAndroid Build Coastguard Worker assert(!s.add_range(HB_SET_VALUE_INVALID - 2, HB_SET_VALUE_INVALID));
149*2d1272b8SAndroid Build Coastguard Worker assert(!s.has(HB_SET_VALUE_INVALID));
150*2d1272b8SAndroid Build Coastguard Worker
151*2d1272b8SAndroid Build Coastguard Worker hb_codepoint_t array[] = {(unsigned) HB_SET_VALUE_INVALID, 0, 2};
152*2d1272b8SAndroid Build Coastguard Worker s.clear();
153*2d1272b8SAndroid Build Coastguard Worker s.add_array(array, 3);
154*2d1272b8SAndroid Build Coastguard Worker assert(!s.has(HB_SET_VALUE_INVALID));
155*2d1272b8SAndroid Build Coastguard Worker assert(s.has(2));
156*2d1272b8SAndroid Build Coastguard Worker
157*2d1272b8SAndroid Build Coastguard Worker hb_codepoint_t sorted_array[] = {0, 2, (unsigned) HB_SET_VALUE_INVALID};
158*2d1272b8SAndroid Build Coastguard Worker s.clear();
159*2d1272b8SAndroid Build Coastguard Worker s.add_sorted_array(sorted_array, 3);
160*2d1272b8SAndroid Build Coastguard Worker assert(!s.has(HB_SET_VALUE_INVALID));
161*2d1272b8SAndroid Build Coastguard Worker assert(s.has(2));
162*2d1272b8SAndroid Build Coastguard Worker }
163*2d1272b8SAndroid Build Coastguard Worker
164*2d1272b8SAndroid Build Coastguard Worker return 0;
165*2d1272b8SAndroid Build Coastguard Worker }
166