OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 1716 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1727 WRITE_DOUBLE_FIELD(this, offset, hole_nan_as_double()); | 1727 WRITE_DOUBLE_FIELD(this, offset, hole_nan_as_double()); |
1728 } | 1728 } |
1729 | 1729 |
1730 | 1730 |
1731 bool FixedDoubleArray::is_the_hole(int index) { | 1731 bool FixedDoubleArray::is_the_hole(int index) { |
1732 int offset = kHeaderSize + index * kDoubleSize; | 1732 int offset = kHeaderSize + index * kDoubleSize; |
1733 return is_the_hole_nan(READ_DOUBLE_FIELD(this, offset)); | 1733 return is_the_hole_nan(READ_DOUBLE_FIELD(this, offset)); |
1734 } | 1734 } |
1735 | 1735 |
1736 | 1736 |
1737 void FixedDoubleArray::Initialize(FixedDoubleArray* from) { | |
1738 int old_length = from->length(); | |
1739 ASSERT(old_length < length()); | |
1740 if (old_length * kDoubleSize >= OS::kMinComplexMemCopy) { | |
1741 OS::MemCopy(FIELD_ADDR(this, kHeaderSize), | |
1742 FIELD_ADDR(from, kHeaderSize), | |
1743 old_length * kDoubleSize); | |
1744 } else { | |
1745 for (int i = 0; i < old_length; ++i) { | |
1746 if (from->is_the_hole(i)) { | |
1747 set_the_hole(i); | |
1748 } else { | |
1749 set(i, from->get_scalar(i)); | |
1750 } | |
1751 } | |
1752 } | |
1753 int offset = kHeaderSize + old_length * kDoubleSize; | |
1754 for (int current = from->length(); current < length(); ++current) { | |
1755 WRITE_DOUBLE_FIELD(this, offset, hole_nan_as_double()); | |
1756 offset += kDoubleSize; | |
1757 } | |
1758 } | |
1759 | |
1760 | |
1761 void FixedDoubleArray::Initialize(FixedArray* from) { | |
1762 int old_length = from->length(); | |
1763 ASSERT(old_length <= length()); | |
1764 for (int i = 0; i < old_length; i++) { | |
1765 Object* hole_or_object = from->get(i); | |
1766 if (hole_or_object->IsTheHole()) { | |
1767 set_the_hole(i); | |
1768 } else { | |
1769 set(i, hole_or_object->Number()); | |
1770 } | |
1771 } | |
1772 int offset = kHeaderSize + old_length * kDoubleSize; | |
1773 for (int current = from->length(); current < length(); ++current) { | |
1774 WRITE_DOUBLE_FIELD(this, offset, hole_nan_as_double()); | |
1775 offset += kDoubleSize; | |
1776 } | |
1777 } | |
1778 | |
1779 | |
1780 void FixedDoubleArray::Initialize(SeededNumberDictionary* from) { | |
1781 int offset = kHeaderSize; | |
1782 for (int current = 0; current < length(); ++current) { | |
1783 WRITE_DOUBLE_FIELD(this, offset, hole_nan_as_double()); | |
1784 offset += kDoubleSize; | |
1785 } | |
1786 for (int i = 0; i < from->Capacity(); i++) { | |
1787 Object* key = from->KeyAt(i); | |
1788 if (key->IsNumber()) { | |
1789 uint32_t entry = static_cast<uint32_t>(key->Number()); | |
1790 set(entry, from->ValueAt(i)->Number()); | |
1791 } | |
1792 } | |
1793 } | |
1794 | |
1795 | |
1796 WriteBarrierMode HeapObject::GetWriteBarrierMode(const AssertNoAllocation&) { | 1737 WriteBarrierMode HeapObject::GetWriteBarrierMode(const AssertNoAllocation&) { |
1797 Heap* heap = GetHeap(); | 1738 Heap* heap = GetHeap(); |
1798 if (heap->incremental_marking()->IsMarking()) return UPDATE_WRITE_BARRIER; | 1739 if (heap->incremental_marking()->IsMarking()) return UPDATE_WRITE_BARRIER; |
1799 if (heap->InNewSpace(this)) return SKIP_WRITE_BARRIER; | 1740 if (heap->InNewSpace(this)) return SKIP_WRITE_BARRIER; |
1800 return UPDATE_WRITE_BARRIER; | 1741 return UPDATE_WRITE_BARRIER; |
1801 } | 1742 } |
1802 | 1743 |
1803 | 1744 |
1804 void FixedArray::set(int index, | 1745 void FixedArray::set(int index, |
1805 Object* value, | 1746 Object* value, |
(...skipping 3168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4974 #undef WRITE_UINT32_FIELD | 4915 #undef WRITE_UINT32_FIELD |
4975 #undef READ_SHORT_FIELD | 4916 #undef READ_SHORT_FIELD |
4976 #undef WRITE_SHORT_FIELD | 4917 #undef WRITE_SHORT_FIELD |
4977 #undef READ_BYTE_FIELD | 4918 #undef READ_BYTE_FIELD |
4978 #undef WRITE_BYTE_FIELD | 4919 #undef WRITE_BYTE_FIELD |
4979 | 4920 |
4980 | 4921 |
4981 } } // namespace v8::internal | 4922 } } // namespace v8::internal |
4982 | 4923 |
4983 #endif // V8_OBJECTS_INL_H_ | 4924 #endif // V8_OBJECTS_INL_H_ |
OLD | NEW |