Commit 84eea3e5 authored by yangguo@chromium.org's avatar yangguo@chromium.org

Inline one level of recursive call of WriteToFlat for the common case of cons string list.

BUG=
TEST=

Review URL: https://chromiumcodereview.appspot.com/9536011

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@10871 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent b854d097
...@@ -6862,10 +6862,21 @@ void String::WriteToFlat(String* src, ...@@ -6862,10 +6862,21 @@ void String::WriteToFlat(String* src,
// Left hand side is longer. Recurse over right. // Left hand side is longer. Recurse over right.
if (to > boundary) { if (to > boundary) {
String* second = cons_string->second(); String* second = cons_string->second();
WriteToFlat(second, // When repeatedly appending to a string, we get a cons string that
sink + boundary - from, // is unbalanced to the left, a list, essentially. We inline the
0, // common case of sequential ascii right child.
if (to - boundary == 1) {
sink[boundary - from] = static_cast<sinkchar>(second->Get(0));
} else if (second->IsSeqAsciiString()) {
CopyChars(sink + boundary - from,
SeqAsciiString::cast(second)->GetChars(),
to - boundary); to - boundary);
} else {
WriteToFlat(second,
sink + boundary - from,
0,
to - boundary);
}
to = boundary; to = boundary;
} }
source = first; source = first;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment