class SyntaxTree::Kw
Kw
represents the use of a keyword. It can be almost anywhere in the syntax tree, so you end up seeing it quite a lot.
if value end
In
the above example, there would be two Kw
nodes: one for the if and one for the end. Note that anything that matches the list of keywords in Ruby will use a Kw
, so if you use a keyword in a symbol literal for instance:
:if
then the contents of the symbol node will contain a Kw
node.
Attributes
name[R]
- Symbol
-
the symbol version of the value
value[R]
- String
-
the value of the keyword
Public Class Methods
new(value:, location:)
click to toggle source
# File lib/syntax_tree/node.rb, line 6948 def initialize(value:, location:) @value = value @name = value.to_sym @location = location @comments = [] end
Public Instance Methods
===(other)
click to toggle source
# File lib/syntax_tree/node.rb, line 6981 def ===(other) other.is_a?(Kw) && value === other.value end
accept(visitor)
click to toggle source
# File lib/syntax_tree/node.rb, line 6955 def accept(visitor) visitor.visit_kw(self) end
child_nodes()
click to toggle source
# File lib/syntax_tree/node.rb, line 6959 def child_nodes [] end
Also aliased as: deconstruct
copy(value: nil, location: nil)
click to toggle source
# File lib/syntax_tree/node.rb, line 6963 def copy(value: nil, location: nil) node = Kw.new(value: value || self.value, location: location || self.location) node.comments.concat(comments.map(&:copy)) node end
deconstruct_keys(_keys)
click to toggle source
# File lib/syntax_tree/node.rb, line 6973 def deconstruct_keys(_keys) { value: value, location: location, comments: comments } end
format(q)
click to toggle source
# File lib/syntax_tree/node.rb, line 6977 def format(q) q.text(value) end