OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/elements.h" | 5 #include "src/elements.h" |
6 | 6 |
7 #include "src/arguments.h" | 7 #include "src/arguments.h" |
8 #include "src/conversions.h" | 8 #include "src/conversions.h" |
9 #include "src/factory.h" | 9 #include "src/factory.h" |
10 #include "src/messages.h" | 10 #include "src/messages.h" |
(...skipping 687 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
698 } | 698 } |
699 } | 699 } |
700 | 700 |
701 // Check whether the backing store should be shrunk. | 701 // Check whether the backing store should be shrunk. |
702 uint32_t capacity = backing_store->length(); | 702 uint32_t capacity = backing_store->length(); |
703 old_length = Min(old_length, capacity); | 703 old_length = Min(old_length, capacity); |
704 if (length == 0) { | 704 if (length == 0) { |
705 array->initialize_elements(); | 705 array->initialize_elements(); |
706 } else if (length <= capacity) { | 706 } else if (length <= capacity) { |
707 if (array->HasFastSmiOrObjectElements()) { | 707 if (array->HasFastSmiOrObjectElements()) { |
708 backing_store = JSObject::EnsureWritableFastElements(array); | 708 JSObject::EnsureWritableFastElements(array); |
| 709 if (array->elements() != *backing_store) { |
| 710 backing_store = handle(array->elements(), isolate); |
| 711 } |
709 } | 712 } |
710 if (2 * length <= capacity) { | 713 if (2 * length <= capacity) { |
711 // If more than half the elements won't be used, trim the array. | 714 // If more than half the elements won't be used, trim the array. |
712 isolate->heap()->RightTrimFixedArray<Heap::CONCURRENT_TO_SWEEPER>( | 715 isolate->heap()->RightTrimFixedArray<Heap::CONCURRENT_TO_SWEEPER>( |
713 *backing_store, capacity - length); | 716 *backing_store, capacity - length); |
714 } else { | 717 } else { |
715 // Otherwise, fill the unused tail with holes. | 718 // Otherwise, fill the unused tail with holes. |
716 for (uint32_t i = length; i < old_length; i++) { | 719 for (uint32_t i = length; i < old_length; i++) { |
717 BackingStore::cast(*backing_store)->set_the_hole(i); | 720 BackingStore::cast(*backing_store)->set_the_hole(i); |
718 } | 721 } |
(...skipping 1958 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2677 } | 2680 } |
2678 } | 2681 } |
2679 | 2682 |
2680 DCHECK(j == result_len); | 2683 DCHECK(j == result_len); |
2681 return result_array; | 2684 return result_array; |
2682 } | 2685 } |
2683 | 2686 |
2684 ElementsAccessor** ElementsAccessor::elements_accessors_ = NULL; | 2687 ElementsAccessor** ElementsAccessor::elements_accessors_ = NULL; |
2685 } // namespace internal | 2688 } // namespace internal |
2686 } // namespace v8 | 2689 } // namespace v8 |
OLD | NEW |