utils/node_modules/@volar/source-map/index.js
2024-02-07 01:33:07 -05:00

182 lines
6.5 KiB
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.buildStacks = exports.buildMappings = exports.SourceMap = void 0;
__exportStar(require("muggle-string"), exports);
class SourceMap {
get memo() {
if (!this._memo) {
const self = this;
this._memo = {
sourceRange: createMemo('sourceRange'),
generatedRange: createMemo('generatedRange'),
};
function createMemo(key) {
const offsets = new Set();
for (const mapping of self.mappings) {
offsets.add(mapping[key][0]);
offsets.add(mapping[key][1]);
}
const arr = [...offsets].sort((a, b) => a - b).map(offset => ({ offset, mappings: new Set() }));
for (const mapping of self.mappings) {
const startIndex = binarySearch(mapping[key][0]);
const endIndex = binarySearch(mapping[key][1]);
for (let i = startIndex; i <= endIndex; i++) {
arr[i].mappings.add(mapping);
}
}
return arr;
function binarySearch(start) {
let low = 0;
let high = arr.length - 1;
while (low <= high) {
const mid = Math.floor((low + high) / 2);
const midValue = arr[mid];
if (midValue.offset < start) {
low = mid + 1;
}
else if (midValue.offset > start) {
high = mid - 1;
}
else {
return mid;
}
}
}
}
}
return this._memo;
}
constructor(mappings) {
this.mappings = mappings;
}
toSourceOffset(start, baseOnRight = false) {
for (const mapped of this.matching(start, 'generatedRange', 'sourceRange', baseOnRight)) {
return mapped;
}
}
toGeneratedOffset(start, baseOnRight = false) {
for (const mapped of this.matching(start, 'sourceRange', 'generatedRange', baseOnRight)) {
return mapped;
}
}
toSourceOffsets(start, baseOnRight = false) {
return this.matching(start, 'generatedRange', 'sourceRange', baseOnRight);
}
toGeneratedOffsets(start, baseOnRight = false) {
return this.matching(start, 'sourceRange', 'generatedRange', baseOnRight);
}
*matching(startOffset, from, to, baseOnRight) {
const memo = this.memo[from];
if (memo.length === 0)
return;
const { low: start, high: end, } = this.binarySearchMemo(memo, startOffset);
const skip = new Set();
for (let i = start; i <= end; i++) {
for (const mapping of memo[i].mappings) {
if (skip.has(mapping)) {
continue;
}
skip.add(mapping);
const mapped = this.matchOffset(startOffset, mapping[from], mapping[to], baseOnRight);
if (mapped !== undefined) {
yield [mapped, mapping];
}
}
}
}
matchOffset(start, mappedFromRange, mappedToRange, baseOnRight) {
if (start >= mappedFromRange[0] && start <= mappedFromRange[1]) {
let offset = mappedToRange[0] + start - mappedFromRange[0];
if (baseOnRight) {
offset += (mappedToRange[1] - mappedToRange[0]) - (mappedFromRange[1] - mappedFromRange[0]);
}
if (offset >= mappedToRange[0] && offset <= mappedToRange[1]) {
return offset;
}
}
}
binarySearchMemo(array, start) {
let low = 0;
let high = array.length - 1;
while (low <= high) {
const mid = Math.floor((low + high) / 2);
const midValue = array[mid];
if (midValue.offset < start) {
low = mid + 1;
}
else if (midValue.offset > start) {
high = mid - 1;
}
else {
low = mid;
high = mid;
break;
}
}
return {
low: Math.max(Math.min(low, high, array.length - 1), 0),
high: Math.min(Math.max(low, high, 0), array.length - 1),
};
}
}
exports.SourceMap = SourceMap;
function buildMappings(chunks) {
let length = 0;
const mappings = [];
for (const segment of chunks) {
if (typeof segment === 'string') {
length += segment.length;
}
else {
mappings.push({
generatedRange: [length, length + segment[0].length],
source: segment[1],
sourceRange: typeof segment[2] === 'number' ? [segment[2], segment[2] + segment[0].length] : segment[2],
// @ts-ignore
data: segment[3],
});
length += segment[0].length;
}
}
return mappings;
}
exports.buildMappings = buildMappings;
function buildStacks(chunks, stacks) {
let offset = 0;
let index = 0;
const result = [];
for (const stack of stacks) {
const start = offset;
for (let i = 0; i < stack.length; i++) {
const segment = chunks[index + i];
if (typeof segment === 'string') {
offset += segment.length;
}
else {
offset += segment[0].length;
}
}
index += stack.length;
result.push({
range: [start, offset],
source: stack.stack,
});
}
return result;
}
exports.buildStacks = buildStacks;
//# sourceMappingURL=index.js.map