Sha256: acbd865a144ecf932c85eb5861a8b7a4b98f34d893467a66dd4beaa623df65ad

Contents?: true

Size: 1.77 KB

Versions: 15

Compression:

Stored size: 1.77 KB

Contents

# typed: strict
# frozen_string_literal: true

require "ruby_lsp/listeners/document_highlight"

module RubyLsp
  module Requests
    # ![Document highlight demo](../../document_highlight.gif)
    #
    # 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).
    #
    # # Example
    #
    # ```ruby
    # FOO = 1 # should be highlighted as "write"
    #
    # def foo
    #   FOO # should be highlighted as "read"
    # end
    # ```
    class DocumentHighlight < Request
      extend T::Sig

      sig do
        params(
          document: Document,
          position: T::Hash[Symbol, T.untyped],
          dispatcher: Prism::Dispatcher,
        ).void
      end
      def initialize(document, position, dispatcher)
        super()
        target, parent = document.locate_node(position)
        @response_builder = T.let(
          ResponseBuilders::CollectionResponseBuilder[Interface::DocumentHighlight].new,
          ResponseBuilders::CollectionResponseBuilder[Interface::DocumentHighlight],
        )
        Listeners::DocumentHighlight.new(@response_builder, target, parent, dispatcher)
      end

      sig { override.returns(T::Array[Interface::DocumentHighlight]) }
      def perform
        @response_builder.response
      end
    end
  end
end

Version data entries

15 entries across 15 versions & 1 rubygems

Version Path
ruby-lsp-0.16.6 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.16.5 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.16.4 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.16.3 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.16.2 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.16.1 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.16.0 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.15.0 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.14.6 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.14.5 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.14.4 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.14.3 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.14.2 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.14.1 lib/ruby_lsp/requests/document_highlight.rb
ruby-lsp-0.14.0 lib/ruby_lsp/requests/document_highlight.rb