-
Notifications
You must be signed in to change notification settings - Fork 12.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. Weβll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Issues with isolatedDeclarations
and the associated fixes in editor
#58426
Comments
I actually do need this turned into separate concrete actionable items. |
I've turned (3) into its own issue: #58449 May or may not be something we can address easily. |
For (4), that's a known pain-point. I'm not sure what the right solution there is. In that case, I would begrudgingly convert that to a module (or in reality I'd use an enum, but people have mixed feelings on that). What would be nice is if we had something like export const TIME_RATIOS: preserveinit = Object.freeze({
ns: 0.000_0001,
us: 0.001,
ms: 1,
s: 1000,
}); to say "actually preserve the entire expression in the declaration file". That means that anyone who runs this has to have |
@DanielRosenwasser Thank you very much and I'm sorry I'm a bit swamped at the moment or I would have done this initially. Apologies @RyanCavanaugh. I have no intuitions about what is actionable here so if it's primarily #3 feel free to close this issue any time. |
Nobody reacted with a π or π on my I think the first actionable thing is to figure out where we can defer some work on these quick fixes. |
It turns out that `typeChecker.getEmitResolver()` can be expensive, so avoid calling it unless necessary. Hopefully this fixes the performance issue (bullet microsoft#1) of microsoft#58426
π Search Terms
isolatedDeclarations, quickfix, lag, editor, VSCode, 5.5
π Version & Regression Information
β― Playground Link
No response
π» Code
_
π Actual behavior
I've been testing out
isolatedDeclarations
in VSCode Insiders on WSL and wanted to collect a few of the issues I noticed in general, especially with some of the associated quick fixes as discussed with @jakebailey in the TS Discord.Here you can see I can hover this.to?.traverseApply which is trivially inferred as a simple type from the base class. But then after I hover outValidator and it has to generate a quick fix, it's like it gets stuck recalculating it:
Code_-_Insiders_BHWOQgSuwq.mp4
More broadly, I also notice the total check time for ArkType's repo has increased from 7.5 seconds in 5.4 to 9.5 seconds in 5.5, so there may be some underlying change to e.g. calculate additional predicates, but these fixes associated with isolatedDelcarations seem to be particularly problematic.
Another pattern I noticed was lots of inline imports when applying a quick-fix which is rarely desirable. It would be great if by default (e.g. if there are no naming conflicts), the import would be added to the top of the file and the type would be referenced as normal:
Code_-_Insiders_gBTyHQRaop.mp4
type SomeType<parameter = SomeDefault>
frequently, and I notice whenever a quickfix is applied it adds the parameter even if it's the default.This wouldn't be a huge deal, but since if
SomeDefault
is a type, it will also be expanded out to its structural form and potentially inline-imported, it can add a ton of visual clutter (sometimes an order of magnitude more than the type itself).isolatedDeclarations
is more constants like those strings initialized as class props or stuff like this could somehow not require duplicating the entire object structure at a type-level to replicate whattypeof someConstant
could do in the past:If that's fundamentally in conflict with the goals of
--isolatedDeclarations
, feel free to disregard, it just feels frustrating to have no way to derive the type and value from a single source without repeating them anymore even for simple cases.Sorry for the haphazard format of this issue. I'm very excited about this feature as some of these kinks are ironed out I think the fixes will also add a lot of value, I just wanted to make sure there was a record of these things, particularly since Jake requested I submit something.
π Expected behavior
_
Additional information about the issue
No response
The text was updated successfully, but these errors were encountered: