-
-
Notifications
You must be signed in to change notification settings - Fork 2.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
Cycle through hover results from multiple language servers #10122
Cycle through hover results from multiple language servers #10122
Conversation
Also, seems there are some concurrency issues in the integration test. And i tried to run Any idea? |
c61cef2
to
8310f64
Compare
I have very similar concerns/review as in #9974:
|
65d7105
to
9f9016b
Compare
Thank for the review and comments. The new push removed the unnecessary handler codes, and updated the keymap as suggested. |
9f9016b
to
a5f9ca8
Compare
This seems to be working great! Merge with
|
42555c3
to
f6aa0e4
Compare
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. |
1510f49
to
3313c60
Compare
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. |
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 :( |
Co-authored-by: Vladyslav Karasov <36513243+cotneit@users.noreply.github.com>
3313c60
to
b258184
Compare
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).
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 hoverA-n
for next hover