Find References Request
toddATavail opened this issue · 0 comments
Support for locating the usages of the name at the specified module coordinates. Mandated by Find References Request.
This amounts to implementing org.eclipse.lsp4j.TextDocumentService.references
.
For guidance, the places to begin digging into Swing/Anvil are:
avail.anvil.AvailEditor.handleClick
avail.anvil.AvailWorkbench.navigateToSendersOfName
avail.anvil.AvailWorkbench.allUsagesThen
avail.anvil.RenderingEngine.applyStylesAndPhrasePaths
Currently, the technique is:
- Resolve the mouse position to a document position
- Use the document position to obtain the
TokenStyle
associated with thePhraseNodeAttributeKey
attribute that was applied byavail.anvil.RenderingEngine.applyStylesAndPhrasePaths
- Use the
TokenStyle
to obtain the name / symbol (NameInModule
) and token index / message part index - Use these to interrogate a
Repository
and aNamesIndex
to obtain all usages associated with the name / symbol
The message part index (usually called tokenIndexInName
) is currently used only to highlight the message part that the user specified. It does not appear that LSP (or lsp4j
) are capable of transmitting this additional information as opaque client data. If we want to preserve the current behavior, then we will need to reply with LocationLink
s rather than mere Location
s, and use the MessageSplitter
(or something akin but with pared down functionality) in the IDEA plugin to identify and highlight the message part. The current behavior was nice enough to build in Swing/Anvil in the first place, but is likely to require significant additional effort to port to IDEA, so we may want to consider strict parity as a stretch goal.
The following items count as usages:
- Lexical sends appearing directly in source code
- Generated sends appearing in macro substitution phrases (produced by executing macro sends during compilation)