-
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
Support 'go to def' and interacting with inlay hint components #47693
Comments
Adding some notes from our previous discussion How expensive would this be to compute?On the TS side, it sounds like we should already have the symbol locations when we compute the inlay hint text The other things is that inlay hints are only returned for the current viewport, so even in a huge file we should not be requesting thousands of these all at once Could this apply to other symbols displayed in the UI?Potentially. Both hovers and error text are good candidates for this However we are not sure if it makes sense to have a unique type for each use case or if we should try having a single Does this need to be opt-in?Yes, since we have already shipped inlay hints support in TS, clients would need to opt-in to start receiving |
@jrieken Once question I ran into while sketching out the TS api: do we need to support multiple locations for a given span? Here's a simple TS example: interface Foo {
a: number
}
interface Foo {
b: string
}
declare const foo: Foo; Go to def on the type Should we change |
I initially wanted to make it N locations but it doesn't have to be because we don't use the location directly but like a "cursor location", e.g it is like hovering over the first |
@DanielRosenwasser this looks like the thing we saw in today's AUA. |
Should we close this? |
I think we should (I might be biased) |
TypeScript Version: 4.6
Search Terms
provideInlayHints
VS Code recently updated our inlay hints to support tagging ranges within each hint with a location (file + position). This lets us perform operations such as go to definition on individual symbols within an inlay hint
You can see the VS Code side of this API here: https://github.com/microsoft/vscode/blob/516bef8deca4a3dc8544de536eb16d5e88ad8a83/src/vscode-dts/vscode.proposed.inlayHints.d.ts#L40
Proposal
I propose that TS also starts returning symbol locations in its inlay hint response. This would let users hover and click on parts of an inlay hint to interact with it
Here's what the protocol change would look like:
As an example, consider the TS:
With variable type inlay hints enabled, we currently see:
With the new proposal, we would want to return unique
InlayHintDisplayPart
elements forA
andB
. The response would look something like:/cc @jrieken
The text was updated successfully, but these errors were encountered: