language_server-protocol 3.14.0.2 → 3.15.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (151) hide show
  1. checksums.yaml +4 -4
  2. data/lib/language_server/protocol/constant.rb +8 -0
  3. data/lib/language_server/protocol/constant/code_action_kind.rb +12 -8
  4. data/lib/language_server/protocol/constant/completion_item_tag.rb +16 -0
  5. data/lib/language_server/protocol/constant/diagnostic_tag.rb +24 -0
  6. data/lib/language_server/protocol/constant/signature_help_trigger_kind.rb +23 -0
  7. data/lib/language_server/protocol/constant/text_document_sync_kind.rb +1 -0
  8. data/lib/language_server/protocol/interface.rb +158 -8
  9. data/lib/language_server/protocol/interface/apply_workspace_edit_response.rb +13 -1
  10. data/lib/language_server/protocol/interface/client_capabilities.rb +11 -2
  11. data/lib/language_server/protocol/interface/code_action.rb +14 -1
  12. data/lib/language_server/protocol/interface/code_action_client_capabilities.rb +52 -0
  13. data/lib/language_server/protocol/interface/code_action_context.rb +5 -1
  14. data/lib/language_server/protocol/interface/code_action_options.rb +3 -5
  15. data/lib/language_server/protocol/interface/code_action_params.rb +3 -2
  16. data/lib/language_server/protocol/interface/code_action_registration_options.rb +2 -1
  17. data/lib/language_server/protocol/interface/code_lens_client_capabilities.rb +33 -0
  18. data/lib/language_server/protocol/interface/code_lens_options.rb +3 -5
  19. data/lib/language_server/protocol/interface/code_lens_params.rb +3 -2
  20. data/lib/language_server/protocol/interface/code_lens_registration_options.rb +3 -11
  21. data/lib/language_server/protocol/interface/color_presentation_params.rb +3 -2
  22. data/lib/language_server/protocol/interface/completion_client_capabilities.rb +59 -0
  23. data/lib/language_server/protocol/interface/completion_item.rb +16 -5
  24. data/lib/language_server/protocol/interface/completion_options.rb +33 -11
  25. data/lib/language_server/protocol/interface/completion_params.rb +3 -4
  26. data/lib/language_server/protocol/interface/completion_registration_options.rb +4 -27
  27. data/lib/language_server/protocol/interface/declaration_client_capabilities.rb +44 -0
  28. data/lib/language_server/protocol/interface/declaration_options.rb +25 -0
  29. data/lib/language_server/protocol/interface/declaration_params.rb +25 -0
  30. data/lib/language_server/protocol/interface/{color_provider_options.rb → declaration_registration_options.rb} +3 -5
  31. data/lib/language_server/protocol/interface/definition_client_capabilities.rb +42 -0
  32. data/lib/language_server/protocol/interface/definition_options.rb +25 -0
  33. data/lib/language_server/protocol/interface/definition_params.rb +25 -0
  34. data/lib/language_server/protocol/interface/definition_registration_options.rb +25 -0
  35. data/lib/language_server/protocol/interface/diagnostic.rb +11 -2
  36. data/lib/language_server/protocol/interface/diagnostic_related_information.rb +1 -1
  37. data/lib/language_server/protocol/interface/did_change_configuration_client_capabilities.rb +33 -0
  38. data/lib/language_server/protocol/interface/did_change_text_document_params.rb +10 -2
  39. data/lib/language_server/protocol/interface/did_change_watched_files_client_capabilities.rb +35 -0
  40. data/lib/language_server/protocol/interface/did_change_watched_files_registration_options.rb +1 -1
  41. data/lib/language_server/protocol/interface/document_color_client_capabilities.rb +33 -0
  42. data/lib/language_server/protocol/interface/document_color_options.rb +25 -0
  43. data/lib/language_server/protocol/interface/document_color_params.rb +34 -0
  44. data/lib/language_server/protocol/interface/document_color_registration_options.rb +25 -0
  45. data/lib/language_server/protocol/interface/document_formatting_client_capabilities.rb +33 -0
  46. data/lib/language_server/protocol/interface/document_formatting_options.rb +25 -0
  47. data/lib/language_server/protocol/interface/document_formatting_params.rb +3 -2
  48. data/lib/language_server/protocol/interface/document_formatting_registration_options.rb +25 -0
  49. data/lib/language_server/protocol/interface/document_highlight_client_capabilities.rb +33 -0
  50. data/lib/language_server/protocol/interface/document_highlight_options.rb +25 -0
  51. data/lib/language_server/protocol/interface/document_highlight_params.rb +25 -0
  52. data/lib/language_server/protocol/interface/document_highlight_registration_options.rb +25 -0
  53. data/lib/language_server/protocol/interface/document_link.rb +14 -1
  54. data/lib/language_server/protocol/interface/document_link_client_capabilities.rb +42 -0
  55. data/lib/language_server/protocol/interface/document_link_options.rb +3 -5
  56. data/lib/language_server/protocol/interface/document_link_params.rb +3 -2
  57. data/lib/language_server/protocol/interface/document_link_registration_options.rb +3 -11
  58. data/lib/language_server/protocol/interface/document_on_type_formatting_client_capabilities.rb +33 -0
  59. data/lib/language_server/protocol/interface/document_on_type_formatting_options.rb +0 -3
  60. data/lib/language_server/protocol/interface/document_on_type_formatting_params.rb +1 -17
  61. data/lib/language_server/protocol/interface/document_on_type_formatting_registration_options.rb +2 -19
  62. data/lib/language_server/protocol/interface/document_range_formatting_client_capabilities.rb +33 -0
  63. data/lib/language_server/protocol/interface/document_range_formatting_options.rb +25 -0
  64. data/lib/language_server/protocol/interface/document_range_formatting_params.rb +3 -2
  65. data/lib/language_server/protocol/interface/document_range_formatting_registration_options.rb +25 -0
  66. data/lib/language_server/protocol/interface/document_symbol.rb +96 -0
  67. data/lib/language_server/protocol/interface/document_symbol_client_capabilities.rb +51 -0
  68. data/lib/language_server/protocol/interface/document_symbol_options.rb +25 -0
  69. data/lib/language_server/protocol/interface/document_symbol_params.rb +3 -2
  70. data/lib/language_server/protocol/interface/document_symbol_registration_options.rb +25 -0
  71. data/lib/language_server/protocol/interface/execute_command_client_capabilities.rb +33 -0
  72. data/lib/language_server/protocol/interface/execute_command_options.rb +3 -5
  73. data/lib/language_server/protocol/interface/execute_command_params.rb +3 -2
  74. data/lib/language_server/protocol/interface/execute_command_registration_options.rb +3 -10
  75. data/lib/language_server/protocol/interface/folding_range.rb +1 -1
  76. data/lib/language_server/protocol/interface/folding_range_client_capabilities.rb +55 -0
  77. data/lib/language_server/protocol/interface/folding_range_options.rb +25 -0
  78. data/lib/language_server/protocol/interface/folding_range_params.rb +3 -2
  79. data/lib/language_server/protocol/interface/{folding_range_provider_options.rb → folding_range_registration_options.rb} +3 -5
  80. data/lib/language_server/protocol/interface/formatting_options.rb +28 -1
  81. data/lib/language_server/protocol/interface/hover_client_capabilities.rb +43 -0
  82. data/lib/language_server/protocol/interface/hover_options.rb +25 -0
  83. data/lib/language_server/protocol/interface/hover_params.rb +25 -0
  84. data/lib/language_server/protocol/interface/hover_registration_options.rb +25 -0
  85. data/lib/language_server/protocol/interface/implementation_client_capabilities.rb +44 -0
  86. data/lib/language_server/protocol/interface/implementation_options.rb +25 -0
  87. data/lib/language_server/protocol/interface/implementation_params.rb +25 -0
  88. data/lib/language_server/protocol/interface/implementation_registration_options.rb +25 -0
  89. data/lib/language_server/protocol/interface/initialize_params.rb +12 -4
  90. data/lib/language_server/protocol/interface/initialize_result.rb +10 -1
  91. data/lib/language_server/protocol/interface/location_link.rb +7 -4
  92. data/lib/language_server/protocol/interface/notification_message.rb +1 -1
  93. data/lib/language_server/protocol/interface/partial_result_params.rb +34 -0
  94. data/lib/language_server/protocol/interface/prepare_rename_params.rb +26 -0
  95. data/lib/language_server/protocol/interface/progress_params.rb +42 -0
  96. data/lib/language_server/protocol/interface/publish_diagnostics_client_capabilities.rb +53 -0
  97. data/lib/language_server/protocol/interface/publish_diagnostics_params.rb +10 -1
  98. data/lib/language_server/protocol/interface/reference_client_capabilities.rb +33 -0
  99. data/lib/language_server/protocol/interface/reference_options.rb +25 -0
  100. data/lib/language_server/protocol/interface/reference_params.rb +3 -4
  101. data/lib/language_server/protocol/interface/reference_registration_options.rb +25 -0
  102. data/lib/language_server/protocol/interface/rename_client_capabilities.rb +43 -0
  103. data/lib/language_server/protocol/interface/rename_options.rb +3 -5
  104. data/lib/language_server/protocol/interface/rename_params.rb +3 -20
  105. data/lib/language_server/protocol/interface/rename_registration_options.rb +3 -11
  106. data/lib/language_server/protocol/interface/request_message.rb +1 -1
  107. data/lib/language_server/protocol/interface/response_error.rb +2 -2
  108. data/lib/language_server/protocol/interface/response_message.rb +4 -4
  109. data/lib/language_server/protocol/interface/save_options.rb +0 -3
  110. data/lib/language_server/protocol/interface/selection_range.rb +42 -0
  111. data/lib/language_server/protocol/interface/selection_range_client_capabilities.rb +35 -0
  112. data/lib/language_server/protocol/interface/selection_range_options.rb +25 -0
  113. data/lib/language_server/protocol/interface/selection_range_params.rb +43 -0
  114. data/lib/language_server/protocol/interface/selection_range_registration_options.rb +25 -0
  115. data/lib/language_server/protocol/interface/server_capabilities.rb +66 -56
  116. data/lib/language_server/protocol/interface/signature_help.rb +8 -5
  117. data/lib/language_server/protocol/interface/signature_help_client_capabilities.rb +55 -0
  118. data/lib/language_server/protocol/interface/signature_help_context.rb +71 -0
  119. data/lib/language_server/protocol/interface/signature_help_options.rb +15 -5
  120. data/lib/language_server/protocol/interface/signature_help_params.rb +35 -0
  121. data/lib/language_server/protocol/interface/signature_help_registration_options.rb +4 -12
  122. data/lib/language_server/protocol/interface/symbol_information.rb +1 -1
  123. data/lib/language_server/protocol/interface/text_document_change_registration_options.rb +1 -1
  124. data/lib/language_server/protocol/interface/text_document_client_capabilities.rb +87 -87
  125. data/lib/language_server/protocol/interface/text_document_registration_options.rb +3 -0
  126. data/lib/language_server/protocol/interface/text_document_sync_client_capabilities.rb +62 -0
  127. data/lib/language_server/protocol/interface/text_document_sync_options.rb +14 -6
  128. data/lib/language_server/protocol/interface/type_definition_client_capabilities.rb +44 -0
  129. data/lib/language_server/protocol/interface/type_definition_options.rb +25 -0
  130. data/lib/language_server/protocol/interface/type_definition_params.rb +25 -0
  131. data/lib/language_server/protocol/interface/type_definition_registration_options.rb +25 -0
  132. data/lib/language_server/protocol/interface/versioned_text_document_identifier.rb +1 -1
  133. data/lib/language_server/protocol/interface/work_done_progress_begin.rb +80 -0
  134. data/lib/language_server/protocol/interface/work_done_progress_cancel_params.rb +33 -0
  135. data/lib/language_server/protocol/interface/work_done_progress_create_params.rb +33 -0
  136. data/lib/language_server/protocol/interface/work_done_progress_end.rb +40 -0
  137. data/lib/language_server/protocol/interface/work_done_progress_options.rb +30 -0
  138. data/lib/language_server/protocol/interface/work_done_progress_params.rb +33 -0
  139. data/lib/language_server/protocol/interface/work_done_progress_report.rb +70 -0
  140. data/lib/language_server/protocol/interface/workspace_edit.rb +1 -1
  141. data/lib/language_server/protocol/interface/workspace_edit_client_capabilities.rb +53 -0
  142. data/lib/language_server/protocol/interface/workspace_folder.rb +2 -2
  143. data/lib/language_server/protocol/interface/workspace_folders_server_capabilities.rb +48 -0
  144. data/lib/language_server/protocol/interface/workspace_symbol_client_capabilities.rb +42 -0
  145. data/lib/language_server/protocol/interface/workspace_symbol_options.rb +25 -0
  146. data/lib/language_server/protocol/interface/workspace_symbol_params.rb +5 -3
  147. data/lib/language_server/protocol/interface/workspace_symbol_registration_options.rb +25 -0
  148. data/lib/language_server/protocol/version.rb +1 -1
  149. metadata +83 -6
  150. data/lib/language_server/protocol/interface/text_document_content_change_event.rb +0 -55
  151. data/lib/language_server/protocol/interface/workspace_client_capabilities.rb +0 -104
@@ -2,10 +2,11 @@ module LanguageServer
2
2
  module Protocol
3
3
  module Interface
4
4
  class ApplyWorkspaceEditResponse
5
- def initialize(applied:)
5
+ def initialize(applied:, failure_reason: nil)
6
6
  @attributes = {}
7
7
 
8
8
  @attributes[:applied] = applied
9
+ @attributes[:failureReason] = failure_reason if failure_reason
9
10
 
10
11
  @attributes.freeze
11
12
  end
@@ -18,6 +19,17 @@ module LanguageServer
18
19
  attributes.fetch(:applied)
19
20
  end
20
21
 
22
+ #
23
+ # An optional textual description for why the edit was not applied.
24
+ # This may be used may be used by the server for diagnostic
25
+ # logging or to provide a suitable error for a request that
26
+ # triggered the edit.
27
+ #
28
+ # @return [string]
29
+ def failure_reason
30
+ attributes.fetch(:failureReason)
31
+ end
32
+
21
33
  attr_reader :attributes
22
34
 
23
35
  def to_hash
@@ -2,11 +2,12 @@ module LanguageServer
2
2
  module Protocol
3
3
  module Interface
4
4
  class ClientCapabilities
5
- def initialize(workspace: nil, text_document: nil, experimental: nil)
5
+ def initialize(workspace: nil, text_document: nil, window: nil, experimental: nil)
6
6
  @attributes = {}
