Class: Fast::Matcher
- Inherits:
-
Object
- Object
- Fast::Matcher
- Defined in:
- lib/fast.rb
Overview
Joins the AST and the search expression to create a complete matcher that recusively check if the node pattern expression matches with the given AST.
Using captures
One of the most important features of the matcher is find captures and also bind them on demand in case the expression is using previous captures.
Instance Method Summary collapse
-
#captures?(expression = @expression) ⇒ true
Look recursively into @param expression to check if the expression is have captures.
-
#find_captures(expression = @expression) ⇒ Array<Object>, true
Find search captures recursively.
-
#initialize(pattern, ast, *args) ⇒ Matcher
constructor
A new instance of Matcher.
- #match?(expression = @expression, ast = @ast) ⇒ true
-
#match_tail?(tail, child) ⇒ true
If all children matches with tail.
Constructor Details
#initialize(pattern, ast, *args) ⇒ Matcher
Returns a new instance of Matcher.
597 598 599 600 601 602 603 604 605 606 |
# File 'lib/fast.rb', line 597 def initialize(pattern, ast, *args) @ast = ast @expression = if pattern.is_a?(String) Fast.expression(pattern) else [*pattern].map(&Find.method(:new)) end @captures = [] prepare_arguments(@expression, args) if args.any? end |
Instance Method Details
#captures?(expression = @expression) ⇒ true
Look recursively into @param expression to check if the expression is have captures.
629 630 631 632 633 634 635 |
# File 'lib/fast.rb', line 629 def captures?(expression = @expression) case expression when Capture then true when Array then expression.any?(&method(:captures?)) when Find then captures?(expression.token) end end |
#find_captures(expression = @expression) ⇒ Array<Object>, true
Find search captures recursively.
643 644 645 646 647 648 649 650 651 |
# File 'lib/fast.rb', line 643 def find_captures(expression = @expression) return true if expression == @expression && !captures?(expression) case expression when Capture then expression.captures when Array then expression.flat_map(&method(:find_captures)).compact when Find then find_captures(expression.token) end end |
#match?(expression = @expression, ast = @ast) ⇒ true
610 611 612 613 614 615 616 |
# File 'lib/fast.rb', line 610 def match?(expression = @expression, ast = @ast) head, *tail_expression = expression return false unless head.match?(ast) return find_captures if tail_expression.empty? match_tail?(tail_expression, ast.children) end |
#match_tail?(tail, child) ⇒ true
Returns if all children matches with tail.
619 620 621 622 623 624 |
# File 'lib/fast.rb', line 619 def match_tail?(tail, child) tail.each_with_index.all? do |token, i| prepare_token(token) token.is_a?(Array) ? match?(token, child[i]) : token.match?(child[i]) end && find_captures end |