Sha256: 68426e58328235f76c76d07ec7474b5f73a1d278e0c36eb243e3cb5232178b5e
Contents?: true
Size: 1.95 KB
Versions: 5
Compression:
Stored size: 1.95 KB
Contents
# typed: strict # frozen_string_literal: true require "ruby_lsp/listeners/document_highlight" module RubyLsp module Requests # The [document highlight](https://microsoft.github.io/language-server-protocol/specification#textDocument_documentHighlight) # informs the editor all relevant elements of the currently pointed item for highlighting. For example, when # the cursor is on the `F` of the constant `FOO`, the editor should identify other occurrences of `FOO` # and highlight them. # # For writable elements like constants or variables, their read/write occurrences should be highlighted differently. # This is achieved by sending different "kind" attributes to the editor (2 for read and 3 for write). class DocumentHighlight < Request extend T::Sig sig do params( global_state: GlobalState, document: T.any(RubyDocument, ERBDocument), position: T::Hash[Symbol, T.untyped], dispatcher: Prism::Dispatcher, ).void end def initialize(global_state, document, position, dispatcher) super() char_position, _ = document.find_index_by_position(position) delegate_request_if_needed!(global_state, document, char_position) node_context = RubyDocument.locate( document.parse_result.value, char_position, code_units_cache: document.code_units_cache, ) @response_builder = T.let( ResponseBuilders::CollectionResponseBuilder[Interface::DocumentHighlight].new, ResponseBuilders::CollectionResponseBuilder[Interface::DocumentHighlight], ) Listeners::DocumentHighlight.new( @response_builder, node_context.node, node_context.parent, dispatcher, position, ) end sig { override.returns(T::Array[Interface::DocumentHighlight]) } def perform @response_builder.response end end end end
Version data entries
5 entries across 5 versions & 1 rubygems