7
7
 
8
8
  @attributes[:workspace] = workspace if workspace
9
9
  @attributes[:textDocument] = text_document if text_document
10
+ @attributes[:window] = window if window
10
11
  @attributes[:experimental] = experimental if experimental
11
12
 
12
13
  @attributes.freeze
@@ -15,7 +16,7 @@ module LanguageServer
15
16
  #
16
17
  # Workspace specific client capabilities.
17
18
  #
18
- # @return [WorkspaceClientCapabilities]
19
+ # @return [{ applyEdit?: boolean; workspaceEdit?: WorkspaceEditClientCapabilities; didChangeConfiguration?: ...]
19
20
  def workspace
20
21
  attributes.fetch(:workspace)
21
22
  end
@@ -28,6 +29,14 @@ module LanguageServer
28
29
  attributes.fetch(:textDocument)
29
30
  end
30
31
 
32
+ #
33
+ # Window specific client capabilities.
34
+ #
35
+ # @return [{ workDoneProgress?: boolean; }]
36
+ def window
37
+ attributes.fetch(:window)
38
+ end
39
+
31
40
  #
32
41
  # Experimental client capabilities.
33
42
  #
@@ -8,12 +8,13 @@ module LanguageServer
8
8
  # A CodeAction must set either `edit` and/or a `command`. If both are supplied, the `edit` is applied first, then the `command` is executed.
9
9
  #
10
10
  class CodeAction
11
- def initialize(title:, kind: nil, diagnostics: nil, edit: nil, command: nil)
11
+ def initialize(title:, kind: nil, diagnostics: nil, is_preferred: nil, edit: nil, command: nil)
12
12
  @attributes = {}
13
13
 
14
14
  @attributes[:title] = title
15
15
  @attributes[:kind] = kind if kind
16
16
  @attributes[:diagnostics] = diagnostics if diagnostics
17
+ @attributes[:isPreferred] = is_preferred if is_preferred
17
18
  @attributes[:edit] = edit if edit
18
19
  @attributes[:command] = command if command
19
20
 
@@ -46,6 +47,18 @@ module LanguageServer
46
47
  attributes.fetch(:diagnostics)
47
48
  end
48
49
 
50
+ #
51
+ # Marks this as a preferred action. Preferred actions are used by the `auto fix` command and can be targeted
52
+ # by keybindings.
53
+ #
54
+ # A quick fix should be marked preferred if it properly addresses the underlying error.
55
+ # A refactoring should be marked preferred if it is the most reasonable choice of actions to take.
56
+ #
57
+ # @return [boolean]
58
+ def is_preferred
59
+ attributes.fetch(:isPreferred)
60
+ end
61
+
49
62
  #
50
63
  # The workspace edit this code action performs.
51
64
  #
@@ -0,0 +1,52 @@
1
+ module LanguageServer
2
+ module Protocol
3
+ module Interface
4
+ class CodeActionClientCapabilities
5
+ def initialize(dynamic_registration: nil, code_action_literal_support: nil, is_preferred_support: nil)
6
+ @attributes = {}
7
+
8
+ @attributes[:dynamicRegistration] = dynamic_registration if dynamic_registration
9
+ @attributes[:codeActionLiteralSupport] = code_action_literal_support if code_action_literal_support
10
+ @attributes[:isPreferredSupport] = is_preferred_support if is_preferred_support
11
+
12
+ @attributes.freeze
13
+ end
14
+
15
+ #
16
+ # Whether code action supports dynamic registration.
17
+ #
18
+ # @return [boolean]
19
+ def dynamic_registration
20
+ attributes.fetch(:dynamicRegistration)
21
+ end
22
+
23
+ #
24
+ # The client supports code action literals as a valid
25
+ # response of the `textDocument/codeAction` request.
26
+ #
27
+ # @return [{ codeActionKind: { valueSet: string[]; }; }]
28
+ def code_action_literal_support
29
+ attributes.fetch(:codeActionLiteralSupport)
30
+ end
31
+
32
+ #
33
+ # Whether code action supports the `isPreferred` property.
34
+ #
35
+ # @return [boolean]
36
+ def is_preferred_support
37
+ attributes.fetch(:isPreferredSupport)
38
+ end
39
+
40
+ attr_reader :attributes
41
+
42
+ def to_hash
43
+ attributes
44
+ end
45
+
46
+ def to_json(*args)
47
+ to_hash.to_json(*args)
48
+ end
49
+ end
50
+ end
51
+ end
52
+ end
@@ -16,7 +16,11 @@ module LanguageServer
16
16
  end
17
17
 
18
18
  #
19
- # An array of diagnostics.
19
+ # An array of diagnostics known on the client side overlapping the range provided to the
20
+ # `textDocument/codeAction` request. They are provided so that the server knows which
21
+ # errors are currently presented to the user for the given range. There is no guarantee
22
+ # that these accurately reflect the error state of the resource. The primary parameter
23
+ # to compute code actions is the provided range.
20
24
  #
21
25
  # @return [Diagnostic[]]
22
26
  def diagnostics
@@ -1,13 +1,11 @@
1
1
  module LanguageServer
2
2
  module Protocol
3
3
  module Interface
4
- #
5
- # Code Action options.
6
- #
7
- class CodeActionOptions
8
- def initialize(code_action_kinds: nil)
4
+ class CodeActionOptions < WorkDoneProgressOptions
5
+ def initialize(work_done_progress: nil, code_action_kinds: nil)
9
6
  @attributes = {}
10
7
 
8
+ @attributes[:workDoneProgress] = work_done_progress if work_done_progress
11
9
  @attributes[:codeActionKinds] = code_action_kinds if code_action_kinds
12
10
 
13
11
  @attributes.freeze
@@ -4,10 +4,11 @@ module LanguageServer
4
4
  #
5
5
  # Params for the CodeActionRequest
6
6
  #
7
- class CodeActionParams
8
- def initialize(text_document:, range:, context:)
7
+ class CodeActionParams < PartialResultParams
8
+ def initialize(partial_result_token: nil, text_document:, range:, context:)
9
9
  @attributes = {}
10
10
 
11
+ @attributes[:partialResultToken] = partial_result_token if partial_result_token
11
12
  @attributes[:textDocument] = text_document
12
13
  @attributes[:range] = range
13
14
  @attributes[:context] = context
@@ -2,9 +2,10 @@ module LanguageServer
2
2
  module Protocol
3
3
  module Interface
4
4
  class CodeActionRegistrationOptions < CodeActionOptions
5
- def initialize(code_action_kinds: nil)
5
+ def initialize(work_done_progress: nil, code_action_kinds: nil)
6
6
  @attributes = {}
7
7
 
8
+ @attributes[:workDoneProgress] = work_done_progress if work_done_progress
8
9
  @attributes[:codeActionKinds] = code_action_kinds if code_action_kinds
9
10
 
10
11
  @attributes.freeze
@@ -0,0 +1,33 @@
1
+ module LanguageServer
2
+ module Protocol
3
+ module Interface
4
+ class CodeLensClientCapabilities
5
+ def initialize(dynamic_registration: nil)
6
+ @attributes = {}
7
+
8
+ @attributes[:dynamicRegistration] = dynamic_registration if dynamic_registration
9
+
10
+ @attributes.freeze
11
+ end
12
+
13
+ #
14
+ # Whether code lens supports dynamic registration.
15
+ #
16
+ # @return [boolean]
17
+ def dynamic_registration
18
+ attributes.fetch(:dynamicRegistration)
19
+ end
20
+
21
+ attr_reader :attributes
22
+
23
+ def to_hash
24
+ attributes
25
+ end
26
+
27
+ def to_json(*args)
28
+ to_hash.to_json(*args)
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
@@ -1,13 +1,11 @@
1
1
  module LanguageServer
2
2
  module Protocol
3
3
  module Interface
4
- #
5
- # Code Lens options.
6
- #
7
- class CodeLensOptions
8
- def initialize(resolve_provider: nil)
4
+ class CodeLensOptions < WorkDoneProgressOptions
5
+ def initialize(work_done_progress: nil, resolve_provider: nil)
9
6
  @attributes = {}
10
7
 
8
+ @attributes[:workDoneProgress] = work_done_progress if work_done_progress
11
9
  @attributes[:resolveProvider] = resolve_provider if resolve_provider
12
10
 
13
11
  @attributes.freeze
@@ -1,10 +1,11 @@
1
1
  module LanguageServer
2
2
  module Protocol
3
3
  module Interface
4
- class CodeLensParams
5
- def initialize(text_document:)
4
+ class CodeLensParams < PartialResultParams
5
+ def initialize(partial_result_token: nil, text_document:)
6
6
  @attributes = {}
7
7
 
8
+ @attributes[:partialResultToken] = partial_result_token if partial_result_token
8
9
  @attributes[:textDocument] = text_document
9
10
 
10
11
  @attributes.freeze
@@ -1,24 +1,16 @@
1
1
  module LanguageServer
2
2
  module Protocol
3
3
  module Interface
4
- class CodeLensRegistrationOptions < TextDocumentRegistrationOptions
5
- def initialize(document_selector:, resolve_provider: nil)
4
+ class CodeLensRegistrationOptions < CodeLensOptions
5
+ def initialize(work_done_progress: nil, resolve_provider: nil)
6
6
  @attributes = {}
7
7
 
8
- @attributes[:documentSelector] = document_selector
8
+ @attributes[:workDoneProgress] = work_done_progress if work_done_progress
9
9
  @attributes[:resolveProvider] = resolve_provider if resolve_provider
10
10
 
11
11
  @attributes.freeze
12
12
  end
13
13
 
14
- #
15
- # Code lens has a resolve provider as well.
16
- #
17
- # @return [boolean]
18
- def resolve_provider
19
- attributes.fetch(:resolveProvider)
20
- end
21
-
22
14
  attr_reader :attributes
