Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(13)

Side by Side Diff: vm/bitmap_test.cc

Issue 9701010: First step towards implementing stack map descriptions for the optimizing compiler. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/runtime/
Patch Set: Created 8 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698