[inspector] honor order in console.table's filter argument

R=sigurds@chromium.org

Bug: chromium:956475
Change-Id: Ie4ccd84e1c239d771fd9238599c687782ddb1356
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1776097
Reviewed-by: Simon Zünd <szuend@chromium.org>
Reviewed-by: Sigurd Schneider <sigurds@chromium.org>
Commit-Queue: Yang Guo <yangguo@chromium.org>
Cr-Commit-Position: refs/heads/master@{#63505}
This commit is contained in:
Yang Guo 2019-09-02 12:08:06 +02:00 committed by Commit Bot
parent cbf56ee501
commit 0b403dcbec
3 changed files with 123 additions and 9 deletions

View File

@ -493,14 +493,18 @@ std::unique_ptr<protocol::Runtime::RemoteObject> InjectedScript::wrapTable(
&limit, &limit, &preview);
if (!preview) return nullptr;
std::unordered_set<String16> selectedColumns;
std::vector<String16> selectedColumns;
std::unordered_set<String16> columnSet;
v8::Local<v8::Array> v8Columns;
if (maybeColumns.ToLocal(&v8Columns)) {
for (uint32_t i = 0; i < v8Columns->Length(); ++i) {
v8::Local<v8::Value> column;
if (v8Columns->Get(context, i).ToLocal(&column) && column->IsString()) {
selectedColumns.insert(
toProtocolString(isolate, column.As<v8::String>()));
String16 name = toProtocolString(isolate, column.As<v8::String>());
if (columnSet.find(name) == columnSet.end()) {
columnSet.insert(name);
selectedColumns.push_back(name);
}
}
}
}
@ -509,14 +513,18 @@ std::unique_ptr<protocol::Runtime::RemoteObject> InjectedScript::wrapTable(
*preview->getProperties()) {
ObjectPreview* columnPreview = column->getValuePreview(nullptr);
if (!columnPreview) continue;
auto filtered = v8::base::make_unique<Array<PropertyPreview>>();
// Use raw pointer here since the lifetime of each PropertyPreview is
// ensured by columnPreview. This saves an additional clone.
std::unordered_map<String16, PropertyPreview*> columnMap;
for (const std::unique_ptr<PropertyPreview>& property :
*columnPreview->getProperties()) {
if (selectedColumns.find(property->getName()) !=
selectedColumns.end()) {
filtered->emplace_back(property->clone());
}
if (columnSet.find(property->getName()) == columnSet.end()) continue;
columnMap[property->getName()] = property.get();
}
auto filtered = v8::base::make_unique<Array<PropertyPreview>>();
for (const String16& column : selectedColumns) {
if (columnMap.find(column) == columnMap.end()) continue;
filtered->push_back(columnMap[column]->clone());
}
columnPreview->setProperties(std::move(filtered));
}

View File

@ -383,3 +383,97 @@ preview:
type : object
}
{
description : Array(2)
overflow : false
properties : [
[0] : {
name : 0
type : object
value : Object
valuePreview : {
description : Object
overflow : false
properties : [
[0] : {
name : c
type : number
value : 3
}
[1] : {
name : b
type : number
value : 2
}
]
type : object
}
}
[1] : {
name : 1
type : object
value : Object
valuePreview : {
description : Object
overflow : false
properties : [
[0] : {
name : c
type : number
value : 3
}
]
type : object
}
}
]
subtype : array
type : object
}
{
description : Array(2)
overflow : false
properties : [
[0] : {
name : 0
type : object
value : Object
valuePreview : {
description : Object
overflow : false
properties : [
[0] : {
name : c
type : number
value : 3
}
[1] : {
name : b
type : number
value : 2
}
]
type : object
}
}
[1] : {
name : 1
type : object
value : Object
valuePreview : {
description : Object
overflow : false
properties : [
[0] : {
name : c
type : number
value : 3
}
]
type : object
}
}
]
subtype : array
type : object
}

View File

@ -65,6 +65,18 @@ const { session, contextGroup, Protocol } =
console.table(bigTable);`
});
await waitConsoleAPICalledAndDump(true /* concise */);
Protocol.Runtime.evaluate({
expression: `var table = [{a:1, b:2, c:3}, {c:3}];
var filter = ['c', 'b'];
console.table(table, filter);`
});
await waitConsoleAPICalledAndDump();
Protocol.Runtime.evaluate({
expression: `var table = [{a:1, b:2, c:3}, {c:3}];
var filter = ['c', 'b', 'c'];
console.table(table, filter);`
});
await waitConsoleAPICalledAndDump();
InspectorTest.completeTest();
})()