1 //===- llvm/unittest/ADT/BitVectorTest.cpp - BitVector tests --------------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 
10 // Some of these tests fail on PowerPC for unknown reasons.
11 #ifndef __ppc__
12 
13 #include "llvm/ADT/BitVector.h"
14 #include "llvm/ADT/SmallBitVector.h"
15 #include "gtest/gtest.h"
16 
17 using namespace llvm;
18 
19 namespace {
20 
21 // Test fixture
22 template <typename T>
23 class BitVectorTest : public ::testing::Test { };
24 
25 // Test both BitVector and SmallBitVector with the same suite of tests.
26 typedef ::testing::Types<BitVector, SmallBitVector> BitVectorTestTypes;
27 TYPED_TEST_CASE(BitVectorTest, BitVectorTestTypes);
28 
TYPED_TEST(BitVectorTest,TrivialOperation)29 TYPED_TEST(BitVectorTest, TrivialOperation) {
30   TypeParam Vec;
31   EXPECT_EQ(0U, Vec.count());
32   EXPECT_EQ(0U, Vec.size());
33   EXPECT_FALSE(Vec.any());
34   EXPECT_TRUE(Vec.all());
35   EXPECT_TRUE(Vec.none());
36   EXPECT_TRUE(Vec.empty());
37 
38   Vec.resize(5, true);
39   EXPECT_EQ(5U, Vec.count());
40   EXPECT_EQ(5U, Vec.size());
41   EXPECT_TRUE(Vec.any());
42   EXPECT_TRUE(Vec.all());
43   EXPECT_FALSE(Vec.none());
44   EXPECT_FALSE(Vec.empty());
45 
46   Vec.resize(11);
47   EXPECT_EQ(5U, Vec.count());
48   EXPECT_EQ(11U, Vec.size());
49   EXPECT_TRUE(Vec.any());
50   EXPECT_FALSE(Vec.all());
51   EXPECT_FALSE(Vec.none());
52   EXPECT_FALSE(Vec.empty());
53 
54   TypeParam Inv = Vec;
55   Inv.flip();
56   EXPECT_EQ(6U, Inv.count());
57   EXPECT_EQ(11U, Inv.size());
58   EXPECT_TRUE(Inv.any());
59   EXPECT_FALSE(Inv.all());
60   EXPECT_FALSE(Inv.none());
61   EXPECT_FALSE(Inv.empty());
62 
63   EXPECT_FALSE(Inv == Vec);
64   EXPECT_TRUE(Inv != Vec);
65   Vec.flip();
66   EXPECT_TRUE(Inv == Vec);
67   EXPECT_FALSE(Inv != Vec);
68 
69   // Add some "interesting" data to Vec.
70   Vec.resize(23, true);
71   Vec.resize(25, false);
72   Vec.resize(26, true);
73   Vec.resize(29, false);
74   Vec.resize(33, true);
75   Vec.resize(57, false);
76   unsigned Count = 0;
77   for (unsigned i = Vec.find_first(); i != -1u; i = Vec.find_next(i)) {
78     ++Count;
79     EXPECT_TRUE(Vec[i]);
80     EXPECT_TRUE(Vec.test(i));
81   }
82   EXPECT_EQ(Count, Vec.count());
83   EXPECT_EQ(Count, 23u);
84   EXPECT_FALSE(Vec[0]);
85   EXPECT_TRUE(Vec[32]);
86   EXPECT_FALSE(Vec[56]);
87   Vec.resize(61, false);
88 
89   TypeParam Copy = Vec;
90   TypeParam Alt(3, false);
91   Alt.resize(6, true);
92   std::swap(Alt, Vec);
93   EXPECT_TRUE(Copy == Alt);
94   EXPECT_TRUE(Vec.size() == 6);
95   EXPECT_TRUE(Vec.count() == 3);
96   EXPECT_TRUE(Vec.find_first() == 3);
97   std::swap(Copy, Vec);
98 
99   // Add some more "interesting" data.
100   Vec.resize(68, true);
101   Vec.resize(78, false);
102   Vec.resize(89, true);
103   Vec.resize(90, false);
104   Vec.resize(91, true);
105   Vec.resize(130, false);
106   Count = 0;
107   for (unsigned i = Vec.find_first(); i != -1u; i = Vec.find_next(i)) {
108     ++Count;
109     EXPECT_TRUE(Vec[i]);
110     EXPECT_TRUE(Vec.test(i));
111   }
112   EXPECT_EQ(Count, Vec.count());
113   EXPECT_EQ(Count, 42u);
114   EXPECT_FALSE(Vec[0]);
115   EXPECT_TRUE(Vec[32]);
116   EXPECT_FALSE(Vec[60]);
117   EXPECT_FALSE(Vec[129]);
118 
119   Vec.flip(60);
120   EXPECT_TRUE(Vec[60]);
121   EXPECT_EQ(Count + 1, Vec.count());
122   Vec.flip(60);
123   EXPECT_FALSE(Vec[60]);
124   EXPECT_EQ(Count, Vec.count());
125 
126   Vec.reset(32);
127   EXPECT_FALSE(Vec[32]);
128   EXPECT_EQ(Count - 1, Vec.count());
129   Vec.set(32);
130   EXPECT_TRUE(Vec[32]);
131   EXPECT_EQ(Count, Vec.count());
132 
133   Vec.flip();
134   EXPECT_EQ(Vec.size() - Count, Vec.count());
135 
136   Vec.reset();
137   EXPECT_EQ(0U, Vec.count());
138   EXPECT_EQ(130U, Vec.size());
139   EXPECT_FALSE(Vec.any());
140   EXPECT_FALSE(Vec.all());
141   EXPECT_TRUE(Vec.none());
142   EXPECT_FALSE(Vec.empty());
143 
144   Vec.flip();
145   EXPECT_EQ(130U, Vec.count());
146   EXPECT_EQ(130U, Vec.size());
147   EXPECT_TRUE(Vec.any());
148   EXPECT_TRUE(Vec.all());
149   EXPECT_FALSE(Vec.none());
150   EXPECT_FALSE(Vec.empty());
151 
152   Vec.resize(64);
153   EXPECT_EQ(64U, Vec.count());
154   EXPECT_EQ(64U, Vec.size());
155   EXPECT_TRUE(Vec.any());
156   EXPECT_TRUE(Vec.all());
157   EXPECT_FALSE(Vec.none());
158   EXPECT_FALSE(Vec.empty());
159 
160   Vec.flip();
161   EXPECT_EQ(0U, Vec.count());
162   EXPECT_EQ(64U, Vec.size());
163   EXPECT_FALSE(Vec.any());
164   EXPECT_FALSE(Vec.all());
165   EXPECT_TRUE(Vec.none());
166   EXPECT_FALSE(Vec.empty());
167 
168   Inv = TypeParam().flip();
169   EXPECT_EQ(0U, Inv.count());
170   EXPECT_EQ(0U, Inv.size());
171   EXPECT_FALSE(Inv.any());
172   EXPECT_TRUE(Inv.all());
173   EXPECT_TRUE(Inv.none());
174   EXPECT_TRUE(Inv.empty());
175 
176   Vec.clear();
177   EXPECT_EQ(0U, Vec.count());
178   EXPECT_EQ(0U, Vec.size());
179   EXPECT_FALSE(Vec.any());
180   EXPECT_TRUE(Vec.all());
181   EXPECT_TRUE(Vec.none());
182   EXPECT_TRUE(Vec.empty());
183 }
184 
TYPED_TEST(BitVectorTest,SimpleFindOps)185 TYPED_TEST(BitVectorTest, SimpleFindOps) {
186   // Test finding in an empty BitVector.
187   TypeParam A;
188   EXPECT_EQ(-1, A.find_first());
189   EXPECT_EQ(-1, A.find_last());
190   EXPECT_EQ(-1, A.find_first_unset());
191   EXPECT_EQ(-1, A.find_last_unset());
192 
193   // Test finding next set and unset bits in a BitVector with multiple words
194   A.resize(100);
195   A.set(12);
196   A.set(13);
197   A.set(75);
198 
199   EXPECT_EQ(75, A.find_last());
200   EXPECT_EQ(12, A.find_first());
201   EXPECT_EQ(13, A.find_next(12));
202   EXPECT_EQ(75, A.find_next(13));
203   EXPECT_EQ(-1, A.find_next(75));
204 
205   EXPECT_EQ(-1, A.find_prev(12));
206   EXPECT_EQ(12, A.find_prev(13));
207   EXPECT_EQ(13, A.find_prev(75));
208   EXPECT_EQ(75, A.find_prev(90));
209 
210   EXPECT_EQ(0, A.find_first_unset());
211   EXPECT_EQ(99, A.find_last_unset());
212   EXPECT_EQ(14, A.find_next_unset(11));
213   EXPECT_EQ(14, A.find_next_unset(12));
214   EXPECT_EQ(14, A.find_next_unset(13));
215   EXPECT_EQ(16, A.find_next_unset(15));
216   EXPECT_EQ(76, A.find_next_unset(74));
217   EXPECT_EQ(76, A.find_next_unset(75));
218   EXPECT_EQ(-1, A.find_next_unset(99));
219 
220   A.set(0, 100);
221   EXPECT_EQ(100U, A.count());
222   EXPECT_EQ(0, A.find_first());
223   EXPECT_EQ(-1, A.find_first_unset());
224   EXPECT_EQ(-1, A.find_last_unset());
225   EXPECT_EQ(99, A.find_last());
226   EXPECT_EQ(99, A.find_next(98));
227 
228   A.reset(0, 100);
229   EXPECT_EQ(0U, A.count());
230   EXPECT_EQ(-1, A.find_first());
231   EXPECT_EQ(-1, A.find_last());
232   EXPECT_EQ(0, A.find_first_unset());
233   EXPECT_EQ(99, A.find_last_unset());
234   EXPECT_EQ(99, A.find_next_unset(98));
235 
236   // Also test with a vector that is small enough to fit in 1 word.
237   A.resize(20);
238   A.set(3);
239   A.set(4);
240   A.set(16);
241   EXPECT_EQ(16, A.find_last());
242   EXPECT_EQ(3, A.find_first());
243   EXPECT_EQ(3, A.find_next(1));
244   EXPECT_EQ(4, A.find_next(3));
245   EXPECT_EQ(16, A.find_next(4));
246   EXPECT_EQ(-1, A.find_next(16));
247 
248   EXPECT_EQ(-1, A.find_prev(3));
249   EXPECT_EQ(3, A.find_prev(4));
250   EXPECT_EQ(4, A.find_prev(16));
251   EXPECT_EQ(16, A.find_prev(18));
252 
253   EXPECT_EQ(0, A.find_first_unset());
254   EXPECT_EQ(19, A.find_last_unset());
255   EXPECT_EQ(5, A.find_next_unset(3));
256   EXPECT_EQ(5, A.find_next_unset(4));
257   EXPECT_EQ(13, A.find_next_unset(12));
258   EXPECT_EQ(17, A.find_next_unset(15));
259 }
260 
TEST(BitVectorTest,FindInRangeMultiWord)261 TEST(BitVectorTest, FindInRangeMultiWord) {
262   BitVector Vec;
263 
264   Vec.resize(200);
265   Vec.set(3, 7);
266   Vec.set(24, 35);
267   Vec.set(50, 70);
268   Vec.set(150);
269   Vec.set(152);
270   Vec.set(154);
271 
272   // find first
273   EXPECT_EQ(-1, Vec.find_first_in(0, 0));
274   EXPECT_EQ(-1, Vec.find_first_in(24, 24));
275   EXPECT_EQ(-1, Vec.find_first_in(7, 24));
276 
277   EXPECT_EQ(3, Vec.find_first_in(0, 10));
278   EXPECT_EQ(4, Vec.find_first_in(4, 10));
279   EXPECT_EQ(150, Vec.find_first_in(100, 200));
280   EXPECT_EQ(152, Vec.find_first_in(151, 200));
281   EXPECT_EQ(154, Vec.find_first_in(153, 200));
282 
283   EXPECT_EQ(-1, Vec.find_first_in(155, 200));
284   Vec.set(199);
285   EXPECT_EQ(199, Vec.find_first_in(199, 200));
286   Vec.reset(199);
287 
288   // find last
289   EXPECT_EQ(-1, Vec.find_last_in(0, 0));
290   EXPECT_EQ(-1, Vec.find_last_in(24, 24));
291   EXPECT_EQ(-1, Vec.find_last_in(7, 24));
292 
293   EXPECT_EQ(6, Vec.find_last_in(0, 10));
294   EXPECT_EQ(5, Vec.find_last_in(0, 6));
295   EXPECT_EQ(154, Vec.find_last_in(100, 155));
296   EXPECT_EQ(152, Vec.find_last_in(100, 154));
297   EXPECT_EQ(150, Vec.find_last_in(100, 152));
298   EXPECT_EQ(-1, Vec.find_last_in(100, 150));
299   Vec.set(199);
300   EXPECT_EQ(199, Vec.find_last_in(199, 200));
301   Vec.reset(199);
302 
303   // find first unset
304   EXPECT_EQ(-1, Vec.find_first_unset_in(0, 0));
305   EXPECT_EQ(-1, Vec.find_first_unset_in(23, 23));
306   EXPECT_EQ(-1, Vec.find_first_unset_in(24, 35));
307 
308   EXPECT_EQ(0, Vec.find_first_unset_in(0, 10));
309   EXPECT_EQ(1, Vec.find_first_unset_in(1, 10));
310   EXPECT_EQ(7, Vec.find_first_unset_in(5, 25));
311   EXPECT_EQ(151, Vec.find_first_unset_in(150, 200));
312   EXPECT_EQ(151, Vec.find_first_unset_in(151, 200));
313   EXPECT_EQ(153, Vec.find_first_unset_in(152, 200));
314   EXPECT_EQ(153, Vec.find_first_unset_in(153, 200));
315   EXPECT_EQ(155, Vec.find_first_unset_in(154, 200));
316   EXPECT_EQ(155, Vec.find_first_unset_in(155, 200));
317   EXPECT_EQ(199, Vec.find_first_unset_in(199, 200));
318 
319   // find last unset
320   EXPECT_EQ(-1, Vec.find_last_unset_in(0, 0));
321   EXPECT_EQ(-1, Vec.find_last_unset_in(23, 23));
322   EXPECT_EQ(-1, Vec.find_last_unset_in(24, 35));
323 
324   EXPECT_EQ(9, Vec.find_last_unset_in(0, 10));
325   EXPECT_EQ(8, Vec.find_last_unset_in(0, 9));
326   EXPECT_EQ(2, Vec.find_last_unset_in(0, 7));
327   EXPECT_EQ(149, Vec.find_last_unset_in(100, 151));
328   EXPECT_EQ(151, Vec.find_last_unset_in(100, 152));
329   EXPECT_EQ(151, Vec.find_last_unset_in(100, 153));
330   EXPECT_EQ(153, Vec.find_last_unset_in(100, 154));
331   EXPECT_EQ(153, Vec.find_last_unset_in(100, 155));
332   EXPECT_EQ(155, Vec.find_last_unset_in(100, 156));
333   EXPECT_EQ(199, Vec.find_last_unset_in(199, 200));
334 }
335 
TEST(BitVectorTest,FindInRangeSingleWord)336 TEST(BitVectorTest, FindInRangeSingleWord) {
337   // When the bit vector contains only a single word, this is slightly different
338   // than when the bit vector contains multiple words, because masks are applied
339   // to the front and back of the same word.  So make sure this works.
340   BitVector Vec;
341 
342   Vec.resize(25);
343   Vec.set(2, 4);
344   Vec.set(6, 9);
345   Vec.set(12, 15);
346   Vec.set(19);
347   Vec.set(21);
348   Vec.set(23);
349 
350   // find first
351   EXPECT_EQ(-1, Vec.find_first_in(0, 0));
352   EXPECT_EQ(-1, Vec.find_first_in(24, 24));
353   EXPECT_EQ(-1, Vec.find_first_in(9, 12));
354 
355   EXPECT_EQ(2, Vec.find_first_in(0, 10));
356   EXPECT_EQ(6, Vec.find_first_in(4, 10));
357   EXPECT_EQ(19, Vec.find_first_in(18, 25));
358   EXPECT_EQ(21, Vec.find_first_in(20, 25));
359   EXPECT_EQ(23, Vec.find_first_in(22, 25));
360   EXPECT_EQ(-1, Vec.find_first_in(24, 25));
361 
362   // find last
363   EXPECT_EQ(-1, Vec.find_last_in(0, 0));
364   EXPECT_EQ(-1, Vec.find_last_in(24, 24));
365   EXPECT_EQ(-1, Vec.find_last_in(9, 12));
366 
367   EXPECT_EQ(8, Vec.find_last_in(0, 10));
368   EXPECT_EQ(3, Vec.find_last_in(0, 6));
369   EXPECT_EQ(23, Vec.find_last_in(18, 25));
370   EXPECT_EQ(21, Vec.find_last_in(18, 23));
371   EXPECT_EQ(19, Vec.find_last_in(18, 21));
372   EXPECT_EQ(-1, Vec.find_last_in(18, 19));
373 
374   // find first unset
375   EXPECT_EQ(-1, Vec.find_first_unset_in(0, 0));
376   EXPECT_EQ(-1, Vec.find_first_unset_in(23, 23));
377   EXPECT_EQ(-1, Vec.find_first_unset_in(6, 9));
378 
379   EXPECT_EQ(0, Vec.find_first_unset_in(0, 6));
380   EXPECT_EQ(1, Vec.find_first_unset_in(1, 6));
381   EXPECT_EQ(9, Vec.find_first_unset_in(7, 13));
382   EXPECT_EQ(18, Vec.find_first_unset_in(18, 25));
383   EXPECT_EQ(20, Vec.find_first_unset_in(19, 25));
384   EXPECT_EQ(20, Vec.find_first_unset_in(20, 25));
385   EXPECT_EQ(22, Vec.find_first_unset_in(21, 25));
386   EXPECT_EQ(22, Vec.find_first_unset_in(22, 25));
387   EXPECT_EQ(24, Vec.find_first_unset_in(23, 25));
388   EXPECT_EQ(24, Vec.find_first_unset_in(24, 25));
389 
390   // find last unset
391   EXPECT_EQ(-1, Vec.find_last_unset_in(0, 0));
392   EXPECT_EQ(-1, Vec.find_last_unset_in(23, 23));
393   EXPECT_EQ(-1, Vec.find_last_unset_in(6, 9));
394 
395   EXPECT_EQ(5, Vec.find_last_unset_in(0, 6));
396   EXPECT_EQ(4, Vec.find_last_unset_in(0, 5));
397   EXPECT_EQ(1, Vec.find_last_unset_in(0, 4));
398   EXPECT_EQ(11, Vec.find_last_unset_in(7, 13));
399   EXPECT_EQ(24, Vec.find_last_unset_in(18, 25));
400   EXPECT_EQ(22, Vec.find_last_unset_in(18, 24));
401   EXPECT_EQ(22, Vec.find_last_unset_in(18, 23));
402   EXPECT_EQ(20, Vec.find_last_unset_in(18, 22));
403   EXPECT_EQ(20, Vec.find_last_unset_in(18, 21));
404   EXPECT_EQ(18, Vec.find_last_unset_in(18, 20));
405   EXPECT_EQ(18, Vec.find_last_unset_in(18, 19));
406 }
407 
TYPED_TEST(BitVectorTest,CompoundAssignment)408 TYPED_TEST(BitVectorTest, CompoundAssignment) {
409   TypeParam A;
410   A.resize(10);
411   A.set(4);
412   A.set(7);
413 
414   TypeParam B;
415   B.resize(50);
416   B.set(5);
417   B.set(18);
418 
419   A |= B;
420   EXPECT_TRUE(A.test(4));
421   EXPECT_TRUE(A.test(5));
422   EXPECT_TRUE(A.test(7));
423   EXPECT_TRUE(A.test(18));
424   EXPECT_EQ(4U, A.count());
425   EXPECT_EQ(50U, A.size());
426 
427   B.resize(10);
428   B.set();
429   B.reset(2);
430   B.reset(7);
431   A &= B;
432   EXPECT_FALSE(A.test(2));
433   EXPECT_FALSE(A.test(7));
434   EXPECT_EQ(2U, A.count());
435   EXPECT_EQ(50U, A.size());
436 
437   B.resize(100);
438   B.set();
439 
440   A ^= B;
441   EXPECT_TRUE(A.test(2));
442   EXPECT_TRUE(A.test(7));
443   EXPECT_EQ(98U, A.count());
444   EXPECT_EQ(100U, A.size());
445 }
446 
TYPED_TEST(BitVectorTest,ProxyIndex)447 TYPED_TEST(BitVectorTest, ProxyIndex) {
448   TypeParam Vec(3);
449   EXPECT_TRUE(Vec.none());
450   Vec[0] = Vec[1] = Vec[2] = true;
451   EXPECT_EQ(Vec.size(), Vec.count());
452   Vec[2] = Vec[1] = Vec[0] = false;
453   EXPECT_TRUE(Vec.none());
454 }
455 
TYPED_TEST(BitVectorTest,PortableBitMask)456 TYPED_TEST(BitVectorTest, PortableBitMask) {
457   TypeParam A;
458   const uint32_t Mask1[] = { 0x80000000, 6, 5 };
459 
460   A.resize(10);
461   A.setBitsInMask(Mask1, 1);
462   EXPECT_EQ(10u, A.size());
463   EXPECT_FALSE(A.test(0));
464 
465   A.resize(32);
466   A.setBitsInMask(Mask1, 1);
467   EXPECT_FALSE(A.test(0));
468   EXPECT_TRUE(A.test(31));
469   EXPECT_EQ(1u, A.count());
470 
471   A.resize(33);
472   A.setBitsInMask(Mask1, 1);
473   EXPECT_EQ(1u, A.count());
474   A.setBitsInMask(Mask1, 2);
475   EXPECT_EQ(1u, A.count());
476 
477   A.resize(34);
478   A.setBitsInMask(Mask1, 2);
479   EXPECT_EQ(2u, A.count());
480 
481   A.resize(65);
482   A.setBitsInMask(Mask1, 3);
483   EXPECT_EQ(4u, A.count());
484 
485   A.setBitsNotInMask(Mask1, 1);
486   EXPECT_EQ(32u+3u, A.count());
487 
488   A.setBitsNotInMask(Mask1, 3);
489   EXPECT_EQ(65u, A.count());
490 
491   A.resize(96);
492   EXPECT_EQ(65u, A.count());
493 
494   A.clear();
495   A.resize(128);
496   A.setBitsNotInMask(Mask1, 3);
497   EXPECT_EQ(96u-5u, A.count());
498 
499   A.clearBitsNotInMask(Mask1, 1);
500   EXPECT_EQ(64-4u, A.count());
501 }
502 
TYPED_TEST(BitVectorTest,BinOps)503 TYPED_TEST(BitVectorTest, BinOps) {
504   TypeParam A;
505   TypeParam B;
506 
507   A.resize(65);
508   EXPECT_FALSE(A.anyCommon(B));
509   EXPECT_FALSE(B.anyCommon(B));
510 
511   B.resize(64);
512   A.set(64);
513   EXPECT_FALSE(A.anyCommon(B));
514   EXPECT_FALSE(B.anyCommon(A));
515 
516   B.set(63);
517   EXPECT_FALSE(A.anyCommon(B));
518   EXPECT_FALSE(B.anyCommon(A));
519 
520   A.set(63);
521   EXPECT_TRUE(A.anyCommon(B));
522   EXPECT_TRUE(B.anyCommon(A));
523 
524   B.resize(70);
525   B.set(64);
526   B.reset(63);
527   A.resize(64);
528   EXPECT_FALSE(A.anyCommon(B));
529   EXPECT_FALSE(B.anyCommon(A));
530 }
531 
532 typedef std::vector<std::pair<int, int>> RangeList;
533 
534 template <typename VecType>
createBitVector(uint32_t Size,const RangeList & setRanges)535 static inline VecType createBitVector(uint32_t Size,
536                                       const RangeList &setRanges) {
537   VecType V;
538   V.resize(Size);
539   for (auto &R : setRanges)
540     V.set(R.first, R.second);
541   return V;
542 }
543 
TYPED_TEST(BitVectorTest,ShiftOpsSingleWord)544 TYPED_TEST(BitVectorTest, ShiftOpsSingleWord) {
545   // Test that shift ops work when the desired shift amount is less
546   // than one word.
547 
548   // 1. Case where the number of bits in the BitVector also fit into a single
549   // word.
550   TypeParam A = createBitVector<TypeParam>(12, {{2, 4}, {8, 10}});
551   TypeParam B = A;
552 
553   EXPECT_EQ(4U, A.count());
554   EXPECT_TRUE(A.test(2));
555   EXPECT_TRUE(A.test(3));
556   EXPECT_TRUE(A.test(8));
557   EXPECT_TRUE(A.test(9));
558 
559   A >>= 1;
560   EXPECT_EQ(createBitVector<TypeParam>(12, {{1, 3}, {7, 9}}), A);
561 
562   A <<= 1;
563   EXPECT_EQ(B, A);
564 
565   A >>= 10;
566   EXPECT_EQ(createBitVector<TypeParam>(12, {}), A);
567 
568   A = B;
569   A <<= 10;
570   EXPECT_EQ(createBitVector<TypeParam>(12, {}), A);
571 
572   // 2. Case where the number of bits in the BitVector do not fit into a single
573   // word.
574 
575   // 31----------------------------------------------------------------------0
576   // XXXXXXXX XXXXXXXX XXXXXXXX 00000111 | 11111110 00000000 00001111 11111111
577   A = createBitVector<TypeParam>(40, {{0, 12}, {25, 35}});
578   EXPECT_EQ(40U, A.size());
579   EXPECT_EQ(22U, A.count());
580 
581   // 2a. Make sure that left shifting some 1 bits out of the vector works.
582   //   31----------------------------------------------------------------------0
583   // Before:
584   //   XXXXXXXX XXXXXXXX XXXXXXXX 00000111 | 11111110 00000000 00001111 11111111
585   // After:
586   //   XXXXXXXX XXXXXXXX XXXXXXXX 11111100 | 00000000 00011111 11111110 00000000
587   A <<= 9;
588   EXPECT_EQ(createBitVector<TypeParam>(40, {{9, 21}, {34, 40}}), A);
589 
590   // 2b. Make sure that keeping the number of one bits unchanged works.
591   //   31----------------------------------------------------------------------0
592   // Before:
593   //   XXXXXXXX XXXXXXXX XXXXXXXX 11111100 | 00000000 00011111 11111110 00000000
594   // After:
595   //   XXXXXXXX XXXXXXXX XXXXXXXX 00000011 | 11110000 00000000 01111111 11111000
596   A >>= 6;
597   EXPECT_EQ(createBitVector<TypeParam>(40, {{3, 15}, {28, 34}}), A);
598 
599   // 2c. Make sure that right shifting some 1 bits out of the vector works.
600   //   31----------------------------------------------------------------------0
601   // Before:
602   //   XXXXXXXX XXXXXXXX XXXXXXXX 00000011 | 11110000 00000000 01111111 11111000
603   // After:
604   //   XXXXXXXX XXXXXXXX XXXXXXXX 00000000 | 00000000 11111100 00000000 00011111
605   A >>= 10;
606   EXPECT_EQ(createBitVector<TypeParam>(40, {{0, 5}, {18, 24}}), A);
607 
608   // 3. Big test.
609   A = createBitVector<TypeParam>(300, {{1, 30}, {60, 95}, {200, 275}});
610   A <<= 29;
611   EXPECT_EQ(createBitVector<TypeParam>(
612                 300, {{1 + 29, 30 + 29}, {60 + 29, 95 + 29}, {200 + 29, 300}}),
613             A);
614 }
615 
TYPED_TEST(BitVectorTest,ShiftOpsMultiWord)616 TYPED_TEST(BitVectorTest, ShiftOpsMultiWord) {
617   // Test that shift ops work when the desired shift amount is greater than or
618   // equal to the size of a single word.
619   auto A = createBitVector<TypeParam>(300, {{1, 30}, {60, 95}, {200, 275}});
620 
621   // Make a copy so we can re-use it later.
622   auto B = A;
623 
624   // 1. Shift left by an exact multiple of the word size.  This should invoke
625   // only a memmove and no per-word bit operations.
626   A <<= 64;
627   auto Expected = createBitVector<TypeParam>(
628       300, {{1 + 64, 30 + 64}, {60 + 64, 95 + 64}, {200 + 64, 300}});
629   EXPECT_EQ(Expected, A);
630 
631   // 2. Shift left by a non multiple of the word size.  This should invoke both
632   // a memmove and per-word bit operations.
633   A = B;
634   A <<= 93;
635   EXPECT_EQ(createBitVector<TypeParam>(
636                 300, {{1 + 93, 30 + 93}, {60 + 93, 95 + 93}, {200 + 93, 300}}),
637             A);
638 
639   // 1. Shift right by an exact multiple of the word size.  This should invoke
640   // only a memmove and no per-word bit operations.
641   A = B;
642   A >>= 64;
643   EXPECT_EQ(
644       createBitVector<TypeParam>(300, {{0, 95 - 64}, {200 - 64, 275 - 64}}), A);
645 
646   // 2. Shift left by a non multiple of the word size.  This should invoke both
647   // a memmove and per-word bit operations.
648   A = B;
649   A >>= 93;
650   EXPECT_EQ(
651       createBitVector<TypeParam>(300, {{0, 95 - 93}, {200 - 93, 275 - 93}}), A);
652 }
653 
TYPED_TEST(BitVectorTest,RangeOps)654 TYPED_TEST(BitVectorTest, RangeOps) {
655   TypeParam A;
656   A.resize(256);
657   A.reset();
658   A.set(1, 255);
659 
660   EXPECT_FALSE(A.test(0));
661   EXPECT_TRUE( A.test(1));
662   EXPECT_TRUE( A.test(23));
663   EXPECT_TRUE( A.test(254));
664   EXPECT_FALSE(A.test(255));
665 
666   TypeParam B;
667   B.resize(256);
668   B.set();
669   B.reset(1, 255);
670 
671   EXPECT_TRUE( B.test(0));
672   EXPECT_FALSE(B.test(1));
673   EXPECT_FALSE(B.test(23));
674   EXPECT_FALSE(B.test(254));
675   EXPECT_TRUE( B.test(255));
676 
677   TypeParam C;
678   C.resize(3);
679   C.reset();
680   C.set(0, 1);
681 
682   EXPECT_TRUE(C.test(0));
683   EXPECT_FALSE( C.test(1));
684   EXPECT_FALSE( C.test(2));
685 
686   TypeParam D;
687   D.resize(3);
688   D.set();
689   D.reset(0, 1);
690 
691   EXPECT_FALSE(D.test(0));
692   EXPECT_TRUE( D.test(1));
693   EXPECT_TRUE( D.test(2));
694 
695   TypeParam E;
696   E.resize(128);
697   E.reset();
698   E.set(1, 33);
699 
700   EXPECT_FALSE(E.test(0));
701   EXPECT_TRUE( E.test(1));
702   EXPECT_TRUE( E.test(32));
703   EXPECT_FALSE(E.test(33));
704 
705   TypeParam BufferOverrun;
706   unsigned size = sizeof(unsigned long) * 8;
707   BufferOverrun.resize(size);
708   BufferOverrun.reset(0, size);
709   BufferOverrun.set(0, size);
710 }
711 
TYPED_TEST(BitVectorTest,CompoundTestReset)712 TYPED_TEST(BitVectorTest, CompoundTestReset) {
713   TypeParam A(50, true);
714   TypeParam B(50, false);
715 
716   TypeParam C(100, true);
717   TypeParam D(100, false);
718 
719   EXPECT_FALSE(A.test(A));
720   EXPECT_TRUE(A.test(B));
721   EXPECT_FALSE(A.test(C));
722   EXPECT_TRUE(A.test(D));
723   EXPECT_FALSE(B.test(A));
724   EXPECT_FALSE(B.test(B));
725   EXPECT_FALSE(B.test(C));
726   EXPECT_FALSE(B.test(D));
727   EXPECT_TRUE(C.test(A));
728   EXPECT_TRUE(C.test(B));
729   EXPECT_FALSE(C.test(C));
730   EXPECT_TRUE(C.test(D));
731 
732   A.reset(B);
733   A.reset(D);
734   EXPECT_TRUE(A.all());
735   A.reset(A);
736   EXPECT_TRUE(A.none());
737   A.set();
738   A.reset(C);
739   EXPECT_TRUE(A.none());
740   A.set();
741 
742   C.reset(A);
743   EXPECT_EQ(50, C.find_first());
744   C.reset(C);
745   EXPECT_TRUE(C.none());
746 }
747 
TYPED_TEST(BitVectorTest,MoveConstructor)748 TYPED_TEST(BitVectorTest, MoveConstructor) {
749   TypeParam A(10, true);
750   TypeParam B(std::move(A));
751   // Check that the move ctor leaves the moved-from object in a valid state.
752   // The following line used to crash.
753   A = B;
754 
755   TypeParam C(10, true);
756   EXPECT_EQ(C, A);
757   EXPECT_EQ(C, B);
758 }
759 
TYPED_TEST(BitVectorTest,MoveAssignment)760 TYPED_TEST(BitVectorTest, MoveAssignment) {
761   TypeParam A(10, true);
762   TypeParam B;
763   B = std::move(A);
764   // Check that move assignment leaves the moved-from object in a valid state.
765   // The following line used to crash.
766   A = B;
767 
768   TypeParam C(10, true);
769   EXPECT_EQ(C, A);
770   EXPECT_EQ(C, B);
771 }
772 
773 template<class TypeParam>
testEmpty(const TypeParam & A)774 static void testEmpty(const TypeParam &A) {
775   EXPECT_TRUE(A.empty());
776   EXPECT_EQ((size_t)0, A.size());
777   EXPECT_EQ((size_t)0, A.count());
778   EXPECT_FALSE(A.any());
779   EXPECT_TRUE(A.all());
780   EXPECT_TRUE(A.none());
781   EXPECT_EQ(-1, A.find_first());
782   EXPECT_EQ(A, TypeParam());
783 }
784 
785 /// Tests whether BitVector behaves well with Bits==nullptr, Capacity==0
TYPED_TEST(BitVectorTest,EmptyVector)786 TYPED_TEST(BitVectorTest, EmptyVector) {
787   TypeParam A;
788   testEmpty(A);
789 
790   TypeParam B;
791   B.reset();
792   testEmpty(B);
793 
794   TypeParam C;
795   C.clear();
796   testEmpty(C);
797 
798   TypeParam D(A);
799   testEmpty(D);
800 
801   TypeParam E;
802   E = A;
803   testEmpty(E);
804 
805   TypeParam F;
806   E.reset(A);
807   testEmpty(E);
808 }
809 
TYPED_TEST(BitVectorTest,Iterators)810 TYPED_TEST(BitVectorTest, Iterators) {
811   TypeParam Filled(10, true);
812   EXPECT_NE(Filled.set_bits_begin(), Filled.set_bits_end());
813   unsigned Counter = 0;
814   for (unsigned Bit : Filled.set_bits())
815     EXPECT_EQ(Bit, Counter++);
816 
817   TypeParam Empty;
818   EXPECT_EQ(Empty.set_bits_begin(), Empty.set_bits_end());
819   for (unsigned Bit : Empty.set_bits()) {
820     (void)Bit;
821     EXPECT_TRUE(false);
822   }
823 
824   TypeParam ToFill(100, false);
825   ToFill.set(0);
826   EXPECT_NE(ToFill.set_bits_begin(), ToFill.set_bits_end());
827   EXPECT_EQ(++ToFill.set_bits_begin(), ToFill.set_bits_end());
828   EXPECT_EQ(*ToFill.set_bits_begin(), 0U);
829   ToFill.reset(0);
830   EXPECT_EQ(ToFill.set_bits_begin(), ToFill.set_bits_end());
831 
832   const unsigned List[] = {1, 10, 25, 99};
833   for (unsigned Num : List)
834     ToFill.set(Num);
835   unsigned i = 0;
836   for (unsigned Bit : ToFill.set_bits())
837     EXPECT_EQ(List[i++], Bit);
838 }
839 }
840 #endif
841