v8/tools/system-analyzer/log/ic.mjs

70 lines
2.0 KiB
JavaScript
Raw Normal View History

// 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.
import {LogEntry} from './log.mjs';
export class IcLogEntry extends LogEntry {
constructor(
type, fn_file, time, line, column, key, oldState, newState, map, reason,
modifier, codeEntry) {
super(type, time);
this.category = 'other';
if (this.type.indexOf('Store') !== -1) {
this.category = 'Store';
} else if (this.type.indexOf('Load') !== -1) {
this.category = 'Load';
}
const parts = fn_file.split(' ');
this.functionName = parts[0];
this.file = parts[1];
this.oldState = oldState;
this.newState = newState;
this.key = key;
this.map = map;
this.reason = reason;
this.modifier = modifier;
this.codeEntry = codeEntry;
}
get state() {
return this.oldState + ' → ' + this.newState;
}
get code() {
return this.codeEntry?.logEntry;
}
parseMapProperties(parts, offset) {
let next = parts[++offset];
if (!next.startsWith('dict')) return offset;
this.propertiesMode = next.substr(5) == '0' ? 'fast' : 'slow';
this.numberOfOwnProperties = parts[++offset].substr(4);
next = parts[++offset];
this.instanceType = next.substr(5, next.length - 6);
return offset;
}
parsePositionAndFile(parts, start) {
// find the position of 'at' in the parts array.
let offset = start;
for (let i = start + 1; i < parts.length; i++) {
offset++;
if (parts[i] == 'at') break;
}
if (parts[offset] !== 'at') return -1;
this.position = parts.slice(start, offset).join(' ');
offset += 1;
this.isNative = parts[offset] == 'native'
offset += this.isNative ? 1 : 0;
this.file = parts[offset];
return offset;
}
static get propertyNames() {
return [
'type', 'category', 'functionName', 'script', 'sourcePosition', 'code',
'state', 'key', 'map', 'reason'
];
}
}