| Index: src/objects-debug.cc
|
| diff --git a/src/objects-debug.cc b/src/objects-debug.cc
|
| index b24d5def04945628e11a83720a39a1c57c96d6fd..171716680512e190c3bfad85fe22fdc217f8afa2 100644
|
| --- a/src/objects-debug.cc
|
| +++ b/src/objects-debug.cc
|
| @@ -1174,15 +1174,13 @@ bool DescriptorArray::IsSortedNoDuplicates(int valid_entries) {
|
| for (int i = 0; i < number_of_descriptors(); i++) {
|
| Name* key = GetSortedKey(i);
|
| if (key == current_key) {
|
| - OFStream os(stdout);
|
| - PrintDescriptors(os);
|
| + Print();
|
| return false;
|
| }
|
| current_key = key;
|
| uint32_t hash = GetSortedKey(i)->Hash();
|
| if (hash < current) {
|
| - OFStream os(stdout);
|
| - PrintDescriptors(os);
|
| + Print();
|
| return false;
|
| }
|
| current = hash;
|
| @@ -1214,23 +1212,36 @@ bool LayoutDescriptor::IsConsistentWithMap(Map* map) {
|
|
|
| bool TransitionArray::IsSortedNoDuplicates(int valid_entries) {
|
| DCHECK(valid_entries == -1);
|
| - Name* current_key = NULL;
|
| - uint32_t current = 0;
|
| + Name* prev_key = NULL;
|
| + bool prev_is_data_property = false;
|
| + PropertyAttributes prev_attributes = NONE;
|
| + uint32_t prev_hash = 0;
|
| for (int i = 0; i < number_of_transitions(); i++) {
|
| Name* key = GetSortedKey(i);
|
| - if (key == current_key) {
|
| - OFStream os(stdout);
|
| - PrintTransitions(os);
|
| - return false;
|
| + uint32_t hash = key->Hash();
|
| + bool is_data_property = false;
|
| + PropertyAttributes attributes = NONE;
|
| + if (!IsSpecialTransition(key)) {
|
| + Map* target = GetTarget(i);
|
| + PropertyDetails details = GetTargetDetails(key, target);
|
| + is_data_property = details.type() == FIELD || details.type() == CONSTANT;
|
| + attributes = details.attributes();
|
| + } else {
|
| + // Duplicate entries are not allowed for non-property transitions.
|
| + CHECK_NE(prev_key, key);
|
| }
|
| - current_key = key;
|
| - uint32_t hash = GetSortedKey(i)->Hash();
|
| - if (hash < current) {
|
| - OFStream os(stdout);
|
| - PrintTransitions(os);
|
| +
|
| + int cmp =
|
| + CompareKeys(prev_key, prev_hash, prev_is_data_property, prev_attributes,
|
| + key, hash, is_data_property, attributes);
|
| + if (cmp >= 0) {
|
| + Print();
|
| return false;
|
| }
|
| - current = hash;
|
| + prev_key = key;
|
| + prev_hash = hash;
|
| + prev_attributes = attributes;
|
| + prev_is_data_property = is_data_property;
|
| }
|
| return true;
|
| }
|
|
|