23
15
 
24
16
  def to_hash
@@ -1,10 +1,11 @@
1
1
  module LanguageServer
2
2
  module Protocol
3
3
  module Interface
4
- class ColorPresentationParams
5
- def initialize(text_document:, color:, range:)
4
+ class ColorPresentationParams < PartialResultParams
5
+ def initialize(partial_result_token: nil, text_document:, color:, range:)
6
6
  @attributes = {}
7
7
 
8
+ @attributes[:partialResultToken] = partial_result_token if partial_result_token
8
9
  @attributes[:textDocument] = text_document
9
10
  @attributes[:color] = color
10
11
  @attributes[:range] = range
@@ -0,0 +1,59 @@
1
+ module LanguageServer
2
+ module Protocol
3
+ module Interface
4
+ class CompletionClientCapabilities
5
+ def initialize(dynamic_registration: nil, completion_item: nil, completion_item_kind: nil, context_support: nil)
6
+ @attributes = {}
7
+
8
+ @attributes[:dynamicRegistration] = dynamic_registration if dynamic_registration
9
+ @attributes[:completionItem] = completion_item if completion_item
10
+ @attributes[:completionItemKind] = completion_item_kind if completion_item_kind
11
+ @attributes[:contextSupport] = context_support if context_support
12
+
13
+ @attributes.freeze
14
+ end
15
+
16
+ #
17
+ # Whether completion supports dynamic registration.
18
+ #
19
+ # @return [boolean]
20
+ def dynamic_registration
21
+ attributes.fetch(:dynamicRegistration)
22
+ end
23
+
24
+ #
25
+ # The client supports the following `CompletionItem` specific
26
+ # capabilities.
27
+ #
28
+ # @return [{ snippetSupport?: boolean; commitCharactersSupport?: boolean; documentationFormat?: MarkupKind[]...]
29
+ def completion_item
30
+ attributes.fetch(:completionItem)
31
+ end
32
+
33
+ # @return [{ valueSet?: any[]; }]
34
+ def completion_item_kind
35
+ attributes.fetch(:completionItemKind)
36
+ end
37
+
38
+ #
39
+ # The client supports to send additional context information for a
40
+ # `textDocument/completion` request.
41
+ #
42
+ # @return [boolean]
43
+ def context_support
44
+ attributes.fetch(:contextSupport)
45
+ end
46
+
47
+ attr_reader :attributes
48
+
49
+ def to_hash
50
+ attributes
51
+ end
52
+
53
+ def to_json(*args)
54
+ to_hash.to_json(*args)
55
+ end
56
+ end
57
+ end
58
+ end
59
+ end
@@ -2,11 +2,12 @@ module LanguageServer
2
2
  module Protocol
3
3
  module Interface
4
4
  class CompletionItem
5
- def initialize(label:, kind: nil, detail: nil, documentation: nil, deprecated: nil, preselect: nil, sort_text: nil, filter_text: nil, insert_text: nil, insert_text_format: nil, text_edit: nil, additional_text_edits: nil, commit_characters: nil, command: nil, data: nil)
5
+ def initialize(label:, kind: nil, tags: nil, detail: nil, documentation: nil, deprecated: nil, preselect: nil, sort_text: nil, filter_text: nil, insert_text: nil, insert_text_format: nil, text_edit: nil, additional_text_edits: nil, commit_characters: nil, command: nil, data: nil)
6
6
  @attributes = {}
7
7
 
8
8
  @attributes[:label] = label
9
9
  @attributes[:kind] = kind if kind
10
+ @attributes[:tags] = tags if tags
10
11
  @attributes[:detail] = detail if detail
11
12
  @attributes[:documentation] = documentation if documentation
12
13
  @attributes[:deprecated] = deprecated if deprecated
@@ -36,13 +37,22 @@ module LanguageServer
36
37
 
37
38
  #
38
39
  # The kind of this completion item. Based of the kind
39
- # an icon is chosen by the editor.
40
+ # an icon is chosen by the editor. The standardized set
41
+ # of available values is defined in `CompletionItemKind`.
40
42
  #
41
43
  # @return [number]
