Class: SyntaxTree::Kw
Overview
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.
Instance Attribute Summary collapse
-
#comments ⇒ Object
readonly
- Array[ Comment | EmbDoc ]
-
the comments attached to this node.
-
#name ⇒ Object
readonly
- Symbol
-
the symbol version of the value.
-
#value ⇒ Object
readonly
- String
-
the value of the keyword.
Attributes inherited from Node
Instance Method Summary collapse
- #===(other) ⇒ Object
- #accept(visitor) ⇒ Object
- #child_nodes ⇒ Object (also: #deconstruct)
- #copy(value: nil, location: nil) ⇒ Object
- #deconstruct_keys(_keys) ⇒ Object
- #format(q) ⇒ Object
-
#initialize(value:, location:) ⇒ Kw
constructor
A new instance of Kw.
Methods inherited from Node
#construct_keys, #end_char, #pretty_print, #start_char, #to_json, #to_mermaid
Constructor Details
#initialize(value:, location:) ⇒ Kw
Returns a new instance of Kw.
6945 6946 6947 6948 6949 6950 |
# File 'lib/syntax_tree/node.rb', line 6945 def initialize(value:, location:) @value = value @name = value.to_sym @location = location @comments = [] end |
Instance Attribute Details
#comments ⇒ Object (readonly)
- Array[ Comment | EmbDoc ]
-
the comments attached to this node
6943 6944 6945 |
# File 'lib/syntax_tree/node.rb', line 6943 def comments @comments end |
#name ⇒ Object (readonly)
- Symbol
-
the symbol version of the value
6940 6941 6942 |
# File 'lib/syntax_tree/node.rb', line 6940 def name @name end |
#value ⇒ Object (readonly)
- String
-
the value of the keyword
6937 6938 6939 |
# File 'lib/syntax_tree/node.rb', line 6937 def value @value end |
Instance Method Details
#===(other) ⇒ Object
6978 6979 6980 |
# File 'lib/syntax_tree/node.rb', line 6978 def ===(other) other.is_a?(Kw) && value === other.value end |
#accept(visitor) ⇒ Object
6952 6953 6954 |
# File 'lib/syntax_tree/node.rb', line 6952 def accept(visitor) visitor.visit_kw(self) end |
#child_nodes ⇒ Object Also known as: deconstruct
6956 6957 6958 |
# File 'lib/syntax_tree/node.rb', line 6956 def child_nodes [] end |
#copy(value: nil, location: nil) ⇒ Object
6960 6961 6962 6963 6964 6965 6966 |
# File 'lib/syntax_tree/node.rb', line 6960 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) ⇒ Object
6970 6971 6972 |
# File 'lib/syntax_tree/node.rb', line 6970 def deconstruct_keys(_keys) { value: value, location: location, comments: comments } end |
#format(q) ⇒ Object
6974 6975 6976 |
# File 'lib/syntax_tree/node.rb', line 6974 def format(q) q.text(value) end |