Class: LanguageServer::Protocol::Interface::CompletionOptions

Inherits:
Object
  • Object
show all
Defined in:
lib/language_server/protocol/interface/completion_options.rb

Overview

Completion options.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(trigger_characters: nil, all_commit_characters: nil, resolve_provider: nil, completion_item: nil, work_done_progress: nil) ⇒ CompletionOptions

Returns a new instance of CompletionOptions.



8
9
10
11
12
13
14
15
16
17
18
# File 'lib/language_server/protocol/interface/completion_options.rb', line 8

def initialize(trigger_characters: nil, all_commit_characters: nil, resolve_provider: nil, completion_item: nil, work_done_progress: nil)
  @attributes = {}

  @attributes[:triggerCharacters] = trigger_characters if trigger_characters
  @attributes[:allCommitCharacters] = all_commit_characters if all_commit_characters
  @attributes[:resolveProvider] = resolve_provider if resolve_provider
  @attributes[:completionItem] = completion_item if completion_item
  @attributes[:workDoneProgress] = work_done_progress if work_done_progress

  @attributes.freeze
end

Instance Attribute Details

#attributesObject (readonly)

Returns the value of attribute attributes.



75
76
77
# File 'lib/language_server/protocol/interface/completion_options.rb', line 75

def attributes
  @attributes
end

Instance Method Details

#all_commit_charactersstring[] | nil

The list of all possible characters that commit a completion. This field can be used if clients don’t support individual commit characters per completion item. See ClientCapabilities.textDocument.completion.completionItem.commitCharactersSupport

If a server provides both allCommitCharacters and commit characters on an individual completion item the ones on the completion item win.

Returns:

  • (string[] | nil)

Since:

  • 3.2.0



46
47
48
# File 'lib/language_server/protocol/interface/completion_options.rb', line 46

def all_commit_characters
  attributes.fetch(:allCommitCharacters)
end

#completion_item{ labelDetailsSupport:boolean } | nil

The server supports the following CompletionItem specific capabilities.

Returns:

  • ({ labelDetailsSupport:boolean } | nil)

Since:

  • 3.17.0



66
67
68
# File 'lib/language_server/protocol/interface/completion_options.rb', line 66

def completion_item
  attributes.fetch(:completionItem)
end

#resolve_providerboolean | nil

The server provides support to resolve additional information for a completion item.

Returns:

  • (boolean | nil)


55
56
57
# File 'lib/language_server/protocol/interface/completion_options.rb', line 55

def resolve_provider
  attributes.fetch(:resolveProvider)
end

#to_hashObject



77
78
79
# File 'lib/language_server/protocol/interface/completion_options.rb', line 77

def to_hash
  attributes
end

#to_json(*args) ⇒ Object



81
82
83
# File 'lib/language_server/protocol/interface/completion_options.rb', line 81

def to_json(*args)
  to_hash.to_json(*args)
end

#trigger_charactersstring[] | nil

Most tools trigger completion request automatically without explicitly requesting it using a keyboard shortcut (e.g. Ctrl+Space). Typically they do so when the user starts to type an identifier. For example if the user types c in a JavaScript file code complete will automatically pop up present console besides others as a completion item. Characters that make up identifiers don’t need to be listed here.

If code complete should automatically be trigger on characters not being valid inside an identifier (for example . in JavaScript) list them in triggerCharacters.

Returns:

  • (string[] | nil)


31
32
33
# File 'lib/language_server/protocol/interface/completion_options.rb', line 31

def trigger_characters
  attributes.fetch(:triggerCharacters)
end

#work_done_progressboolean | nil

Returns:

  • (boolean | nil)


71
72
73
# File 'lib/language_server/protocol/interface/completion_options.rb', line 71

def work_done_progress
  attributes.fetch(:workDoneProgress)
end