blob: 551beb2e6239ba0d1cab4c61dce12272335f89e9 [file] [log] [blame]
Ben Murdoch3ef787d2012-04-12 10:51:47 +01001// Copyright 2012 the V8 project authors. All rights reserved.
Ben Murdochb8a8cc12014-11-26 15:28:44 +00002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
Steve Block9fac8402011-05-12 15:51:54 +01004
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00005#include "src/objects.h"
Steve Block9fac8402011-05-12 15:51:54 +01006
Ben Murdochb8a8cc12014-11-26 15:28:44 +00007#include "src/disasm.h"
8#include "src/disassembler.h"
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00009#include "src/interpreter/bytecodes.h"
10#include "src/objects-inl.h"
Ben Murdochb8a8cc12014-11-26 15:28:44 +000011#include "src/ostreams.h"
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000012#include "src/regexp/jsregexp.h"
Steve Block9fac8402011-05-12 15:51:54 +010013
14namespace v8 {
15namespace internal {
16
17#ifdef OBJECT_PRINT
18
Ben Murdochb8a8cc12014-11-26 15:28:44 +000019void Object::Print() {
20 OFStream os(stdout);
21 this->Print(os);
Emily Bernierd0a1eb72015-03-24 16:35:39 -040022 os << std::flush;
Ben Murdochb8a8cc12014-11-26 15:28:44 +000023}
Steve Block9fac8402011-05-12 15:51:54 +010024
25
Emily Bernierd0a1eb72015-03-24 16:35:39 -040026void Object::Print(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +000027 if (IsSmi()) {
28 Smi::cast(this)->SmiPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +010029 } else {
Ben Murdochb8a8cc12014-11-26 15:28:44 +000030 HeapObject::cast(this)->HeapObjectPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +010031 }
Steve Block9fac8402011-05-12 15:51:54 +010032}
33
34
Emily Bernierd0a1eb72015-03-24 16:35:39 -040035void HeapObject::PrintHeader(std::ostream& os, const char* id) { // NOLINT
Ben Murdochc5610432016-08-08 18:44:38 +010036 os << reinterpret_cast<void*>(this) << ": [";
37 if (id != nullptr) {
38 os << id;
39 } else {
40 os << map()->instance_type();
41 }
42 os << "]";
Steve Block9fac8402011-05-12 15:51:54 +010043}
44
45
Emily Bernierd0a1eb72015-03-24 16:35:39 -040046void HeapObject::HeapObjectPrint(std::ostream& os) { // NOLINT
Steve Block9fac8402011-05-12 15:51:54 +010047 InstanceType instance_type = map()->instance_type();
48
Ben Murdochb8a8cc12014-11-26 15:28:44 +000049 HandleScope scope(GetIsolate());
Steve Block9fac8402011-05-12 15:51:54 +010050 if (instance_type < FIRST_NONSTRING_TYPE) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +000051 String::cast(this)->StringPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +010052 return;
53 }
54
55 switch (instance_type) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +000056 case SYMBOL_TYPE:
57 Symbol::cast(this)->SymbolPrint(os);
58 break;
Steve Block9fac8402011-05-12 15:51:54 +010059 case MAP_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +000060 Map::cast(this)->MapPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +010061 break;
62 case HEAP_NUMBER_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +000063 HeapNumber::cast(this)->HeapNumberPrint(os);
64 break;
65 case MUTABLE_HEAP_NUMBER_TYPE:
66 os << "<mutable ";
67 HeapNumber::cast(this)->HeapNumberPrint(os);
68 os << ">";
Steve Block9fac8402011-05-12 15:51:54 +010069 break;
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000070 case SIMD128_VALUE_TYPE:
71 Simd128Value::cast(this)->Simd128ValuePrint(os);
72 break;
Ben Murdoch3ef787d2012-04-12 10:51:47 +010073 case FIXED_DOUBLE_ARRAY_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +000074 FixedDoubleArray::cast(this)->FixedDoubleArrayPrint(os);
75 break;
Steve Block9fac8402011-05-12 15:51:54 +010076 case FIXED_ARRAY_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +000077 FixedArray::cast(this)->FixedArrayPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +010078 break;
79 case BYTE_ARRAY_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +000080 ByteArray::cast(this)->ByteArrayPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +010081 break;
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000082 case BYTECODE_ARRAY_TYPE:
83 BytecodeArray::cast(this)->BytecodeArrayPrint(os);
84 break;
85 case TRANSITION_ARRAY_TYPE:
86 TransitionArray::cast(this)->TransitionArrayPrint(os);
87 break;
Ben Murdoch3ef787d2012-04-12 10:51:47 +010088 case FREE_SPACE_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +000089 FreeSpace::cast(this)->FreeSpacePrint(os);
Ben Murdoch3ef787d2012-04-12 10:51:47 +010090 break;
Ben Murdochb8a8cc12014-11-26 15:28:44 +000091
Ben Murdochb8a8cc12014-11-26 15:28:44 +000092#define PRINT_FIXED_TYPED_ARRAY(Type, type, TYPE, ctype, size) \
93 case Fixed##Type##Array::kInstanceType: \
94 Fixed##Type##Array::cast(this)->FixedTypedArrayPrint(os); \
95 break;
96
97 TYPED_ARRAYS(PRINT_FIXED_TYPED_ARRAY)
98#undef PRINT_FIXED_TYPED_ARRAY
99
Steve Block9fac8402011-05-12 15:51:54 +0100100 case FILLER_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000101 os << "filler";
Steve Block9fac8402011-05-12 15:51:54 +0100102 break;
103 case JS_OBJECT_TYPE: // fall through
Ben Murdochc5610432016-08-08 18:44:38 +0100104 case JS_API_OBJECT_TYPE:
Ben Murdochda12d292016-06-02 14:46:10 +0100105 case JS_SPECIAL_API_OBJECT_TYPE:
Steve Block9fac8402011-05-12 15:51:54 +0100106 case JS_CONTEXT_EXTENSION_OBJECT_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000107 case JS_GENERATOR_OBJECT_TYPE:
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000108 case JS_PROMISE_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000109 JSObject::cast(this)->JSObjectPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +0100110 break;
Ben Murdochc5610432016-08-08 18:44:38 +0100111 case JS_ARRAY_TYPE:
112 JSArray::cast(this)->JSArrayPrint(os);
113 break;
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000114 case JS_REGEXP_TYPE:
115 JSRegExp::cast(this)->JSRegExpPrint(os);
116 break;
Steve Block9fac8402011-05-12 15:51:54 +0100117 case ODDBALL_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000118 Oddball::cast(this)->to_string()->Print(os);
119 break;
120 case JS_MODULE_TYPE:
121 JSModule::cast(this)->JSModulePrint(os);
Steve Block9fac8402011-05-12 15:51:54 +0100122 break;
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000123 case JS_BOUND_FUNCTION_TYPE:
124 JSBoundFunction::cast(this)->JSBoundFunctionPrint(os);
125 break;
Steve Block9fac8402011-05-12 15:51:54 +0100126 case JS_FUNCTION_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000127 JSFunction::cast(this)->JSFunctionPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +0100128 break;
129 case JS_GLOBAL_PROXY_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000130 JSGlobalProxy::cast(this)->JSGlobalProxyPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +0100131 break;
132 case JS_GLOBAL_OBJECT_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000133 JSGlobalObject::cast(this)->JSGlobalObjectPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +0100134 break;
Steve Block9fac8402011-05-12 15:51:54 +0100135 case JS_VALUE_TYPE:
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000136 JSValue::cast(this)->JSValuePrint(os);
Steve Block9fac8402011-05-12 15:51:54 +0100137 break;
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100138 case JS_DATE_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000139 JSDate::cast(this)->JSDatePrint(os);
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100140 break;
Steve Block9fac8402011-05-12 15:51:54 +0100141 case CODE_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000142 Code::cast(this)->CodePrint(os);
Steve Block9fac8402011-05-12 15:51:54 +0100143 break;
Ben Murdoch257744e2011-11-30 15:57:28 +0000144 case JS_PROXY_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000145 JSProxy::cast(this)->JSProxyPrint(os);
Ben Murdoch257744e2011-11-30 15:57:28 +0000146 break;
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000147 case JS_SET_TYPE:
148 JSSet::cast(this)->JSSetPrint(os);
149 break;
150 case JS_MAP_TYPE:
151 JSMap::cast(this)->JSMapPrint(os);
152 break;
153 case JS_SET_ITERATOR_TYPE:
154 JSSetIterator::cast(this)->JSSetIteratorPrint(os);
155 break;
156 case JS_MAP_ITERATOR_TYPE:
157 JSMapIterator::cast(this)->JSMapIteratorPrint(os);
Ben Murdoch589d6972011-11-30 16:04:58 +0000158 break;
Ben Murdoch69a99ed2011-11-30 16:03:39 +0000159 case JS_WEAK_MAP_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000160 JSWeakMap::cast(this)->JSWeakMapPrint(os);
161 break;
162 case JS_WEAK_SET_TYPE:
163 JSWeakSet::cast(this)->JSWeakSetPrint(os);
Ben Murdoch69a99ed2011-11-30 16:03:39 +0000164 break;
Ben Murdoch257744e2011-11-30 15:57:28 +0000165 case FOREIGN_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000166 Foreign::cast(this)->ForeignPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +0100167 break;
168 case SHARED_FUNCTION_INFO_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000169 SharedFunctionInfo::cast(this)->SharedFunctionInfoPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +0100170 break;
Steve Block1e0659c2011-05-24 12:43:12 +0100171 case JS_MESSAGE_OBJECT_TYPE:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000172 JSMessageObject::cast(this)->JSMessageObjectPrint(os);
Steve Block1e0659c2011-05-24 12:43:12 +0100173 break;
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000174 case CELL_TYPE:
175 Cell::cast(this)->CellPrint(os);
176 break;
177 case PROPERTY_CELL_TYPE:
178 PropertyCell::cast(this)->PropertyCellPrint(os);
179 break;
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400180 case WEAK_CELL_TYPE:
181 WeakCell::cast(this)->WeakCellPrint(os);
182 break;
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000183 case JS_ARRAY_BUFFER_TYPE:
184 JSArrayBuffer::cast(this)->JSArrayBufferPrint(os);
185 break;
186 case JS_TYPED_ARRAY_TYPE:
187 JSTypedArray::cast(this)->JSTypedArrayPrint(os);
188 break;
189 case JS_DATA_VIEW_TYPE:
190 JSDataView::cast(this)->JSDataViewPrint(os);
Steve Block9fac8402011-05-12 15:51:54 +0100191 break;
192#define MAKE_STRUCT_CASE(NAME, Name, name) \
193 case NAME##_TYPE: \
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000194 Name::cast(this)->Name##Print(os); \
Steve Block9fac8402011-05-12 15:51:54 +0100195 break;
196 STRUCT_LIST(MAKE_STRUCT_CASE)
197#undef MAKE_STRUCT_CASE
198
199 default:
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000200 os << "UNKNOWN TYPE " << map()->instance_type();
Steve Block9fac8402011-05-12 15:51:54 +0100201 UNREACHABLE();
202 break;
203 }
204}
205
206
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000207void Simd128Value::Simd128ValuePrint(std::ostream& os) { // NOLINT
208#define PRINT_SIMD128_VALUE(TYPE, Type, type, lane_count, lane_type) \
209 if (Is##Type()) return Type::cast(this)->Type##Print(os);
210 SIMD128_TYPES(PRINT_SIMD128_VALUE)
211#undef PRINT_SIMD128_VALUE
212 UNREACHABLE();
213}
214
215
216void Float32x4::Float32x4Print(std::ostream& os) { // NOLINT
217 char arr[100];
218 Vector<char> buffer(arr, arraysize(arr));
219 os << std::string(DoubleToCString(get_lane(0), buffer)) << ", "
220 << std::string(DoubleToCString(get_lane(1), buffer)) << ", "
221 << std::string(DoubleToCString(get_lane(2), buffer)) << ", "
222 << std::string(DoubleToCString(get_lane(3), buffer));
223}
224
225
226#define SIMD128_INT_PRINT_FUNCTION(type, lane_count) \
227 void type::type##Print(std::ostream& os) { \
228 char arr[100]; \
229 Vector<char> buffer(arr, arraysize(arr)); \
230 os << std::string(IntToCString(get_lane(0), buffer)); \
231 for (int i = 1; i < lane_count; i++) { \
232 os << ", " << std::string(IntToCString(get_lane(i), buffer)); \
233 } \
234 }
235SIMD128_INT_PRINT_FUNCTION(Int32x4, 4)
236SIMD128_INT_PRINT_FUNCTION(Uint32x4, 4)
237SIMD128_INT_PRINT_FUNCTION(Int16x8, 8)
238SIMD128_INT_PRINT_FUNCTION(Uint16x8, 8)
239SIMD128_INT_PRINT_FUNCTION(Int8x16, 16)
240SIMD128_INT_PRINT_FUNCTION(Uint8x16, 16)
241#undef SIMD128_INT_PRINT_FUNCTION
242
243
244#define SIMD128_BOOL_PRINT_FUNCTION(type, lane_count) \
245 void type::type##Print(std::ostream& os) { \
246 char arr[100]; \
247 Vector<char> buffer(arr, arraysize(arr)); \
248 os << std::string(get_lane(0) ? "true" : "false"); \
249 for (int i = 1; i < lane_count; i++) { \
250 os << ", " << std::string(get_lane(i) ? "true" : "false"); \
251 } \
252 }
253SIMD128_BOOL_PRINT_FUNCTION(Bool32x4, 4)
254SIMD128_BOOL_PRINT_FUNCTION(Bool16x8, 8)
255SIMD128_BOOL_PRINT_FUNCTION(Bool8x16, 16)
256#undef SIMD128_BOOL_PRINT_FUNCTION
257
258
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400259void ByteArray::ByteArrayPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000260 os << "byte array, data starts at " << GetDataStartAddress();
Steve Block9fac8402011-05-12 15:51:54 +0100261}
262
263
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000264void BytecodeArray::BytecodeArrayPrint(std::ostream& os) { // NOLINT
265 Disassemble(os);
266}
267
268
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400269void FreeSpace::FreeSpacePrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000270 os << "free space, size " << Size();
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100271}
272
273
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000274template <class Traits>
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400275void FixedTypedArray<Traits>::FixedTypedArrayPrint(
276 std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000277 os << "fixed " << Traits::Designator();
Steve Block9fac8402011-05-12 15:51:54 +0100278}
279
280
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400281void JSObject::PrintProperties(std::ostream& os) { // NOLINT
Steve Block9fac8402011-05-12 15:51:54 +0100282 if (HasFastProperties()) {
283 DescriptorArray* descs = map()->instance_descriptors();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000284 for (int i = 0; i < map()->NumberOfOwnDescriptors(); i++) {
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000285 os << "\n ";
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000286 descs->GetKey(i)->NamePrint(os);
287 os << ": ";
Steve Block9fac8402011-05-12 15:51:54 +0100288 switch (descs->GetType(i)) {
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000289 case DATA: {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000290 FieldIndex index = FieldIndex::ForDescriptor(map(), i);
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400291 if (IsUnboxedDoubleField(index)) {
292 os << "<unboxed double> " << RawFastDoublePropertyAt(index);
293 } else {
294 os << Brief(RawFastPropertyAt(index));
295 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000296 os << " (data field at offset " << index.property_index() << ")";
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400297 break;
298 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000299 case ACCESSOR: {
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400300 FieldIndex index = FieldIndex::ForDescriptor(map(), i);
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000301 os << " (accessor field at offset " << index.property_index() << ")";
Steve Block9fac8402011-05-12 15:51:54 +0100302 break;
303 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000304 case DATA_CONSTANT:
305 os << Brief(descs->GetConstant(i)) << " (data constant)";
Steve Block9fac8402011-05-12 15:51:54 +0100306 break;
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000307 case ACCESSOR_CONSTANT:
308 os << Brief(descs->GetCallbacksObject(i)) << " (accessor constant)";
Steve Block9fac8402011-05-12 15:51:54 +0100309 break;
310 }
311 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000312 } else if (IsJSGlobalObject()) {
313 global_dictionary()->Print(os);
Steve Block9fac8402011-05-12 15:51:54 +0100314 } else {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000315 property_dictionary()->Print(os);
Steve Block9fac8402011-05-12 15:51:54 +0100316 }
317}
318
319
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000320template <class T>
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400321static void DoPrintElements(std::ostream& os, Object* object) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000322 T* p = T::cast(object);
323 for (int i = 0; i < p->length(); i++) {
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000324 os << "\n " << i << ": " << p->get_scalar(i);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000325 }
326}
327
328
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400329void JSObject::PrintElements(std::ostream& os) { // NOLINT
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100330 // Don't call GetElementsKind, its validation code can cause the printer to
331 // fail when debugging.
332 switch (map()->elements_kind()) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000333 case FAST_HOLEY_SMI_ELEMENTS:
334 case FAST_SMI_ELEMENTS:
335 case FAST_HOLEY_ELEMENTS:
Ben Murdoch097c5b22016-05-18 11:27:45 +0100336 case FAST_ELEMENTS:
337 case FAST_STRING_WRAPPER_ELEMENTS: {
Steve Block9fac8402011-05-12 15:51:54 +0100338 // Print in array notation for non-sparse arrays.
339 FixedArray* p = FixedArray::cast(elements());
340 for (int i = 0; i < p->length(); i++) {
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000341 os << "\n " << i << ": " << Brief(p->get(i));
Steve Block9fac8402011-05-12 15:51:54 +0100342 }
343 break;
344 }
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000345 case FAST_HOLEY_DOUBLE_ELEMENTS:
Ben Murdoch69a99ed2011-11-30 16:03:39 +0000346 case FAST_DOUBLE_ELEMENTS: {
347 // Print in array notation for non-sparse arrays.
Ben Murdoch5710cea2012-05-21 14:52:42 +0100348 if (elements()->length() > 0) {
349 FixedDoubleArray* p = FixedDoubleArray::cast(elements());
350 for (int i = 0; i < p->length(); i++) {
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000351 os << "\n " << i << ": ";
Ben Murdoch5710cea2012-05-21 14:52:42 +0100352 if (p->is_the_hole(i)) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000353 os << "<the hole>";
Ben Murdoch5710cea2012-05-21 14:52:42 +0100354 } else {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000355 os << p->get_scalar(i);
Ben Murdoch5710cea2012-05-21 14:52:42 +0100356 }
Ben Murdoch69a99ed2011-11-30 16:03:39 +0000357 }
Ben Murdoch69a99ed2011-11-30 16:03:39 +0000358 }
359 break;
360 }
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000361
362
363#define PRINT_ELEMENTS(Kind, Type) \
364 case Kind: { \
365 DoPrintElements<Type>(os, elements()); \
366 break; \
367 }
368
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000369 PRINT_ELEMENTS(UINT8_ELEMENTS, FixedUint8Array)
370 PRINT_ELEMENTS(UINT8_CLAMPED_ELEMENTS, FixedUint8ClampedArray)
371 PRINT_ELEMENTS(INT8_ELEMENTS, FixedInt8Array)
372 PRINT_ELEMENTS(UINT16_ELEMENTS, FixedUint16Array)
373 PRINT_ELEMENTS(INT16_ELEMENTS, FixedInt16Array)
374 PRINT_ELEMENTS(UINT32_ELEMENTS, FixedUint32Array)
375 PRINT_ELEMENTS(INT32_ELEMENTS, FixedInt32Array)
376 PRINT_ELEMENTS(FLOAT32_ELEMENTS, FixedFloat32Array)
377 PRINT_ELEMENTS(FLOAT64_ELEMENTS, FixedFloat64Array)
378
379#undef PRINT_ELEMENTS
380
Steve Block9fac8402011-05-12 15:51:54 +0100381 case DICTIONARY_ELEMENTS:
Ben Murdoch097c5b22016-05-18 11:27:45 +0100382 case SLOW_STRING_WRAPPER_ELEMENTS:
383 os << "\n - elements: ";
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000384 elements()->Print(os);
Steve Block9fac8402011-05-12 15:51:54 +0100385 break;
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000386 case FAST_SLOPPY_ARGUMENTS_ELEMENTS:
387 case SLOW_SLOPPY_ARGUMENTS_ELEMENTS: {
Ben Murdoch3fb3ca82011-12-02 17:19:32 +0000388 FixedArray* p = FixedArray::cast(elements());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000389 os << "\n parameter map:";
Ben Murdoch3fb3ca82011-12-02 17:19:32 +0000390 for (int i = 2; i < p->length(); i++) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000391 os << " " << (i - 2) << ":" << Brief(p->get(i));
Ben Murdoch3fb3ca82011-12-02 17:19:32 +0000392 }
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000393 os << "\n context: " << Brief(p->get(0))
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000394 << "\n arguments: " << Brief(p->get(1));
Ben Murdoch3fb3ca82011-12-02 17:19:32 +0000395 break;
396 }
Ben Murdoch097c5b22016-05-18 11:27:45 +0100397 case NO_ELEMENTS:
398 break;
Steve Block9fac8402011-05-12 15:51:54 +0100399 }
400}
401
402
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000403static void JSObjectPrintHeader(std::ostream& os, JSObject* obj,
404 const char* id) { // NOLINT
405 obj->PrintHeader(os, id);
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100406 // Don't call GetElementsKind, its validation code can cause the printer to
407 // fail when debugging.
Ben Murdochc5610432016-08-08 18:44:38 +0100408 os << "\n - map = " << reinterpret_cast<void*>(obj->map()) << " [";
409 if (obj->HasFastProperties()) {
410 os << "FastProperties";
411 } else {
412 os << "DictionaryProperties";
413 }
414 PrototypeIterator iter(obj->GetIsolate(), obj);
415 os << "]\n - prototype = " << reinterpret_cast<void*>(iter.GetCurrent());
416 os << "\n - elements = " << Brief(obj->elements()) << " ["
Ben Murdochda12d292016-06-02 14:46:10 +0100417 << ElementsKindToString(obj->map()->elements_kind());
418 if (obj->elements()->map() == obj->GetHeap()->fixed_cow_array_map()) {
419 os << " (COW)";
420 }
Ben Murdochc5610432016-08-08 18:44:38 +0100421 os << "]";
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000422}
423
424
425static void JSObjectPrintBody(std::ostream& os, JSObject* obj, // NOLINT
426 bool print_elements = true) {
427 os << "\n {";
428 obj->PrintProperties(os);
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000429 if (print_elements) obj->PrintElements(os);
430 os << "\n }\n";
431}
432
433
434void JSObject::JSObjectPrint(std::ostream& os) { // NOLINT
Ben Murdochc5610432016-08-08 18:44:38 +0100435 JSObjectPrintHeader(os, this, nullptr);
436 JSObjectPrintBody(os, this);
437}
438
439void JSArray::JSArrayPrint(std::ostream& os) { // NOLINT
440 JSObjectPrintHeader(os, this, "JSArray");
441 os << "\n - length = " << Brief(this->length());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000442 JSObjectPrintBody(os, this);
443}
444
445
446void JSRegExp::JSRegExpPrint(std::ostream& os) { // NOLINT
447 JSObjectPrintHeader(os, this, "JSRegExp");
448 os << "\n - data = " << Brief(data());
449 JSObjectPrintBody(os, this);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000450}
451
452
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400453void JSModule::JSModulePrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000454 JSObjectPrintHeader(os, this, "JSModule");
455 os << "\n - context = " << Brief(context());
456 os << " - scope_info = " << Brief(scope_info());
457 JSObjectPrintBody(os, this);
Steve Block9fac8402011-05-12 15:51:54 +0100458}
459
460
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400461void Symbol::SymbolPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000462 HeapObject::PrintHeader(os, "Symbol");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100463 os << "\n - hash: " << Hash();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000464 os << "\n - name: " << Brief(name());
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400465 if (name()->IsUndefined()) {
466 os << " (" << PrivateSymbolToName() << ")";
467 }
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000468 os << "\n - private: " << is_private();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000469 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +0100470}
471
472
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400473void Map::MapPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000474 HeapObject::PrintHeader(os, "Map");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100475 os << "\n - type: " << instance_type();
476 os << "\n - instance size: " << instance_size();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000477 if (IsJSObjectMap()) {
Ben Murdoch097c5b22016-05-18 11:27:45 +0100478 os << "\n - inobject properties: " << GetInObjectProperties();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000479 }
Ben Murdoch097c5b22016-05-18 11:27:45 +0100480 os << "\n - elements kind: " << ElementsKindToString(elements_kind());
481 os << "\n - unused property fields: " << unused_property_fields();
Ben Murdochda12d292016-06-02 14:46:10 +0100482 os << "\n - enum length: ";
483 if (EnumLength() == kInvalidEnumCacheSentinel) {
484 os << "invalid";
485 } else {
486 os << EnumLength();
487 }
Ben Murdoch097c5b22016-05-18 11:27:45 +0100488 if (is_deprecated()) os << "\n - deprecated_map";
489 if (is_stable()) os << "\n - stable_map";
490 if (is_dictionary_map()) os << "\n - dictionary_map";
491 if (has_hidden_prototype()) os << "\n - has_hidden_prototype";
492 if (has_named_interceptor()) os << " - named_interceptor";
493 if (has_indexed_interceptor()) os << "\n - indexed_interceptor";
494 if (is_undetectable()) os << "\n - undetectable";
495 if (is_callable()) os << "\n - callable";
496 if (is_constructor()) os << "\n - constructor";
497 if (is_access_check_needed()) os << "\n - access_check_needed";
498 if (!is_extensible()) os << "\n - non-extensible";
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000499 if (is_prototype_map()) {
Ben Murdoch097c5b22016-05-18 11:27:45 +0100500 os << "\n - prototype_map";
501 os << "\n - prototype info: " << Brief(prototype_info());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000502 } else {
Ben Murdoch097c5b22016-05-18 11:27:45 +0100503 os << "\n - back pointer: " << Brief(GetBackPointer());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000504 }
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000505 os << "\n - instance descriptors " << (owns_descriptors() ? "(own) " : "")
506 << "#" << NumberOfOwnDescriptors() << ": "
507 << Brief(instance_descriptors());
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400508 if (FLAG_unbox_double_fields) {
509 os << "\n - layout descriptor: " << Brief(layout_descriptor());
510 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000511 int nof_transitions = TransitionArray::NumberOfTransitions(raw_transitions());
512 if (nof_transitions > 0) {
513 os << "\n - transitions #" << nof_transitions << ": "
514 << Brief(raw_transitions());
515 TransitionArray::PrintTransitions(os, raw_transitions(), false);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000516 }
517 os << "\n - prototype: " << Brief(prototype());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000518 os << "\n - constructor: " << Brief(GetConstructor());
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000519 os << "\n - code cache: " << Brief(code_cache());
520 os << "\n - dependent code: " << Brief(dependent_code());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000521 os << "\n - construction counter: " << construction_counter();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000522 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +0100523}
524
525
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400526void TypeFeedbackInfo::TypeFeedbackInfoPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000527 HeapObject::PrintHeader(os, "TypeFeedbackInfo");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100528 os << "\n - ic_total_count: " << ic_total_count()
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000529 << ", ic_with_type_info_count: " << ic_with_type_info_count()
530 << ", ic_generic_count: " << ic_generic_count() << "\n";
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100531}
532
533
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400534void AliasedArgumentsEntry::AliasedArgumentsEntryPrint(
535 std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000536 HeapObject::PrintHeader(os, "AliasedArgumentsEntry");
537 os << "\n - aliased_context_slot: " << aliased_context_slot();
538}
539
540
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400541void FixedArray::FixedArrayPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000542 HeapObject::PrintHeader(os, "FixedArray");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100543 os << "\n - length: " << length();
Steve Block9fac8402011-05-12 15:51:54 +0100544 for (int i = 0; i < length(); i++) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000545 os << "\n [" << i << "]: " << Brief(get(i));
Steve Block9fac8402011-05-12 15:51:54 +0100546 }
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000547 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +0100548}
549
550
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400551void FixedDoubleArray::FixedDoubleArrayPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000552 HeapObject::PrintHeader(os, "FixedDoubleArray");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100553 os << "\n - length: " << length();
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100554 for (int i = 0; i < length(); i++) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000555 os << "\n [" << i << "]: ";
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100556 if (is_the_hole(i)) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000557 os << "<the hole>";
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100558 } else {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000559 os << get_scalar(i);
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100560 }
561 }
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000562 os << "\n";
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100563}
564
565
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000566void TransitionArray::TransitionArrayPrint(std::ostream& os) { // NOLINT
567 HeapObject::PrintHeader(os, "TransitionArray");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100568 os << "\n - capacity: " << length();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000569 for (int i = 0; i < length(); i++) {
570 os << "\n [" << i << "]: " << Brief(get(i));
571 if (i == kNextLinkIndex) os << " (next link)";
572 if (i == kPrototypeTransitionsIndex) os << " (prototype transitions)";
573 if (i == kTransitionLengthIndex) os << " (number of transitions)";
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000574 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000575 os << "\n";
576}
577
578
579void TypeFeedbackMetadata::Print() {
580 OFStream os(stdout);
581 TypeFeedbackMetadataPrint(os);
582 os << std::flush;
583}
584
585
586void TypeFeedbackMetadata::TypeFeedbackMetadataPrint(
587 std::ostream& os) { // NOLINT
588 HeapObject::PrintHeader(os, "TypeFeedbackMetadata");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100589 os << "\n - length: " << length();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000590 if (length() == 0) {
591 os << " (empty)\n";
592 return;
593 }
594
595 TypeFeedbackMetadataIterator iter(this);
596 while (iter.HasNext()) {
597 FeedbackVectorSlot slot = iter.Next();
598 FeedbackVectorSlotKind kind = iter.kind();
599 os << "\n Slot " << slot << " " << kind;
600 }
601 os << "\n";
602}
603
604
605void TypeFeedbackVector::Print() {
606 OFStream os(stdout);
607 TypeFeedbackVectorPrint(os);
608 os << std::flush;
609}
610
611
612void TypeFeedbackVector::TypeFeedbackVectorPrint(std::ostream& os) { // NOLINT
613 HeapObject::PrintHeader(os, "TypeFeedbackVector");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100614 os << "\n - length: " << length();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000615 if (length() == 0) {
616 os << " (empty)\n";
617 return;
618 }
619
620 TypeFeedbackMetadataIterator iter(metadata());
621 while (iter.HasNext()) {
622 FeedbackVectorSlot slot = iter.Next();
623 FeedbackVectorSlotKind kind = iter.kind();
624
625 os << "\n Slot " << slot << " " << kind << " ";
626 switch (kind) {
627 case FeedbackVectorSlotKind::LOAD_IC: {
628 LoadICNexus nexus(this, slot);
629 os << Code::ICState2String(nexus.StateFromFeedback());
630 break;
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000631 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000632 case FeedbackVectorSlotKind::KEYED_LOAD_IC: {
633 KeyedLoadICNexus nexus(this, slot);
634 os << Code::ICState2String(nexus.StateFromFeedback());
635 break;
636 }
637 case FeedbackVectorSlotKind::CALL_IC: {
638 CallICNexus nexus(this, slot);
639 os << Code::ICState2String(nexus.StateFromFeedback());
640 break;
641 }
642 case FeedbackVectorSlotKind::STORE_IC: {
643 StoreICNexus nexus(this, slot);
644 os << Code::ICState2String(nexus.StateFromFeedback());
645 break;
646 }
647 case FeedbackVectorSlotKind::KEYED_STORE_IC: {
648 KeyedStoreICNexus nexus(this, slot);
649 os << Code::ICState2String(nexus.StateFromFeedback());
650 break;
651 }
652 case FeedbackVectorSlotKind::GENERAL:
653 break;
654 case FeedbackVectorSlotKind::INVALID:
655 case FeedbackVectorSlotKind::KINDS_NUMBER:
656 UNREACHABLE();
657 break;
658 }
659
660 int entry_size = iter.entry_size();
661 for (int i = 0; i < entry_size; i++) {
662 int index = GetIndex(slot) + i;
663 os << "\n [" << index << "]: " << Brief(get(index));
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000664 }
665 }
666 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +0100667}
668
669
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400670void JSValue::JSValuePrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000671 JSObjectPrintHeader(os, this, "JSValue");
672 os << "\n - value = " << Brief(value());
673 JSObjectPrintBody(os, this);
Steve Block1e0659c2011-05-24 12:43:12 +0100674}
675
676
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400677void JSMessageObject::JSMessageObjectPrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000678 JSObjectPrintHeader(os, this, "JSMessageObject");
679 os << "\n - type: " << type();
680 os << "\n - arguments: " << Brief(argument());
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000681 os << "\n - start_position: " << start_position();
682 os << "\n - end_position: " << end_position();
683 os << "\n - script: " << Brief(script());
684 os << "\n - stack_frames: " << Brief(stack_frames());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000685 JSObjectPrintBody(os, this);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000686}
687
688
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400689void String::StringPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000690 if (StringShape(this).IsInternalized()) {
691 os << "#";
Steve Block9fac8402011-05-12 15:51:54 +0100692 } else if (StringShape(this).IsCons()) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000693 os << "c\"";
Steve Block9fac8402011-05-12 15:51:54 +0100694 } else {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000695 os << "\"";
Steve Block9fac8402011-05-12 15:51:54 +0100696 }
697
698 const char truncated_epilogue[] = "...<truncated>";
699 int len = length();
700 if (!FLAG_use_verbose_printer) {
701 if (len > 100) {
702 len = 100 - sizeof(truncated_epilogue);
703 }
704 }
705 for (int i = 0; i < len; i++) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000706 os << AsUC16(Get(i));
Steve Block9fac8402011-05-12 15:51:54 +0100707 }
708 if (len != length()) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000709 os << truncated_epilogue;
Steve Block9fac8402011-05-12 15:51:54 +0100710 }
711
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000712 if (!StringShape(this).IsInternalized()) os << "\"";
713}
714
715
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400716void Name::NamePrint(std::ostream& os) { // NOLINT
717 if (IsString()) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000718 String::cast(this)->StringPrint(os);
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400719 } else if (IsSymbol()) {
720 Symbol::cast(this)->name()->Print(os);
721 } else {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000722 os << Brief(this);
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400723 }
Ben Murdoch69a99ed2011-11-30 16:03:39 +0000724}
725
726
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100727static const char* const weekdays[] = {
728 "???", "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"
729};
730
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000731
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400732void JSDate::JSDatePrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000733 JSObjectPrintHeader(os, this, "JSDate");
734 os << "\n - value = " << Brief(value());
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100735 if (!year()->IsSmi()) {
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000736 os << "\n - time = NaN\n";
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100737 } else {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000738 // TODO(svenpanne) Add some basic formatting to our streams.
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000739 ScopedVector<char> buf(100);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000740 SNPrintF(
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000741 buf, "\n - time = %s %04d/%02d/%02d %02d:%02d:%02d\n",
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000742 weekdays[weekday()->IsSmi() ? Smi::cast(weekday())->value() + 1 : 0],
743 year()->IsSmi() ? Smi::cast(year())->value() : -1,
744 month()->IsSmi() ? Smi::cast(month())->value() : -1,
745 day()->IsSmi() ? Smi::cast(day())->value() : -1,
746 hour()->IsSmi() ? Smi::cast(hour())->value() : -1,
747 min()->IsSmi() ? Smi::cast(min())->value() : -1,
748 sec()->IsSmi() ? Smi::cast(sec())->value() : -1);
749 os << buf.start();
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100750 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000751 JSObjectPrintBody(os, this);
Ben Murdoch3ef787d2012-04-12 10:51:47 +0100752}
753
754
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400755void JSProxy::JSProxyPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000756 HeapObject::PrintHeader(os, "JSProxy");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100757 os << "\n - map = " << reinterpret_cast<void*>(map());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000758 os << "\n - target = ";
759 target()->ShortPrint(os);
760 os << "\n - handler = ";
761 handler()->ShortPrint(os);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000762 os << "\n - hash = ";
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000763 hash()->ShortPrint(os);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000764 os << "\n";
Ben Murdoch589d6972011-11-30 16:04:58 +0000765}
766
767
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400768void JSSet::JSSetPrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000769 JSObjectPrintHeader(os, this, "JSSet");
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000770 os << " - table = " << Brief(table());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000771 JSObjectPrintBody(os, this);
Ben Murdoch69a99ed2011-11-30 16:03:39 +0000772}
773
774
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400775void JSMap::JSMapPrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000776 JSObjectPrintHeader(os, this, "JSMap");
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000777 os << " - table = " << Brief(table());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000778 JSObjectPrintBody(os, this);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000779}
780
781
782template <class Derived, class TableType>
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400783void
784OrderedHashTableIterator<Derived, TableType>::OrderedHashTableIteratorPrint(
785 std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000786 os << "\n - table = " << Brief(table());
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000787 os << "\n - index = " << Brief(index());
788 os << "\n - kind = " << Brief(kind());
789 os << "\n";
790}
791
792
793template void OrderedHashTableIterator<
794 JSSetIterator,
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400795 OrderedHashSet>::OrderedHashTableIteratorPrint(std::ostream& os); // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000796
797
798template void OrderedHashTableIterator<
799 JSMapIterator,
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400800 OrderedHashMap>::OrderedHashTableIteratorPrint(std::ostream& os); // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000801
802
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400803void JSSetIterator::JSSetIteratorPrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000804 JSObjectPrintHeader(os, this, "JSSetIterator");
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000805 OrderedHashTableIteratorPrint(os);
806}
807
808
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400809void JSMapIterator::JSMapIteratorPrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000810 JSObjectPrintHeader(os, this, "JSMapIterator");
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000811 OrderedHashTableIteratorPrint(os);
812}
813
814
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000815void JSWeakMap::JSWeakMapPrint(std::ostream& os) { // NOLINT
816 JSObjectPrintHeader(os, this, "JSWeakMap");
817 os << "\n - table = " << Brief(table());
818 JSObjectPrintBody(os, this);
819}
820
821
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400822void JSWeakSet::JSWeakSetPrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000823 JSObjectPrintHeader(os, this, "JSWeakSet");
824 os << "\n - table = " << Brief(table());
825 JSObjectPrintBody(os, this);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000826}
827
828
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400829void JSArrayBuffer::JSArrayBufferPrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000830 JSObjectPrintHeader(os, this, "JSArrayBuffer");
831 os << "\n - backing_store = " << backing_store();
832 os << "\n - byte_length = " << Brief(byte_length());
833 if (was_neutered()) os << " - neutered\n";
834 JSObjectPrintBody(os, this, !was_neutered());
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000835}
836
837
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400838void JSTypedArray::JSTypedArrayPrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000839 JSObjectPrintHeader(os, this, "JSTypedArray");
840 os << "\n - buffer = " << Brief(buffer());
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000841 os << "\n - byte_offset = " << Brief(byte_offset());
842 os << "\n - byte_length = " << Brief(byte_length());
843 os << "\n - length = " << Brief(length());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000844 if (WasNeutered()) os << " - neutered\n";
845 JSObjectPrintBody(os, this, !WasNeutered());
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000846}
847
848
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400849void JSDataView::JSDataViewPrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000850 JSObjectPrintHeader(os, this, "JSDataView");
851 os << "\n - buffer =" << Brief(buffer());
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000852 os << "\n - byte_offset = " << Brief(byte_offset());
853 os << "\n - byte_length = " << Brief(byte_length());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000854 if (WasNeutered()) os << " - neutered\n";
855 JSObjectPrintBody(os, this, !WasNeutered());
856}
857
858
859void JSBoundFunction::JSBoundFunctionPrint(std::ostream& os) { // NOLINT
860 JSObjectPrintHeader(os, this, "JSBoundFunction");
861 os << "\n - bound_target_function = " << Brief(bound_target_function());
862 os << "\n - bound_this = " << Brief(bound_this());
863 os << "\n - bound_arguments = " << Brief(bound_arguments());
864 JSObjectPrintBody(os, this);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000865}
866
867
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400868void JSFunction::JSFunctionPrint(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000869 JSObjectPrintHeader(os, this, "Function");
870 os << "\n - initial_map = ";
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000871 if (has_initial_map()) os << Brief(initial_map());
872 os << "\n - shared_info = " << Brief(shared());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000873 os << "\n - name = " << Brief(shared()->name());
Ben Murdochda12d292016-06-02 14:46:10 +0100874 os << "\n - formal_parameter_count = "
875 << shared()->internal_formal_parameter_count();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000876 if (shared()->is_generator()) {
877 os << "\n - generator";
Steve Block9fac8402011-05-12 15:51:54 +0100878 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000879 os << "\n - context = " << Brief(context());
880 os << "\n - literals = " << Brief(literals());
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000881 os << "\n - code = " << Brief(code());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000882 JSObjectPrintBody(os, this);
Steve Block9fac8402011-05-12 15:51:54 +0100883}
884
885
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400886void SharedFunctionInfo::SharedFunctionInfoPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000887 HeapObject::PrintHeader(os, "SharedFunctionInfo");
Ben Murdochda12d292016-06-02 14:46:10 +0100888 os << "\n - name = " << Brief(name());
889 os << "\n - formal_parameter_count = " << internal_formal_parameter_count();
890 os << "\n - expected_nof_properties = " << expected_nof_properties();
891 os << "\n - ast_node_count = " << ast_node_count();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000892 os << "\n - instance class name = ";
893 instance_class_name()->Print(os);
894 os << "\n - code = " << Brief(code());
895 if (HasSourceCode()) {
896 os << "\n - source code = ";
897 String* source = String::cast(Script::cast(script())->source());
898 int start = start_position();
899 int length = end_position() - start;
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000900 base::SmartArrayPointer<char> source_string = source->ToCString(
901 DISALLOW_NULLS, FAST_STRING_TRAVERSAL, start, length, NULL);
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000902 os << source_string.get();
903 }
Steve Block9fac8402011-05-12 15:51:54 +0100904 // Script files are often large, hard to read.
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000905 // os << "\n - script =";
906 // script()->Print(os);
Ben Murdoch097c5b22016-05-18 11:27:45 +0100907 if (is_named_expression()) {
908 os << "\n - named expression";
909 } else if (is_anonymous_expression()) {
910 os << "\n - anonymous expression";
911 } else if (is_declaration()) {
912 os << "\n - declaration";
913 }
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000914 os << "\n - function token position = " << function_token_position();
915 os << "\n - start position = " << start_position();
916 os << "\n - end position = " << end_position();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000917 os << "\n - debug info = " << Brief(debug_info());
918 os << "\n - length = " << length();
919 os << "\n - optimized_code_map = " << Brief(optimized_code_map());
920 os << "\n - feedback_vector = ";
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000921 feedback_vector()->TypeFeedbackVectorPrint(os);
922 if (HasBytecodeArray()) {
923 os << "\n - bytecode_array = " << bytecode_array();
924 }
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000925 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +0100926}
927
928
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400929void JSGlobalProxy::JSGlobalProxyPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000930 os << "global_proxy ";
931 JSObjectPrint(os);
932 os << "native context : " << Brief(native_context());
933 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +0100934}
935
936
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400937void JSGlobalObject::JSGlobalObjectPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000938 os << "global ";
939 JSObjectPrint(os);
940 os << "native context : " << Brief(native_context());
941 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +0100942}
943
944
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400945void Cell::CellPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000946 HeapObject::PrintHeader(os, "Cell");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100947 os << "\n - value: " << Brief(value());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000948 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +0100949}
950
951
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400952void PropertyCell::PropertyCellPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000953 HeapObject::PrintHeader(os, "PropertyCell");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100954 os << "\n - value: " << Brief(value());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000955 os << "\n - details: " << property_details();
956 os << "\n";
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000957}
958
959
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400960void WeakCell::WeakCellPrint(std::ostream& os) { // NOLINT
961 HeapObject::PrintHeader(os, "WeakCell");
962 if (cleared()) {
963 os << "\n - cleared";
964 } else {
965 os << "\n - value: " << Brief(value());
966 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000967 os << "\n";
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400968}
969
970
971void Code::CodePrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000972 HeapObject::PrintHeader(os, "Code");
Ben Murdoch097c5b22016-05-18 11:27:45 +0100973 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +0100974#ifdef ENABLE_DISASSEMBLER
975 if (FLAG_use_verbose_printer) {
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000976 Disassemble(NULL, os);
Steve Block9fac8402011-05-12 15:51:54 +0100977 }
978#endif
979}
980
981
Emily Bernierd0a1eb72015-03-24 16:35:39 -0400982void Foreign::ForeignPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000983 os << "foreign address : " << foreign_address();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000984 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +0100985}
986
987
Ben Murdoch097c5b22016-05-18 11:27:45 +0100988void AccessorInfo::AccessorInfoPrint(std::ostream& os) { // NOLINT
989 HeapObject::PrintHeader(os, "AccessorInfo");
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000990 os << "\n - name: " << Brief(name());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000991 os << "\n - flag: " << flag();
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000992 os << "\n - getter: " << Brief(getter());
993 os << "\n - setter: " << Brief(setter());
Ben Murdochc5610432016-08-08 18:44:38 +0100994 os << "\n - js_getter: " << Brief(js_getter());
Ben Murdochb8a8cc12014-11-26 15:28:44 +0000995 os << "\n - data: " << Brief(data());
996 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +0100997}
998
999
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001000void Box::BoxPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001001 HeapObject::PrintHeader(os, "Box");
1002 os << "\n - value: " << Brief(value());
1003 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +01001004}
1005
1006
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001007void PrototypeInfo::PrototypeInfoPrint(std::ostream& os) { // NOLINT
1008 HeapObject::PrintHeader(os, "PrototypeInfo");
1009 os << "\n - prototype users: " << Brief(prototype_users());
1010 os << "\n - registry slot: " << registry_slot();
1011 os << "\n - validity cell: " << Brief(validity_cell());
1012 os << "\n";
1013}
1014
1015
1016void SloppyBlockWithEvalContextExtension::
1017 SloppyBlockWithEvalContextExtensionPrint(std::ostream& os) { // NOLINT
1018 HeapObject::PrintHeader(os, "SloppyBlockWithEvalContextExtension");
1019 os << "\n - scope_info: " << Brief(scope_info());
1020 os << "\n - extension: " << Brief(extension());
1021 os << "\n";
1022}
1023
1024
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001025void AccessorPair::AccessorPairPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001026 HeapObject::PrintHeader(os, "AccessorPair");
1027 os << "\n - getter: " << Brief(getter());
1028 os << "\n - setter: " << Brief(setter());
1029 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +01001030}
1031
1032
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001033void AccessCheckInfo::AccessCheckInfoPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001034 HeapObject::PrintHeader(os, "AccessCheckInfo");
1035 os << "\n - named_callback: " << Brief(named_callback());
1036 os << "\n - indexed_callback: " << Brief(indexed_callback());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001037 os << "\n - callback: " << Brief(callback());
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001038 os << "\n - data: " << Brief(data());
1039 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +01001040}
1041
1042
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001043void InterceptorInfo::InterceptorInfoPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001044 HeapObject::PrintHeader(os, "InterceptorInfo");
1045 os << "\n - getter: " << Brief(getter());
1046 os << "\n - setter: " << Brief(setter());
1047 os << "\n - query: " << Brief(query());
1048 os << "\n - deleter: " << Brief(deleter());
1049 os << "\n - enumerator: " << Brief(enumerator());
1050 os << "\n - data: " << Brief(data());
1051 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +01001052}
1053
1054
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001055void CallHandlerInfo::CallHandlerInfoPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001056 HeapObject::PrintHeader(os, "CallHandlerInfo");
1057 os << "\n - callback: " << Brief(callback());
1058 os << "\n - data: " << Brief(data());
1059 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +01001060}
1061
1062
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001063void FunctionTemplateInfo::FunctionTemplateInfoPrint(
1064 std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001065 HeapObject::PrintHeader(os, "FunctionTemplateInfo");
1066 os << "\n - class name: " << Brief(class_name());
1067 os << "\n - tag: " << Brief(tag());
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001068 os << "\n - serial_number: " << Brief(serial_number());
Ben Murdoch097c5b22016-05-18 11:27:45 +01001069 os << "\n - property_list: " << Brief(property_list());
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001070 os << "\n - call_code: " << Brief(call_code());
1071 os << "\n - property_accessors: " << Brief(property_accessors());
1072 os << "\n - prototype_template: " << Brief(prototype_template());
1073 os << "\n - parent_template: " << Brief(parent_template());
1074 os << "\n - named_property_handler: " << Brief(named_property_handler());
1075 os << "\n - indexed_property_handler: " << Brief(indexed_property_handler());
1076 os << "\n - instance_template: " << Brief(instance_template());
1077 os << "\n - signature: " << Brief(signature());
1078 os << "\n - access_check_info: " << Brief(access_check_info());
1079 os << "\n - hidden_prototype: " << (hidden_prototype() ? "true" : "false");
1080 os << "\n - undetectable: " << (undetectable() ? "true" : "false");
1081 os << "\n - need_access_check: " << (needs_access_check() ? "true" : "false");
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001082 os << "\n - instantiated: " << (instantiated() ? "true" : "false");
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001083 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +01001084}
1085
1086
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001087void ObjectTemplateInfo::ObjectTemplateInfoPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001088 HeapObject::PrintHeader(os, "ObjectTemplateInfo");
Ben Murdoch097c5b22016-05-18 11:27:45 +01001089 os << "\n - tag: " << Brief(tag());
1090 os << "\n - serial_number: " << Brief(serial_number());
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001091 os << "\n - property_list: " << Brief(property_list());
1092 os << "\n - property_accessors: " << Brief(property_accessors());
1093 os << "\n - constructor: " << Brief(constructor());
1094 os << "\n - internal_field_count: " << Brief(internal_field_count());
1095 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +01001096}
1097
1098
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001099void AllocationSite::AllocationSitePrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001100 HeapObject::PrintHeader(os, "AllocationSite");
Ben Murdoch097c5b22016-05-18 11:27:45 +01001101 os << "\n - weak_next: " << Brief(weak_next());
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001102 os << "\n - dependent code: " << Brief(dependent_code());
1103 os << "\n - nested site: " << Brief(nested_site());
1104 os << "\n - memento found count: "
1105 << Brief(Smi::FromInt(memento_found_count()));
1106 os << "\n - memento create count: "
1107 << Brief(Smi::FromInt(memento_create_count()));
1108 os << "\n - pretenure decision: "
1109 << Brief(Smi::FromInt(pretenure_decision()));
1110 os << "\n - transition_info: ";
1111 if (transition_info()->IsSmi()) {
1112 ElementsKind kind = GetElementsKind();
1113 os << "Array allocation with ElementsKind " << ElementsKindToString(kind);
1114 } else if (transition_info()->IsJSArray()) {
1115 os << "Array literal " << Brief(transition_info());
1116 } else {
1117 os << "unknown transition_info" << Brief(transition_info());
1118 }
1119 os << "\n";
1120}
1121
1122
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001123void AllocationMemento::AllocationMementoPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001124 HeapObject::PrintHeader(os, "AllocationMemento");
Ben Murdoch097c5b22016-05-18 11:27:45 +01001125 os << "\n - allocation site: ";
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001126 if (IsValid()) {
1127 GetAllocationSite()->Print(os);
1128 } else {
1129 os << "<invalid>\n";
1130 }
1131}
1132
1133
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001134void Script::ScriptPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001135 HeapObject::PrintHeader(os, "Script");
1136 os << "\n - source: " << Brief(source());
1137 os << "\n - name: " << Brief(name());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001138 os << "\n - line_offset: " << line_offset();
1139 os << "\n - column_offset: " << column_offset();
1140 os << "\n - type: " << type();
1141 os << "\n - id: " << id();
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001142 os << "\n - context data: " << Brief(context_data());
1143 os << "\n - wrapper: " << Brief(wrapper());
1144 os << "\n - compilation type: " << compilation_type();
1145 os << "\n - line ends: " << Brief(line_ends());
1146 os << "\n - eval from shared: " << Brief(eval_from_shared());
Ben Murdochc5610432016-08-08 18:44:38 +01001147 os << "\n - eval from position: " << eval_from_position();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001148 os << "\n - shared function infos: " << Brief(shared_function_infos());
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001149 os << "\n";
1150}
1151
1152
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001153void DebugInfo::DebugInfoPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001154 HeapObject::PrintHeader(os, "DebugInfo");
1155 os << "\n - shared: " << Brief(shared());
Ben Murdoch097c5b22016-05-18 11:27:45 +01001156 os << "\n - code: " << Brief(abstract_code());
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001157 os << "\n - break_points: ";
1158 break_points()->Print(os);
1159}
1160
1161
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001162void BreakPointInfo::BreakPointInfoPrint(std::ostream& os) { // NOLINT
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001163 HeapObject::PrintHeader(os, "BreakPointInfo");
Ben Murdoch097c5b22016-05-18 11:27:45 +01001164 os << "\n - code_offset: " << code_offset();
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001165 os << "\n - source_position: " << source_position();
1166 os << "\n - statement_position: " << statement_position();
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001167 os << "\n - break_point_objects: " << Brief(break_point_objects());
1168 os << "\n";
1169}
1170
1171
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001172static void PrintBitMask(std::ostream& os, uint32_t value) { // NOLINT
1173 for (int i = 0; i < 32; i++) {
1174 if ((i & 7) == 0) os << " ";
1175 os << (((value & 1) == 0) ? "_" : "x");
1176 value >>= 1;
Steve Block9fac8402011-05-12 15:51:54 +01001177 }
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001178}
1179
1180
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001181void LayoutDescriptor::Print() {
1182 OFStream os(stdout);
1183 this->Print(os);
1184 os << std::flush;
1185}
1186
1187
1188void LayoutDescriptor::Print(std::ostream& os) { // NOLINT
1189 os << "Layout descriptor: ";
1190 if (IsUninitialized()) {
1191 os << "<uninitialized>";
1192 } else if (IsFastPointerLayout()) {
1193 os << "<all tagged>";
1194 } else if (IsSmi()) {
1195 os << "fast";
1196 PrintBitMask(os, static_cast<uint32_t>(Smi::cast(this)->value()));
1197 } else {
1198 os << "slow";
1199 int len = length();
1200 for (int i = 0; i < len; i++) {
1201 if (i > 0) os << " |";
1202 PrintBitMask(os, get_scalar(i));
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001203 }
1204 }
1205 os << "\n";
Steve Block9fac8402011-05-12 15:51:54 +01001206}
1207
1208
1209#endif // OBJECT_PRINT
1210
1211
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001212#if TRACE_MAPS
1213
1214
1215void Name::NameShortPrint() {
1216 if (this->IsString()) {
1217 PrintF("%s", String::cast(this)->ToCString().get());
1218 } else {
1219 DCHECK(this->IsSymbol());
1220 Symbol* s = Symbol::cast(this);
1221 if (s->name()->IsUndefined()) {
1222 PrintF("#<%s>", s->PrivateSymbolToName());
1223 } else {
1224 PrintF("<%s>", String::cast(s->name())->ToCString().get());
1225 }
1226 }
1227}
1228
1229
1230int Name::NameShortPrint(Vector<char> str) {
1231 if (this->IsString()) {
1232 return SNPrintF(str, "%s", String::cast(this)->ToCString().get());
1233 } else {
1234 DCHECK(this->IsSymbol());
1235 Symbol* s = Symbol::cast(this);
1236 if (s->name()->IsUndefined()) {
1237 return SNPrintF(str, "#<%s>", s->PrivateSymbolToName());
1238 } else {
1239 return SNPrintF(str, "<%s>", String::cast(s->name())->ToCString().get());
1240 }
1241 }
1242}
1243
1244
1245#endif // TRACE_MAPS
1246
1247
1248#if defined(DEBUG) || defined(OBJECT_PRINT)
1249// This method is only meant to be called from gdb for debugging purposes.
1250// Since the string can also be in two-byte encoding, non-Latin1 characters
1251// will be ignored in the output.
1252char* String::ToAsciiArray() {
1253 // Static so that subsequent calls frees previously allocated space.
1254 // This also means that previous results will be overwritten.
1255 static char* buffer = NULL;
1256 if (buffer != NULL) delete[] buffer;
1257 buffer = new char[length() + 1];
1258 WriteToFlat(this, reinterpret_cast<uint8_t*>(buffer), 0, length());
1259 buffer[length()] = 0;
1260 return buffer;
1261}
1262
1263
1264void DescriptorArray::Print() {
1265 OFStream os(stdout);
1266 this->PrintDescriptors(os);
1267 os << std::flush;
1268}
1269
1270
1271void DescriptorArray::PrintDescriptors(std::ostream& os) { // NOLINT
1272 HandleScope scope(GetIsolate());
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001273 os << "Descriptor array #" << number_of_descriptors();
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001274 for (int i = 0; i < number_of_descriptors(); i++) {
1275 Descriptor desc;
1276 Get(i, &desc);
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001277 os << "\n " << i << ": " << desc;
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001278 }
1279 os << "\n";
1280}
1281
1282
1283void TransitionArray::Print() {
1284 OFStream os(stdout);
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001285 TransitionArray::PrintTransitions(os, this);
1286 os << "\n" << std::flush;
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001287}
1288
1289
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001290void TransitionArray::PrintTransitions(std::ostream& os, Object* transitions,
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001291 bool print_header) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001292 int num_transitions = NumberOfTransitions(transitions);
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001293 if (print_header) {
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001294 os << "Transition array #" << num_transitions << ":";
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001295 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001296 for (int i = 0; i < num_transitions; i++) {
1297 Name* key = GetKey(transitions, i);
1298 Map* target = GetTarget(transitions, i);
Ben Murdochc5610432016-08-08 18:44:38 +01001299 os << "\n ";
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001300#ifdef OBJECT_PRINT
1301 key->NamePrint(os);
1302#else
1303 key->ShortPrint(os);
1304#endif
1305 os << ": ";
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001306 Heap* heap = key->GetHeap();
1307 if (key == heap->nonextensible_symbol()) {
1308 os << "(transition to non-extensible)";
1309 } else if (key == heap->sealed_symbol()) {
1310 os << "(transition to sealed)";
1311 } else if (key == heap->frozen_symbol()) {
1312 os << "(transition to frozen)";
1313 } else if (key == heap->elements_transition_symbol()) {
1314 os << "(transition to " << ElementsKindToString(target->elements_kind())
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001315 << ")";
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001316 } else if (key == heap->strict_function_transition_symbol()) {
1317 os << " (transition to strict function)";
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001318 } else {
1319 PropertyDetails details = GetTargetDetails(key, target);
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001320 os << "(transition to ";
1321 if (details.location() == kDescriptor) {
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001322 os << "immutable ";
1323 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001324 os << (details.kind() == kData ? "data" : "accessor");
1325 if (details.location() == kDescriptor) {
1326 Object* value =
1327 target->instance_descriptors()->GetValue(target->LastAdded());
1328 os << " " << Brief(value);
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001329 }
1330 os << "), attrs: " << details.attributes();
1331 }
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001332 os << " -> " << Brief(target);
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001333 }
1334}
1335
1336
1337void JSObject::PrintTransitions(std::ostream& os) { // NOLINT
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001338 Object* transitions = map()->raw_transitions();
1339 int num_transitions = TransitionArray::NumberOfTransitions(transitions);
1340 if (num_transitions == 0) return;
1341 os << "\n - transitions";
1342 TransitionArray::PrintTransitions(os, transitions, false);
Emily Bernierd0a1eb72015-03-24 16:35:39 -04001343}
1344#endif // defined(DEBUG) || defined(OBJECT_PRINT)
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001345} // namespace internal
1346} // namespace v8