UNPKG

@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
"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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"}