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.
3132 3133 3134 3135 3136 3137 3138 |
# File 'lib/syntax_tree/node.rb', line 3132 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
3130 3131 3132 |
# File 'lib/syntax_tree/node.rb', line 3130 def comments @comments end |
#consequent ⇒ Object (readonly)
- In | When
-
the next clause in the chain
3127 3128 3129 |
# File 'lib/syntax_tree/node.rb', line 3127 def consequent @consequent end |
#keyword ⇒ Object (readonly)
- Kw
-
the keyword that opens this expression
3121 3122 3123 |
# File 'lib/syntax_tree/node.rb', line 3121 def keyword @keyword end |
#value ⇒ Object (readonly)
- nil | Node
-
optional value being switched on
3124 3125 3126 |
# File 'lib/syntax_tree/node.rb', line 3124 def value @value end |
Instance Method Details
#===(other) ⇒ Object
3190 3191 3192 3193 |
# File 'lib/syntax_tree/node.rb', line 3190 def ===(other) other.is_a?(Case) && keyword === other.keyword && value === other.value && consequent === other.consequent end |
#accept(visitor) ⇒ Object
3140 3141 3142 |
# File 'lib/syntax_tree/node.rb', line 3140 def accept(visitor) visitor.visit_case(self) end |
#child_nodes ⇒ Object Also known as: deconstruct
3144 3145 3146 |
# File 'lib/syntax_tree/node.rb', line 3144 def child_nodes [keyword, value, consequent] end |
#copy(keyword: nil, value: nil, consequent: nil, location: nil) ⇒ Object
3148 3149 3150 3151 3152 3153 3154 3155 3156 3157 3158 3159 |
# File 'lib/syntax_tree/node.rb', line 3148 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
3163 3164 3165 3166 3167 3168 3169 3170 3171 |
# File 'lib/syntax_tree/node.rb', line 3163 def deconstruct_keys(_keys) { keyword: keyword, value: value, consequent: consequent, location: location, comments: comments } end |
#format(q) ⇒ Object
3173 3174 3175 3176 3177 3178 3179 3180 3181 3182 3183 3184 3185 3186 3187 3188 |
# File 'lib/syntax_tree/node.rb', line 3173 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 |