@oaklean/profiler-core
Version:
Part of the @oaklean suite. It provides all basic functions to work with the `.oak` file format. It allows parsing the `.oak` file format as well as tools for analyzing the measurement values. It also provides all necessary capabilities required for prec
228 lines • 17.8 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.CPUNode = exports.CPUNodeType = exports.RegExpTestRegex = void 0;
const NodeModuleUtils_1 = require("./NodeModuleUtils");
const SourceNodeRegex_1 = require("../constants/SourceNodeRegex");
const NodeModule_1 = require("../model/NodeModule");
const UnifiedPath_1 = require("../system/UnifiedPath");
// Types
const types_1 = require("../types");
exports.RegExpTestRegex = new RegExp(`^${SourceNodeRegex_1.LangInternalSourceNodeRegExpRegexString}$`);
var CPUNodeType;
(function (CPUNodeType) {
CPUNodeType["extern"] = "extern";
CPUNodeType["intern"] = "intern";
CPUNodeType["langInternal"] = "lang_internal";
})(CPUNodeType || (exports.CPUNodeType = CPUNodeType = {}));
class CPUNode {
constructor(index, cpuModel, rootDir, node) {
this._index = index;
this.cpuModel = cpuModel;
this.rootDir = rootDir;
this.cpuNode = node;
}
get profilerHits() {
return this.cpuModel.profilerHitsPerNode[this.index];
}
get selfCPUEnergyConsumption() {
return this.cpuModel.energyValuesPerNode ?
this.cpuModel.energyValuesPerNode[this.index][types_1.EnergyValuesType.CPU] : 0;
}
get selfRAMEnergyConsumption() {
return this.cpuModel.energyValuesPerNode ?
this.cpuModel.energyValuesPerNode[this.index][types_1.EnergyValuesType.RAM] : 0;
}
get aggregatedEnergyConsumption() {
if (this._aggregatedEnergyConsumption) {
return this._aggregatedEnergyConsumption;
}
let totalCPU = this.selfCPUEnergyConsumption;
let totalRAM = this.selfRAMEnergyConsumption;
for (const child of this.children()) {
totalCPU = totalCPU + child.aggregatedEnergyConsumption[types_1.EnergyValuesType.CPU];
totalRAM = totalRAM + child.aggregatedEnergyConsumption[types_1.EnergyValuesType.RAM];
}
return (this._aggregatedEnergyConsumption = [totalCPU, totalRAM]);
}
get cpuEnergyConsumption() {
return {
selfCPUEnergyConsumption: this.selfCPUEnergyConsumption,
aggregatedCPUEnergyConsumption: this.aggregatedEnergyConsumption[types_1.EnergyValuesType.CPU]
};
}
get ramEnergyConsumption() {
return {
selfRAMEnergyConsumption: this.selfRAMEnergyConsumption,
aggregatedRAMEnergyConsumption: this.aggregatedEnergyConsumption[types_1.EnergyValuesType.RAM]
};
}
get index() {
return this._index;
}
get cpuTime() {
return {
selfCPUTime: this.cpuNode.selfTime,
aggregatedCPUTime: this.cpuNode.aggregateTime
};
}
get ISourceLocation() {
if (this._sourceLocation === undefined) {
this._sourceLocation = this.cpuModel.ILocations[this.cpuNode.locationId];
}
return this._sourceLocation;
}
get sourceLocation() {
const { lineNumber, columnNumber } = this.ISourceLocation.callFrame;
return {
lineNumber,
columnNumber
};
}
get isLangInternal() {
if (this._isLangInternal === undefined) {
const sourceLocation = this.ISourceLocation;
this._isLangInternal = sourceLocation.callFrame.url.startsWith('node:') ||
(sourceLocation.callFrame.url === '' && sourceLocation.callFrame.functionName.length > 0);
}
return this._isLangInternal;
}
get isEmpty() {
if (this._isEmpty === undefined) {
this._isEmpty = this.ISourceLocation.callFrame.url === '';
}
return this._isEmpty;
}
get rawUrl() {
if (this._rawUrl === undefined) {
this._rawUrl = this.ISourceLocation.callFrame.url;
}
return this._rawUrl;
}
get url() {
if (this._url === undefined) {
this._url = new UnifiedPath_1.UnifiedPath(this.rawUrl);
}
return this._url;
}
get relativeUrl() {
if (this._relativeUrl === undefined) {
if (this.url.isRelative()) {
this._relativeUrl = this.url.copy();
}
else {
this._relativeUrl = this.rootDir.pathTo(this.url);
}
}
return this._relativeUrl;
}
get nodeModulePath() {
if (this._nodeModulePath === undefined) {
const modulePath = NodeModuleUtils_1.NodeModuleUtils.getParentModuleFromPath(this.relativeUrl);
if (modulePath) {
this._nodeModulePath = this.rootDir.join(modulePath);
}
else {
this._nodeModulePath = null;
}
}
return this._nodeModulePath;
}
get nodeModule() {
if (this._nodeModule === undefined) {
this._nodeModule = this.nodeModulePath ? NodeModule_1.NodeModule.fromNodeModulePath(this.nodeModulePath) : null;
if (this.nodeModulePath && !this._nodeModule) {
throw new Error('Module could not be found: ' + this.nodeModulePath.toString());
}
}
return this._nodeModule;
}
get relativeSourceFilePath() {
if (this._relativeSourceFilePath === undefined) {
if (!this.nodeModulePath || !this.nodeModule) {
this._relativeSourceFilePath = this.relativeUrl;
}
else {
if (this.url.isRelative()) {
this._relativeSourceFilePath = this.nodeModulePath.pathTo(this.rootDir.join(this.url));
}
else {
this._relativeSourceFilePath = this.nodeModulePath.pathTo(this.url);
}
}
}
return this._relativeSourceFilePath;
}
get isExtern() {
if (this._isExtern === undefined) {
this._isExtern = (this.nodeModulePath !== null);
}
return this._isExtern;
}
get type() {
if (this.isLangInternal) {
return CPUNodeType.langInternal;
}
if (this.isExtern) {
return CPUNodeType.extern;
}
return CPUNodeType.intern;
}
functionNameToSourceNodeIdentifier(functionName) {
const chunks = [];
let chunk = '';
let lastChar = '';
for (const char of functionName) {
if (char === '.') {
if (lastChar === '.') {
chunk += char;
}
else {
chunks.push(`{${chunk}}`);
chunk = '';
}
}
else {
chunk += char;
}
lastChar = char;
}
chunks.push(`{${chunk}}`);
return chunks.join('.');
}
get sourceNodeIdentifier() {
if (this._sourceNodeIdentifier === undefined) {
if (exports.RegExpTestRegex.test(this.ISourceLocation.callFrame.functionName)) {
this._sourceNodeIdentifier = this.ISourceLocation.callFrame.functionName;
}
else {
this._sourceNodeIdentifier = this.functionNameToSourceNodeIdentifier(this.ISourceLocation.callFrame.functionName);
}
}
return this._sourceNodeIdentifier;
}
get isWithinTypescriptFile() {
if (this._isWithinTypescriptFile === undefined) {
this._isWithinTypescriptFile = this.relativeUrl.toString().slice(-3) === '.ts';
}
return this._isWithinTypescriptFile;
}
get relativeJavascriptUrl() {
if (this._relativeJavascriptUrl === undefined) {
this._relativeJavascriptUrl = new UnifiedPath_1.UnifiedPath(this.relativeUrl.toString().slice(0, -3) + '.js');
}
return this._relativeJavascriptUrl;
}
get javascriptUrl() {
if (this._javascriptUrl === undefined) {
this._javascriptUrl = new UnifiedPath_1.UnifiedPath(this.url.toString().slice(0, -3) + '.js');
}
return this._javascriptUrl;
}
*children() {
for (const childId of this.cpuNode.children) {
yield this.cpuModel.getNode(childId);
}
}
}
exports.CPUNode = CPUNode;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CPUNode.js","sourceRoot":"","sources":["../../../src/helper/CPUNode.ts"],"names":[],"mappings":"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"}