OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/v8.h" | 5 #include "src/v8.h" |
6 | 6 |
7 #include "src/disasm.h" | 7 #include "src/disasm.h" |
8 #include "src/disassembler.h" | 8 #include "src/disassembler.h" |
9 #include "src/heap/objects-visiting.h" | 9 #include "src/heap/objects-visiting.h" |
10 #include "src/jsregexp.h" | 10 #include "src/jsregexp.h" |
11 #include "src/ostreams.h" | 11 #include "src/ostreams.h" |
12 | 12 |
13 namespace v8 { | 13 namespace v8 { |
14 namespace internal { | 14 namespace internal { |
15 | 15 |
16 #ifdef OBJECT_PRINT | 16 #ifdef OBJECT_PRINT |
17 | 17 |
18 void Object::Print() { | 18 void Object::Print() { |
19 OFStream os(stdout); | 19 OFStream os(stdout); |
20 this->Print(os); | 20 this->Print(os); |
21 os << flush; | 21 os << std::flush; |
22 } | 22 } |
23 | 23 |
24 | 24 |
25 void Object::Print(OStream& os) { // NOLINT | 25 void Object::Print(std::ostream& os) { // NOLINT |
26 if (IsSmi()) { | 26 if (IsSmi()) { |
27 Smi::cast(this)->SmiPrint(os); | 27 Smi::cast(this)->SmiPrint(os); |
28 } else { | 28 } else { |
29 HeapObject::cast(this)->HeapObjectPrint(os); | 29 HeapObject::cast(this)->HeapObjectPrint(os); |
30 } | 30 } |
31 } | 31 } |
32 | 32 |
33 | 33 |
34 void HeapObject::PrintHeader(OStream& os, const char* id) { // NOLINT | 34 void HeapObject::PrintHeader(std::ostream& os, const char* id) { // NOLINT |
35 os << "" << reinterpret_cast<void*>(this) << ": [" << id << "]\n"; | 35 os << "" << reinterpret_cast<void*>(this) << ": [" << id << "]\n"; |
36 } | 36 } |
37 | 37 |
38 | 38 |
39 void HeapObject::HeapObjectPrint(OStream& os) { // NOLINT | 39 void HeapObject::HeapObjectPrint(std::ostream& os) { // NOLINT |
40 InstanceType instance_type = map()->instance_type(); | 40 InstanceType instance_type = map()->instance_type(); |
41 | 41 |
42 HandleScope scope(GetIsolate()); | 42 HandleScope scope(GetIsolate()); |
43 if (instance_type < FIRST_NONSTRING_TYPE) { | 43 if (instance_type < FIRST_NONSTRING_TYPE) { |
44 String::cast(this)->StringPrint(os); | 44 String::cast(this)->StringPrint(os); |
45 return; | 45 return; |
46 } | 46 } |
47 | 47 |
48 switch (instance_type) { | 48 switch (instance_type) { |
49 case SYMBOL_TYPE: | 49 case SYMBOL_TYPE: |
(...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
186 #undef MAKE_STRUCT_CASE | 186 #undef MAKE_STRUCT_CASE |
187 | 187 |
188 default: | 188 default: |
189 os << "UNKNOWN TYPE " << map()->instance_type(); | 189 os << "UNKNOWN TYPE " << map()->instance_type(); |
190 UNREACHABLE(); | 190 UNREACHABLE(); |
191 break; | 191 break; |
192 } | 192 } |
193 } | 193 } |
194 | 194 |
195 | 195 |
196 void ByteArray::ByteArrayPrint(OStream& os) { // NOLINT | 196 void ByteArray::ByteArrayPrint(std::ostream& os) { // NOLINT |
197 os << "byte array, data starts at " << GetDataStartAddress(); | 197 os << "byte array, data starts at " << GetDataStartAddress(); |
198 } | 198 } |
199 | 199 |
200 | 200 |
201 void FreeSpace::FreeSpacePrint(OStream& os) { // NOLINT | 201 void FreeSpace::FreeSpacePrint(std::ostream& os) { // NOLINT |
202 os << "free space, size " << Size(); | 202 os << "free space, size " << Size(); |
203 } | 203 } |
204 | 204 |
205 | 205 |
206 #define EXTERNAL_ARRAY_PRINTER(Type, type, TYPE, ctype, size) \ | 206 #define EXTERNAL_ARRAY_PRINTER(Type, type, TYPE, ctype, size) \ |
207 void External##Type##Array::External##Type##ArrayPrint(OStream& os) { \ | 207 void External##Type##Array::External##Type##ArrayPrint(std::ostream& os) { \ |
208 os << "external " #type " array"; \ | 208 os << "external " #type " array"; \ |
209 } | 209 } |
210 | 210 |
211 TYPED_ARRAYS(EXTERNAL_ARRAY_PRINTER) | 211 TYPED_ARRAYS(EXTERNAL_ARRAY_PRINTER) |
212 | 212 |
213 #undef EXTERNAL_ARRAY_PRINTER | 213 #undef EXTERNAL_ARRAY_PRINTER |
214 | 214 |
215 | 215 |
216 template <class Traits> | 216 template <class Traits> |
217 void FixedTypedArray<Traits>::FixedTypedArrayPrint(OStream& os) { // NOLINT | 217 void FixedTypedArray<Traits>::FixedTypedArrayPrint( |
| 218 std::ostream& os) { // NOLINT |
218 os << "fixed " << Traits::Designator(); | 219 os << "fixed " << Traits::Designator(); |
219 } | 220 } |
220 | 221 |
221 | 222 |
222 void JSObject::PrintProperties(OStream& os) { // NOLINT | 223 void JSObject::PrintProperties(std::ostream& os) { // NOLINT |
223 if (HasFastProperties()) { | 224 if (HasFastProperties()) { |
224 DescriptorArray* descs = map()->instance_descriptors(); | 225 DescriptorArray* descs = map()->instance_descriptors(); |
225 for (int i = 0; i < map()->NumberOfOwnDescriptors(); i++) { | 226 for (int i = 0; i < map()->NumberOfOwnDescriptors(); i++) { |
226 os << " "; | 227 os << " "; |
227 descs->GetKey(i)->NamePrint(os); | 228 descs->GetKey(i)->NamePrint(os); |
228 os << ": "; | 229 os << ": "; |
229 switch (descs->GetType(i)) { | 230 switch (descs->GetType(i)) { |
230 case FIELD: { | 231 case FIELD: { |
231 FieldIndex index = FieldIndex::ForDescriptor(map(), i); | 232 FieldIndex index = FieldIndex::ForDescriptor(map(), i); |
232 os << Brief(RawFastPropertyAt(index)) << " (field at offset " | 233 os << Brief(RawFastPropertyAt(index)) << " (field at offset " |
(...skipping 11 matching lines...) Expand all Loading... |
244 break; | 245 break; |
245 } | 246 } |
246 } | 247 } |
247 } else { | 248 } else { |
248 property_dictionary()->Print(os); | 249 property_dictionary()->Print(os); |
249 } | 250 } |
250 } | 251 } |
251 | 252 |
252 | 253 |
253 template <class T> | 254 template <class T> |
254 static void DoPrintElements(OStream& os, Object* object) { // NOLINT | 255 static void DoPrintElements(std::ostream& os, Object* object) { // NOLINT |
255 T* p = T::cast(object); | 256 T* p = T::cast(object); |
256 for (int i = 0; i < p->length(); i++) { | 257 for (int i = 0; i < p->length(); i++) { |
257 os << " " << i << ": " << p->get_scalar(i) << "\n"; | 258 os << " " << i << ": " << p->get_scalar(i) << "\n"; |
258 } | 259 } |
259 } | 260 } |
260 | 261 |
261 | 262 |
262 void JSObject::PrintElements(OStream& os) { // NOLINT | 263 void JSObject::PrintElements(std::ostream& os) { // NOLINT |
263 // Don't call GetElementsKind, its validation code can cause the printer to | 264 // Don't call GetElementsKind, its validation code can cause the printer to |
264 // fail when debugging. | 265 // fail when debugging. |
265 switch (map()->elements_kind()) { | 266 switch (map()->elements_kind()) { |
266 case FAST_HOLEY_SMI_ELEMENTS: | 267 case FAST_HOLEY_SMI_ELEMENTS: |
267 case FAST_SMI_ELEMENTS: | 268 case FAST_SMI_ELEMENTS: |
268 case FAST_HOLEY_ELEMENTS: | 269 case FAST_HOLEY_ELEMENTS: |
269 case FAST_ELEMENTS: { | 270 case FAST_ELEMENTS: { |
270 // Print in array notation for non-sparse arrays. | 271 // Print in array notation for non-sparse arrays. |
271 FixedArray* p = FixedArray::cast(elements()); | 272 FixedArray* p = FixedArray::cast(elements()); |
272 for (int i = 0; i < p->length(); i++) { | 273 for (int i = 0; i < p->length(); i++) { |
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
334 os << " " << (i - 2) << ":" << Brief(p->get(i)); | 335 os << " " << (i - 2) << ":" << Brief(p->get(i)); |
335 } | 336 } |
336 os << "\n context: " << Brief(p->get(0)) | 337 os << "\n context: " << Brief(p->get(0)) |
337 << "\n arguments: " << Brief(p->get(1)) << "\n"; | 338 << "\n arguments: " << Brief(p->get(1)) << "\n"; |
338 break; | 339 break; |
339 } | 340 } |
340 } | 341 } |
341 } | 342 } |
342 | 343 |
343 | 344 |
344 void JSObject::PrintTransitions(OStream& os) { // NOLINT | 345 void JSObject::PrintTransitions(std::ostream& os) { // NOLINT |
345 if (!map()->HasTransitionArray()) return; | 346 if (!map()->HasTransitionArray()) return; |
346 TransitionArray* transitions = map()->transitions(); | 347 TransitionArray* transitions = map()->transitions(); |
347 for (int i = 0; i < transitions->number_of_transitions(); i++) { | 348 for (int i = 0; i < transitions->number_of_transitions(); i++) { |
348 Name* key = transitions->GetKey(i); | 349 Name* key = transitions->GetKey(i); |
349 os << " "; | 350 os << " "; |
350 key->NamePrint(os); | 351 key->NamePrint(os); |
351 os << ": "; | 352 os << ": "; |
352 if (key == GetHeap()->frozen_symbol()) { | 353 if (key == GetHeap()->frozen_symbol()) { |
353 os << " (transition to frozen)\n"; | 354 os << " (transition to frozen)\n"; |
354 } else if (key == GetHeap()->elements_transition_symbol()) { | 355 } else if (key == GetHeap()->elements_transition_symbol()) { |
(...skipping 17 matching lines...) Expand all Loading... |
372 // Values below are never in the target descriptor array. | 373 // Values below are never in the target descriptor array. |
373 case NORMAL: | 374 case NORMAL: |
374 UNREACHABLE(); | 375 UNREACHABLE(); |
375 break; | 376 break; |
376 } | 377 } |
377 } | 378 } |
378 } | 379 } |
379 } | 380 } |
380 | 381 |
381 | 382 |
382 void JSObject::JSObjectPrint(OStream& os) { // NOLINT | 383 void JSObject::JSObjectPrint(std::ostream& os) { // NOLINT |
383 HeapObject::PrintHeader(os, "JSObject"); | 384 HeapObject::PrintHeader(os, "JSObject"); |
384 // Don't call GetElementsKind, its validation code can cause the printer to | 385 // Don't call GetElementsKind, its validation code can cause the printer to |
385 // fail when debugging. | 386 // fail when debugging. |
386 PrototypeIterator iter(GetIsolate(), this); | 387 PrototypeIterator iter(GetIsolate(), this); |
387 os << " - map = " << reinterpret_cast<void*>(map()) << " [" | 388 os << " - map = " << reinterpret_cast<void*>(map()) << " [" |
388 << ElementsKindToString(this->map()->elements_kind()) | 389 << ElementsKindToString(this->map()->elements_kind()) |
389 << "]\n - prototype = " << reinterpret_cast<void*>(iter.GetCurrent()) | 390 << "]\n - prototype = " << reinterpret_cast<void*>(iter.GetCurrent()) |
390 << "\n {\n"; | 391 << "\n {\n"; |
391 PrintProperties(os); | 392 PrintProperties(os); |
392 PrintTransitions(os); | 393 PrintTransitions(os); |
393 PrintElements(os); | 394 PrintElements(os); |
394 os << " }\n"; | 395 os << " }\n"; |
395 } | 396 } |
396 | 397 |
397 | 398 |
398 void JSModule::JSModulePrint(OStream& os) { // NOLINT | 399 void JSModule::JSModulePrint(std::ostream& os) { // NOLINT |
399 HeapObject::PrintHeader(os, "JSModule"); | 400 HeapObject::PrintHeader(os, "JSModule"); |
400 os << " - map = " << reinterpret_cast<void*>(map()) << "\n" | 401 os << " - map = " << reinterpret_cast<void*>(map()) << "\n" |
401 << " - context = "; | 402 << " - context = "; |
402 context()->Print(os); | 403 context()->Print(os); |
403 os << " - scope_info = " << Brief(scope_info()) | 404 os << " - scope_info = " << Brief(scope_info()) |
404 << ElementsKindToString(this->map()->elements_kind()) << " {\n"; | 405 << ElementsKindToString(this->map()->elements_kind()) << " {\n"; |
405 PrintProperties(os); | 406 PrintProperties(os); |
406 PrintElements(os); | 407 PrintElements(os); |
407 os << " }\n"; | 408 os << " }\n"; |
408 } | 409 } |
409 | 410 |
410 | 411 |
411 static const char* TypeToString(InstanceType type) { | 412 static const char* TypeToString(InstanceType type) { |
412 switch (type) { | 413 switch (type) { |
413 #define TYPE_TO_STRING(TYPE) case TYPE: return #TYPE; | 414 #define TYPE_TO_STRING(TYPE) case TYPE: return #TYPE; |
414 INSTANCE_TYPE_LIST(TYPE_TO_STRING) | 415 INSTANCE_TYPE_LIST(TYPE_TO_STRING) |
415 #undef TYPE_TO_STRING | 416 #undef TYPE_TO_STRING |
416 } | 417 } |
417 UNREACHABLE(); | 418 UNREACHABLE(); |
418 return "UNKNOWN"; // Keep the compiler happy. | 419 return "UNKNOWN"; // Keep the compiler happy. |
419 } | 420 } |
420 | 421 |
421 | 422 |
422 void Symbol::SymbolPrint(OStream& os) { // NOLINT | 423 void Symbol::SymbolPrint(std::ostream& os) { // NOLINT |
423 HeapObject::PrintHeader(os, "Symbol"); | 424 HeapObject::PrintHeader(os, "Symbol"); |
424 os << " - hash: " << Hash(); | 425 os << " - hash: " << Hash(); |
425 os << "\n - name: " << Brief(name()); | 426 os << "\n - name: " << Brief(name()); |
426 os << "\n - private: " << is_private(); | 427 os << "\n - private: " << is_private(); |
427 os << "\n - own: " << is_own(); | 428 os << "\n - own: " << is_own(); |
428 os << "\n"; | 429 os << "\n"; |
429 } | 430 } |
430 | 431 |
431 | 432 |
432 void Map::MapPrint(OStream& os) { // NOLINT | 433 void Map::MapPrint(std::ostream& os) { // NOLINT |
433 HeapObject::PrintHeader(os, "Map"); | 434 HeapObject::PrintHeader(os, "Map"); |
434 os << " - type: " << TypeToString(instance_type()) << "\n"; | 435 os << " - type: " << TypeToString(instance_type()) << "\n"; |
435 os << " - instance size: " << instance_size() << "\n"; | 436 os << " - instance size: " << instance_size() << "\n"; |
436 os << " - inobject properties: " << inobject_properties() << "\n"; | 437 os << " - inobject properties: " << inobject_properties() << "\n"; |
437 os << " - elements kind: " << ElementsKindToString(elements_kind()); | 438 os << " - elements kind: " << ElementsKindToString(elements_kind()); |
438 os << "\n - pre-allocated property fields: " | 439 os << "\n - pre-allocated property fields: " |
439 << pre_allocated_property_fields() << "\n"; | 440 << pre_allocated_property_fields() << "\n"; |
440 os << " - unused property fields: " << unused_property_fields() << "\n"; | 441 os << " - unused property fields: " << unused_property_fields() << "\n"; |
441 if (is_hidden_prototype()) os << " - hidden_prototype\n"; | 442 if (is_hidden_prototype()) os << " - hidden_prototype\n"; |
442 if (has_named_interceptor()) os << " - named_interceptor\n"; | 443 if (has_named_interceptor()) os << " - named_interceptor\n"; |
(...skipping 14 matching lines...) Expand all Loading... |
457 os << "\n - transitions: " << Brief(transitions()); | 458 os << "\n - transitions: " << Brief(transitions()); |
458 } | 459 } |
459 os << "\n - prototype: " << Brief(prototype()); | 460 os << "\n - prototype: " << Brief(prototype()); |
460 os << "\n - constructor: " << Brief(constructor()); | 461 os << "\n - constructor: " << Brief(constructor()); |
461 os << "\n - code cache: " << Brief(code_cache()); | 462 os << "\n - code cache: " << Brief(code_cache()); |
462 os << "\n - dependent code: " << Brief(dependent_code()); | 463 os << "\n - dependent code: " << Brief(dependent_code()); |
463 os << "\n"; | 464 os << "\n"; |
464 } | 465 } |
465 | 466 |
466 | 467 |
467 void CodeCache::CodeCachePrint(OStream& os) { // NOLINT | 468 void CodeCache::CodeCachePrint(std::ostream& os) { // NOLINT |
468 HeapObject::PrintHeader(os, "CodeCache"); | 469 HeapObject::PrintHeader(os, "CodeCache"); |
469 os << "\n - default_cache: " << Brief(default_cache()); | 470 os << "\n - default_cache: " << Brief(default_cache()); |
470 os << "\n - normal_type_cache: " << Brief(normal_type_cache()); | 471 os << "\n - normal_type_cache: " << Brief(normal_type_cache()); |
471 } | 472 } |
472 | 473 |
473 | 474 |
474 void PolymorphicCodeCache::PolymorphicCodeCachePrint(OStream& os) { // NOLINT | 475 void PolymorphicCodeCache::PolymorphicCodeCachePrint( |
| 476 std::ostream& os) { // NOLINT |
475 HeapObject::PrintHeader(os, "PolymorphicCodeCache"); | 477 HeapObject::PrintHeader(os, "PolymorphicCodeCache"); |
476 os << "\n - cache: " << Brief(cache()); | 478 os << "\n - cache: " << Brief(cache()); |
477 } | 479 } |
478 | 480 |
479 | 481 |
480 void TypeFeedbackInfo::TypeFeedbackInfoPrint(OStream& os) { // NOLINT | 482 void TypeFeedbackInfo::TypeFeedbackInfoPrint(std::ostream& os) { // NOLINT |
481 HeapObject::PrintHeader(os, "TypeFeedbackInfo"); | 483 HeapObject::PrintHeader(os, "TypeFeedbackInfo"); |
482 os << " - ic_total_count: " << ic_total_count() | 484 os << " - ic_total_count: " << ic_total_count() |
483 << ", ic_with_type_info_count: " << ic_with_type_info_count() | 485 << ", ic_with_type_info_count: " << ic_with_type_info_count() |
484 << ", ic_generic_count: " << ic_generic_count() << "\n"; | 486 << ", ic_generic_count: " << ic_generic_count() << "\n"; |
485 } | 487 } |
486 | 488 |
487 | 489 |
488 void AliasedArgumentsEntry::AliasedArgumentsEntryPrint(OStream& os) { // NOLINT | 490 void AliasedArgumentsEntry::AliasedArgumentsEntryPrint( |
| 491 std::ostream& os) { // NOLINT |
489 HeapObject::PrintHeader(os, "AliasedArgumentsEntry"); | 492 HeapObject::PrintHeader(os, "AliasedArgumentsEntry"); |
490 os << "\n - aliased_context_slot: " << aliased_context_slot(); | 493 os << "\n - aliased_context_slot: " << aliased_context_slot(); |
491 } | 494 } |
492 | 495 |
493 | 496 |
494 void FixedArray::FixedArrayPrint(OStream& os) { // NOLINT | 497 void FixedArray::FixedArrayPrint(std::ostream& os) { // NOLINT |
495 HeapObject::PrintHeader(os, "FixedArray"); | 498 HeapObject::PrintHeader(os, "FixedArray"); |
496 os << " - length: " << length(); | 499 os << " - length: " << length(); |
497 for (int i = 0; i < length(); i++) { | 500 for (int i = 0; i < length(); i++) { |
498 os << "\n [" << i << "]: " << Brief(get(i)); | 501 os << "\n [" << i << "]: " << Brief(get(i)); |
499 } | 502 } |
500 os << "\n"; | 503 os << "\n"; |
501 } | 504 } |
502 | 505 |
503 | 506 |
504 void FixedDoubleArray::FixedDoubleArrayPrint(OStream& os) { // NOLINT | 507 void FixedDoubleArray::FixedDoubleArrayPrint(std::ostream& os) { // NOLINT |
505 HeapObject::PrintHeader(os, "FixedDoubleArray"); | 508 HeapObject::PrintHeader(os, "FixedDoubleArray"); |
506 os << " - length: " << length(); | 509 os << " - length: " << length(); |
507 for (int i = 0; i < length(); i++) { | 510 for (int i = 0; i < length(); i++) { |
508 os << "\n [" << i << "]: "; | 511 os << "\n [" << i << "]: "; |
509 if (is_the_hole(i)) { | 512 if (is_the_hole(i)) { |
510 os << "<the hole>"; | 513 os << "<the hole>"; |
511 } else { | 514 } else { |
512 os << get_scalar(i); | 515 os << get_scalar(i); |
513 } | 516 } |
514 } | 517 } |
515 os << "\n"; | 518 os << "\n"; |
516 } | 519 } |
517 | 520 |
518 | 521 |
519 void ConstantPoolArray::ConstantPoolArrayPrint(OStream& os) { // NOLINT | 522 void ConstantPoolArray::ConstantPoolArrayPrint(std::ostream& os) { // NOLINT |
520 HeapObject::PrintHeader(os, "ConstantPoolArray"); | 523 HeapObject::PrintHeader(os, "ConstantPoolArray"); |
521 os << " - length: " << length(); | 524 os << " - length: " << length(); |
522 for (int i = 0; i <= last_index(INT32, SMALL_SECTION); i++) { | 525 for (int i = 0; i <= last_index(INT32, SMALL_SECTION); i++) { |
523 if (i < last_index(INT64, SMALL_SECTION)) { | 526 if (i < last_index(INT64, SMALL_SECTION)) { |
524 os << "\n [" << i << "]: double: " << get_int64_entry_as_double(i); | 527 os << "\n [" << i << "]: double: " << get_int64_entry_as_double(i); |
525 } else if (i <= last_index(CODE_PTR, SMALL_SECTION)) { | 528 } else if (i <= last_index(CODE_PTR, SMALL_SECTION)) { |
526 os << "\n [" << i << "]: code target pointer: " | 529 os << "\n [" << i << "]: code target pointer: " |
527 << reinterpret_cast<void*>(get_code_ptr_entry(i)); | 530 << reinterpret_cast<void*>(get_code_ptr_entry(i)); |
528 } else if (i <= last_index(HEAP_PTR, SMALL_SECTION)) { | 531 } else if (i <= last_index(HEAP_PTR, SMALL_SECTION)) { |
529 os << "\n [" << i << "]: heap pointer: " | 532 os << "\n [" << i << "]: heap pointer: " |
(...skipping 16 matching lines...) Expand all Loading... |
546 << reinterpret_cast<void*>(get_heap_ptr_entry(i)); | 549 << reinterpret_cast<void*>(get_heap_ptr_entry(i)); |
547 } else if (i <= last_index(INT32, EXTENDED_SECTION)) { | 550 } else if (i <= last_index(INT32, EXTENDED_SECTION)) { |
548 os << "\n [" << i << "]: int32: " << get_int32_entry(i); | 551 os << "\n [" << i << "]: int32: " << get_int32_entry(i); |
549 } | 552 } |
550 } | 553 } |
551 } | 554 } |
552 os << "\n"; | 555 os << "\n"; |
553 } | 556 } |
554 | 557 |
555 | 558 |
556 void JSValue::JSValuePrint(OStream& os) { // NOLINT | 559 void JSValue::JSValuePrint(std::ostream& os) { // NOLINT |
557 HeapObject::PrintHeader(os, "ValueObject"); | 560 HeapObject::PrintHeader(os, "ValueObject"); |
558 value()->Print(os); | 561 value()->Print(os); |
559 } | 562 } |
560 | 563 |
561 | 564 |
562 void JSMessageObject::JSMessageObjectPrint(OStream& os) { // NOLINT | 565 void JSMessageObject::JSMessageObjectPrint(std::ostream& os) { // NOLINT |
563 HeapObject::PrintHeader(os, "JSMessageObject"); | 566 HeapObject::PrintHeader(os, "JSMessageObject"); |
564 os << " - type: " << Brief(type()); | 567 os << " - type: " << Brief(type()); |
565 os << "\n - arguments: " << Brief(arguments()); | 568 os << "\n - arguments: " << Brief(arguments()); |
566 os << "\n - start_position: " << start_position(); | 569 os << "\n - start_position: " << start_position(); |
567 os << "\n - end_position: " << end_position(); | 570 os << "\n - end_position: " << end_position(); |
568 os << "\n - script: " << Brief(script()); | 571 os << "\n - script: " << Brief(script()); |
569 os << "\n - stack_frames: " << Brief(stack_frames()); | 572 os << "\n - stack_frames: " << Brief(stack_frames()); |
570 os << "\n"; | 573 os << "\n"; |
571 } | 574 } |
572 | 575 |
573 | 576 |
574 void String::StringPrint(OStream& os) { // NOLINT | 577 void String::StringPrint(std::ostream& os) { // NOLINT |
575 if (StringShape(this).IsInternalized()) { | 578 if (StringShape(this).IsInternalized()) { |
576 os << "#"; | 579 os << "#"; |
577 } else if (StringShape(this).IsCons()) { | 580 } else if (StringShape(this).IsCons()) { |
578 os << "c\""; | 581 os << "c\""; |
579 } else { | 582 } else { |
580 os << "\""; | 583 os << "\""; |
581 } | 584 } |
582 | 585 |
583 const char truncated_epilogue[] = "...<truncated>"; | 586 const char truncated_epilogue[] = "...<truncated>"; |
584 int len = length(); | 587 int len = length(); |
585 if (!FLAG_use_verbose_printer) { | 588 if (!FLAG_use_verbose_printer) { |
586 if (len > 100) { | 589 if (len > 100) { |
587 len = 100 - sizeof(truncated_epilogue); | 590 len = 100 - sizeof(truncated_epilogue); |
588 } | 591 } |
589 } | 592 } |
590 for (int i = 0; i < len; i++) { | 593 for (int i = 0; i < len; i++) { |
591 os << AsUC16(Get(i)); | 594 os << AsUC16(Get(i)); |
592 } | 595 } |
593 if (len != length()) { | 596 if (len != length()) { |
594 os << truncated_epilogue; | 597 os << truncated_epilogue; |
595 } | 598 } |
596 | 599 |
597 if (!StringShape(this).IsInternalized()) os << "\""; | 600 if (!StringShape(this).IsInternalized()) os << "\""; |
598 } | 601 } |
599 | 602 |
600 | 603 |
601 void Name::NamePrint(OStream& os) { // NOLINT | 604 void Name::NamePrint(std::ostream& os) { // NOLINT |
602 if (IsString()) | 605 if (IsString()) |
603 String::cast(this)->StringPrint(os); | 606 String::cast(this)->StringPrint(os); |
604 else | 607 else |
605 os << Brief(this); | 608 os << Brief(this); |
606 } | 609 } |
607 | 610 |
608 | 611 |
609 // This method is only meant to be called from gdb for debugging purposes. | 612 // This method is only meant to be called from gdb for debugging purposes. |
610 // Since the string can also be in two-byte encoding, non-Latin1 characters | 613 // Since the string can also be in two-byte encoding, non-Latin1 characters |
611 // will be ignored in the output. | 614 // will be ignored in the output. |
612 char* String::ToAsciiArray() { | 615 char* String::ToAsciiArray() { |
613 // Static so that subsequent calls frees previously allocated space. | 616 // Static so that subsequent calls frees previously allocated space. |
614 // This also means that previous results will be overwritten. | 617 // This also means that previous results will be overwritten. |
615 static char* buffer = NULL; | 618 static char* buffer = NULL; |
616 if (buffer != NULL) free(buffer); | 619 if (buffer != NULL) free(buffer); |
617 buffer = new char[length()+1]; | 620 buffer = new char[length()+1]; |
618 WriteToFlat(this, reinterpret_cast<uint8_t*>(buffer), 0, length()); | 621 WriteToFlat(this, reinterpret_cast<uint8_t*>(buffer), 0, length()); |
619 buffer[length()] = 0; | 622 buffer[length()] = 0; |
620 return buffer; | 623 return buffer; |
621 } | 624 } |
622 | 625 |
623 | 626 |
624 static const char* const weekdays[] = { | 627 static const char* const weekdays[] = { |
625 "???", "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" | 628 "???", "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" |
626 }; | 629 }; |
627 | 630 |
628 | 631 |
629 void JSDate::JSDatePrint(OStream& os) { // NOLINT | 632 void JSDate::JSDatePrint(std::ostream& os) { // NOLINT |
630 HeapObject::PrintHeader(os, "JSDate"); | 633 HeapObject::PrintHeader(os, "JSDate"); |
631 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 634 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
632 os << " - value = "; | 635 os << " - value = "; |
633 value()->Print(os); | 636 value()->Print(os); |
634 if (!year()->IsSmi()) { | 637 if (!year()->IsSmi()) { |
635 os << " - time = NaN\n"; | 638 os << " - time = NaN\n"; |
636 } else { | 639 } else { |
637 // TODO(svenpanne) Add some basic formatting to our streams. | 640 // TODO(svenpanne) Add some basic formatting to our streams. |
638 Vector<char> buf = Vector<char>::New(100); | 641 Vector<char> buf = Vector<char>::New(100); |
639 SNPrintF( | 642 SNPrintF( |
640 buf, " - time = %s %04d/%02d/%02d %02d:%02d:%02d\n", | 643 buf, " - time = %s %04d/%02d/%02d %02d:%02d:%02d\n", |
641 weekdays[weekday()->IsSmi() ? Smi::cast(weekday())->value() + 1 : 0], | 644 weekdays[weekday()->IsSmi() ? Smi::cast(weekday())->value() + 1 : 0], |
642 year()->IsSmi() ? Smi::cast(year())->value() : -1, | 645 year()->IsSmi() ? Smi::cast(year())->value() : -1, |
643 month()->IsSmi() ? Smi::cast(month())->value() : -1, | 646 month()->IsSmi() ? Smi::cast(month())->value() : -1, |
644 day()->IsSmi() ? Smi::cast(day())->value() : -1, | 647 day()->IsSmi() ? Smi::cast(day())->value() : -1, |
645 hour()->IsSmi() ? Smi::cast(hour())->value() : -1, | 648 hour()->IsSmi() ? Smi::cast(hour())->value() : -1, |
646 min()->IsSmi() ? Smi::cast(min())->value() : -1, | 649 min()->IsSmi() ? Smi::cast(min())->value() : -1, |
647 sec()->IsSmi() ? Smi::cast(sec())->value() : -1); | 650 sec()->IsSmi() ? Smi::cast(sec())->value() : -1); |
648 os << buf.start(); | 651 os << buf.start(); |
649 } | 652 } |
650 } | 653 } |
651 | 654 |
652 | 655 |
653 void JSProxy::JSProxyPrint(OStream& os) { // NOLINT | 656 void JSProxy::JSProxyPrint(std::ostream& os) { // NOLINT |
654 HeapObject::PrintHeader(os, "JSProxy"); | 657 HeapObject::PrintHeader(os, "JSProxy"); |
655 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 658 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
656 os << " - handler = "; | 659 os << " - handler = "; |
657 handler()->Print(os); | 660 handler()->Print(os); |
658 os << "\n - hash = "; | 661 os << "\n - hash = "; |
659 hash()->Print(os); | 662 hash()->Print(os); |
660 os << "\n"; | 663 os << "\n"; |
661 } | 664 } |
662 | 665 |
663 | 666 |
664 void JSFunctionProxy::JSFunctionProxyPrint(OStream& os) { // NOLINT | 667 void JSFunctionProxy::JSFunctionProxyPrint(std::ostream& os) { // NOLINT |
665 HeapObject::PrintHeader(os, "JSFunctionProxy"); | 668 HeapObject::PrintHeader(os, "JSFunctionProxy"); |
666 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 669 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
667 os << " - handler = "; | 670 os << " - handler = "; |
668 handler()->Print(os); | 671 handler()->Print(os); |
669 os << "\n - call_trap = "; | 672 os << "\n - call_trap = "; |
670 call_trap()->Print(os); | 673 call_trap()->Print(os); |
671 os << "\n - construct_trap = "; | 674 os << "\n - construct_trap = "; |
672 construct_trap()->Print(os); | 675 construct_trap()->Print(os); |
673 os << "\n"; | 676 os << "\n"; |
674 } | 677 } |
675 | 678 |
676 | 679 |
677 void JSSet::JSSetPrint(OStream& os) { // NOLINT | 680 void JSSet::JSSetPrint(std::ostream& os) { // NOLINT |
678 HeapObject::PrintHeader(os, "JSSet"); | 681 HeapObject::PrintHeader(os, "JSSet"); |
679 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 682 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
680 os << " - table = " << Brief(table()); | 683 os << " - table = " << Brief(table()); |
681 os << "\n"; | 684 os << "\n"; |
682 } | 685 } |
683 | 686 |
684 | 687 |
685 void JSMap::JSMapPrint(OStream& os) { // NOLINT | 688 void JSMap::JSMapPrint(std::ostream& os) { // NOLINT |
686 HeapObject::PrintHeader(os, "JSMap"); | 689 HeapObject::PrintHeader(os, "JSMap"); |
687 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 690 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
688 os << " - table = " << Brief(table()); | 691 os << " - table = " << Brief(table()); |
689 os << "\n"; | 692 os << "\n"; |
690 } | 693 } |
691 | 694 |
692 | 695 |
693 template <class Derived, class TableType> | 696 template <class Derived, class TableType> |
694 void OrderedHashTableIterator< | 697 void |
695 Derived, TableType>::OrderedHashTableIteratorPrint(OStream& os) { // NOLINT | 698 OrderedHashTableIterator<Derived, TableType>::OrderedHashTableIteratorPrint( |
| 699 std::ostream& os) { // NOLINT |
696 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 700 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
697 os << " - table = " << Brief(table()); | 701 os << " - table = " << Brief(table()); |
698 os << "\n - index = " << Brief(index()); | 702 os << "\n - index = " << Brief(index()); |
699 os << "\n - kind = " << Brief(kind()); | 703 os << "\n - kind = " << Brief(kind()); |
700 os << "\n"; | 704 os << "\n"; |
701 } | 705 } |
702 | 706 |
703 | 707 |
704 template void OrderedHashTableIterator< | 708 template void OrderedHashTableIterator< |
705 JSSetIterator, | 709 JSSetIterator, |
706 OrderedHashSet>::OrderedHashTableIteratorPrint(OStream& os); // NOLINT | 710 OrderedHashSet>::OrderedHashTableIteratorPrint(std::ostream& os); // NOLINT |
707 | 711 |
708 | 712 |
709 template void OrderedHashTableIterator< | 713 template void OrderedHashTableIterator< |
710 JSMapIterator, | 714 JSMapIterator, |
711 OrderedHashMap>::OrderedHashTableIteratorPrint(OStream& os); // NOLINT | 715 OrderedHashMap>::OrderedHashTableIteratorPrint(std::ostream& os); // NOLINT |
712 | 716 |
713 | 717 |
714 void JSSetIterator::JSSetIteratorPrint(OStream& os) { // NOLINT | 718 void JSSetIterator::JSSetIteratorPrint(std::ostream& os) { // NOLINT |
715 HeapObject::PrintHeader(os, "JSSetIterator"); | 719 HeapObject::PrintHeader(os, "JSSetIterator"); |
716 OrderedHashTableIteratorPrint(os); | 720 OrderedHashTableIteratorPrint(os); |
717 } | 721 } |
718 | 722 |
719 | 723 |
720 void JSMapIterator::JSMapIteratorPrint(OStream& os) { // NOLINT | 724 void JSMapIterator::JSMapIteratorPrint(std::ostream& os) { // NOLINT |
721 HeapObject::PrintHeader(os, "JSMapIterator"); | 725 HeapObject::PrintHeader(os, "JSMapIterator"); |
722 OrderedHashTableIteratorPrint(os); | 726 OrderedHashTableIteratorPrint(os); |
723 } | 727 } |
724 | 728 |
725 | 729 |
726 void JSWeakMap::JSWeakMapPrint(OStream& os) { // NOLINT | 730 void JSWeakMap::JSWeakMapPrint(std::ostream& os) { // NOLINT |
727 HeapObject::PrintHeader(os, "JSWeakMap"); | 731 HeapObject::PrintHeader(os, "JSWeakMap"); |
728 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 732 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
729 os << " - table = " << Brief(table()); | 733 os << " - table = " << Brief(table()); |
730 os << "\n"; | 734 os << "\n"; |
731 } | 735 } |
732 | 736 |
733 | 737 |
734 void JSWeakSet::JSWeakSetPrint(OStream& os) { // NOLINT | 738 void JSWeakSet::JSWeakSetPrint(std::ostream& os) { // NOLINT |
735 HeapObject::PrintHeader(os, "JSWeakSet"); | 739 HeapObject::PrintHeader(os, "JSWeakSet"); |
736 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 740 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
737 os << " - table = " << Brief(table()); | 741 os << " - table = " << Brief(table()); |
738 os << "\n"; | 742 os << "\n"; |
739 } | 743 } |
740 | 744 |
741 | 745 |
742 void JSArrayBuffer::JSArrayBufferPrint(OStream& os) { // NOLINT | 746 void JSArrayBuffer::JSArrayBufferPrint(std::ostream& os) { // NOLINT |
743 HeapObject::PrintHeader(os, "JSArrayBuffer"); | 747 HeapObject::PrintHeader(os, "JSArrayBuffer"); |
744 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 748 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
745 os << " - backing_store = " << backing_store() << "\n"; | 749 os << " - backing_store = " << backing_store() << "\n"; |
746 os << " - byte_length = " << Brief(byte_length()); | 750 os << " - byte_length = " << Brief(byte_length()); |
747 os << "\n"; | 751 os << "\n"; |
748 } | 752 } |
749 | 753 |
750 | 754 |
751 void JSTypedArray::JSTypedArrayPrint(OStream& os) { // NOLINT | 755 void JSTypedArray::JSTypedArrayPrint(std::ostream& os) { // NOLINT |
752 HeapObject::PrintHeader(os, "JSTypedArray"); | 756 HeapObject::PrintHeader(os, "JSTypedArray"); |
753 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 757 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
754 os << " - buffer = " << Brief(buffer()); | 758 os << " - buffer = " << Brief(buffer()); |
755 os << "\n - byte_offset = " << Brief(byte_offset()); | 759 os << "\n - byte_offset = " << Brief(byte_offset()); |
756 os << "\n - byte_length = " << Brief(byte_length()); | 760 os << "\n - byte_length = " << Brief(byte_length()); |
757 os << "\n - length = " << Brief(length()); | 761 os << "\n - length = " << Brief(length()); |
758 os << "\n"; | 762 os << "\n"; |
759 PrintElements(os); | 763 PrintElements(os); |
760 } | 764 } |
761 | 765 |
762 | 766 |
763 void JSDataView::JSDataViewPrint(OStream& os) { // NOLINT | 767 void JSDataView::JSDataViewPrint(std::ostream& os) { // NOLINT |
764 HeapObject::PrintHeader(os, "JSDataView"); | 768 HeapObject::PrintHeader(os, "JSDataView"); |
765 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 769 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
766 os << " - buffer =" << Brief(buffer()); | 770 os << " - buffer =" << Brief(buffer()); |
767 os << "\n - byte_offset = " << Brief(byte_offset()); | 771 os << "\n - byte_offset = " << Brief(byte_offset()); |
768 os << "\n - byte_length = " << Brief(byte_length()); | 772 os << "\n - byte_length = " << Brief(byte_length()); |
769 os << "\n"; | 773 os << "\n"; |
770 } | 774 } |
771 | 775 |
772 | 776 |
773 void JSFunction::JSFunctionPrint(OStream& os) { // NOLINT | 777 void JSFunction::JSFunctionPrint(std::ostream& os) { // NOLINT |
774 HeapObject::PrintHeader(os, "Function"); | 778 HeapObject::PrintHeader(os, "Function"); |
775 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; | 779 os << " - map = " << reinterpret_cast<void*>(map()) << "\n"; |
776 os << " - initial_map = "; | 780 os << " - initial_map = "; |
777 if (has_initial_map()) os << Brief(initial_map()); | 781 if (has_initial_map()) os << Brief(initial_map()); |
778 os << "\n - shared_info = " << Brief(shared()); | 782 os << "\n - shared_info = " << Brief(shared()); |
779 os << "\n - name = " << Brief(shared()->name()); | 783 os << "\n - name = " << Brief(shared()->name()); |
780 os << "\n - context = " << Brief(context()); | 784 os << "\n - context = " << Brief(context()); |
781 if (shared()->bound()) { | 785 if (shared()->bound()) { |
782 os << "\n - bindings = " << Brief(function_bindings()); | 786 os << "\n - bindings = " << Brief(function_bindings()); |
783 } else { | 787 } else { |
784 os << "\n - literals = " << Brief(literals()); | 788 os << "\n - literals = " << Brief(literals()); |
785 } | 789 } |
786 os << "\n - code = " << Brief(code()); | 790 os << "\n - code = " << Brief(code()); |
787 os << "\n"; | 791 os << "\n"; |
788 PrintProperties(os); | 792 PrintProperties(os); |
789 PrintElements(os); | 793 PrintElements(os); |
790 os << "\n"; | 794 os << "\n"; |
791 } | 795 } |
792 | 796 |
793 | 797 |
794 void SharedFunctionInfo::SharedFunctionInfoPrint(OStream& os) { // NOLINT | 798 void SharedFunctionInfo::SharedFunctionInfoPrint(std::ostream& os) { // NOLINT |
795 HeapObject::PrintHeader(os, "SharedFunctionInfo"); | 799 HeapObject::PrintHeader(os, "SharedFunctionInfo"); |
796 os << " - name: " << Brief(name()); | 800 os << " - name: " << Brief(name()); |
797 os << "\n - expected_nof_properties: " << expected_nof_properties(); | 801 os << "\n - expected_nof_properties: " << expected_nof_properties(); |
798 os << "\n - ast_node_count: " << ast_node_count(); | 802 os << "\n - ast_node_count: " << ast_node_count(); |
799 os << "\n - instance class name = "; | 803 os << "\n - instance class name = "; |
800 instance_class_name()->Print(os); | 804 instance_class_name()->Print(os); |
801 os << "\n - code = " << Brief(code()); | 805 os << "\n - code = " << Brief(code()); |
802 if (HasSourceCode()) { | 806 if (HasSourceCode()) { |
803 os << "\n - source code = "; | 807 os << "\n - source code = "; |
804 String* source = String::cast(Script::cast(script())->source()); | 808 String* source = String::cast(Script::cast(script())->source()); |
(...skipping 14 matching lines...) Expand all Loading... |
819 os << "\n - is expression = " << is_expression(); | 823 os << "\n - is expression = " << is_expression(); |
820 os << "\n - debug info = " << Brief(debug_info()); | 824 os << "\n - debug info = " << Brief(debug_info()); |
821 os << "\n - length = " << length(); | 825 os << "\n - length = " << length(); |
822 os << "\n - optimized_code_map = " << Brief(optimized_code_map()); | 826 os << "\n - optimized_code_map = " << Brief(optimized_code_map()); |
823 os << "\n - feedback_vector = "; | 827 os << "\n - feedback_vector = "; |
824 feedback_vector()->FixedArrayPrint(os); | 828 feedback_vector()->FixedArrayPrint(os); |
825 os << "\n"; | 829 os << "\n"; |
826 } | 830 } |
827 | 831 |
828 | 832 |
829 void JSGlobalProxy::JSGlobalProxyPrint(OStream& os) { // NOLINT | 833 void JSGlobalProxy::JSGlobalProxyPrint(std::ostream& os) { // NOLINT |
830 os << "global_proxy "; | 834 os << "global_proxy "; |
831 JSObjectPrint(os); | 835 JSObjectPrint(os); |
832 os << "native context : " << Brief(native_context()); | 836 os << "native context : " << Brief(native_context()); |
833 os << "\n"; | 837 os << "\n"; |
834 } | 838 } |
835 | 839 |
836 | 840 |
837 void JSGlobalObject::JSGlobalObjectPrint(OStream& os) { // NOLINT | 841 void JSGlobalObject::JSGlobalObjectPrint(std::ostream& os) { // NOLINT |
838 os << "global "; | 842 os << "global "; |
839 JSObjectPrint(os); | 843 JSObjectPrint(os); |
840 os << "native context : " << Brief(native_context()); | 844 os << "native context : " << Brief(native_context()); |
841 os << "\n"; | 845 os << "\n"; |
842 } | 846 } |
843 | 847 |
844 | 848 |
845 void JSBuiltinsObject::JSBuiltinsObjectPrint(OStream& os) { // NOLINT | 849 void JSBuiltinsObject::JSBuiltinsObjectPrint(std::ostream& os) { // NOLINT |
846 os << "builtins "; | 850 os << "builtins "; |
847 JSObjectPrint(os); | 851 JSObjectPrint(os); |
848 } | 852 } |
849 | 853 |
850 | 854 |
851 void Cell::CellPrint(OStream& os) { // NOLINT | 855 void Cell::CellPrint(std::ostream& os) { // NOLINT |
852 HeapObject::PrintHeader(os, "Cell"); | 856 HeapObject::PrintHeader(os, "Cell"); |
853 } | 857 } |
854 | 858 |
855 | 859 |
856 void PropertyCell::PropertyCellPrint(OStream& os) { // NOLINT | 860 void PropertyCell::PropertyCellPrint(std::ostream& os) { // NOLINT |
857 HeapObject::PrintHeader(os, "PropertyCell"); | 861 HeapObject::PrintHeader(os, "PropertyCell"); |
858 } | 862 } |
859 | 863 |
860 | 864 |
861 void Code::CodePrint(OStream& os) { // NOLINT | 865 void Code::CodePrint(std::ostream& os) { // NOLINT |
862 HeapObject::PrintHeader(os, "Code"); | 866 HeapObject::PrintHeader(os, "Code"); |
863 #ifdef ENABLE_DISASSEMBLER | 867 #ifdef ENABLE_DISASSEMBLER |
864 if (FLAG_use_verbose_printer) { | 868 if (FLAG_use_verbose_printer) { |
865 Disassemble(NULL, os); | 869 Disassemble(NULL, os); |
866 } | 870 } |
867 #endif | 871 #endif |
868 } | 872 } |
869 | 873 |
870 | 874 |
871 void Foreign::ForeignPrint(OStream& os) { // NOLINT | 875 void Foreign::ForeignPrint(std::ostream& os) { // NOLINT |
872 os << "foreign address : " << foreign_address(); | 876 os << "foreign address : " << foreign_address(); |
873 } | 877 } |
874 | 878 |
875 | 879 |
876 void ExecutableAccessorInfo::ExecutableAccessorInfoPrint( | 880 void ExecutableAccessorInfo::ExecutableAccessorInfoPrint( |
877 OStream& os) { // NOLINT | 881 std::ostream& os) { // NOLINT |
878 HeapObject::PrintHeader(os, "ExecutableAccessorInfo"); | 882 HeapObject::PrintHeader(os, "ExecutableAccessorInfo"); |
879 os << "\n - name: " << Brief(name()); | 883 os << "\n - name: " << Brief(name()); |
880 os << "\n - flag: " << Brief(flag()); | 884 os << "\n - flag: " << Brief(flag()); |
881 os << "\n - getter: " << Brief(getter()); | 885 os << "\n - getter: " << Brief(getter()); |
882 os << "\n - setter: " << Brief(setter()); | 886 os << "\n - setter: " << Brief(setter()); |
883 os << "\n - data: " << Brief(data()); | 887 os << "\n - data: " << Brief(data()); |
884 os << "\n"; | 888 os << "\n"; |
885 } | 889 } |
886 | 890 |
887 | 891 |
888 void DeclaredAccessorInfo::DeclaredAccessorInfoPrint(OStream& os) { // NOLINT | 892 void DeclaredAccessorInfo::DeclaredAccessorInfoPrint( |
| 893 std::ostream& os) { // NOLINT |
889 HeapObject::PrintHeader(os, "DeclaredAccessorInfo"); | 894 HeapObject::PrintHeader(os, "DeclaredAccessorInfo"); |
890 os << "\n - name: " << Brief(name()); | 895 os << "\n - name: " << Brief(name()); |
891 os << "\n - flag: " << Brief(flag()); | 896 os << "\n - flag: " << Brief(flag()); |
892 os << "\n - descriptor: " << Brief(descriptor()); | 897 os << "\n - descriptor: " << Brief(descriptor()); |
893 os << "\n"; | 898 os << "\n"; |
894 } | 899 } |
895 | 900 |
896 | 901 |
897 void DeclaredAccessorDescriptor::DeclaredAccessorDescriptorPrint( | 902 void DeclaredAccessorDescriptor::DeclaredAccessorDescriptorPrint( |
898 OStream& os) { // NOLINT | 903 std::ostream& os) { // NOLINT |
899 HeapObject::PrintHeader(os, "DeclaredAccessorDescriptor"); | 904 HeapObject::PrintHeader(os, "DeclaredAccessorDescriptor"); |
900 os << "\n - internal field: " << Brief(serialized_data()); | 905 os << "\n - internal field: " << Brief(serialized_data()); |
901 os << "\n"; | 906 os << "\n"; |
902 } | 907 } |
903 | 908 |
904 | 909 |
905 void Box::BoxPrint(OStream& os) { // NOLINT | 910 void Box::BoxPrint(std::ostream& os) { // NOLINT |
906 HeapObject::PrintHeader(os, "Box"); | 911 HeapObject::PrintHeader(os, "Box"); |
907 os << "\n - value: " << Brief(value()); | 912 os << "\n - value: " << Brief(value()); |
908 os << "\n"; | 913 os << "\n"; |
909 } | 914 } |
910 | 915 |
911 | 916 |
912 void AccessorPair::AccessorPairPrint(OStream& os) { // NOLINT | 917 void AccessorPair::AccessorPairPrint(std::ostream& os) { // NOLINT |
913 HeapObject::PrintHeader(os, "AccessorPair"); | 918 HeapObject::PrintHeader(os, "AccessorPair"); |
914 os << "\n - getter: " << Brief(getter()); | 919 os << "\n - getter: " << Brief(getter()); |
915 os << "\n - setter: " << Brief(setter()); | 920 os << "\n - setter: " << Brief(setter()); |
916 os << "\n"; | 921 os << "\n"; |
917 } | 922 } |
918 | 923 |
919 | 924 |
920 void AccessCheckInfo::AccessCheckInfoPrint(OStream& os) { // NOLINT | 925 void AccessCheckInfo::AccessCheckInfoPrint(std::ostream& os) { // NOLINT |
921 HeapObject::PrintHeader(os, "AccessCheckInfo"); | 926 HeapObject::PrintHeader(os, "AccessCheckInfo"); |
922 os << "\n - named_callback: " << Brief(named_callback()); | 927 os << "\n - named_callback: " << Brief(named_callback()); |
923 os << "\n - indexed_callback: " << Brief(indexed_callback()); | 928 os << "\n - indexed_callback: " << Brief(indexed_callback()); |
924 os << "\n - data: " << Brief(data()); | 929 os << "\n - data: " << Brief(data()); |
925 os << "\n"; | 930 os << "\n"; |
926 } | 931 } |
927 | 932 |
928 | 933 |
929 void InterceptorInfo::InterceptorInfoPrint(OStream& os) { // NOLINT | 934 void InterceptorInfo::InterceptorInfoPrint(std::ostream& os) { // NOLINT |
930 HeapObject::PrintHeader(os, "InterceptorInfo"); | 935 HeapObject::PrintHeader(os, "InterceptorInfo"); |
931 os << "\n - getter: " << Brief(getter()); | 936 os << "\n - getter: " << Brief(getter()); |
932 os << "\n - setter: " << Brief(setter()); | 937 os << "\n - setter: " << Brief(setter()); |
933 os << "\n - query: " << Brief(query()); | 938 os << "\n - query: " << Brief(query()); |
934 os << "\n - deleter: " << Brief(deleter()); | 939 os << "\n - deleter: " << Brief(deleter()); |
935 os << "\n - enumerator: " << Brief(enumerator()); | 940 os << "\n - enumerator: " << Brief(enumerator()); |
936 os << "\n - data: " << Brief(data()); | 941 os << "\n - data: " << Brief(data()); |
937 os << "\n"; | 942 os << "\n"; |
938 } | 943 } |
939 | 944 |
940 | 945 |
941 void CallHandlerInfo::CallHandlerInfoPrint(OStream& os) { // NOLINT | 946 void CallHandlerInfo::CallHandlerInfoPrint(std::ostream& os) { // NOLINT |
942 HeapObject::PrintHeader(os, "CallHandlerInfo"); | 947 HeapObject::PrintHeader(os, "CallHandlerInfo"); |
943 os << "\n - callback: " << Brief(callback()); | 948 os << "\n - callback: " << Brief(callback()); |
944 os << "\n - data: " << Brief(data()); | 949 os << "\n - data: " << Brief(data()); |
945 os << "\n"; | 950 os << "\n"; |
946 } | 951 } |
947 | 952 |
948 | 953 |
949 void FunctionTemplateInfo::FunctionTemplateInfoPrint(OStream& os) { // NOLINT | 954 void FunctionTemplateInfo::FunctionTemplateInfoPrint( |
| 955 std::ostream& os) { // NOLINT |
950 HeapObject::PrintHeader(os, "FunctionTemplateInfo"); | 956 HeapObject::PrintHeader(os, "FunctionTemplateInfo"); |
951 os << "\n - class name: " << Brief(class_name()); | 957 os << "\n - class name: " << Brief(class_name()); |
952 os << "\n - tag: " << Brief(tag()); | 958 os << "\n - tag: " << Brief(tag()); |
953 os << "\n - property_list: " << Brief(property_list()); | 959 os << "\n - property_list: " << Brief(property_list()); |
954 os << "\n - serial_number: " << Brief(serial_number()); | 960 os << "\n - serial_number: " << Brief(serial_number()); |
955 os << "\n - call_code: " << Brief(call_code()); | 961 os << "\n - call_code: " << Brief(call_code()); |
956 os << "\n - property_accessors: " << Brief(property_accessors()); | 962 os << "\n - property_accessors: " << Brief(property_accessors()); |
957 os << "\n - prototype_template: " << Brief(prototype_template()); | 963 os << "\n - prototype_template: " << Brief(prototype_template()); |
958 os << "\n - parent_template: " << Brief(parent_template()); | 964 os << "\n - parent_template: " << Brief(parent_template()); |
959 os << "\n - named_property_handler: " << Brief(named_property_handler()); | 965 os << "\n - named_property_handler: " << Brief(named_property_handler()); |
960 os << "\n - indexed_property_handler: " << Brief(indexed_property_handler()); | 966 os << "\n - indexed_property_handler: " << Brief(indexed_property_handler()); |
961 os << "\n - instance_template: " << Brief(instance_template()); | 967 os << "\n - instance_template: " << Brief(instance_template()); |
962 os << "\n - signature: " << Brief(signature()); | 968 os << "\n - signature: " << Brief(signature()); |
963 os << "\n - access_check_info: " << Brief(access_check_info()); | 969 os << "\n - access_check_info: " << Brief(access_check_info()); |
964 os << "\n - hidden_prototype: " << (hidden_prototype() ? "true" : "false"); | 970 os << "\n - hidden_prototype: " << (hidden_prototype() ? "true" : "false"); |
965 os << "\n - undetectable: " << (undetectable() ? "true" : "false"); | 971 os << "\n - undetectable: " << (undetectable() ? "true" : "false"); |
966 os << "\n - need_access_check: " << (needs_access_check() ? "true" : "false"); | 972 os << "\n - need_access_check: " << (needs_access_check() ? "true" : "false"); |
967 os << "\n"; | 973 os << "\n"; |
968 } | 974 } |
969 | 975 |
970 | 976 |
971 void ObjectTemplateInfo::ObjectTemplateInfoPrint(OStream& os) { // NOLINT | 977 void ObjectTemplateInfo::ObjectTemplateInfoPrint(std::ostream& os) { // NOLINT |
972 HeapObject::PrintHeader(os, "ObjectTemplateInfo"); | 978 HeapObject::PrintHeader(os, "ObjectTemplateInfo"); |
973 os << " - tag: " << Brief(tag()); | 979 os << " - tag: " << Brief(tag()); |
974 os << "\n - property_list: " << Brief(property_list()); | 980 os << "\n - property_list: " << Brief(property_list()); |
975 os << "\n - property_accessors: " << Brief(property_accessors()); | 981 os << "\n - property_accessors: " << Brief(property_accessors()); |
976 os << "\n - constructor: " << Brief(constructor()); | 982 os << "\n - constructor: " << Brief(constructor()); |
977 os << "\n - internal_field_count: " << Brief(internal_field_count()); | 983 os << "\n - internal_field_count: " << Brief(internal_field_count()); |
978 os << "\n"; | 984 os << "\n"; |
979 } | 985 } |
980 | 986 |
981 | 987 |
982 void SignatureInfo::SignatureInfoPrint(OStream& os) { // NOLINT | 988 void SignatureInfo::SignatureInfoPrint(std::ostream& os) { // NOLINT |
983 HeapObject::PrintHeader(os, "SignatureInfo"); | 989 HeapObject::PrintHeader(os, "SignatureInfo"); |
984 os << "\n - receiver: " << Brief(receiver()); | 990 os << "\n - receiver: " << Brief(receiver()); |
985 os << "\n - args: " << Brief(args()); | 991 os << "\n - args: " << Brief(args()); |
986 os << "\n"; | 992 os << "\n"; |
987 } | 993 } |
988 | 994 |
989 | 995 |
990 void TypeSwitchInfo::TypeSwitchInfoPrint(OStream& os) { // NOLINT | 996 void TypeSwitchInfo::TypeSwitchInfoPrint(std::ostream& os) { // NOLINT |
991 HeapObject::PrintHeader(os, "TypeSwitchInfo"); | 997 HeapObject::PrintHeader(os, "TypeSwitchInfo"); |
992 os << "\n - types: " << Brief(types()); | 998 os << "\n - types: " << Brief(types()); |
993 os << "\n"; | 999 os << "\n"; |
994 } | 1000 } |
995 | 1001 |
996 | 1002 |
997 void AllocationSite::AllocationSitePrint(OStream& os) { // NOLINT | 1003 void AllocationSite::AllocationSitePrint(std::ostream& os) { // NOLINT |
998 HeapObject::PrintHeader(os, "AllocationSite"); | 1004 HeapObject::PrintHeader(os, "AllocationSite"); |
999 os << " - weak_next: " << Brief(weak_next()); | 1005 os << " - weak_next: " << Brief(weak_next()); |
1000 os << "\n - dependent code: " << Brief(dependent_code()); | 1006 os << "\n - dependent code: " << Brief(dependent_code()); |
1001 os << "\n - nested site: " << Brief(nested_site()); | 1007 os << "\n - nested site: " << Brief(nested_site()); |
1002 os << "\n - memento found count: " | 1008 os << "\n - memento found count: " |
1003 << Brief(Smi::FromInt(memento_found_count())); | 1009 << Brief(Smi::FromInt(memento_found_count())); |
1004 os << "\n - memento create count: " | 1010 os << "\n - memento create count: " |
1005 << Brief(Smi::FromInt(memento_create_count())); | 1011 << Brief(Smi::FromInt(memento_create_count())); |
1006 os << "\n - pretenure decision: " | 1012 os << "\n - pretenure decision: " |
1007 << Brief(Smi::FromInt(pretenure_decision())); | 1013 << Brief(Smi::FromInt(pretenure_decision())); |
1008 os << "\n - transition_info: "; | 1014 os << "\n - transition_info: "; |
1009 if (transition_info()->IsSmi()) { | 1015 if (transition_info()->IsSmi()) { |
1010 ElementsKind kind = GetElementsKind(); | 1016 ElementsKind kind = GetElementsKind(); |
1011 os << "Array allocation with ElementsKind " << ElementsKindToString(kind); | 1017 os << "Array allocation with ElementsKind " << ElementsKindToString(kind); |
1012 } else if (transition_info()->IsJSArray()) { | 1018 } else if (transition_info()->IsJSArray()) { |
1013 os << "Array literal " << Brief(transition_info()); | 1019 os << "Array literal " << Brief(transition_info()); |
1014 } else { | 1020 } else { |
1015 os << "unknown transition_info" << Brief(transition_info()); | 1021 os << "unknown transition_info" << Brief(transition_info()); |
1016 } | 1022 } |
1017 os << "\n"; | 1023 os << "\n"; |
1018 } | 1024 } |
1019 | 1025 |
1020 | 1026 |
1021 void AllocationMemento::AllocationMementoPrint(OStream& os) { // NOLINT | 1027 void AllocationMemento::AllocationMementoPrint(std::ostream& os) { // NOLINT |
1022 HeapObject::PrintHeader(os, "AllocationMemento"); | 1028 HeapObject::PrintHeader(os, "AllocationMemento"); |
1023 os << " - allocation site: "; | 1029 os << " - allocation site: "; |
1024 if (IsValid()) { | 1030 if (IsValid()) { |
1025 GetAllocationSite()->Print(os); | 1031 GetAllocationSite()->Print(os); |
1026 } else { | 1032 } else { |
1027 os << "<invalid>\n"; | 1033 os << "<invalid>\n"; |
1028 } | 1034 } |
1029 } | 1035 } |
1030 | 1036 |
1031 | 1037 |
1032 void Script::ScriptPrint(OStream& os) { // NOLINT | 1038 void Script::ScriptPrint(std::ostream& os) { // NOLINT |
1033 HeapObject::PrintHeader(os, "Script"); | 1039 HeapObject::PrintHeader(os, "Script"); |
1034 os << "\n - source: " << Brief(source()); | 1040 os << "\n - source: " << Brief(source()); |
1035 os << "\n - name: " << Brief(name()); | 1041 os << "\n - name: " << Brief(name()); |
1036 os << "\n - line_offset: " << Brief(line_offset()); | 1042 os << "\n - line_offset: " << Brief(line_offset()); |
1037 os << "\n - column_offset: " << Brief(column_offset()); | 1043 os << "\n - column_offset: " << Brief(column_offset()); |
1038 os << "\n - type: " << Brief(type()); | 1044 os << "\n - type: " << Brief(type()); |
1039 os << "\n - id: " << Brief(id()); | 1045 os << "\n - id: " << Brief(id()); |
1040 os << "\n - context data: " << Brief(context_data()); | 1046 os << "\n - context data: " << Brief(context_data()); |
1041 os << "\n - wrapper: " << Brief(wrapper()); | 1047 os << "\n - wrapper: " << Brief(wrapper()); |
1042 os << "\n - compilation type: " << compilation_type(); | 1048 os << "\n - compilation type: " << compilation_type(); |
1043 os << "\n - line ends: " << Brief(line_ends()); | 1049 os << "\n - line ends: " << Brief(line_ends()); |
1044 os << "\n - eval from shared: " << Brief(eval_from_shared()); | 1050 os << "\n - eval from shared: " << Brief(eval_from_shared()); |
1045 os << "\n - eval from instructions offset: " | 1051 os << "\n - eval from instructions offset: " |
1046 << Brief(eval_from_instructions_offset()); | 1052 << Brief(eval_from_instructions_offset()); |
1047 os << "\n"; | 1053 os << "\n"; |
1048 } | 1054 } |
1049 | 1055 |
1050 | 1056 |
1051 void DebugInfo::DebugInfoPrint(OStream& os) { // NOLINT | 1057 void DebugInfo::DebugInfoPrint(std::ostream& os) { // NOLINT |
1052 HeapObject::PrintHeader(os, "DebugInfo"); | 1058 HeapObject::PrintHeader(os, "DebugInfo"); |
1053 os << "\n - shared: " << Brief(shared()); | 1059 os << "\n - shared: " << Brief(shared()); |
1054 os << "\n - original_code: " << Brief(original_code()); | 1060 os << "\n - original_code: " << Brief(original_code()); |
1055 os << "\n - code: " << Brief(code()); | 1061 os << "\n - code: " << Brief(code()); |
1056 os << "\n - break_points: "; | 1062 os << "\n - break_points: "; |
1057 break_points()->Print(os); | 1063 break_points()->Print(os); |
1058 } | 1064 } |
1059 | 1065 |
1060 | 1066 |
1061 void BreakPointInfo::BreakPointInfoPrint(OStream& os) { // NOLINT | 1067 void BreakPointInfo::BreakPointInfoPrint(std::ostream& os) { // NOLINT |
1062 HeapObject::PrintHeader(os, "BreakPointInfo"); | 1068 HeapObject::PrintHeader(os, "BreakPointInfo"); |
1063 os << "\n - code_position: " << code_position()->value(); | 1069 os << "\n - code_position: " << code_position()->value(); |
1064 os << "\n - source_position: " << source_position()->value(); | 1070 os << "\n - source_position: " << source_position()->value(); |
1065 os << "\n - statement_position: " << statement_position()->value(); | 1071 os << "\n - statement_position: " << statement_position()->value(); |
1066 os << "\n - break_point_objects: " << Brief(break_point_objects()); | 1072 os << "\n - break_point_objects: " << Brief(break_point_objects()); |
1067 os << "\n"; | 1073 os << "\n"; |
1068 } | 1074 } |
1069 | 1075 |
1070 | 1076 |
1071 void DescriptorArray::PrintDescriptors(OStream& os) { // NOLINT | 1077 void DescriptorArray::PrintDescriptors(std::ostream& os) { // NOLINT |
1072 os << "Descriptor array " << number_of_descriptors() << "\n"; | 1078 os << "Descriptor array " << number_of_descriptors() << "\n"; |
1073 for (int i = 0; i < number_of_descriptors(); i++) { | 1079 for (int i = 0; i < number_of_descriptors(); i++) { |
1074 Descriptor desc; | 1080 Descriptor desc; |
1075 Get(i, &desc); | 1081 Get(i, &desc); |
1076 os << " " << i << ": " << desc; | 1082 os << " " << i << ": " << desc; |
1077 } | 1083 } |
1078 os << "\n"; | 1084 os << "\n"; |
1079 } | 1085 } |
1080 | 1086 |
1081 | 1087 |
1082 void TransitionArray::PrintTransitions(OStream& os) { // NOLINT | 1088 void TransitionArray::PrintTransitions(std::ostream& os) { // NOLINT |
1083 os << "Transition array %d\n", number_of_transitions(); | 1089 os << "Transition array %d\n", number_of_transitions(); |
1084 for (int i = 0; i < number_of_transitions(); i++) { | 1090 for (int i = 0; i < number_of_transitions(); i++) { |
1085 os << " " << i << ": "; | 1091 os << " " << i << ": "; |
1086 GetKey(i)->NamePrint(os); | 1092 GetKey(i)->NamePrint(os); |
1087 os << ": "; | 1093 os << ": "; |
1088 switch (GetTargetDetails(i).type()) { | 1094 switch (GetTargetDetails(i).type()) { |
1089 case FIELD: { | 1095 case FIELD: { |
1090 os << " (transition to field)\n"; | 1096 os << " (transition to field)\n"; |
1091 break; | 1097 break; |
1092 } | 1098 } |
(...skipping 10 matching lines...) Expand all Loading... |
1103 } | 1109 } |
1104 } | 1110 } |
1105 os << "\n"; | 1111 os << "\n"; |
1106 } | 1112 } |
1107 | 1113 |
1108 | 1114 |
1109 #endif // OBJECT_PRINT | 1115 #endif // OBJECT_PRINT |
1110 | 1116 |
1111 | 1117 |
1112 } } // namespace v8::internal | 1118 } } // namespace v8::internal |
OLD | NEW |