Skip to content
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

Cycle through hover results from multiple language servers #10122

Merged
merged 10 commits into from
Jan 26, 2025

Conversation

kyfanc
Copy link
Contributor

@kyfanc kyfanc commented Apr 3, 2024

replaces #9744 with improved UX.

inspired by #9974
fixes #8985

This PR refactor LSP hover feature with the event system, with support of cycling through hover results from multiple LSPs.

keybinding:

  • A-p for previous hover
  • A-n for next hover

asciicast

@kyfanc
Copy link
Contributor Author

kyfanc commented Apr 4, 2024

Also, seems there are some concurrency issues in the integration test.
It failed after ~6h in the previous action.

And i tried to run cargo integration-test locally in my mac, for both this PR & tag 24.03, both failed unstably.
like 2x out of 82 tests failed. but if I run them individually like cargo integration-test test::movement, the failed tests ran successfully.

Any idea?

@kyfanc kyfanc force-pushed the cycle-multi-lsp-hover branch from c61cef2 to 8310f64 Compare April 4, 2024 03:04
@kyfanc kyfanc marked this pull request as draft April 4, 2024 03:08
@kyfanc kyfanc marked this pull request as ready for review April 4, 2024 03:49
@kirawi kirawi added A-language-server Area: Language server client A-helix-term Area: Helix term improvements S-waiting-on-review Status: Awaiting review from a maintainer. labels Apr 4, 2024
@pascalkuthe
Copy link
Member

I have very similar concerns/review as in #9974:

  • you don't need to introduce a handler since this is not really async, the current hover code works fine. Eagerly requesting however from all lsps and then cycling trough them is much much simpler and more efficient. Specifically I refactoring the signature help with the event system because that is something that pops up automatically and hence needs timeouts/denounces. However is only requested by pressing <space>k so all that complex code is not needed
  • keymap should be a-p and a-n to avoid conflicts yet stay consistent with feat: add symbol kind info in picker #9774

@pascalkuthe pascalkuthe added S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. and removed S-waiting-on-review Status: Awaiting review from a maintainer. labels Apr 14, 2024
@kyfanc kyfanc force-pushed the cycle-multi-lsp-hover branch 2 times, most recently from 65d7105 to 9f9016b Compare April 16, 2024 09:09
@kyfanc
Copy link
Contributor Author

kyfanc commented Apr 16, 2024

Thank for the review and comments.

The new push removed the unnecessary handler codes, and updated the keymap as suggested.

@pascalkuthe pascalkuthe added S-waiting-on-review Status: Awaiting review from a maintainer. and removed S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. labels Apr 16, 2024
@kyfanc kyfanc force-pushed the cycle-multi-lsp-hover branch from 9f9016b to a5f9ca8 Compare April 17, 2024 16:05
@cotneit
Copy link
Contributor

cotneit commented Aug 26, 2024

This seems to be working great! Merge with master was pretty straightforward, just a few suggestions:

  • I think it would be better to not display LS name if only one LS returned a result
  • Bottom padding seems excessive, I think 1 line instead of 2 would be a better fit

For visual reference:
master
image
this PR
image

@kyfanc kyfanc force-pushed the cycle-multi-lsp-hover branch from 42555c3 to f6aa0e4 Compare August 27, 2024 04:18
@kyfanc
Copy link
Contributor Author

kyfanc commented Aug 27, 2024

Thanks for the suggestions.
I have rebased onto master with some conflict resolved, and improved the UI as suggested.
This is how it looks like now.

Single result

Screenshot 2024-08-27 at 7 38 54 PM

Multiple results

Screenshot 2024-08-27 at 7 39 41 PM

@paulvandermeijs
Copy link

Great work!

I've been exploring the use of a language server to show git blame information on hover, which was pretty much useless without this. Only issue I noticed during development of the language server is that when the language server is slow or times out it will block messages from other language servers.

@kyfanc kyfanc force-pushed the cycle-multi-lsp-hover branch from 1510f49 to 3313c60 Compare October 18, 2024 04:26
@kyfanc
Copy link
Contributor Author

kyfanc commented Oct 18, 2024

Thanks for your comment! The Git LSP sounds like interesting idea.

Regarding the blocking behaviour, it might be a bit complicated to manage UI interaction with the async responses from each LSPs. I am thinking about if it should display hovers preserving the order of LSPs in config, or by the response sequence from LSPs. It might better to be a separate PR as improvement.

I have rebased onto master with some conflict resolved.

@kas2020-commits
Copy link
Contributor

Thanks for putting the work in on an impl! I've been eyeing this PR for a while now hoping it gets merged.

This would be very handy in a lots of FE projects. For example I work on a project that uses astro-ls + tailwindcss where you want to expose your tailwind classes' css but also need hover for the typescript frontmatter. Since Helix can't do it I have to revert back to nvim for that project :(

kyfanc and others added 3 commits December 13, 2024 11:40
Co-authored-by: Vladyslav Karasov <36513243+cotneit@users.noreply.github.com>
If we skip `format!` then the message is a static string instead of
allocated.
minor wording nit
* Prefer a OnceCell for caching header/body content
* Avoid rendering a Markdown for headers when it will not be shown
  (i.e. there is only one hover).
* Remove unused methods (visible_popup, set_hover)
* Inline definitions of next/prev hover, use the same calculations as
  in signature help (mod and checked sub).
@the-mikedavis the-mikedavis changed the title Cycle through hover results from multiple LSPs Cycle through hover results from multiple language servers Jan 26, 2025
@the-mikedavis the-mikedavis merged commit 9829ac0 into helix-editor:master Jan 26, 2025
6 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-helix-term Area: Helix term improvements A-language-server Area: Language server client S-waiting-on-review Status: Awaiting review from a maintainer.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Request textDocument/hover from all configured language servers
8 participants