Commit 908f08e4 authored by Leszek Swirski's avatar Leszek Swirski Committed by Commit Bot

[ast] Remove literal allocation from CallPrinter

Access literal data directly in CallPrinter, rather than allocating
their values. This allows us to remove the isolate member from
CallPrinter entirely.

Change-Id: Ib4203009c86b6778ee843e8956fc7cee2214841e
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2122019Reviewed-by: 's avatarToon Verwaest <verwaest@chromium.org>
Commit-Queue: Leszek Swirski <leszeks@chromium.org>
Cr-Commit-Position: refs/heads/master@{#67471}
parent d4cb48c1
...@@ -20,7 +20,6 @@ namespace internal { ...@@ -20,7 +20,6 @@ namespace internal {
CallPrinter::CallPrinter(Isolate* isolate, bool is_user_js, CallPrinter::CallPrinter(Isolate* isolate, bool is_user_js,
SpreadErrorInArgsHint error_in_spread_args) SpreadErrorInArgsHint error_in_spread_args)
: builder_(new IncrementalStringBuilder(isolate)) { : builder_(new IncrementalStringBuilder(isolate)) {
isolate_ = isolate;
position_ = 0; position_ = 0;
num_prints_ = 0; num_prints_ = 0;
found_ = false; found_ = false;
...@@ -77,10 +76,16 @@ void CallPrinter::Print(const char* str) { ...@@ -77,10 +76,16 @@ void CallPrinter::Print(const char* str) {
builder_->AppendCString(str); builder_->AppendCString(str);
} }
void CallPrinter::Print(Handle<String> str) { void CallPrinter::Print(const AstRawString* str) {
if (!found_ || done_) return; if (!found_ || done_) return;
num_prints_++; num_prints_++;
builder_->AppendString(str); if (str->is_one_byte()) {
builder_->AppendNString(reinterpret_cast<const char*>(str->raw_data()),
str->length());
} else {
builder_->AppendNString(reinterpret_cast<const uc16*>(str->raw_data()),
str->length());
}
} }
void CallPrinter::VisitBlock(Block* node) { void CallPrinter::VisitBlock(Block* node) {
...@@ -244,17 +249,11 @@ void CallPrinter::VisitConditional(Conditional* node) { ...@@ -244,17 +249,11 @@ void CallPrinter::VisitConditional(Conditional* node) {
Find(node->else_expression()); Find(node->else_expression());
} }
void CallPrinter::VisitLiteral(Literal* node) { PrintLiteral(node, true); }
void CallPrinter::VisitLiteral(Literal* node) {
// TODO(adamk): Teach Literal how to print its values without
// allocating on the heap.
PrintLiteral(node->BuildValue(isolate_), true);
}
void CallPrinter::VisitRegExpLiteral(RegExpLiteral* node) { void CallPrinter::VisitRegExpLiteral(RegExpLiteral* node) {
Print("/"); Print("/");
PrintLiteral(node->pattern(), false); Print(node->raw_pattern());
Print("/"); Print("/");
if (node->flags() & RegExp::kGlobal) Print("g"); if (node->flags() & RegExp::kGlobal) Print("g");
if (node->flags() & RegExp::kIgnoreCase) Print("i"); if (node->flags() & RegExp::kIgnoreCase) Print("i");
...@@ -295,7 +294,7 @@ void CallPrinter::VisitArrayLiteral(ArrayLiteral* node) { ...@@ -295,7 +294,7 @@ void CallPrinter::VisitArrayLiteral(ArrayLiteral* node) {
void CallPrinter::VisitVariableProxy(VariableProxy* node) { void CallPrinter::VisitVariableProxy(VariableProxy* node) {
if (is_user_js_) { if (is_user_js_) {
PrintLiteral(node->name(), false); Print(node->raw_name());
} else { } else {
// Variable names of non-user code are meaningless due to minification. // Variable names of non-user code are meaningless due to minification.
Print("(var)"); Print("(var)");
...@@ -380,16 +379,13 @@ void CallPrinter::VisitOptionalChain(OptionalChain* node) { ...@@ -380,16 +379,13 @@ void CallPrinter::VisitOptionalChain(OptionalChain* node) {
void CallPrinter::VisitProperty(Property* node) { void CallPrinter::VisitProperty(Property* node) {
Expression* key = node->key(); Expression* key = node->key();
Literal* literal = key->AsLiteral(); Literal* literal = key->AsLiteral();
if (literal != nullptr && if (literal != nullptr && literal->IsStringLiteral()) {
literal->BuildValue(isolate_)->IsInternalizedString()) {
Find(node->obj(), true); Find(node->obj(), true);
if (node->is_optional_chain_link()) { if (node->is_optional_chain_link()) {
Print("?"); Print("?");
} }
Print("."); Print(".");
// TODO(adamk): Teach Literal how to print its values without PrintLiteral(literal, false);
// allocating on the heap.
PrintLiteral(literal->BuildValue(isolate_), false);
} else { } else {
Find(node->obj(), true); Find(node->obj(), true);
if (node->is_optional_chain_link()) { if (node->is_optional_chain_link()) {
...@@ -578,31 +574,45 @@ void CallPrinter::FindArguments(const ZonePtrList<Expression>* arguments) { ...@@ -578,31 +574,45 @@ void CallPrinter::FindArguments(const ZonePtrList<Expression>* arguments) {
} }
} }
void CallPrinter::PrintLiteral(Handle<Object> value, bool quote) { void CallPrinter::PrintLiteral(Literal* literal, bool quote) {
if (value->IsString()) { switch (literal->type()) {
if (quote) Print("\""); case Literal::kSmi:
Print(Handle<String>::cast(value)); case Literal::kHeapNumber: {
if (quote) Print("\""); double double_value = literal->AsNumber();
} else if (value->IsNull(isolate_)) { char buffer_data[kDoubleToCStringMinBufferSize];
Print("null"); Vector<char> buffer(buffer_data, kDoubleToCStringMinBufferSize);
} else if (value->IsTrue(isolate_)) {
Print("true"); int smi_value;
} else if (value->IsFalse(isolate_)) { if (DoubleToSmiInteger(double_value, &smi_value)) {
Print("false"); return Print(DoubleToCString(smi_value, buffer));
} else if (value->IsUndefined(isolate_)) { }
Print("undefined"); return Print(DoubleToCString(double_value, buffer));
} else if (value->IsNumber()) { }
Print(isolate_->factory()->NumberToString(value)); case Literal::kBigInt:
} else if (value->IsSymbol()) { return Print(literal->AsBigInt().c_str());
// Symbols can only occur as literals if they were inserted by the parser. case Literal::kString:
PrintLiteral(handle(Handle<Symbol>::cast(value)->description(), isolate_), return PrintLiteral(literal->AsRawString(), quote);
false); case Literal::kSymbol:
switch (literal->AsSymbol()) {
case AstSymbol::kHomeObjectSymbol:
return Print("HomeObjectSymbol");
}
UNREACHABLE();
case Literal::kBoolean:
return Print(literal->ToBooleanIsTrue() ? "true" : "false");
case Literal::kUndefined:
return Print("undefined");
case Literal::kNull:
return Print("null");
case Literal::kTheHole:
return;
} }
} }
void CallPrinter::PrintLiteral(const AstRawString* value, bool quote) { void CallPrinter::PrintLiteral(const AstRawString* value, bool quote) {
PrintLiteral(value->string(), quote); if (quote) Print("\"");
Print(value);
if (quote) Print("\"");
} }
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
......
...@@ -53,11 +53,10 @@ class CallPrinter final : public AstVisitor<CallPrinter> { ...@@ -53,11 +53,10 @@ class CallPrinter final : public AstVisitor<CallPrinter> {
private: private:
void Print(const char* str); void Print(const char* str);
void Print(Handle<String> str); void Print(const AstRawString* str);
void Find(AstNode* node, bool print = false); void Find(AstNode* node, bool print = false);
Isolate* isolate_;
int num_prints_; int num_prints_;
// Allocate the builder on the heap simply because it's forward declared. // Allocate the builder on the heap simply because it's forward declared.
std::unique_ptr<IncrementalStringBuilder> builder_; std::unique_ptr<IncrementalStringBuilder> builder_;
...@@ -76,7 +75,7 @@ class CallPrinter final : public AstVisitor<CallPrinter> { ...@@ -76,7 +75,7 @@ class CallPrinter final : public AstVisitor<CallPrinter> {
DEFINE_AST_VISITOR_SUBCLASS_MEMBERS(); DEFINE_AST_VISITOR_SUBCLASS_MEMBERS();
protected: protected:
void PrintLiteral(Handle<Object> value, bool quote); void PrintLiteral(Literal* literal, bool quote);
void PrintLiteral(const AstRawString* value, bool quote); void PrintLiteral(const AstRawString* value, bool quote);
void FindStatements(const ZonePtrList<Statement>* statements); void FindStatements(const ZonePtrList<Statement>* statements);
void FindArguments(const ZonePtrList<Expression>* arguments); void FindArguments(const ZonePtrList<Expression>* arguments);
......
...@@ -147,6 +147,25 @@ class IncrementalStringBuilder { ...@@ -147,6 +147,25 @@ class IncrementalStringBuilder {
} }
} }
V8_INLINE void AppendNString(const char* s, size_t len) {
const uint8_t* u = reinterpret_cast<const uint8_t*>(s);
const uint8_t* end = u + len;
if (encoding_ == String::ONE_BYTE_ENCODING) {
while (u != end) Append<uint8_t, uint8_t>(*(u++));
} else {
while (u != end) Append<uint8_t, uc16>(*(u++));
}
}
V8_INLINE void AppendNString(const uc16* s, size_t len) {
const uc16* end = s + len;
if (encoding_ == String::ONE_BYTE_ENCODING) {
while (s != end) Append<uc16, uint8_t>(*(s++));
} else {
while (s != end) Append<uc16, uc16>(*(s++));
}
}
V8_INLINE void AppendInt(int i) { V8_INLINE void AppendInt(int i) {
char buffer[kIntToCStringBufferSize]; char buffer[kIntToCStringBufferSize];
const char* str = const char* str =
......
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