2020-07-16 14:46:13 +00:00
|
|
|
// Copyright 2020 the V8 project authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
|
|
// found in the LICENSE file.
|
|
|
|
|
|
|
|
const KB = 1024;
|
|
|
|
const MB = KB * KB;
|
|
|
|
const GB = MB * KB;
|
|
|
|
const kMillis2Seconds = 1 / 1000;
|
|
|
|
|
|
|
|
function formatBytes(bytes) {
|
|
|
|
const units = ['B', 'KiB', 'MiB', 'GiB'];
|
|
|
|
const divisor = 1024;
|
|
|
|
let index = 0;
|
|
|
|
while (index < units.length && bytes >= divisor) {
|
|
|
|
index++;
|
|
|
|
bytes /= divisor;
|
|
|
|
}
|
|
|
|
return bytes.toFixed(2) + units[index];
|
|
|
|
}
|
|
|
|
|
|
|
|
function formatSeconds(millis) {
|
|
|
|
return (millis * kMillis2Seconds).toFixed(2) + 's';
|
|
|
|
}
|
|
|
|
|
2020-07-22 15:00:22 +00:00
|
|
|
function defineCustomElement(path, generator) {
|
|
|
|
let name = path.substring(path.lastIndexOf("/") + 1, path.length);
|
|
|
|
path = path + '-template.html';
|
|
|
|
fetch(path)
|
2020-07-16 14:46:13 +00:00
|
|
|
.then(stream => stream.text())
|
|
|
|
.then(
|
|
|
|
templateText => customElements.define(name, generator(templateText)));
|
|
|
|
}
|
|
|
|
|
|
|
|
// DOM Helpers
|
|
|
|
function removeAllChildren(node) {
|
|
|
|
let range = document.createRange();
|
|
|
|
range.selectNodeContents(node);
|
|
|
|
range.deleteContents();
|
|
|
|
}
|
|
|
|
|
|
|
|
function $(id) {
|
|
|
|
return document.querySelector(id)
|
|
|
|
}
|
|
|
|
|
2020-07-28 09:02:26 +00:00
|
|
|
class CSSColor {
|
|
|
|
static getColor(name) {
|
|
|
|
const style = getComputedStyle(document.body);
|
|
|
|
return style.getPropertyValue(`--${name}`);
|
|
|
|
}
|
|
|
|
static get backgroundColor() {
|
|
|
|
return CSSColor.getColor('backgroud-color');
|
|
|
|
}
|
|
|
|
static get surfaceColor() {
|
|
|
|
return CSSColor.getColor('surface-color');
|
|
|
|
}
|
|
|
|
static get primaryColor() {
|
|
|
|
return CSSColor.getColor('primary-color');
|
|
|
|
}
|
|
|
|
static get secondaryColor() {
|
|
|
|
return CSSColor.getColor('secondary-color');
|
|
|
|
}
|
|
|
|
static get onSurfaceColor() {
|
|
|
|
return CSSColor.getColor('on-surface-color');
|
|
|
|
}
|
|
|
|
static get onBackgroundColor() {
|
|
|
|
return CSSColor.getColor('on-background-color');
|
|
|
|
}
|
|
|
|
static get onPrimaryColor() {
|
|
|
|
return CSSColor.getColor('on-primary-color');
|
|
|
|
}
|
|
|
|
static get onSecondaryColor() {
|
|
|
|
return CSSColor.getColor('on-secondary-color');
|
|
|
|
}
|
|
|
|
static get defaultColor() {
|
|
|
|
return CSSColor.getColor('default-color');
|
|
|
|
}
|
|
|
|
static get errorColor() {
|
|
|
|
return CSSColor.getColor('error-color');
|
|
|
|
}
|
|
|
|
static get mapBackgroundColor() {
|
|
|
|
return CSSColor.getColor('map-background-color');
|
|
|
|
}
|
|
|
|
static get timelineBackgroundColor() {
|
|
|
|
return CSSColor.getColor('timeline-background-color');
|
|
|
|
}
|
|
|
|
static get red() {
|
|
|
|
return CSSColor.getColor('red');
|
|
|
|
}
|
|
|
|
static get green() {
|
|
|
|
return CSSColor.getColor('green');
|
|
|
|
}
|
|
|
|
static get yellow() {
|
|
|
|
return CSSColor.getColor('yellow');
|
|
|
|
}
|
|
|
|
static get blue() {
|
|
|
|
return CSSColor.getColor('blue');
|
|
|
|
}
|
|
|
|
static get orange() {
|
|
|
|
return CSSColor.getColor('orange');
|
|
|
|
}
|
|
|
|
static get violet() {
|
|
|
|
return CSSColor.getColor('violet');
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
function transitionTypeToColor(type) {
|
|
|
|
switch (type) {
|
|
|
|
case 'new':
|
|
|
|
return CSSColor.green;
|
|
|
|
case 'Normalize':
|
|
|
|
return CSSColor.violet;
|
|
|
|
case 'SlowToFast':
|
|
|
|
return CSSColor.orange;
|
|
|
|
case 'InitialMap':
|
|
|
|
return CSSColor.yellow;
|
|
|
|
case 'Transition':
|
|
|
|
return CSSColor.primaryColor;
|
|
|
|
case 'ReplaceDescriptors':
|
|
|
|
return CSSColor.red;
|
2020-07-28 12:46:10 +00:00
|
|
|
case 'LoadGlobalIC':
|
|
|
|
return CSSColor.green;
|
|
|
|
case 'StoreInArrayLiteralIC':
|
|
|
|
return CSSColor.violet;
|
|
|
|
case 'StoreIC':
|
|
|
|
return CSSColor.orange;
|
|
|
|
case 'KeyedLoadIC':
|
|
|
|
return CSSColor.red;
|
|
|
|
case 'KeyedStoreIC':
|
|
|
|
return CSSColor.primaryColor;
|
2020-07-28 09:02:26 +00:00
|
|
|
}
|
|
|
|
return CSSColor.primaryColor;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-07-28 12:46:10 +00:00
|
|
|
|
2020-07-16 14:46:13 +00:00
|
|
|
function div(classes) {
|
|
|
|
let node = document.createElement('div');
|
|
|
|
if (classes !== void 0) {
|
|
|
|
if (typeof classes === 'string') {
|
|
|
|
node.classList.add(classes);
|
|
|
|
} else {
|
|
|
|
classes.forEach(cls => node.classList.add(cls));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return node;
|
|
|
|
}
|
|
|
|
|
|
|
|
class V8CustomElement extends HTMLElement {
|
|
|
|
constructor(templateText) {
|
|
|
|
super();
|
|
|
|
const shadowRoot = this.attachShadow({mode: 'open'});
|
|
|
|
shadowRoot.innerHTML = templateText;
|
|
|
|
}
|
|
|
|
$(id) {
|
|
|
|
return this.shadowRoot.querySelector(id);
|
|
|
|
}
|
|
|
|
|
|
|
|
querySelectorAll(query) {
|
|
|
|
return this.shadowRoot.querySelectorAll(query);
|
|
|
|
}
|
|
|
|
|
|
|
|
div(classes) {return div(classes)}
|
|
|
|
|
|
|
|
table(className) {
|
|
|
|
let node = document.createElement('table')
|
|
|
|
if (className) node.classList.add(className)
|
|
|
|
return node;
|
|
|
|
}
|
|
|
|
|
|
|
|
td(textOrNode) {
|
|
|
|
let node = document.createElement('td');
|
|
|
|
if (typeof textOrNode === 'object') {
|
|
|
|
node.appendChild(textOrNode);
|
|
|
|
} else {
|
|
|
|
node.innerText = textOrNode;
|
|
|
|
}
|
|
|
|
return node;
|
|
|
|
}
|
|
|
|
|
|
|
|
tr(){
|
|
|
|
return document.createElement('tr');
|
|
|
|
}
|
|
|
|
|
|
|
|
removeAllChildren(node) { return removeAllChildren(node); }
|
|
|
|
}
|
|
|
|
|
2020-07-28 09:02:26 +00:00
|
|
|
export {defineCustomElement, V8CustomElement, removeAllChildren,
|
|
|
|
$, div, transitionTypeToColor, CSSColor};
|