Class: LanguageServer::Protocol::Interface::CodeActionContext

Inherits:
Object
  • Object
show all
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

Instance Method Summary collapse

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

#attributesObject (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

#diagnosticsDiagnostic[]

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.

Returns:



28
29
30
# File 'lib/language_server/protocol/interface/code_action_context.rb', line 28

def diagnostics
  attributes.fetch(:diagnostics)
end

#onlystring[]

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.

Returns:

  • (string[])


39
40
41
# File 'lib/language_server/protocol/interface/code_action_context.rb', line 39

def only
  attributes.fetch(:only)
end

#to_hashObject



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_kindCodeActionTriggerKind

The reason why code actions were requested.

Returns:

  • (CodeActionTriggerKind)


47
48
49
# File 'lib/language_server/protocol/interface/code_action_context.rb', line 47

def trigger_kind
  attributes.fetch(:triggerKind)
end