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