Class: ActionDispatch::Journey::Path::Pattern::AnchoredRegexp

Inherits:
Visitors::Visitor show all
Defined in:
lib/action_dispatch/journey/path/pattern.rb

Overview

:nodoc:

Direct Known Subclasses

UnanchoredRegexp

Constant Summary

Constants inherited from Visitors::Visitor

Visitors::Visitor::DISPATCH_CACHE

Instance Method Summary collapse

Constructor Details

#initialize(separator, matchers) ⇒ AnchoredRegexp

Returns a new instance of AnchoredRegexp.



57
58
59
60
61
62
# File 'lib/action_dispatch/journey/path/pattern.rb', line 57

def initialize(separator, matchers)
  @separator = separator
  @matchers  = matchers
  @separator_re = "([^#{separator}]+)"
  super()
end

Instance Method Details

#accept(node) ⇒ Object



64
65
66
# File 'lib/action_dispatch/journey/path/pattern.rb', line 64

def accept(node)
  %r{\A#{visit node}\Z}
end

#visit_CAT(node) ⇒ Object



68
69
70
# File 'lib/action_dispatch/journey/path/pattern.rb', line 68

def visit_CAT(node)
  "#{visit(node.left)}#{visit(node.right)}"
end

#visit_GROUP(node) ⇒ Object



81
82
83
# File 'lib/action_dispatch/journey/path/pattern.rb', line 81

def visit_GROUP(node)
  "(?:#{visit node.left})?"
end

#visit_LITERAL(node) ⇒ Object Also known as: visit_DOT



85
86
87
# File 'lib/action_dispatch/journey/path/pattern.rb', line 85

def visit_LITERAL(node)
  Regexp.escape(node.left)
end

#visit_OR(node) ⇒ Object



99
100
101
102
# File 'lib/action_dispatch/journey/path/pattern.rb', line 99

def visit_OR(node)
  children = node.children.map { |n| visit n }
  "(?:#{children.join(?|)})"
end

#visit_SLASH(node) ⇒ Object



90
91
92
# File 'lib/action_dispatch/journey/path/pattern.rb', line 90

def visit_SLASH(node)
  node.left
end

#visit_STAR(node) ⇒ Object



94
95
96
97
# File 'lib/action_dispatch/journey/path/pattern.rb', line 94

def visit_STAR(node)
  re = @matchers[node.left.to_sym]
  re ? "(#{re})" : "(.+)"
end

#visit_SYMBOL(node) ⇒ Object



72
73
74
75
76
77
78
79
# File 'lib/action_dispatch/journey/path/pattern.rb', line 72

def visit_SYMBOL(node)
  node = node.to_sym

  return @separator_re unless @matchers.key?(node)

  re = @matchers[node]
  "(#{Regexp.union(re)})"
end