DynaSymbol
represents a symbol literal that uses quotes to dynamically define its value.
:"#{variable}"
They can also be used as a special kind of dynamic hash key, as in:
{ "#{key}": value }Attributes
the quote used to delimit the dynamic symbol
def initialize(parts:, quote:, location:) @parts = parts @quote = quote @location = location @comments = [] endPublic Instance Methods Source
def ===(other) other.is_a?(DynaSymbol) && ArrayMatch.call(parts, other.parts) && quote === other.quote endSource
def accept(visitor) visitor.visit_dyna_symbol(self) endSource
def child_nodes parts endSource
def copy(parts: nil, quote: nil, location: nil) node = DynaSymbol.new( parts: parts || self.parts, quote: quote || self.quote, location: location || self.location ) node.comments.concat(comments.map(&:copy)) node endSource
def deconstruct_keys(_keys) { parts: parts, quote: quote, location: location, comments: comments } endSource
def format(q) opening_quote, closing_quote = quotes(q) q.text(opening_quote) q.group do parts.each do |part| if part.is_a?(TStringContent) value = Quotes.normalize(part.value, closing_quote) first = true value.each_line(chomp: true) do |line| if first first = false else q.breakable_return end q.text(line) end q.breakable_return if value.end_with?("\n") else q.format(part) end end end q.text(closing_quote) end
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4