1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
module LanguageServer
module Protocol
module Interface
class ClientCapabilities
def initialize(workspace: nil, text_document: nil, notebook_document: nil, window: nil, general: nil, experimental: nil)
@attributes = {}
@attributes[:workspace] = workspace if workspace
@attributes[:textDocument] = text_document if text_document
@attributes[:notebookDocument] = notebook_document if notebook_document
@attributes[:window] = window if window
@attributes[:general] = general if general
@attributes[:experimental] = experimental if experimental
@attributes.freeze
end
#
# Workspace specific client capabilities.
#
# @return [{ applyEdit?: boolean; workspaceEdit?: WorkspaceEditClientCapabilities; didChangeConfiguration?: DidChangeConfigurationClientCapabilities; ... 10 more ...; diagnostics?: DiagnosticWorkspaceClientCapabilities; }]
def workspace
attributes.fetch(:workspace)
end
#
# Text document specific client capabilities.
#
# @return [TextDocumentClientCapabilities]
def text_document
attributes.fetch(:textDocument)
end
#
# Capabilities specific to the notebook document support.
#
# @return [NotebookDocumentClientCapabilities]
def notebook_document
attributes.fetch(:notebookDocument)
end
#
# Window specific client capabilities.
#
# @return [{ workDoneProgress?: boolean; showMessage?: ShowMessageRequestClientCapabilities; showDocument?: ShowDocumentClientCapabilities; }]
def window
attributes.fetch(:window)
end
#
# General client capabilities.
#
# @return [{ staleRequestSupport?: { cancel: boolean; retryOnContentModified: string[]; }; regularExpressions?: RegularExpressionsClientCapabilities; markdown?: any; positionEncodings?: string[]; }]
def general
attributes.fetch(:general)
end
#
# Experimental client capabilities.
#
# @return [LSPAny]
def experimental
attributes.fetch(:experimental)
end
attr_reader :attributes
def to_hash
attributes
end
def to_json(*args)
to_hash.to_json(*args)
end
end
end
end
end
|