Sha256: b9c70863a2a14f23137e2aa8f1c77669fb14a25b7bacd2758c2be82af5469534
Contents?: true
Size: 1.28 KB
Versions: 1
Compression:
Stored size: 1.28 KB
Contents
module Regexp::Expression class Subexpression < Regexp::Expression::Base attr_accessor :expressions def initialize(token, options = {}) super self.expressions = [] end # Override base method to clone the expressions as well. def initialize_clone(other) other.expressions = expressions.map(&:clone) super end def <<(exp) if exp.is_a?(WhiteSpace) && last && last.is_a?(WhiteSpace) last.merge(exp) else exp.nesting_level = nesting_level + 1 expressions << exp end end %w[[] all? any? at collect count each each_with_index empty? fetch find first index join last length map values_at].each do |m| define_method(m) { |*args, &block| expressions.send(m, *args, &block) } end def te ts + to_s.length end def to_s(format = :full) # Note: the format does not get passed down to subexpressions. # Note: cant use #text accessor, b/c it is overriden as def text; to_s end # in Expression::Sequence, causing infinite recursion. Clean-up needed. "#{@text}#{expressions.join}#{quantifier_affix(format)}" end def to_h super.merge({ text: to_s(:base), expressions: expressions.map(&:to_h) }) end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
regexp_parser-1.0.0 | lib/regexp_parser/expression/subexpression.rb |