Class: LanguageServer::Protocol::Interface::CodeActionContext
- Inherits:
-
Object
- Object
- LanguageServer::Protocol::Interface::CodeActionContext
- Defined in:
- lib/language_server/protocol/interface/code_action_context.rb
Overview
Contains additional diagnostic information about the context in which a code action is run.
Instance Attribute Summary collapse
-
#attributes ⇒ Object
readonly
Returns the value of attribute attributes.
Instance Method Summary collapse
-
#diagnostics ⇒ Diagnostic[]
An array of diagnostics known on the client side overlapping the range provided to the ‘textDocument/codeAction` request.
-
#initialize(diagnostics:, only: nil, trigger_kind: nil) ⇒ CodeActionContext
constructor
A new instance of CodeActionContext.
-
#only ⇒ string[]
Requested kind of actions to return.
- #to_hash ⇒ Object
- #to_json(*args) ⇒ Object
-
#trigger_kind ⇒ CodeActionTriggerKind
The reason why code actions were requested.
Constructor Details
#initialize(diagnostics:, only: nil, trigger_kind: nil) ⇒ CodeActionContext
Returns a new instance of CodeActionContext.
9 10 11 12 13 14 15 16 17 |
# File 'lib/language_server/protocol/interface/code_action_context.rb', line 9 def initialize(diagnostics:, only: nil, trigger_kind: nil) @attributes = {} @attributes[:diagnostics] = diagnostics @attributes[:only] = only if only @attributes[:triggerKind] = trigger_kind if trigger_kind @attributes.freeze end |
Instance Attribute Details
#attributes ⇒ Object (readonly)
Returns the value of attribute attributes.
51 52 53 |
# File 'lib/language_server/protocol/interface/code_action_context.rb', line 51 def attributes @attributes end |
Instance Method Details
#diagnostics ⇒ Diagnostic[]
An array of diagnostics known on the client side overlapping the range provided to the ‘textDocument/codeAction` request. They are provided so that the server knows which errors are currently presented to the user for the given range. There is no guarantee that these accurately reflect the error state of the resource. The primary parameter to compute code actions is the provided range.
28 29 30 |
# File 'lib/language_server/protocol/interface/code_action_context.rb', line 28 def diagnostics attributes.fetch(:diagnostics) end |
#only ⇒ string[]
Requested kind of actions to return.
Actions not of this kind are filtered out by the client before being shown. So servers can omit computing them.
39 40 41 |
# File 'lib/language_server/protocol/interface/code_action_context.rb', line 39 def only attributes.fetch(:only) end |
#to_hash ⇒ Object
53 54 55 |
# File 'lib/language_server/protocol/interface/code_action_context.rb', line 53 def to_hash attributes end |
#to_json(*args) ⇒ Object
57 58 59 |
# File 'lib/language_server/protocol/interface/code_action_context.rb', line 57 def to_json(*args) to_hash.to_json(*args) end |
#trigger_kind ⇒ CodeActionTriggerKind
The reason why code actions were requested.
47 48 49 |
# File 'lib/language_server/protocol/interface/code_action_context.rb', line 47 def trigger_kind attributes.fetch(:triggerKind) end |