Description
π Search Terms
wildcard pattern include exclude tsconfig regex regexp regular expression glob performance slow node
π Version & Regression Information
- This is the behavior in every version I tried
β― Playground Link
No response
π» Code
Create a TS project with any empty TS file and the following TSConfig.
{
"compilerOptions": {
"noCheck": true,
"noEmit": true,
"noResolve": true,
},
"exclude": [
"alpha/beta/gamma/delta/epsilon/zeta/eta/theta/iota/kappa/lambda/**/*.ts",
"alpha/beta/gamma/delta/epsilon/zeta/eta/theta/iota/kappa/lambda/**/*.ts",
"alpha/beta/gamma/delta/epsilon/zeta/eta/theta/iota/kappa/lambda/**/*.ts",
...repeat a couple hundred or more times
]
}
I've created a repo to more easily reproduce the behavior: https://github.com/MichaelMitchell-at/typescript_slow_wildcards_repro
π Actual behavior
tsc
takes several seconds to run on the project, even though there is no work to do and there are no files to compare the exclude
patterns against. In fact, running tsc
with node --jitless
is much faster than without.
π Expected behavior
tsc
should complete quickly.
Additional information about the issue
I've determined through profiling that the issue is that a giant RegExp
combining all the patterns gets created which is very slow to evaluate.
TypeScript/src/compiler/utilities.ts
Lines 9556 to 9566 in 739d729
From my testing, it's much faster to build a separate RegExp
for each pattern and test them one by one for large number of patterns and for a small number of patterns there is no perceivable difference in speed. I've created a PR implementing this change which greatly improves the performance: #61104