OLD | NEW |
1 // Copyright 2006-2009 the V8 project authors. All rights reserved. | 1 // Copyright 2006-2009 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 821 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
832 | 832 |
833 // Fill the remainder of the string with dead wood. | 833 // Fill the remainder of the string with dead wood. |
834 int new_size = this->Size(); // Byte size of the external String object. | 834 int new_size = this->Size(); // Byte size of the external String object. |
835 Heap::CreateFillerObjectAt(this->address() + new_size, size - new_size); | 835 Heap::CreateFillerObjectAt(this->address() + new_size, size - new_size); |
836 return true; | 836 return true; |
837 } | 837 } |
838 | 838 |
839 | 839 |
840 void String::StringShortPrint(StringStream* accumulator) { | 840 void String::StringShortPrint(StringStream* accumulator) { |
841 int len = length(); | 841 int len = length(); |
842 if (len > kMaxMediumStringSize) { | 842 if (len > kMaxMediumSize) { |
843 accumulator->Add("<Very long string[%u]>", len); | 843 accumulator->Add("<Very long string[%u]>", len); |
844 return; | 844 return; |
845 } | 845 } |
846 | 846 |
847 if (!LooksValid()) { | 847 if (!LooksValid()) { |
848 accumulator->Add("<Invalid String>"); | 848 accumulator->Add("<Invalid String>"); |
849 return; | 849 return; |
850 } | 850 } |
851 | 851 |
852 StringInputBuffer buf(this); | 852 StringInputBuffer buf(this); |
(...skipping 3800 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4653 static inline uint32_t HashField(uint32_t hash, bool is_array_index) { | 4653 static inline uint32_t HashField(uint32_t hash, bool is_array_index) { |
4654 uint32_t result = | 4654 uint32_t result = |
4655 (hash << String::kLongLengthShift) | String::kHashComputedMask; | 4655 (hash << String::kLongLengthShift) | String::kHashComputedMask; |
4656 if (is_array_index) result |= String::kIsArrayIndexMask; | 4656 if (is_array_index) result |= String::kIsArrayIndexMask; |
4657 return result; | 4657 return result; |
4658 } | 4658 } |
4659 | 4659 |
4660 | 4660 |
4661 uint32_t StringHasher::GetHashField() { | 4661 uint32_t StringHasher::GetHashField() { |
4662 ASSERT(is_valid()); | 4662 ASSERT(is_valid()); |
4663 if (length_ <= String::kMaxShortStringSize) { | 4663 if (length_ <= String::kMaxShortSize) { |
4664 uint32_t payload; | 4664 uint32_t payload; |
4665 if (is_array_index()) { | 4665 if (is_array_index()) { |
4666 payload = v8::internal::HashField(array_index(), true); | 4666 payload = v8::internal::HashField(array_index(), true); |
4667 } else { | 4667 } else { |
4668 payload = v8::internal::HashField(GetHash(), false); | 4668 payload = v8::internal::HashField(GetHash(), false); |
4669 } | 4669 } |
4670 return (payload & ((1 << String::kShortLengthShift) - 1)) | | 4670 return (payload & ((1 << String::kShortLengthShift) - 1)) | |
4671 (length_ << String::kShortLengthShift); | 4671 (length_ << String::kShortLengthShift); |
4672 } else if (length_ <= String::kMaxMediumStringSize) { | 4672 } else if (length_ <= String::kMaxMediumSize) { |
4673 uint32_t payload = v8::internal::HashField(GetHash(), false); | 4673 uint32_t payload = v8::internal::HashField(GetHash(), false); |
4674 return (payload & ((1 << String::kMediumLengthShift) - 1)) | | 4674 return (payload & ((1 << String::kMediumLengthShift) - 1)) | |
4675 (length_ << String::kMediumLengthShift); | 4675 (length_ << String::kMediumLengthShift); |
4676 } else { | 4676 } else { |
4677 return v8::internal::HashField(length_, false); | 4677 return v8::internal::HashField(length_, false); |
4678 } | 4678 } |
4679 } | 4679 } |
4680 | 4680 |
4681 | 4681 |
4682 uint32_t String::ComputeLengthAndHashField(unibrow::CharacterStream* buffer, | 4682 uint32_t String::ComputeLengthAndHashField(unibrow::CharacterStream* buffer, |
(...skipping 3624 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
8307 if (break_point_objects()->IsUndefined()) return 0; | 8307 if (break_point_objects()->IsUndefined()) return 0; |
8308 // Single beak point. | 8308 // Single beak point. |
8309 if (!break_point_objects()->IsFixedArray()) return 1; | 8309 if (!break_point_objects()->IsFixedArray()) return 1; |
8310 // Multiple break points. | 8310 // Multiple break points. |
8311 return FixedArray::cast(break_point_objects())->length(); | 8311 return FixedArray::cast(break_point_objects())->length(); |
8312 } | 8312 } |
8313 #endif | 8313 #endif |
8314 | 8314 |
8315 | 8315 |
8316 } } // namespace v8::internal | 8316 } } // namespace v8::internal |
OLD | NEW |