Index: runtime/vm/object.cc |
diff --git a/runtime/vm/object.cc b/runtime/vm/object.cc |
index b1c28aba81f2603a35d78499f7d873d65b55382d..fa4bbaef2a9129032889d94b5b4c3267152927c5 100644 |
--- a/runtime/vm/object.cc |
+++ b/runtime/vm/object.cc |
@@ -6979,6 +6979,10 @@ void Function::PrintJSONImpl(JSONStream* stream, bool ref) const { |
if (!code.IsNull()) { |
jsobj.AddProperty("code", code); |
} |
+ Array& ics = Array::Handle(ic_data_array()); |
+ if (!ics.IsNull()) { |
+ jsobj.AddProperty("_icDataArray", ics); |
+ } |
jsobj.AddProperty("_optimizable", is_optimizable()); |
jsobj.AddProperty("_inlinable", is_inlinable()); |
code = unoptimized_code(); |
@@ -10709,7 +10713,14 @@ const char* Instructions::ToCString() const { |
void Instructions::PrintJSONImpl(JSONStream* stream, bool ref) const { |
- Object::PrintJSONImpl(stream, ref); |
+ JSONObject jsobj(stream); |
+ AddCommonObjectProperties(&jsobj, "Object", ref); |
+ jsobj.AddServiceId(*this); |
+ jsobj.AddProperty("_code", Code::Handle(code())); |
+ if (ref) { |
+ return; |
+ } |
+ jsobj.AddProperty("_objectPool", ObjectPool::Handle(object_pool())); |
} |
@@ -10800,7 +10811,35 @@ const char* ObjectPool::ToCString() const { |
void ObjectPool::PrintJSONImpl(JSONStream* stream, bool ref) const { |
- Object::PrintJSONImpl(stream, ref); |
+ JSONObject jsobj(stream); |
+ AddCommonObjectProperties(&jsobj, "Object", ref); |
+ jsobj.AddServiceId(*this); |
+ jsobj.AddProperty("length", Length()); |
+ if (ref) { |
+ return; |
+ } |
+ |
+ { |
+ JSONArray jsarr(&jsobj, "_entries"); |
+ uword imm; |
+ Object& obj = Object::Handle(); |
+ for (intptr_t i = 0; i < Length(); i++) { |
+ switch (InfoAt(i)) { |
+ case ObjectPool::kTaggedObject: |
+ obj = ObjectAt(i); |
+ jsarr.AddValue(obj); |
+ break; |
+ case ObjectPool::kImmediate: |
+ // We might want to distingiush between immediates and addresses |
+ // in the future. |
+ imm = RawValueAt(i); |
+ jsarr.AddValue64(imm); |
+ break; |
+ default: |
+ UNREACHABLE(); |
+ } |
+ } |
+ } |
} |
@@ -12212,7 +12251,17 @@ RawICData* ICData::NewFrom(const ICData& from, intptr_t num_args_tested) { |
void ICData::PrintJSONImpl(JSONStream* stream, bool ref) const { |
- Object::PrintJSONImpl(stream, ref); |
+ JSONObject jsobj(stream); |
+ AddCommonObjectProperties(&jsobj, "Object", ref); |
+ jsobj.AddServiceId(*this); |
+ jsobj.AddProperty("_owner", Object::Handle(owner())); |
+ jsobj.AddProperty("_selector", String::Handle(target_name()).ToCString()); |
+ if (ref) { |
+ return; |
+ } |
+ jsobj.AddProperty("_argumentsDescriptor", |
+ Object::Handle(arguments_descriptor())); |
+ jsobj.AddProperty("_entries", Object::Handle(ic_data())); |
} |
@@ -12974,7 +13023,7 @@ void Code::PrintJSONImpl(JSONStream* stream, bool ref) const { |
// Generate a fake function reference. |
JSONObject func(&jsobj, "function"); |
func.AddProperty("type", "@Function"); |
- func.AddProperty("kind", "Stub"); |
+ func.AddProperty("_kind", "Stub"); |
func.AddProperty("name", user_name.ToCString()); |
AddNameProperties(&func, user_name, vm_name); |
} |