Improved printing of Simulate, LoadNamedFieldPolymorphic, LoadNamedGeneric,...

Improved printing of Simulate, LoadNamedFieldPolymorphic, LoadNamedGeneric, and StoreNamedField Hydrogen instructions a bit.
Review URL: http://codereview.chromium.org/8352044

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@9725 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent bd5e694a
...@@ -1146,15 +1146,16 @@ void HPhi::AddIndirectUsesTo(int* dest) { ...@@ -1146,15 +1146,16 @@ void HPhi::AddIndirectUsesTo(int* dest) {
void HSimulate::PrintDataTo(StringStream* stream) { void HSimulate::PrintDataTo(StringStream* stream) {
stream->Add("id=%d ", ast_id()); stream->Add("id=%d", ast_id());
if (pop_count_ > 0) stream->Add("pop %d", pop_count_); if (pop_count_ > 0) stream->Add(" pop %d", pop_count_);
if (values_.length() > 0) { if (values_.length() > 0) {
if (pop_count_ > 0) stream->Add(" /"); if (pop_count_ > 0) stream->Add(" /");
for (int i = 0; i < values_.length(); ++i) { for (int i = 0; i < values_.length(); ++i) {
if (!HasAssignedIndexAt(i)) { if (i > 0) stream->Add(",");
stream->Add(" push "); if (HasAssignedIndexAt(i)) {
} else {
stream->Add(" var[%d] = ", GetAssignedIndexAt(i)); stream->Add(" var[%d] = ", GetAssignedIndexAt(i));
} else {
stream->Add(" push ");
} }
values_[i]->PrintNameTo(stream); values_[i]->PrintNameTo(stream);
} }
...@@ -1456,14 +1457,14 @@ bool HLoadNamedFieldPolymorphic::DataEquals(HValue* value) { ...@@ -1456,14 +1457,14 @@ bool HLoadNamedFieldPolymorphic::DataEquals(HValue* value) {
void HLoadNamedFieldPolymorphic::PrintDataTo(StringStream* stream) { void HLoadNamedFieldPolymorphic::PrintDataTo(StringStream* stream) {
object()->PrintNameTo(stream); object()->PrintNameTo(stream);
stream->Add(" ."); stream->Add(".");
stream->Add(*String::cast(*name())->ToCString()); stream->Add(*String::cast(*name())->ToCString());
} }
void HLoadNamedGeneric::PrintDataTo(StringStream* stream) { void HLoadNamedGeneric::PrintDataTo(StringStream* stream) {
object()->PrintNameTo(stream); object()->PrintNameTo(stream);
stream->Add(" ."); stream->Add(".");
stream->Add(*String::cast(*name())->ToCString()); stream->Add(*String::cast(*name())->ToCString());
} }
...@@ -1560,10 +1561,10 @@ void HStoreNamedGeneric::PrintDataTo(StringStream* stream) { ...@@ -1560,10 +1561,10 @@ void HStoreNamedGeneric::PrintDataTo(StringStream* stream) {
void HStoreNamedField::PrintDataTo(StringStream* stream) { void HStoreNamedField::PrintDataTo(StringStream* stream) {
object()->PrintNameTo(stream); object()->PrintNameTo(stream);
stream->Add("."); stream->Add(".");
ASSERT(name()->IsString());
stream->Add(*String::cast(*name())->ToCString()); stream->Add(*String::cast(*name())->ToCString());
stream->Add(" = "); stream->Add(" = ");
value()->PrintNameTo(stream); value()->PrintNameTo(stream);
stream->Add(" @%d%s", offset(), is_in_object() ? "[in-object]" : "");
if (!transition().is_null()) { if (!transition().is_null()) {
stream->Add(" (transition map %p)", *transition()); stream->Add(" (transition map %p)", *transition());
} }
......
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