| OLD | NEW |
| 1 // Copyright 2006-2008 the V8 project authors. All rights reserved. | 1 // Copyright 2006-2008 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 325 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 336 | 336 |
| 337 | 337 |
| 338 void StringStream::PrintUsingMap(JSObject* js_object) { | 338 void StringStream::PrintUsingMap(JSObject* js_object) { |
| 339 Map* map = js_object->map(); | 339 Map* map = js_object->map(); |
| 340 if (!Heap::Contains(map) || | 340 if (!Heap::Contains(map) || |
| 341 !map->IsHeapObject() || | 341 !map->IsHeapObject() || |
| 342 !map->IsMap()) { | 342 !map->IsMap()) { |
| 343 Add("<Invalid map>\n"); | 343 Add("<Invalid map>\n"); |
| 344 return; | 344 return; |
| 345 } | 345 } |
| 346 for (DescriptorReader r(map->instance_descriptors()); !r.eos(); r.advance()) { | 346 DescriptorArray* descs = map->instance_descriptors(); |
| 347 switch (r.type()) { | 347 for (int i = 0; i < descs->number_of_descriptors(); i++) { |
| 348 switch (descs->GetType(i)) { |
| 348 case FIELD: { | 349 case FIELD: { |
| 349 Object* key = r.GetKey(); | 350 Object* key = descs->GetKey(i); |
| 350 if (key->IsString() || key->IsNumber()) { | 351 if (key->IsString() || key->IsNumber()) { |
| 351 int len = 3; | 352 int len = 3; |
| 352 if (key->IsString()) { | 353 if (key->IsString()) { |
| 353 len = String::cast(key)->length(); | 354 len = String::cast(key)->length(); |
| 354 } | 355 } |
| 355 for (; len < 18; len++) | 356 for (; len < 18; len++) |
| 356 Put(' '); | 357 Put(' '); |
| 357 if (key->IsString()) { | 358 if (key->IsString()) { |
| 358 Put(String::cast(key)); | 359 Put(String::cast(key)); |
| 359 } else { | 360 } else { |
| 360 key->ShortPrint(); | 361 key->ShortPrint(); |
| 361 } | 362 } |
| 362 Add(": "); | 363 Add(": "); |
| 363 Object* value = js_object->FastPropertyAt(r.GetFieldIndex()); | 364 Object* value = js_object->FastPropertyAt(descs->GetFieldIndex(i)); |
| 364 Add("%o\n", value); | 365 Add("%o\n", value); |
| 365 } | 366 } |
| 366 } | 367 } |
| 367 break; | 368 break; |
| 368 default: | 369 default: |
| 369 break; | 370 break; |
| 370 } | 371 } |
| 371 } | 372 } |
| 372 } | 373 } |
| 373 | 374 |
| (...skipping 199 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 573 | 574 |
| 574 // Only grow once to the maximum allowable size. | 575 // Only grow once to the maximum allowable size. |
| 575 char* NoAllocationStringAllocator::grow(unsigned* bytes) { | 576 char* NoAllocationStringAllocator::grow(unsigned* bytes) { |
| 576 ASSERT(size_ >= *bytes); | 577 ASSERT(size_ >= *bytes); |
| 577 *bytes = size_; | 578 *bytes = size_; |
| 578 return space_; | 579 return space_; |
| 579 } | 580 } |
| 580 | 581 |
| 581 | 582 |
| 582 } } // namespace v8::internal | 583 } } // namespace v8::internal |
| OLD | NEW |