Class: SyntaxTree::SymBeg

Inherits:
Node
  • Object
show all
Defined in:
lib/syntax_tree/node.rb

Overview

SymBeg represents the beginning of a symbol literal.

:symbol

SymBeg is also used for dynamic symbols, as in:

:"symbol"

Finally, SymBeg is also used for symbols using the %s syntax, as in:

%s[symbol]

The value of this node is a string. In most cases (as in the first example above) it will contain just “:”. In the case of dynamic symbols it will contain “:‘” or “:"”. In the case of %s symbols, it will contain the start of the symbol including the %s and the delimiter.

Instance Attribute Summary collapse

Attributes inherited from Node

#location

Instance Method Summary collapse

Methods inherited from Node

#construct_keys, #format, #pretty_print, #to_json

Constructor Details

#initialize(value:, location:) ⇒ SymBeg

Returns a new instance of SymBeg.



10315
10316
10317
10318
# File 'lib/syntax_tree/node.rb', line 10315

def initialize(value:, location:)
  @value = value
  @location = location
end

Instance Attribute Details

#valueObject (readonly)

String

the beginning of the symbol



10313
10314
10315
# File 'lib/syntax_tree/node.rb', line 10313

def value
  @value
end

Instance Method Details

#===(other) ⇒ Object



10341
10342
10343
# File 'lib/syntax_tree/node.rb', line 10341

def ===(other)
  other.is_a?(SymBeg) && value === other.value
end

#accept(visitor) ⇒ Object



10320
10321
10322
# File 'lib/syntax_tree/node.rb', line 10320

def accept(visitor)
  visitor.visit_symbeg(self)
end

#child_nodesObject Also known as: deconstruct



10324
10325
10326
# File 'lib/syntax_tree/node.rb', line 10324

def child_nodes
  []
end

#copy(value: nil, location: nil) ⇒ Object



10328
10329
10330
10331
10332
10333
# File 'lib/syntax_tree/node.rb', line 10328

def copy(value: nil, location: nil)
  SymBeg.new(
    value: value || self.value,
    location: location || self.location
  )
end

#deconstruct_keys(_keys) ⇒ Object



10337
10338
10339
# File 'lib/syntax_tree/node.rb', line 10337

def deconstruct_keys(_keys)
  { value: value, location: location }
end