Index: src/objects.cc |
diff --git a/src/objects.cc b/src/objects.cc |
index 178b5fdae58ae5d3051f835071a7ae196841c3cf..bdd06b40fc6fb313a73a308b735908507a28d854 100644 |
--- a/src/objects.cc |
+++ b/src/objects.cc |
@@ -2346,6 +2346,18 @@ Handle<Map> Map::CopyGeneralizeAllRepresentations(Handle<Map> map, |
} |
+// static |
+Handle<Map> Map::CopyGeneralizeAllRepresentations(Handle<Map> map, |
+ int modify_index, |
+ StoreMode store_mode, |
+ const char* reason) { |
+ PropertyDetails details = |
+ map->instance_descriptors()->GetDetails(modify_index); |
+ return CopyGeneralizeAllRepresentations(map, modify_index, store_mode, |
+ details.attributes(), reason); |
+} |
+ |
+ |
void Map::DeprecateTransitionTree() { |
if (is_deprecated()) return; |
if (HasTransitionArray()) { |
@@ -2591,8 +2603,8 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map, |
// Check the state of the root map. |
Handle<Map> root_map(old_map->FindRootMap(), isolate); |
if (!old_map->EquivalentToForTransition(*root_map)) { |
- return CopyGeneralizeAllRepresentations(old_map, modify_index, store_mode, |
- old_details.attributes(), "not equivalent"); |
+ return CopyGeneralizeAllRepresentations( |
+ old_map, modify_index, store_mode, "not equivalent"); |
} |
int root_nof = root_map->NumberOfOwnDescriptors(); |
if (modify_index < root_nof) { |
@@ -2601,8 +2613,8 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map, |
(old_details.type() == FIELD && |
(!new_field_type->NowIs(old_descriptors->GetFieldType(modify_index)) || |
!new_representation.fits_into(old_details.representation())))) { |
- return CopyGeneralizeAllRepresentations(old_map, modify_index, store_mode, |
- old_details.attributes(), "root modification"); |
+ return CopyGeneralizeAllRepresentations( |
+ old_map, modify_index, store_mode, "root modification"); |
} |
} |
@@ -2624,8 +2636,7 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map, |
(tmp_type != old_type || |
tmp_descriptors->GetValue(i) != old_descriptors->GetValue(i)))) { |
return CopyGeneralizeAllRepresentations( |
- old_map, modify_index, store_mode, |
- old_details.attributes(), "incompatible"); |
+ old_map, modify_index, store_mode, "incompatible"); |
} |
Representation old_representation = old_details.representation(); |
Representation tmp_representation = tmp_details.representation(); |
@@ -2689,8 +2700,7 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map, |
(tmp_details.type() != old_details.type() || |
tmp_descriptors->GetValue(i) != old_descriptors->GetValue(i)))) { |
return CopyGeneralizeAllRepresentations( |
- old_map, modify_index, store_mode, |
- old_details.attributes(), "incompatible"); |
+ old_map, modify_index, store_mode, "incompatible"); |
} |
target_map = tmp_map; |
} |
@@ -2733,6 +2743,7 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map, |
target_details = target_details.CopyWithRepresentation( |
new_representation.generalize(target_details.representation())); |
} |
+ ASSERT_EQ(old_details.attributes(), target_details.attributes()); |
if (old_details.type() == FIELD || |
target_details.type() == FIELD || |
(modify_index == i && store_mode == FORCE_FIELD) || |