From a7a3243499d94518f1449bb02387375ca01cc699 Mon Sep 17 00:00:00 2001 From: David Michon Date: Thu, 19 Dec 2024 21:30:19 +0000 Subject: [PATCH] Early exit from traversal --- .../bulk-suppressions-patch.ts | 36 ++++++++++++------- 1 file changed, 24 insertions(+), 12 deletions(-) diff --git a/eslint/eslint-patch/src/eslint-bulk-suppressions/bulk-suppressions-patch.ts b/eslint/eslint-patch/src/eslint-bulk-suppressions/bulk-suppressions-patch.ts index 6557f6f7d5c..4e55ad3c309 100644 --- a/eslint/eslint-patch/src/eslint-bulk-suppressions/bulk-suppressions-patch.ts +++ b/eslint/eslint-patch/src/eslint-bulk-suppressions/bulk-suppressions-patch.ts @@ -63,10 +63,15 @@ export interface ITraverser { traverse(node: TSESTree.Node, options: ITraverseOptions): void; } +export interface ITraverseMethods { + break(): void; + skip(): void; +} + export interface ITraverseOptions { visitorKeys: Record; - enter(this: ITraverseOptions & { skip(): void }, node: TSESTree.Node): void; - leave(this: ITraverseOptions & { skip(): void }, node: TSESTree.Node): void; + enter(this: ITraverseOptions & ITraverseMethods, node: TSESTree.Node): void; + leave(this: ITraverseOptions & ITraverseMethods, node: TSESTree.Node): void; } interface ILinterInternalSlots { @@ -244,23 +249,31 @@ function getScopeIdMap( let low: number = 0; let high: number = positions.length - 1; - const boundsStack: [number, number][] = []; + const max: number = positions[high]; + + const highStack: number[] = []; traverser.traverse(sourceCode.ast, { visitorKeys: sourceCode.visitorKeys, enter(node: TSESTree.Node): void { - boundsStack.push([low, high]); - if (node.range[0] > positions[high] || node.range[1] <= positions[low]) { - return this.skip(); + const startInclusive: number = node.range[0]; + if (startInclusive > max) { + // Future nodes irrelevant. We can break out of the traversal. + return this.break(); } - let newLow: number = binarySearch(positions, node.range[0], low, high); - let newHigh: number = binarySearch(positions, node.range[1], low, high); + highStack.push(high); + const endInclusive: number = node.range[1] - 1; + + let newLow: number = binarySearch(positions, startInclusive, low, high); + let newHigh: number = binarySearch(positions, endInclusive, low, high); if (newLow < 0) { + // Start point before the current minimum gets excluded newLow = ~newLow; } if (newHigh < 0) { + // End point above the current maximum gets excluded newHigh = ~newHigh - 1; } @@ -281,12 +294,11 @@ function getScopeIdMap( } } }, - leave(): void { + leave(node: TSESTree.Node): void { // eslint-disable-next-line @typescript-eslint/no-non-null-assertion - const [oldLow, oldHigh] = boundsStack.pop()!; - low = oldLow; + const oldHigh: number = highStack.pop()!; + // Traversal has monotonically increasing positions, so no need to reduce low high = oldHigh; - // Do nothing } });