Class: LanguageServer::Protocol::Interface::FoldingRangeClientCapabilities

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

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(dynamic_registration: nil, range_limit: nil, line_folding_only: nil) ⇒ FoldingRangeClientCapabilities

Returns a new instance of FoldingRangeClientCapabilities.



5
6
7
8
9
10
11
12
13
# File 'lib/language_server/protocol/interface/folding_range_client_capabilities.rb', line 5

def initialize(dynamic_registration: nil, range_limit: nil, line_folding_only: nil)
  @attributes = {}

  @attributes[:dynamicRegistration] = dynamic_registration if dynamic_registration
  @attributes[:rangeLimit] = range_limit if range_limit
  @attributes[:lineFoldingOnly] = line_folding_only if line_folding_only

  @attributes.freeze
end

Instance Attribute Details

#attributesObject (readonly)

Returns the value of attribute attributes.



43
44
45
# File 'lib/language_server/protocol/interface/folding_range_client_capabilities.rb', line 43

def attributes
  @attributes
end

Instance Method Details

#dynamic_registrationboolean

Whether implementation supports dynamic registration for folding range providers. If this is set to ‘true` the client supports the new `FoldingRangeRegistrationOptions` return value for the corresponding server capability as well.

Returns:

  • (boolean)


21
22
23
# File 'lib/language_server/protocol/interface/folding_range_client_capabilities.rb', line 21

def dynamic_registration
  attributes.fetch(:dynamicRegistration)
end

#line_folding_onlyboolean

If set, the client signals that it only supports folding complete lines. If set, client will ignore specified ‘startCharacter` and `endCharacter` properties in a FoldingRange.

Returns:

  • (boolean)


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

def line_folding_only
  attributes.fetch(:lineFoldingOnly)
end

#range_limitnumber

The maximum number of folding ranges that the client prefers to receive per document. The value serves as a hint, servers are free to follow the limit.

Returns:

  • (number)


30
31
32
# File 'lib/language_server/protocol/interface/folding_range_client_capabilities.rb', line 30

def range_limit
  attributes.fetch(:rangeLimit)
end

#to_hashObject



45
46
47
# File 'lib/language_server/protocol/interface/folding_range_client_capabilities.rb', line 45

def to_hash
  attributes
end

#to_json(*args) ⇒ Object



49
50
51
# File 'lib/language_server/protocol/interface/folding_range_client_capabilities.rb', line 49

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