| 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 "vm/bitmap.h" | 5 #include "vm/bitmap.h" |
| 6 | 6 |
| 7 #include "platform/assert.h" | 7 #include "platform/assert.h" |
| 8 #include "vm/object.h" | 8 #include "vm/object.h" |
| 9 | 9 |
| 10 namespace dart { | 10 namespace dart { |
| 11 | 11 |
| 12 bool BitmapBuilder::Get(intptr_t bit_offset) const { | 12 bool BitmapBuilder::Get(intptr_t bit_offset) const { |
| 13 if (!InRange(bit_offset)) { | 13 if (!InRange(bit_offset)) { |
| 14 return false; | 14 return false; |
| 15 } | 15 } |
| 16 return GetBit(bit_offset); | 16 return GetBit(bit_offset); |
| 17 } | 17 } |
| 18 | 18 |
| 19 | 19 |
| 20 void BitmapBuilder::Set(intptr_t bit_offset, bool value) { | 20 void BitmapBuilder::Set(intptr_t bit_offset, bool value) { |
| 21 while (!InRange(bit_offset)) { | 21 while (!InRange(bit_offset)) { |
| 22 intptr_t new_size = size_in_bytes_ + kIncrementSizeInBytes; | 22 intptr_t new_size = size_in_bytes_ + kIncrementSizeInBytes; |
| 23 ASSERT(new_size > size_in_bytes_); | 23 ASSERT(new_size > 0); |
| 24 uint8_t* new_bit_list = reinterpret_cast<uint8_t*>( | 24 uint8_t* new_bit_list = reinterpret_cast<uint8_t*>( |
| 25 Isolate::Current()->current_zone()->Allocate(new_size)); | 25 Isolate::Current()->current_zone()->Allocate(new_size)); |
| 26 ASSERT(new_bit_list != NULL); | 26 ASSERT(new_bit_list != NULL); |
| 27 ASSERT(bit_list_ != NULL); | 27 ASSERT(bit_list_ != NULL); |
| 28 uint8_t* old_bit_list = bit_list_; | 28 uint8_t* old_bit_list = bit_list_; |
| 29 memmove(new_bit_list, old_bit_list, size_in_bytes_); | 29 memmove(new_bit_list, old_bit_list, size_in_bytes_); |
| 30 memset((new_bit_list + size_in_bytes_), 0, kIncrementSizeInBytes); | 30 memset((new_bit_list + size_in_bytes_), 0, kIncrementSizeInBytes); |
| 31 size_in_bytes_ = new_size; | 31 size_in_bytes_ = new_size; |
| 32 bit_list_ = new_bit_list; | 32 bit_list_ = new_bit_list; |
| 33 } | 33 } |
| (...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 100 ASSERT(bit_list_ != NULL); | 100 ASSERT(bit_list_ != NULL); |
| 101 byte_addr = &(bit_list_[byte_offset]); | 101 byte_addr = &(bit_list_[byte_offset]); |
| 102 if (value) { | 102 if (value) { |
| 103 *byte_addr |= mask; | 103 *byte_addr |= mask; |
| 104 } else { | 104 } else { |
| 105 *byte_addr &= ~mask; | 105 *byte_addr &= ~mask; |
| 106 } | 106 } |
| 107 } | 107 } |
| 108 | 108 |
| 109 } // namespace dart | 109 } // namespace dart |
| OLD | NEW |