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

308 lines 23.7 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); Object.defineProperty(exports, "__esModule", { value: true }); exports.ProgramStructureTree = void 0; const fs = __importStar(require("fs")); const BaseModel_1 = require("./BaseModel"); const ModelMap_1 = require("./ModelMap"); const PermissionHelper_1 = require("../helper/PermissionHelper"); const SourceNodeIdentifierHelper_1 = require("../helper/SourceNodeIdentifierHelper"); // Types const types_1 = require("../types"); class ProgramStructureTree extends BaseModel_1.BaseModel { constructor(parent, id, type, identifierType, identifier, beginLoc, endLoc) { super(); if (!SourceNodeIdentifierHelper_1.SourceNodeIdentifierHelper.validateSourceNodeIdentifierPart(identifier)) { throw new Error('ProgramStructureTree.constructor invalid identifier format: ' + identifier); } this.parent = parent; this.id = id; this.type = type; this.identifierType = identifierType; this.identifier = identifier; this.beginLoc = beginLoc; this.endLoc = endLoc; this._children = new ModelMap_1.ModelMap('string'); this._childrenByBeginLoc = new Map(); // Cache initialization this.identifierBySourceLocationCache = new Map(); this.containsLocationCache = new Map(); this.sourceLocationOfIdentifierCache = new Map(); } hasChildren(sourceNodeIdentifierPart) { return this._children.has(sourceNodeIdentifierPart); } getChildren(sourceNodeIdentifierPart) { return this._children.get(sourceNodeIdentifierPart); } childrenValues() { return this._children.values(); } childrenEntries() { return this._children.entries(); } get childrenSize() { return this._children.size; } addChildren(child) { this._children.set(child.identifier, child); this._childrenByBeginLoc.set(`${child.beginLoc.line}:${child.beginLoc.column}`, child); } static compareNodeLocations(a, b) { const [aLine, aColumn] = a.split(':').map(Number); const [bLine, bColumn] = b.split(':').map(Number); if (aLine < bLine) { return -1; } if (aLine > bLine) { return 1; } if (aColumn < bColumn) { return -1; } if (aColumn > bColumn) { return 1; } return 0; } get sortedChildrenKeys() { if (this._sortedChildrenKeys === undefined) { this._sortedChildrenKeys = Array.from(this._childrenByBeginLoc.keys()).sort(ProgramStructureTree.compareNodeLocations); } return this._sortedChildrenKeys; } numberOfLeafs() { const traverse = (currentNode) => { if (currentNode._children.size === 0) { if (currentNode.type === types_1.ProgramStructureTreeType.Root) { return 0; } return 1; } let count = 0; for (const child of currentNode._children.values()) { count += traverse(child); } return count; }; return traverse(this); } /** * Returns the identifier path of the current node. */ identifierPath() { if (this.parent === null) { return this.identifier; } return (this.parent.identifierPath() + '.' + this.identifier); } identifierHierarchy() { const traverse = (currentNode) => { const result = { type: currentNode.type }; for (const [childIdentifier, child] of currentNode._children.entries()) { const children = result.children || {}; children[childIdentifier] = traverse(child); result.children = children; } return result; }; return traverse(this); } toJSON() { return { id: this.id, type: this.type, identifierType: this.identifierType, identifier: this.identifier, beginLoc: this.beginLoc, endLoc: this.endLoc, children: this._children.toJSON() || {} }; } storeToFile(filePath) { PermissionHelper_1.PermissionHelper.writeFileWithUserPermission(filePath, JSON.stringify(this, null, 2)); } static loadFromFile(filePath) { if (!fs.existsSync(filePath.toPlatformString())) { return undefined; } return ProgramStructureTree.fromJSON(fs.readFileSync(filePath.toPlatformString()).toString()); } static fromJSON(json) { return ProgramStructureTree.fromJSONWithParent(json, null); } static fromJSONWithParent(json, parent) { let data; if (typeof json === 'string') { data = JSON.parse(json); } else { data = json; } const result = new ProgramStructureTree(parent, data.id, data.type, data.identifierType, data.identifier, data.beginLoc, data.endLoc); for (const key of Object.keys(data.children)) { result.addChildren(ProgramStructureTree.fromJSON(data.children[key])); } return result; } containsLocation(loc) { const lookupKey = `${loc.line}:${loc.column}`; const cacheResult = this.containsLocationCache.get(lookupKey); if (cacheResult !== undefined) { return cacheResult; } if (loc.line >= this.beginLoc.line && loc.line <= this.endLoc.line) { if (loc.line === this.beginLoc.line && loc.column < this.beginLoc.column) { this.containsLocationCache.set(lookupKey, false); return false; } if (loc.line === this.endLoc.line && loc.column > this.endLoc.column) { this.containsLocationCache.set(lookupKey, false); return false; } this.containsLocationCache.set(lookupKey, true); return true; } this.containsLocationCache.set(lookupKey, false); return false; } identifierNodeBySourceLocation(targetLoc) { const lookupKey = `${targetLoc.line}:${targetLoc.column}`; const traverse = (identifier, currentNode) => { if (currentNode._children.size === 0) { return { identifier, node: currentNode }; } const childrenBeginLocations = currentNode.sortedChildrenKeys; let beginIndex = 0; let endIndex = currentNode._children.size - 1; let pivotIndex; while (beginIndex <= endIndex) { pivotIndex = Math.floor((beginIndex + endIndex) / 2); const pivotBeginLocation = childrenBeginLocations[pivotIndex]; // eslint-disable-next-line @typescript-eslint/no-non-null-assertion const child = currentNode._childrenByBeginLoc.get(pivotBeginLocation); const comp = ProgramStructureTree.compareNodeLocations(lookupKey, pivotBeginLocation); if (comp === 0) { return { identifier: (identifier + '.' + child.identifier), node: child }; } if (comp === -1) { endIndex = pivotIndex - 1; } else { if (child.containsLocation(targetLoc)) { return traverse((identifier + '.' + child.identifier), child); } beginIndex = pivotIndex + 1; } } return { identifier, node: currentNode }; }; if (this.containsLocation(targetLoc)) { return traverse(this.identifier, this); } if (this.type === types_1.ProgramStructureTreeType.Root) { if (targetLoc.line <= this.beginLoc.line && targetLoc.line <= this.endLoc.line) { return { // treat as root node if its before the root node identifier: this.identifier, node: this }; } } return undefined; } identifierBySourceLocation(targetLoc) { const lookupKey = `${targetLoc.line}:${targetLoc.column}`; const cacheResult = this.identifierBySourceLocationCache.get(lookupKey); if (cacheResult !== undefined) { return cacheResult; } const { identifier } = this.identifierNodeBySourceLocation(targetLoc) || { identifier: '' }; this.identifierBySourceLocationCache.set(lookupKey, identifier); return identifier; } sourceLocationOfIdentifier(identifier) { const cacheResult = this.sourceLocationOfIdentifierCache.get(identifier); if (cacheResult !== undefined) { return cacheResult; } const traverse = (identifierStack, currentNode) => { if (identifierStack[0] === currentNode.identifier) { if (identifierStack.length === 1) { return { beginLoc: currentNode.beginLoc, endLoc: currentNode.endLoc }; } const shiftedIdentifierStack = identifierStack.slice(1); for (const child of currentNode._children.values()) { const result = traverse(shiftedIdentifierStack, child); if (result) { return result; } } } return null; }; const identifierStack = SourceNodeIdentifierHelper_1.SourceNodeIdentifierHelper.split(identifier); const result = traverse(identifierStack, this); this.sourceLocationOfIdentifierCache.set(identifier, result); return result; } } exports.ProgramStructureTree = ProgramStructureTree; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ProgramStructureTree.js","sourceRoot":"","sources":["../../../src/model/ProgramStructureTree.ts"],"names":[],"mappings":"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"}