-
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
Add inlay hints support #42089
Add inlay hints support #42089
Changes from 51 commits
cd99389
ab3c937
d91b2f7
8388add
1058fdd
1517b1f
fd9b09f
23afce2
ee6527e
679b58d
446bee4
d2fbd1e
c4abb87
a9e007a
df62a11
fce2619
679f066
eb4b4ad
9297051
467b5cd
e5ca31b
37a7089
2ccfc98
0e5f223
7197d0d
e785943
637c7f8
b3c3e7e
7948cec
a374417
7ac2a35
5767d7e
d7d72d6
9306d72
5cab46f
2750c6b
0090962
f771afc
67dcbb0
957756c
db4135b
b74af7c
388cc6d
f5695a1
6336803
09cdf37
71bae5e
cba4dc3
0e8cdb6
cc06dbc
e8fef30
d8dc8f1
52c9d5c
7ce7a44
24e1a4a
6b279e7
8e9a8d8
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -644,6 +644,20 @@ namespace ts.server { | |
|
||
applyCodeActionCommand = notImplemented; | ||
|
||
provideInlayHints(file: string, span: TextSpan): InlayHint[] { | ||
const { start, length } = span; | ||
const args: protocol.ProvideInlayHintsRequestArgs = { file, start, length }; | ||
|
||
const request = this.processRequest<protocol.ProvideInlayHintsRequest>(CommandNames.ProvideInlayHints, args); | ||
const response = this.processResponse<protocol.ProvideInlayHintsResponse>(request); | ||
|
||
return response.body!.map(item => ({ // TODO: GH#18217 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Does this need the TODO comment? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Seems yes.
At line 641. |
||
...item, | ||
kind: item.kind as InlayHintKind | undefined, | ||
position: this.lineOffsetToPosition(file, item.position), | ||
})); | ||
} | ||
|
||
private createFileLocationOrRangeRequestArgs(positionOrRange: number | TextRange, fileName: string): protocol.FileLocationOrRangeRequestArgs { | ||
return typeof positionOrRange === "number" | ||
? this.createFileLocationRequestArgs(fileName, positionOrRange) | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What are “duplicated” parameter name hints? Do we need all three of these options? What happens if I have
includeInlayParameterNameHints
disabled but the other two enabled? (Sorry if these questions have already been addressed.)There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the review.
The argument is an identifier and it's same as the parameter name.
I'm not sure how to accurately describe this behavior. Any suggestions about the naming?
here's some context. I'm ok to remove them.
There's no hints will be provided.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I actually like the format that Cyrus showed where it was “suppress hints when ...” because it makes it more clear that those options won’t do anything if
includeInlayParameterNameHints
is disabled. Also, does VS Code let us show a nested/hierarchical checkbox list like that screenshot? I don’t think so, but that would be really nice.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I guess that's the description what UI shows. Not about the implementations.
Another problem is VSCode would not open new feature's options by default.
If the option is
suppress something
, the default behavior isnot suppress something
, that isinclude/provide something
. (If I'm correct).Sadly it's not supported.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What about:
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think my ideal scenario would be
and the latter can default to
true
both in VS Code and in TS Server. But I’m ok with swapping it toincludeInlayParameterNameHintsWhenArgumentMatchesName
in the options, and maybe trying to use “suppress” language in the VS Code UI and invert the value sent. I just really don’t want the options UI to allow for a bunch of checkboxes that sound like they should enable something but actually do nothing because they’re really sub-options ofincludeInlayParameterNameHints
.