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
|
module LanguageServer
module Protocol
module Interface
class DocumentSymbolClientCapabilities
def initialize(dynamic_registration: nil, symbol_kind: nil, hierarchical_document_symbol_support: nil, tag_support: nil, label_support: nil)
@attributes = {}
@attributes[:dynamicRegistration] = dynamic_registration if dynamic_registration
@attributes[:symbolKind] = symbol_kind if symbol_kind
@attributes[:hierarchicalDocumentSymbolSupport] = hierarchical_document_symbol_support if hierarchical_document_symbol_support
@attributes[:tagSupport] = tag_support if tag_support
@attributes[:labelSupport] = label_support if label_support
@attributes.freeze
end
#
# Whether document symbol supports dynamic registration.
#
# @return [boolean]
def dynamic_registration
attributes.fetch(:dynamicRegistration)
end
#
# Specific capabilities for the `SymbolKind` in the
# `textDocument/documentSymbol` request.
#
# @return [{ valueSet?: SymbolKind[]; }]
def symbol_kind
attributes.fetch(:symbolKind)
end
#
# The client supports hierarchical document symbols.
#
# @return [boolean]
def hierarchical_document_symbol_support
attributes.fetch(:hierarchicalDocumentSymbolSupport)
end
#
# The client supports tags on `SymbolInformation`. Tags are supported on
# `DocumentSymbol` if `hierarchicalDocumentSymbolSupport` is set to true.
# Clients supporting tags have to handle unknown tags gracefully.
#
# @return [{ valueSet: 1[]; }]
def tag_support
attributes.fetch(:tagSupport)
end
#
# The client supports an additional label presented in the UI when
# registering a document symbol provider.
#
# @return [boolean]
def label_support
attributes.fetch(:labelSupport)
end
attr_reader :attributes
def to_hash
attributes
end
def to_json(*args)
to_hash.to_json(*args)
end
end
end
end
end
|