OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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 294 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
305 if (HasFastProperties()) { | 305 if (HasFastProperties()) { |
306 CHECK_EQ(map()->unused_property_fields(), | 306 CHECK_EQ(map()->unused_property_fields(), |
307 (map()->inobject_properties() + properties()->length() - | 307 (map()->inobject_properties() + properties()->length() - |
308 map()->NextFreePropertyIndex())); | 308 map()->NextFreePropertyIndex())); |
309 DescriptorArray* descriptors = map()->instance_descriptors(); | 309 DescriptorArray* descriptors = map()->instance_descriptors(); |
310 for (int i = 0; i < map()->NumberOfOwnDescriptors(); i++) { | 310 for (int i = 0; i < map()->NumberOfOwnDescriptors(); i++) { |
311 if (descriptors->GetDetails(i).type() == FIELD) { | 311 if (descriptors->GetDetails(i).type() == FIELD) { |
312 Representation r = descriptors->GetDetails(i).representation(); | 312 Representation r = descriptors->GetDetails(i).representation(); |
313 int field = descriptors->GetFieldIndex(i); | 313 int field = descriptors->GetFieldIndex(i); |
314 Object* value = RawFastPropertyAt(field); | 314 Object* value = RawFastPropertyAt(field); |
| 315 if (r.IsDouble()) ASSERT(value->IsHeapNumber()); |
| 316 if (value->IsUninitialized()) continue; |
315 if (r.IsSmi()) ASSERT(value->IsSmi()); | 317 if (r.IsSmi()) ASSERT(value->IsSmi()); |
316 if (r.IsDouble()) ASSERT(value->IsHeapNumber()); | |
317 if (r.IsHeapObject()) ASSERT(value->IsHeapObject()); | 318 if (r.IsHeapObject()) ASSERT(value->IsHeapObject()); |
318 } | 319 } |
319 } | 320 } |
320 } | 321 } |
321 CHECK_EQ((map()->has_fast_smi_or_object_elements() || | 322 CHECK_EQ((map()->has_fast_smi_or_object_elements() || |
322 (elements() == GetHeap()->empty_fixed_array())), | 323 (elements() == GetHeap()->empty_fixed_array())), |
323 (elements()->map() == GetHeap()->fixed_array_map() || | 324 (elements()->map() == GetHeap()->fixed_array_map() || |
324 elements()->map() == GetHeap()->fixed_cow_array_map())); | 325 elements()->map() == GetHeap()->fixed_cow_array_map())); |
325 CHECK(map()->has_fast_object_elements() == HasFastObjectElements()); | 326 CHECK(map()->has_fast_object_elements() == HasFastObjectElements()); |
326 } | 327 } |
(...skipping 792 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1119 for (int i = 0; i < number_of_transitions(); ++i) { | 1120 for (int i = 0; i < number_of_transitions(); ++i) { |
1120 if (!CheckOneBackPointer(current_map, GetTarget(i))) return false; | 1121 if (!CheckOneBackPointer(current_map, GetTarget(i))) return false; |
1121 } | 1122 } |
1122 return true; | 1123 return true; |
1123 } | 1124 } |
1124 | 1125 |
1125 | 1126 |
1126 #endif // DEBUG | 1127 #endif // DEBUG |
1127 | 1128 |
1128 } } // namespace v8::internal | 1129 } } // namespace v8::internal |
OLD | NEW |