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

Side by Side Diff: src/objects.cc

Issue 2683903002: Fix missing cases of empty_string canonicalization (Closed)
Patch Set: make LSan happy Created 3 years, 10 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
« no previous file with comments | « src/mips64/macro-assembler-mips64.cc ('k') | src/objects-debug.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 the V8 project authors. All rights reserved. 1 // Copyright 2015 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/objects.h" 5 #include "src/objects.h"
6 6
7 #include <cmath> 7 #include <cmath>
8 #include <iomanip> 8 #include <iomanip>
9 #include <memory> 9 #include <memory>
10 #include <sstream> 10 #include <sstream>
(...skipping 11690 matching lines...) Expand 10 before | Expand all | Expand 10 after
11701 // Isolate the array index form the full hash field. 11701 // Isolate the array index form the full hash field.
11702 *index = ArrayIndexValueBits::decode(field); 11702 *index = ArrayIndexValueBits::decode(field);
11703 return true; 11703 return true;
11704 } else { 11704 } else {
11705 return ComputeArrayIndex(index); 11705 return ComputeArrayIndex(index);
11706 } 11706 }
11707 } 11707 }
11708 11708
11709 11709
11710 Handle<String> SeqString::Truncate(Handle<SeqString> string, int new_length) { 11710 Handle<String> SeqString::Truncate(Handle<SeqString> string, int new_length) {
11711 Heap* heap = string->GetHeap();
11712 if (new_length == 0) return heap->isolate()->factory()->empty_string();
11713
11711 int new_size, old_size; 11714 int new_size, old_size;
11712 int old_length = string->length(); 11715 int old_length = string->length();
11713 if (old_length <= new_length) return string; 11716 if (old_length <= new_length) return string;
11714 11717
11715 if (string->IsSeqOneByteString()) { 11718 if (string->IsSeqOneByteString()) {
11716 old_size = SeqOneByteString::SizeFor(old_length); 11719 old_size = SeqOneByteString::SizeFor(old_length);
11717 new_size = SeqOneByteString::SizeFor(new_length); 11720 new_size = SeqOneByteString::SizeFor(new_length);
11718 } else { 11721 } else {
11719 DCHECK(string->IsSeqTwoByteString()); 11722 DCHECK(string->IsSeqTwoByteString());
11720 old_size = SeqTwoByteString::SizeFor(old_length); 11723 old_size = SeqTwoByteString::SizeFor(old_length);
11721 new_size = SeqTwoByteString::SizeFor(new_length); 11724 new_size = SeqTwoByteString::SizeFor(new_length);
11722 } 11725 }
11723 11726
11724 int delta = old_size - new_size; 11727 int delta = old_size - new_size;
11725 11728
11726 Address start_of_string = string->address(); 11729 Address start_of_string = string->address();
11727 DCHECK_OBJECT_ALIGNED(start_of_string); 11730 DCHECK_OBJECT_ALIGNED(start_of_string);
11728 DCHECK_OBJECT_ALIGNED(start_of_string + new_size); 11731 DCHECK_OBJECT_ALIGNED(start_of_string + new_size);
11729 11732
11730 Heap* heap = string->GetHeap();
11731 // Sizes are pointer size aligned, so that we can use filler objects 11733 // Sizes are pointer size aligned, so that we can use filler objects
11732 // that are a multiple of pointer size. 11734 // that are a multiple of pointer size.
11733 heap->CreateFillerObjectAt(start_of_string + new_size, delta, 11735 heap->CreateFillerObjectAt(start_of_string + new_size, delta,
11734 ClearRecordedSlots::kNo); 11736 ClearRecordedSlots::kNo);
11735 heap->AdjustLiveBytes(*string, -delta); 11737 heap->AdjustLiveBytes(*string, -delta);
11736 11738
11737 // We are storing the new length using release store after creating a filler 11739 // We are storing the new length using release store after creating a filler
11738 // for the left-over space to avoid races with the sweeper thread. 11740 // for the left-over space to avoid races with the sweeper thread.
11739 string->synchronized_set_length(new_length); 11741 string->synchronized_set_length(new_length);
11740 11742
11741 if (new_length == 0) return heap->isolate()->factory()->empty_string();
11742 return string; 11743 return string;
11743 } 11744 }
11744 11745
11745 11746
11746 uint32_t StringHasher::MakeArrayIndexHash(uint32_t value, int length) { 11747 uint32_t StringHasher::MakeArrayIndexHash(uint32_t value, int length) {
11747 // For array indexes mix the length into the hash as an array index could 11748 // For array indexes mix the length into the hash as an array index could
11748 // be zero. 11749 // be zero.
11749 DCHECK(length > 0); 11750 DCHECK(length > 0);
11750 DCHECK(length <= String::kMaxArrayIndexSize); 11751 DCHECK(length <= String::kMaxArrayIndexSize);
11751 DCHECK(TenToThe(String::kMaxCachedArrayIndexLength) < 11752 DCHECK(TenToThe(String::kMaxCachedArrayIndexLength) <
(...skipping 8456 matching lines...) Expand 10 before | Expand all | Expand 10 after
20208 // depend on this. 20209 // depend on this.
20209 return DICTIONARY_ELEMENTS; 20210 return DICTIONARY_ELEMENTS;
20210 } 20211 }
20211 DCHECK_LE(kind, LAST_ELEMENTS_KIND); 20212 DCHECK_LE(kind, LAST_ELEMENTS_KIND);
20212 return kind; 20213 return kind;
20213 } 20214 }
20214 } 20215 }
20215 20216
20216 } // namespace internal 20217 } // namespace internal
20217 } // namespace v8 20218 } // namespace v8
OLDNEW
« no previous file with comments | « src/mips64/macro-assembler-mips64.cc ('k') | src/objects-debug.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698