42
44
  def kind
43
45
  attributes.fetch(:kind)
44
46
  end
45
47
 
48
+ #
49
+ # Tags for this completion item.
50
+ #
51
+ # @return [1[]]
52
+ def tags
53
+ attributes.fetch(:tags)
54
+ end
55
+
46
56
  #
47
57
  # A human-readable string with additional information
48
58
  # about this item, like type or symbol information.
@@ -116,9 +126,10 @@ module LanguageServer
116
126
 
117
127
  #
118
128
  # The format of the insert text. The format applies to both the `insertText` property
119
- # and the `newText` property of a provided `textEdit`.
129
+ # and the `newText` property of a provided `textEdit`. If omitted defaults to
130
+ # `InsertTextFormat.PlainText`.
120
131
  #
121
- # @return [InsertTextFormat]
132
+ # @return [DiagnosticTag]
122
133
  def insert_text_format
123
134
  attributes.fetch(:insertTextFormat)
124
135
  end
@@ -170,7 +181,7 @@ module LanguageServer
170
181
  end
171
182
 
172
183
  #
173
- # An data entry field that is preserved on a completion item between
184
+ # A data entry field that is preserved on a completion item between
174
185
  # a completion and a completion resolve request.
175
186
  #
176
187
  # @return [any]
@@ -4,31 +4,53 @@ module LanguageServer
4
4
  #
5
5
  # Completion options.
6
6
  #
7
- class CompletionOptions
8
- def initialize(resolve_provider: nil, trigger_characters: nil)
7
+ class CompletionOptions < WorkDoneProgressOptions
8
+ def initialize(work_done_progress: nil, trigger_characters: nil, all_commit_characters: nil, resolve_provider: nil)
9
9
  @attributes = {}
10
10
 
11
- @attributes[:resolveProvider] = resolve_provider if resolve_provider
11
+ @attributes[:workDoneProgress] = work_done_progress if work_done_progress
12
12
  @attributes[:triggerCharacters] = trigger_characters if trigger_characters
13
+ @attributes[:allCommitCharacters] = all_commit_characters if all_commit_characters
14
+ @attributes[:resolveProvider] = resolve_provider if resolve_provider
13
15
 
14
16
  @attributes.freeze
15
17
  end
16
18
 
17
19
  #
18
- # The server provides support to resolve additional
19
- # information for a completion item.
20
+ # Most tools trigger completion request automatically without explicitly requesting
21
+ # it using a keyboard shortcut (e.g. Ctrl+Space). Typically they do so when the user
22
+ # starts to type an identifier. For example if the user types `c` in a JavaScript file
23
+ # code complete will automatically pop up present `console` besides others as a
24
+ # completion item. Characters that make up identifiers don't need to be listed here.
20
25
  #
21
- # @return [boolean]
22
- def resolve_provider
23
- attributes.fetch(:resolveProvider)
26
+ # If code complete should automatically be trigger on characters not being valid inside
27
+ # an identifier (for example `.` in JavaScript) list them in `triggerCharacters`.
28
+ #
29
+ # @return [string[]]
30
+ def trigger_characters
31
+ attributes.fetch(:triggerCharacters)
24
32
  end
25
33
 
26
34
  #
27
- # The characters that trigger completion automatically.
35
+ # The list of all possible characters that commit a completion. This field can be used
36
+ # if clients don't support individual commit characters per completion item. See
37
+ # `ClientCapabilities.textDocument.completion.completionItem.commitCharactersSupport`.
38
+ #
39
+ # If a server provides both `allCommitCharacters` and commit characters on an individual
40
+ # completion item the ones on the completion item win.
28
41
  #
29
42
  # @return [string[]]
30
- def trigger_characters
31
- attributes.fetch(:triggerCharacters)
43
+ def all_commit_characters
44
+ attributes.fetch(:allCommitCharacters)
45
+ end
46
+
47
+ #
48
+ # The server provides support to resolve additional
49
+ # information for a completion item.
50
+ #
51
+ # @return [boolean]
52
+ def resolve_provider
53
+ attributes.fetch(:resolveProvider)
32
54
  end
33
55
 
34
56
  attr_reader :attributes