Class: ActionDispatch::Routing::RouteSet::NamedRouteCollection

Inherits:
Object
  • Object
show all
Includes:
Enumerable
Defined in:
lib/action_dispatch/routing/route_set.rb

Overview

A NamedRouteCollection instance is a collection of named routes, and also maintains an anonymous module that can be used to install helpers for the named routes.

Defined Under Namespace

Classes: UrlHelper

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeNamedRouteCollection

Returns a new instance of NamedRouteCollection.

[View source]

72
73
74
75
76
77
78
# File 'lib/action_dispatch/routing/route_set.rb', line 72

def initialize
  @routes = {}
  @path_helpers = Set.new
  @url_helpers = Set.new
  @url_helpers_module  = Module.new
  @path_helpers_module = Module.new
end

Instance Attribute Details

#path_helpers_moduleObject (readonly)

Returns the value of attribute path_helpers_module.


69
70
71
# File 'lib/action_dispatch/routing/route_set.rb', line 69

def path_helpers_module
  @path_helpers_module
end

#url_helpers_moduleObject (readonly)

Returns the value of attribute url_helpers_module.


69
70
71
# File 'lib/action_dispatch/routing/route_set.rb', line 69

def url_helpers_module
  @url_helpers_module
end

Instance Method Details

#add(name, route) ⇒ Object Also known as: []=

[View source]

103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
# File 'lib/action_dispatch/routing/route_set.rb', line 103

def add(name, route)
  key       = name.to_sym
  path_name = :"#{name}_path"
  url_name  = :"#{name}_url"

  if routes.key? key
    @path_helpers_module.undef_method path_name
    @url_helpers_module.undef_method url_name
  end
  routes[key] = route
  define_url_helper @path_helpers_module, route, path_name, route.defaults, name, PATH
  define_url_helper @url_helpers_module,  route, url_name,  route.defaults, name, UNKNOWN

  @path_helpers << path_name
  @url_helpers << url_name
end

#add_url_helper(name, defaults, &block) ⇒ Object

Given a name, defines name_path and name_url helpers. Used by 'direct', 'resolve', and 'polymorphic' route helpers.

[View source]

148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
# File 'lib/action_dispatch/routing/route_set.rb', line 148

def add_url_helper(name, defaults, &block)
  helper = CustomUrlHelper.new(name, defaults, &block)
  path_name = :"#{name}_path"
  url_name = :"#{name}_url"

  @path_helpers_module.module_eval do
    redefine_method(path_name) do |*args|
      helper.call(self, args, true)
    end
  end

  @url_helpers_module.module_eval do
    redefine_method(url_name) do |*args|
      helper.call(self, args, false)
    end
  end

  @path_helpers << path_name
  @url_helpers << url_name

  self
end

#clear!Object Also known as: clear

[View source]

89
90
91
92
93
94
95
96
97
98
99
100
101
# File 'lib/action_dispatch/routing/route_set.rb', line 89

def clear!
  @path_helpers.each do |helper|
    @path_helpers_module.remove_method helper
  end

  @url_helpers.each do |helper|
    @url_helpers_module.remove_method helper
  end

  @routes.clear
  @path_helpers.clear
  @url_helpers.clear
end

#eachObject

[View source]

133
134
135
136
# File 'lib/action_dispatch/routing/route_set.rb', line 133

def each
  routes.each { |name, route| yield name, route }
  self
end

#get(name) ⇒ Object Also known as: []

[View source]

120
121
122
# File 'lib/action_dispatch/routing/route_set.rb', line 120

def get(name)
  routes[name.to_sym]
end

#helper_namesObject

[View source]

85
86
87
# File 'lib/action_dispatch/routing/route_set.rb', line 85

def helper_names
  @path_helpers.map(&:to_s) + @url_helpers.map(&:to_s)
end

#key?(name) ⇒ Boolean

Returns:

  • (Boolean)
[View source]

124
125
126
127
# File 'lib/action_dispatch/routing/route_set.rb', line 124

def key?(name)
  return unless name
  routes.key? name.to_sym
end

#lengthObject

[View source]

142
143
144
# File 'lib/action_dispatch/routing/route_set.rb', line 142

def length
  routes.length
end

#namesObject

[View source]

138
139
140
# File 'lib/action_dispatch/routing/route_set.rb', line 138

def names
  routes.keys
end

#route_defined?(name) ⇒ Boolean

Returns:

  • (Boolean)
[View source]

80
81
82
83
# File 'lib/action_dispatch/routing/route_set.rb', line 80

def route_defined?(name)
  key = name.to_sym
  @path_helpers.include?(key) || @url_helpers.include?(key)
end