Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(17)

Unified Diff: third_party/WebKit/Source/devtools/front_end/components/RemoteObjectPreviewFormatter.js

Issue 2586623002: Revert of DevTools: merge array formatting logic (Closed)
Patch Set: Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/devtools/front_end/components/RemoteObjectPreviewFormatter.js
diff --git a/third_party/WebKit/Source/devtools/front_end/components/RemoteObjectPreviewFormatter.js b/third_party/WebKit/Source/devtools/front_end/components/RemoteObjectPreviewFormatter.js
index e868de21d1c13af41141602360d3487945baa96f..54b36b0506c204d162804a7155aecbb6f9195e9d 100644
--- a/third_party/WebKit/Source/devtools/front_end/components/RemoteObjectPreviewFormatter.js
+++ b/third_party/WebKit/Source/devtools/front_end/components/RemoteObjectPreviewFormatter.js
@@ -5,19 +5,6 @@
* @unrestricted
*/
Components.RemoteObjectPreviewFormatter = class {
- /**
- * @param {!Protocol.Runtime.PropertyPreview} a
- * @param {!Protocol.Runtime.PropertyPreview} b
- * @return {number}
- */
- static _objectPropertyComparator(a, b) {
- if (a.type !== 'function' && b.type === 'function')
- return -1;
- if (a.type === 'function' && b.type !== 'function')
- return 1;
- return 0;
- }
-
/**
* @param {!Element} parentElement
* @param {!Protocol.Runtime.ObjectPreview} preview
@@ -62,8 +49,20 @@
* @param {!Protocol.Runtime.ObjectPreview} preview
*/
_appendObjectPropertiesPreview(parentElement, preview) {
- var properties = preview.properties.filter(p => p.type !== 'accessor')
- .stableSort(Components.RemoteObjectPreviewFormatter._objectPropertyComparator);
+ var properties = preview.properties.filter(p => p.type !== 'accessor').stableSort(compareFunctionsLast);
+
+ /**
+ * @param {!Protocol.Runtime.PropertyPreview} a
+ * @param {!Protocol.Runtime.PropertyPreview} b
+ */
+ function compareFunctionsLast(a, b) {
+ if (a.type !== 'function' && b.type === 'function')
+ return -1;
+ if (a.type === 'function' && b.type !== 'function')
+ return 1;
+ return 0;
+ }
+
for (var i = 0; i < properties.length; ++i) {
if (i > 0)
parentElement.createTextChild(', ');
@@ -82,17 +81,18 @@
_appendArrayPropertiesPreview(parentElement, preview) {
var arrayLength = SDK.RemoteObject.arrayLength(preview);
var properties = preview.properties;
- var indexProperties = properties.filter(p => toArrayIndex(p.name) !== -1).stableSort(arrayPropertyComparator);
- var otherProperties = properties.filter(p => toArrayIndex(p.name) === -1)
- .stableSort(Components.RemoteObjectPreviewFormatter._objectPropertyComparator);
+ properties = properties.slice().stableSort(compareIndexesFirst);
/**
* @param {!Protocol.Runtime.PropertyPreview} a
* @param {!Protocol.Runtime.PropertyPreview} b
- * @return {number}
*/
- function arrayPropertyComparator(a, b) {
- return toArrayIndex(a.name) - toArrayIndex(b.name);
+ function compareIndexesFirst(a, b) {
+ var index1 = toArrayIndex(a.name);
+ var index2 = toArrayIndex(b.name);
+ if (index1 < 0)
+ return index2 < 0 ? 0 : 1;
+ return index2 < 0 ? -1 : index1 - index2;
}
/**
@@ -106,44 +106,16 @@
return -1;
}
- var lastNonEmptyArrayIndex = -1;
- var property;
- for (var i = 0; i < indexProperties.length; ++i) {
+ for (var i = 0; i < properties.length; ++i) {
if (i > 0)
parentElement.createTextChild(', ');
- property = indexProperties[i];
- var index = toArrayIndex(property.name);
- if (index - lastNonEmptyArrayIndex > 1) {
- appendUndefined(index);
- parentElement.createTextChild(', ');
+
+ var property = properties[i];
+ if (property.name !== String(i) || i >= arrayLength) {
+ parentElement.appendChild(this._renderDisplayName(property.name));
+ parentElement.createTextChild(': ');
}
- lastNonEmptyArrayIndex = index;
parentElement.appendChild(this._renderPropertyPreviewOrAccessor([property]));
- }
-
- var elementsAdded = indexProperties.length > 0;
- if (arrayLength - lastNonEmptyArrayIndex > 1) {
- if (lastNonEmptyArrayIndex > -1)
- parentElement.createTextChild(', ');
- appendUndefined(arrayLength);
- elementsAdded = true;
- }
-
- for (var i = 0; i < otherProperties.length; ++i) {
- if (elementsAdded || i > 0)
- parentElement.createTextChild(', ');
- property = otherProperties[i];
- parentElement.appendChild(this._renderDisplayName(property.name));
- parentElement.createTextChild(': ');
- parentElement.appendChild(this._renderPropertyPreviewOrAccessor([property]));
- }
-
- /**
- * @param {number} index
- */
- function appendUndefined(index) {
- var span = parentElement.createChild('span', 'object-value-undefined');
- span.textContent = Common.UIString('undefined × %d', index - lastNonEmptyArrayIndex - 1);
}
}

Powered by Google App Engine
This is Rietveld 408576698