OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. |
| 4 |
| 5 #include "platform/assert.h" |
| 6 #include "vm/bitmap.h" |
| 7 #include "vm/object.h" |
| 8 #include "vm/unit_test.h" |
| 9 |
| 10 namespace dart { |
| 11 |
| 12 TEST_CASE(BitmapBuilder) { |
| 13 // Test basic bit map builder operations. |
| 14 BitmapBuilder* bmap1_builder = new BitmapBuilder(); |
| 15 |
| 16 EXPECT_EQ(-1, bmap1_builder->Maximum()); |
| 17 EXPECT_EQ(-1, bmap1_builder->Minimum()); |
| 18 |
| 19 bool value = true; |
| 20 for (int32_t i = 0; i < 128; i++) { |
| 21 bmap1_builder->Set(i, value); |
| 22 value = !value; |
| 23 } |
| 24 value = true; |
| 25 for (int32_t i = 0; i < 128; i++) { |
| 26 EXPECT_EQ(value, bmap1_builder->Get(i)); |
| 27 value = !value; |
| 28 } |
| 29 value = true; |
| 30 for (int32_t i = 0; i < 1024; i++) { |
| 31 bmap1_builder->Set(i, value); |
| 32 value = !value; |
| 33 } |
| 34 value = true; |
| 35 for (int32_t i = 0; i < 1024; i++) { |
| 36 EXPECT_EQ(value, bmap1_builder->Get(i)); |
| 37 value = !value; |
| 38 } |
| 39 // Create a Bitmap object from the builder and verify it's contents. |
| 40 const Bitmap& bmap1 = Bitmap::Handle(bmap1_builder->GetBitmap()); |
| 41 EXPECT_EQ(1022, bmap1.Maximum()); |
| 42 EXPECT_EQ(0, bmap1.Minimum()); |
| 43 OS::Print("%s\n", bmap1.ToCString()); |
| 44 value = true; |
| 45 for (int32_t i = 0; i < 1024; i++) { |
| 46 EXPECT_EQ(value, bmap1.Get(i)); |
| 47 value = !value; |
| 48 } |
| 49 EXPECT(!bmap1.Get(2056)); // Out of range so returns false. |
| 50 |
| 51 // Test the SetRange function in the builder. |
| 52 bmap1_builder->SetRange(0, 256, false); |
| 53 bmap1_builder->SetRange(257, 1024, true); |
| 54 bmap1_builder->SetRange(1025, 2048, false); |
| 55 for (int32_t i = 0; i <= 256; i++) { |
| 56 EXPECT(!bmap1_builder->Get(i)); |
| 57 } |
| 58 for (int32_t i = 257; i <= 1024; i++) { |
| 59 EXPECT(bmap1_builder->Get(i)); |
| 60 } |
| 61 for (int32_t i = 1025; i <= 2048; i++) { |
| 62 EXPECT(!bmap1_builder->Get(i)); |
| 63 } |
| 64 const Bitmap& bmap2 = Bitmap::Handle(bmap1_builder->GetBitmap()); |
| 65 EXPECT_EQ(1024, bmap2.Maximum()); |
| 66 EXPECT_EQ(257, bmap2.Minimum()); |
| 67 for (int32_t i = 0; i <= 256; i++) { |
| 68 EXPECT(!bmap2.Get(i)); |
| 69 } |
| 70 for (int32_t i = 257; i <= 1024; i++) { |
| 71 EXPECT(bmap2.Get(i)); |
| 72 } |
| 73 for (int32_t i = 1025; i <= 2048; i++) { |
| 74 EXPECT(!bmap2.Get(i)); |
| 75 } |
| 76 |
| 77 // Test the functionality to copy a Bitmap object into a builder. |
| 78 BitmapBuilder* bmap2_builder = new BitmapBuilder(); |
| 79 bmap2_builder->SetBits(bmap1); |
| 80 EXPECT_EQ(1022, bmap2_builder->Maximum()); |
| 81 EXPECT_EQ(0, bmap2_builder->Minimum()); |
| 82 value = true; |
| 83 for (int32_t i = 0; i < 1024; i++) { |
| 84 EXPECT_EQ(value, bmap2_builder->Get(i)); |
| 85 value = !value; |
| 86 } |
| 87 |
| 88 BitmapBuilder* bmap3_builder = new BitmapBuilder(); |
| 89 bmap3_builder->SetBits(bmap2); |
| 90 EXPECT_EQ(1024, bmap3_builder->Maximum()); |
| 91 EXPECT_EQ(257, bmap3_builder->Minimum()); |
| 92 for (int32_t i = 0; i <= 256; i++) { |
| 93 EXPECT(!bmap3_builder->Get(i)); |
| 94 } |
| 95 for (int32_t i = 257; i <= 1024; i++) { |
| 96 EXPECT(bmap3_builder->Get(i)); |
| 97 } |
| 98 for (int32_t i = 1025; i <= 2048; i++) { |
| 99 EXPECT(!bmap3_builder->Get(i)); |
| 100 } |
| 101 } |
| 102 |
| 103 } // namespace dart |
OLD | NEW |