profview: Make entire tree row clickable, and change row node structure.

This patch also includes some CSS tweaks and other minor cleanup.

Bug: v8:6240
Change-Id: I86e26fe53465dff6f9a706f58e565b1f1ee559da
Reviewed-on: https://chromium-review.googlesource.com/1172360
Commit-Queue: Bret Sepulveda <bsep@chromium.org>
Reviewed-by: Jaroslav Sevcik <jarin@chromium.org>
Cr-Commit-Position: refs/heads/master@{#55089}
This commit is contained in:
Bret Sepulveda 2018-08-13 15:45:39 +02:00 committed by Commit Bot
parent 1fc3dc2fcf
commit 38e0fb849f
3 changed files with 79 additions and 77 deletions

View File

@ -108,7 +108,7 @@ found in the LICENSE file. -->
<br>
<br>
<br>
Copyright the V8 Authors - Last change to this page: 2017/02/15
Copyright the V8 Authors - Last change to this page: 2018/08/13
</p>
</body>

View File

@ -2,6 +2,11 @@ table.calltree {
width : 100%;
}
td {
padding-top: 0.1em;
padding-bottom: 0.1em;
}
.numeric {
width : 12ex;
}
@ -14,27 +19,25 @@ body {
font-family: 'Roboto', sans-serif;
}
div.code-type-chip {
display : inline-block;
padding : 0.0em;
.tree-row-arrow {
margin-right: 0.2em;
text-align: right;
}
span.code-type-chip {
.code-type-chip {
border-radius : 1em;
display : inline-block;
padding : 0.1em;
padding : 0.2em;
background-color : #4040c0;
color: #ffffff;
font-size : small;
box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
}
span.code-type-chip-space {
width : 0.5ex;
display : inline-block;
.tree-row-name {
margin-left: 0.2em;
}
span.codeid-link {
.codeid-link {
text-decoration: underline;
cursor: pointer;
}

View File

@ -292,27 +292,15 @@ function codeTypeToText(type) {
console.error("Unknown type: " + type);
}
function createTypeDiv(type) {
function createTypeNode(type) {
if (type === "CAT") {
return document.createTextNode("");
}
let div = document.createElement("div");
div.classList.add("code-type-chip");
let span = document.createElement("span");
span.classList.add("code-type-chip");
span.textContent = codeTypeToText(type);
div.appendChild(span);
span = document.createElement("span");
span.classList.add("code-type-chip-space");
div.appendChild(span);
return div;
}
function isBytecodeHandler(kind) {
return kind === "BytecodeHandler";
return span;
}
function filterFromFilterId(id) {
@ -323,31 +311,42 @@ function filterFromFilterId(id) {
return (type, kind) => type !== 'CODE';
case "js-exclude-bc":
return (type, kind) =>
type !== 'CODE' || !isBytecodeHandler(kind);
type !== 'CODE' || kind !== "BytecodeHandler";
}
}
function createTableExpander(indent) {
function createIndentNode(indent) {
let div = document.createElement("div");
div.style.width = (indent + 0.5) + "em";
div.style.display = "inline-block";
div.style.textAlign = "right";
div.style.width = (indent + 0.5) + "em";
return div;
}
function createFunctionNode(name, codeId) {
if (codeId === -1) {
return document.createTextNode(name);
function createArrowNode() {
let span = document.createElement("span");
span.classList.add("tree-row-arrow");
return span;
}
function createFunctionNode(name, codeId) {
let nameElement = document.createElement("span");
nameElement.classList.add("codeid-link");
nameElement.onclick = function() {
main.setCurrentCode(codeId);
};
nameElement.appendChild(document.createTextNode(name));
nameElement.classList.add("tree-row-name");
if (codeId !== -1) {
nameElement.classList.add("codeid-link");
nameElement.onclick = (event) => {
main.setCurrentCode(codeId);
// Prevent the click from bubbling to the row and causing it to
// collapse/expand.
event.stopPropagation();
};
}
return nameElement;
}
const COLLAPSED_ARROW = "\u25B6";
const EXPANDED_ARROW = "\u25BC";
class CallTreeView {
constructor() {
this.element = $("calltree");
@ -401,22 +400,19 @@ class CallTreeView {
}
expandTree(tree, indent) {
let that = this;
let index = 0;
let id = "R/";
let row = tree.row;
let expander = tree.expander;
if (row) {
index = row.rowIndex;
id = row.id;
// Make sure we collapse the children when the row is clicked
// again.
expander.textContent = "\u25BE";
let expandHandler = expander.onclick;
expander.onclick = () => {
that.collapseRow(tree, expander, expandHandler);
tree.arrow.textContent = EXPANDED_ARROW;
// Collapse the children when the row is clicked again.
let expandHandler = row.onclick;
row.onclick = () => {
this.collapseRow(tree, expandHandler);
}
}
@ -463,9 +459,10 @@ class CallTreeView {
// Create the name cell.
let nameCell = row.insertCell();
let expander = createTableExpander(indent + 1);
nameCell.appendChild(expander);
nameCell.appendChild(createTypeDiv(node.type));
nameCell.appendChild(createIndentNode(indent + 1));
let arrow = createArrowNode();
nameCell.appendChild(arrow);
nameCell.appendChild(createTypeNode(node.type));
nameCell.appendChild(createFunctionNode(node.name, node.codeId));
// Inclusive ticks cell.
@ -479,18 +476,18 @@ class CallTreeView {
c.style.textAlign = "right";
}
if (node.children.length > 0) {
expander.textContent = "\u25B8";
expander.onclick = () => { that.expandTree(node, indent + 1); };
arrow.textContent = COLLAPSED_ARROW;
row.onclick = () => { this.expandTree(node, indent + 1); };
}
node.row = row;
node.expander = expander;
node.arrow = arrow;
index++;
}
}
collapseRow(tree, expander, expandHandler) {
collapseRow(tree, expandHandler) {
let row = tree.row;
let id = row.id;
let index = row.rowIndex;
@ -499,8 +496,8 @@ class CallTreeView {
this.rows.deleteRow(index);
}
expander.textContent = "\u25B8";
expander.onclick = expandHandler;
tree.arrow.textContent = COLLAPSED_ARROW;
row.onclick = expandHandler;
}
fillSelects(mode, calltree) {
@ -1117,22 +1114,22 @@ class SummaryView {
return row;
}
function makeCollapsible(row, expander) {
expander.textContent = "\u25BE";
let expandHandler = expander.onclick;
expander.onclick = () => {
function makeCollapsible(row, arrow) {
arrow.textContent = EXPANDED_ARROW;
let expandHandler = row.onclick;
row.onclick = () => {
let id = row.id;
let index = row.rowIndex + 1;
while (index < rows.rows.length &&
rows.rows[index].id.startsWith(id)) {
rows.deleteRow(index);
}
expander.textContent = "\u25B8";
expander.onclick = expandHandler;
arrow.textContent = COLLAPSED_ARROW;
row.onclick = expandHandler;
}
}
function expandDeoptInstances(row, expander, instances, indent, kind) {
function expandDeoptInstances(row, arrow, instances, indent, kind) {
let index = row.rowIndex;
for (let i = 0; i < instances.length; i++) {
let childRow = rows.insertRow(index + 1);
@ -1148,18 +1145,19 @@ class SummaryView {
document.createTextNode("Reason: " + deopt.reason));
reasonCell.style.textIndent = indent + "em";
}
makeCollapsible(row, expander);
makeCollapsible(row, arrow);
}
function expandDeoptFunctionList(row, expander, list, indent, kind) {
function expandDeoptFunctionList(row, arrow, list, indent, kind) {
let index = row.rowIndex;
for (let i = 0; i < list.length; i++) {
let childRow = rows.insertRow(index + 1);
childRow.id = row.id + i + "/";
let textCell = childRow.insertCell(-1);
let expander = createTableExpander(indent);
textCell.appendChild(expander);
textCell.appendChild(createIndentNode(indent));
let childArrow = createArrowNode();
textCell.appendChild(childArrow);
textCell.appendChild(
createFunctionNode(list[i].f.name, list[i].f.codes[0]));
@ -1167,16 +1165,16 @@ class SummaryView {
numberCell.textContent = list[i].instances.length;
numberCell.style.textIndent = indent + "em";
expander.textContent = "\u25B8";
expander.onclick = () => {
childArrow.textContent = COLLAPSED_ARROW;
childRow.onclick = () => {
expandDeoptInstances(
childRow, expander, list[i].instances, indent + 1);
childRow, childArrow, list[i].instances, indent + 1);
};
}
makeCollapsible(row, expander);
makeCollapsible(row, arrow);
}
function expandOptimizedFunctionList(row, expander, list, indent, kind) {
function expandOptimizedFunctionList(row, arrow, list, indent, kind) {
let index = row.rowIndex;
for (let i = 0; i < list.length; i++) {
let childRow = rows.insertRow(index + 1);
@ -1191,7 +1189,7 @@ class SummaryView {
numberCell.textContent = list[i].instances.length;
numberCell.style.textIndent = indent + "em";
}
makeCollapsible(row, expander);
makeCollapsible(row, arrow);
}
function addExpandableRow(text, list, indent, kind) {
@ -1201,8 +1199,9 @@ class SummaryView {
row.style.backgroundColor = CATEGORY_COLOR;
let textCell = row.insertCell(-1);
let expander = createTableExpander(indent);
textCell.appendChild(expander);
textCell.appendChild(createIndentNode(indent));
let arrow = createArrowNode();
textCell.appendChild(arrow);
textCell.appendChild(document.createTextNode(text));
let numberCell = row.insertCell(-1);
@ -1212,16 +1211,16 @@ class SummaryView {
}
if (list.count > 0) {
expander.textContent = "\u25B8";
arrow.textContent = COLLAPSED_ARROW;
if (kind === "opt") {
expander.onclick = () => {
row.onclick = () => {
expandOptimizedFunctionList(
row, expander, list.functions, indent + 1, kind);
row, arrow, list.functions, indent + 1, kind);
};
} else {
expander.onclick = () => {
row.onclick = () => {
expandDeoptFunctionList(
row, expander, list.functions, indent + 1, kind);
row, arrow, list.functions, indent + 1, kind);
};
}
}