diff options
Diffstat (limited to 'actionpack/lib/action_dispatch/routing/url_for.rb')
| -rw-r--r-- | actionpack/lib/action_dispatch/routing/url_for.rb | 31 | 
1 files changed, 26 insertions, 5 deletions
| diff --git a/actionpack/lib/action_dispatch/routing/url_for.rb b/actionpack/lib/action_dispatch/routing/url_for.rb index eb554ec383..b6c031dcf4 100644 --- a/actionpack/lib/action_dispatch/routing/url_for.rb +++ b/actionpack/lib/action_dispatch/routing/url_for.rb @@ -1,7 +1,7 @@  module ActionDispatch    module Routing      # In <tt>config/routes.rb</tt> you define URL-to-controller mappings, but the reverse -    # is also possible: an URL can be generated from one of your routing definitions. +    # is also possible: a URL can be generated from one of your routing definitions.      # URL generation functionality is centralized in this module.      #      # See ActionDispatch::Routing for general information about routing and routes.rb. @@ -52,9 +52,11 @@ module ActionDispatch      # argument.      #      # For convenience reasons, mailers provide a shortcut for ActionController::UrlFor#url_for. -    # So within mailers, you only have to type 'url_for' instead of 'ActionController::UrlFor#url_for' -    # in full. However, mailers don't have hostname information, and that's why you'll still -    # have to specify the <tt>:host</tt> argument when generating URLs in mailers. +    # So within mailers, you only have to type +url_for+ instead of 'ActionController::UrlFor#url_for' +    # in full. However, mailers don't have hostname information, and you still have to provide +    # the +:host+ argument or set the default host that will be used in all mailers using the +    # configuration option +config.action_mailer.default_url_options+. For more information on +    # url_for in mailers read the ActionMailer#Base documentation.      #      #      # == URL generation for named routes @@ -147,6 +149,20 @@ module ActionDispatch        #    # => 'http://somehost.org/myapp/tasks/testing'        #    url_for controller: 'tasks', action: 'testing', host: 'somehost.org', script_name: "/myapp", only_path: true        #    # => '/myapp/tasks/testing' +      # +      # Missing routes keys may be filled in from the current request's parameters +      # (e.g. +:controller+, +:action+, +:id+ and any other parameters that are +      # placed in the path). Given that the current action has been reached +      # through `GET /users/1`: +      # +      #   url_for(only_path: true)                        # => '/users/1' +      #   url_for(only_path: true, action: 'edit')        # => '/users/1/edit' +      #   url_for(only_path: true, action: 'edit', id: 2) # => '/users/2/edit' +      # +      # Notice that no +:id+ parameter was provided to the first +url_for+ call +      # and the helper used the one from the route's path. Any path parameter +      # implicitly used by +url_for+ can always be overwritten like shown on the +      # last +url_for+ calls.        def url_for(options = nil)          case options          when nil @@ -155,12 +171,17 @@ module ActionDispatch            route_name = options.delete :use_route            _routes.url_for(options.symbolize_keys.reverse_merge!(url_options),                           route_name) +        when ActionController::Parameters +          route_name = options.delete :use_route +          _routes.url_for(options.to_unsafe_h.symbolize_keys. +                          reverse_merge!(url_options), route_name)          when String            options          when Symbol            HelperMethodBuilder.url.handle_string_call self, options          when Array -          polymorphic_url(options, options.extract_options!) +          components = options.dup +          polymorphic_url(components, components.extract_options!)          when Class            HelperMethodBuilder.url.handle_class_call self, options          else | 
