You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
On my machine type checking takes at least 18s to execute. This is an extremely long time to wait for feedback and contributes to poor DX. Even with watch mode on, reactions to file saves can take a couple of seconds to catch up. We can see from the extended diagnostics that the problem isn't I/O, as almost all of the total time spent is in Check Time:
I think some fairly simple changes can be made to the codebase to speed up check time. And we can persist this changes by enabling lint rules like @typescript-eslint/explicit-function-return-type.
The text was updated successfully, but these errors were encountered:
As another data point, I see similarly long times in Codespaces:
$ time (npm run type-check -w @primer/react >> dev/null)
real 0m22.054s
user 0m34.194s
sys 0m1.221s
That said, I haven't noticed issues with the VSCode extension; incremental checking in that form seems to work pretty quickly.
We are talking about over 85k lines of TypeScript -- I'd be interested in knowing what 'typical' tsc performance looks like to see if/how bad our code really is, vs just the typechecker not being that fast in general. (Although even if we're seeing typical times, there's still no reason not to try and get some performance gains if it's not too much effort and doesn't require sacrificing code quality)
Definitely all for improving performance 👍 Would be great to know what's the floor performance-wise for a project this size along with what the effort would be to get there 👀 When it comes to simplifying types, another possible benefit for this could be improved docgen on the storybook side if they're easier to infer which would be great.
Random, is it possible to profile the project and see which files or types are contributing the most to the check phase?
On my machine type checking takes at least 18s to execute. This is an extremely long time to wait for feedback and contributes to poor DX. Even with watch mode on, reactions to file saves can take a couple of seconds to catch up. We can see from the extended diagnostics that the problem isn't I/O, as almost all of the total time spent is in Check Time:
Luckily the TypeScript wiki has some tips on Performance. Also lucky for us, we seem to have low hanging fruit in almost every area where they claim performance costs can add up, including:
I think some fairly simple changes can be made to the codebase to speed up check time. And we can persist this changes by enabling lint rules like
@typescript-eslint/explicit-function-return-type
.The text was updated successfully, but these errors were encountered: