-
Notifications
You must be signed in to change notification settings - Fork 3
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Add go-to-symbol and open-symbol-by-name features #8
Conversation
|
||
You can navigate symbols inside a file. This is helpful for quickly navigating among functions, values and types in a file. | ||
|
||
data:image/s3,"s3://crabby-images/62775/62775b9d6262d4f6177544253ec7d38e40fc87ed" alt="Go to symbol" |
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.
TODO for Ryan: Create this gif
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.
TODO for Ryan: Update the performance tables further below
(should probably be done on the same computer as the other features?)
|
||
You can navigate to any top-level declaration in any file, which is a quick way of getting to the right file. | ||
|
||
data:image/s3,"s3://crabby-images/0bf64/0bf64a06425a2d577bc75795461cdcca4e74aba3" alt="Open symbol by name" |
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.
TODO for Ryan: And this one
Conflicts: src/features/jump-to-definition.ts
any update on this? |
I’ve been running a build based on this PR + #21 on my computer for a while now, and it’s working well! @ryan-haskell Do you have time to merge? (And do the two readme tasks.) |
Status: This seems to work well for me. I just need Ryan’s help with the docs stuff (we talked about it IRL a while ago).
This implements Go to Symbol and the Outline view (they go together), as well as Open symbol by name (which is a bit hacky, but I think it provides a lot of value even if it’s not 100 % pedantically correct). That’s what VSCode calls those features (see the links), but personally I think it’s not super clear what is what. Open to name changes if you want!
At first, on a large file it was too slow (when typing, the UI locked up and the characters appeared too late). It turned out 99.9 % of the time was spent parsing. I solved this by parsing in a Worker Thread. So now it never blocks the main thread. For small files, the outline feels instant (like 15 ms), and for big files I notice a ~0.5 second delay for it sometimes.
Note that the worker stuff is a bit tricky, so some extra testing might be good – this affects all features that parses using elm-syntax.