Sha256: fa3e7c2f742a88d7ad1e4b16d81e808f599236704ca669a04ac1f3f2fc85a606

Contents?: true

Size: 1.82 KB

Versions: 23

Compression:

Stored size: 1.82 KB

Contents

module Regexp::Expression
  class Subexpression < Regexp::Expression::Base

    # Traverses the subexpression (depth-first, pre-order) and calls the given
    # block for each expression with three arguments; the traversal event,
    # the expression, and the index of the expression within its parent.
    #
    # The event argument is passed as follows:
    #
    # - For subexpressions, :enter upon entrering the subexpression, and
    #   :exit upon exiting it.
    #
    # - For terminal expressions, :visit is called once.
    #
    # Returns self.
    def traverse(include_self = false, &block)
      raise 'traverse requires a block' unless block_given?

      block.call(:enter, self, 0) if include_self

      each_with_index do |exp, index|
        if exp.terminal?
          block.call(:visit, exp, index)
        else
          block.call(:enter, exp, index)
          exp.traverse(&block)
          block.call(:exit, exp, index)
        end
      end

      block.call(:exit, self, 0) if include_self

      self
    end
    alias :walk :traverse

    # Iterates over the expressions of this expression as an array, passing
    # the expression and its index within its parent to the given block.
    def each_expression(include_self = false, &block)
      traverse(include_self) do |event, exp, index|
        yield(exp, index) unless event == :exit
      end
    end

    # Returns a new array with the results of calling the given block once
    # for every expression. If a block is not given, returns an array with
    # each expression and its level index as an array.
    def map(include_self = false, &block)
      result = []

      each_expression(include_self) do |exp, index|
        if block_given?
          result << yield(exp, index)
        else
          result << [exp, index]
        end
      end

      result
    end

  end
end

Version data entries

23 entries across 23 versions & 1 rubygems

Version Path
regexp_parser-0.4.13 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.12 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.11 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.10 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.9 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.8 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.7 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.6 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.5 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.4 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.3 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.2 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.1 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.4.0 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.3.6 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.3.5 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.3.4 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.3.3 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.3.2 lib/regexp_parser/expression/methods/traverse.rb
regexp_parser-0.3.1 lib/regexp_parser/expression/methods/traverse.rb