Class: LanguageServer::Protocol::Interface::LinkedEditingRanges

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

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(ranges:, word_pattern: nil) ⇒ LinkedEditingRanges

Returns a new instance of LinkedEditingRanges.



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

def initialize(ranges:, word_pattern: nil)
  @attributes = {}

  @attributes[:ranges] = ranges
  @attributes[:wordPattern] = word_pattern if word_pattern

  @attributes.freeze
end

Instance Attribute Details

#attributesObject (readonly)

Returns the value of attribute attributes.



34
35
36
# File 'lib/language_server/protocol/interface/linked_editing_ranges.rb', line 34

def attributes
  @attributes
end

Instance Method Details

#rangesRange[]

A list of ranges that can be renamed together. The ranges must have identical length and contain identical text content. The ranges cannot overlap.

Returns:



20
21
22
# File 'lib/language_server/protocol/interface/linked_editing_ranges.rb', line 20

def ranges
  attributes.fetch(:ranges)
end

#to_hashObject



36
37
38
# File 'lib/language_server/protocol/interface/linked_editing_ranges.rb', line 36

def to_hash
  attributes
end

#to_json(*args) ⇒ Object



40
41
42
# File 'lib/language_server/protocol/interface/linked_editing_ranges.rb', line 40

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

#word_patternstring

An optional word pattern (regular expression) that describes valid contents for the given ranges. If no pattern is provided, the client configuration’s word pattern will be used.

Returns:

  • (string)


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

def word_pattern
  attributes.fetch(:wordPattern)
end