Class: SyntaxTree::Case
Overview
Case represents the beginning of a case chain.
case value
when 1
"one"
when 2
"two"
else
"number"
end
Instance Attribute Summary collapse
-
#comments ⇒ Object
readonly
- Array[ Comment | EmbDoc ]
-
the comments attached to this node.
-
#consequent ⇒ Object
readonly
- In | When
-
the next clause in the chain.
-
#keyword ⇒ Object
readonly
- Kw
-
the keyword that opens this expression.
-
#value ⇒ Object
readonly
- nil | Node
-
optional value being switched on.
Attributes inherited from Node
Instance Method Summary collapse
- #===(other) ⇒ Object
- #accept(visitor) ⇒ Object
- #child_nodes ⇒ Object (also: #deconstruct)
- #copy(keyword: nil, value: nil, consequent: nil, location: nil) ⇒ Object
- #deconstruct_keys(_keys) ⇒ Object
- #format(q) ⇒ Object
-
#initialize(keyword:, value:, consequent:, location:) ⇒ Case
constructor
A new instance of Case.
Methods inherited from Node
#construct_keys, #end_char, #pretty_print, #start_char, #to_json, #to_mermaid
Constructor Details
#initialize(keyword:, value:, consequent:, location:) ⇒ Case
Returns a new instance of Case.
3129 3130 3131 3132 3133 3134 3135 |
# File 'lib/syntax_tree/node.rb', line 3129 def initialize(keyword:, value:, consequent:, location:) @keyword = keyword @value = value @consequent = consequent @location = location @comments = [] end |
Instance Attribute Details
#comments ⇒ Object (readonly)
- Array[ Comment | EmbDoc ]
-
the comments attached to this node
3127 3128 3129 |
# File 'lib/syntax_tree/node.rb', line 3127 def comments @comments end |
#consequent ⇒ Object (readonly)
- In | When
-
the next clause in the chain
3124 3125 3126 |
# File 'lib/syntax_tree/node.rb', line 3124 def consequent @consequent end |
#keyword ⇒ Object (readonly)
- Kw
-
the keyword that opens this expression
3118 3119 3120 |
# File 'lib/syntax_tree/node.rb', line 3118 def keyword @keyword end |
#value ⇒ Object (readonly)
- nil | Node
-
optional value being switched on
3121 3122 3123 |
# File 'lib/syntax_tree/node.rb', line 3121 def value @value end |
Instance Method Details
#===(other) ⇒ Object
3187 3188 3189 3190 |
# File 'lib/syntax_tree/node.rb', line 3187 def ===(other) other.is_a?(Case) && keyword === other.keyword && value === other.value && consequent === other.consequent end |
#accept(visitor) ⇒ Object
3137 3138 3139 |
# File 'lib/syntax_tree/node.rb', line 3137 def accept(visitor) visitor.visit_case(self) end |
#child_nodes ⇒ Object Also known as: deconstruct
3141 3142 3143 |
# File 'lib/syntax_tree/node.rb', line 3141 def child_nodes [keyword, value, consequent] end |
#copy(keyword: nil, value: nil, consequent: nil, location: nil) ⇒ Object
3145 3146 3147 3148 3149 3150 3151 3152 3153 3154 3155 3156 |
# File 'lib/syntax_tree/node.rb', line 3145 def copy(keyword: nil, value: nil, consequent: nil, location: nil) node = Case.new( keyword: keyword || self.keyword, value: value || self.value, consequent: consequent || self.consequent, location: location || self.location ) node.comments.concat(comments.map(&:copy)) node end |
#deconstruct_keys(_keys) ⇒ Object
3160 3161 3162 3163 3164 3165 3166 3167 3168 |
# File 'lib/syntax_tree/node.rb', line 3160 def deconstruct_keys(_keys) { keyword: keyword, value: value, consequent: consequent, location: location, comments: comments } end |
#format(q) ⇒ Object
3170 3171 3172 3173 3174 3175 3176 3177 3178 3179 3180 3181 3182 3183 3184 3185 |
# File 'lib/syntax_tree/node.rb', line 3170 def format(q) q.group do q.format(keyword) if value q.text(" ") q.format(value) end q.breakable_force q.format(consequent) q.breakable_force q.text("end") end end |