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