Class: RubyLsp::Requests::Hover
- Extended by:
- T::Generic, T::Sig
- Defined in:
- lib/ruby_lsp/requests/hover.rb
Overview

The [hover request](microsoft.github.io/language-server-protocol/specification#textDocument_hover) displays the documentation for the symbol currently under the cursor.
# Example
“‘ruby String # -> Hovering over the class reference will show all declaration locations and the documentation “`
Constant Summary collapse
- ResponseType =
type_member { { fixed: T.nilable(Interface::Hover) } }
- ALLOWED_TARGETS =
T.let( [ Prism::CallNode, Prism::ConstantReadNode, Prism::ConstantWriteNode, Prism::ConstantPathNode, ], T::Array[T.class_of(Prism::Node)], )
Instance Attribute Summary collapse
-
#_response ⇒ Object
readonly
Returns the value of attribute _response.
Instance Method Summary collapse
-
#initialize(index, nesting, dispatcher, message_queue) ⇒ Hover
constructor
A new instance of Hover.
- #initialize_external_listener(addon) ⇒ Object
- #merge_response!(other) ⇒ Object
- #on_constant_path_node_enter(node) ⇒ Object
- #on_constant_read_node_enter(node) ⇒ Object
- #on_constant_write_node_enter(node) ⇒ Object
Methods inherited from Listener
Methods included from Support::Common
#create_code_lens, #markdown_from_index_entries, #range_from_location, #range_from_node, #visible?
Constructor Details
#initialize(index, nesting, dispatcher, message_queue) ⇒ Hover
Returns a new instance of Hover.
43 44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'lib/ruby_lsp/requests/hover.rb', line 43 def initialize(index, nesting, dispatcher, ) @index = index @nesting = nesting @_response = T.let(nil, ResponseType) super(dispatcher, ) dispatcher.register( self, :on_constant_read_node_enter, :on_constant_write_node_enter, :on_constant_path_node_enter, ) end |
Instance Attribute Details
#_response ⇒ Object (readonly)
Returns the value of attribute _response.
33 34 35 |
# File 'lib/ruby_lsp/requests/hover.rb', line 33 def _response @_response end |
Instance Method Details
#initialize_external_listener(addon) ⇒ Object
58 59 60 |
# File 'lib/ruby_lsp/requests/hover.rb', line 58 def initialize_external_listener(addon) addon.create_hover_listener(@nesting, @index, @dispatcher, ) end |
#merge_response!(other) ⇒ Object
64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'lib/ruby_lsp/requests/hover.rb', line 64 def merge_response!(other) other_response = other.response return self unless other_response if @_response.nil? @_response = other.response else @_response.contents.value << "\n\n" << other_response.contents.value end self end |
#on_constant_path_node_enter(node) ⇒ Object
92 93 94 95 96 |
# File 'lib/ruby_lsp/requests/hover.rb', line 92 def on_constant_path_node_enter(node) return if DependencyDetector.instance.typechecker generate_hover(node.slice, node.location) end |
#on_constant_read_node_enter(node) ⇒ Object
78 79 80 81 82 |
# File 'lib/ruby_lsp/requests/hover.rb', line 78 def on_constant_read_node_enter(node) return if DependencyDetector.instance.typechecker generate_hover(node.slice, node.location) end |
#on_constant_write_node_enter(node) ⇒ Object
85 86 87 88 89 |
# File 'lib/ruby_lsp/requests/hover.rb', line 85 def on_constant_write_node_enter(node) return if DependencyDetector.instance.typechecker generate_hover(node.name.to_s, node.name_loc) end |