Skip to content

Commit

Permalink
Fix shorthand routes where controller and action are in the scope
Browse files Browse the repository at this point in the history
Merge `:action` from routing scope and assign endpoint if both `:controller`
and `:action` are present. The endpoint assignment only occurs if there is
no `:to` present in the options hash so should only affect routes using the
shorthand syntax (i.e. endpoint is inferred from the the path).

Fixes #9856
  • Loading branch information
pixeltrix committed Jun 25, 2013
1 parent 55d9176 commit 37b4276
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 2 deletions.
9 changes: 9 additions & 0 deletions actionpack/CHANGELOG.md
@@ -1,3 +1,12 @@
* Merge `:action` from routing scope and assign endpoint if both `:controller`
and `:action` are present. The endpoint assignment only occurs if there is
no `:to` present in the options hash so should only affect routes using the
shorthand syntax (i.e. endpoint is inferred from the the path).

Fixes #9856

*Yves Senn*, *Andrew White*

* ActionView extracted from ActionPack

*Piotr Sarnacki*, *Łukasz Strzałkowski*
Expand Down
12 changes: 10 additions & 2 deletions actionpack/lib/action_dispatch/routing/mapper.rb
Expand Up @@ -11,8 +11,8 @@ module Routing
class Mapper
URL_OPTIONS = [:protocol, :subdomain, :domain, :host, :port]
SCOPE_OPTIONS = [:path, :shallow_path, :as, :shallow_prefix, :module,
:controller, :path_names, :constraints, :defaults,
:shallow, :blocks, :options]
:controller, :action, :path_names, :constraints,
:shallow, :blocks, :defaults, :options]

class Constraints #:nodoc:
def self.new(app, constraints, request = Rack::Request)
Expand Down Expand Up @@ -874,6 +874,10 @@ def merge_controller_scope(parent, child) #:nodoc:
child
end

def merge_action_scope(parent, child) #:nodoc:
child
end

def merge_path_names_scope(parent, child) #:nodoc:
merge_options_scope(parent, child)
end
Expand Down Expand Up @@ -1383,6 +1387,10 @@ def match(path, *rest)
raise ArgumentError, "Unknown scope #{on.inspect} given to :on"
end

if @scope[:controller] && @scope[:action]
options[:to] ||= "#{@scope[:controller]}##{@scope[:action]}"
end

paths.each do |_path|
route_options = options.dup
route_options[:path] ||= _path if _path.is_a?(String)
Expand Down

0 comments on commit 37b4276

Please sign in to comment.