From 2888f8653e2e0a6394e41cb4e8db2e2d81313eb7 Mon Sep 17 00:00:00 2001 From: Aaron Patterson Date: Thu, 17 Jul 2014 10:47:58 -0700 Subject: use a strategy object for generating urls in named helpers since we know that the route should be a path or fully qualified, we can pass a strategy object that handles generation. This allows us to eliminate an "if only_path" branch when generating urls. --- actionpack/lib/action_dispatch/http/url.rb | 21 +++++++----- .../lib/action_dispatch/routing/route_set.rb | 37 ++++++++++++++-------- 2 files changed, 37 insertions(+), 21 deletions(-) (limited to 'actionpack') diff --git a/actionpack/lib/action_dispatch/http/url.rb b/actionpack/lib/action_dispatch/http/url.rb index 5decab3d8f..473f692b05 100644 --- a/actionpack/lib/action_dispatch/http/url.rb +++ b/actionpack/lib/action_dispatch/http/url.rb @@ -29,20 +29,25 @@ module ActionDispatch end def url_for(options) - host = options[:host] - unless host || options[:only_path] - raise ArgumentError, 'Missing host to link to! Please provide the :host parameter, set default_url_options[:host], or set :only_path to true' - end - if options[:only_path] path_for options else - protocol = options[:protocol] - port = options[:port] - build_host_url(host, port, protocol, options, path_for(options)) + full_url_for options end end + def full_url_for(options) + host = options[:host] + protocol = options[:protocol] + port = options[:port] + + unless host + raise ArgumentError, 'Missing host to link to! Please provide the :host parameter, set default_url_options[:host], or set :only_path to true' + end + + build_host_url(host, port, protocol, options, path_for(options)) + end + def path_for(options) result = options[:script_name].to_s.chomp("/") result << options[:path].to_s diff --git a/actionpack/lib/action_dispatch/routing/route_set.rb b/actionpack/lib/action_dispatch/routing/route_set.rb index 4fb32a76eb..3ecf6a76f1 100644 --- a/actionpack/lib/action_dispatch/routing/route_set.rb +++ b/actionpack/lib/action_dispatch/routing/route_set.rb @@ -134,11 +134,11 @@ module ActionDispatch end class UrlHelper # :nodoc: - def self.create(route, options) + def self.create(route, options, url_strategy) if optimize_helper?(route) - OptimizedUrlHelper.new(route, options) + OptimizedUrlHelper.new(route, options, url_strategy) else - new route, options + new route, options, url_strategy end end @@ -146,10 +146,12 @@ module ActionDispatch !route.glob? && route.path.requirements.empty? end + attr_reader :url_strategy + class OptimizedUrlHelper < UrlHelper # :nodoc: attr_reader :arg_size - def initialize(route, options) + def initialize(route, options, url_strategy) super @required_parts = @route.required_parts @arg_size = @required_parts.size @@ -159,7 +161,7 @@ module ActionDispatch if args.size == arg_size && !inner_options && optimize_routes_generation?(t) options = t.url_options.merge @options options[:path] = optimized_helper(args) - ActionDispatch::Http::URL.url_for(options) + url_strategy.call options else super end @@ -201,10 +203,11 @@ module ActionDispatch end end - def initialize(route, options) + def initialize(route, options, url_strategy) @options = options @segment_keys = route.segment_keys.uniq @route = route + @url_strategy = url_strategy end def call(t, args, inner_options) @@ -216,7 +219,7 @@ module ActionDispatch options, @segment_keys) - t._routes.url_for(hash) + t._routes.url_for(hash, url_strategy) end def handle_positional_args(controller_options, inner_options, args, result, path_params) @@ -249,8 +252,8 @@ module ActionDispatch # # foo_url(bar, baz, bang, sort_by: 'baz') # - def define_url_helper(route, name, opts) - helper = UrlHelper.create(route, opts) + def define_url_helper(route, name, opts, url_strategy) + helper = UrlHelper.create(route, opts, url_strategy) @module.remove_possible_method name @module.module_eval do @@ -266,12 +269,20 @@ module ActionDispatch def define_named_route_methods(name, route) define_url_helper route, :"#{name}_path", - route.defaults.merge(:use_route => name, :only_path => true) + route.defaults.merge(:use_route => name), PATH + define_url_helper route, :"#{name}_url", - route.defaults.merge(:use_route => name, :only_path => false) + route.defaults.merge(:use_route => name), FULL end end + # :stopdoc: + # strategy for building urls to send to the client + PATH = ->(options) { ActionDispatch::Http::URL.path_for(options) } + FULL = ->(options) { ActionDispatch::Http::URL.full_url_for(options) } + UNKNOWN = ->(options) { ActionDispatch::Http::URL.url_for(options) } + # :startdoc: + attr_accessor :formatter, :set, :named_routes, :default_scope, :router attr_accessor :disable_clear_and_finalize, :resources_path_names attr_accessor :default_url_options, :request_class @@ -643,7 +654,7 @@ module ActionDispatch end # The +options+ argument must be a hash whose keys are *symbols*. - def url_for(options) + def url_for(options, url_strategy = UNKNOWN) options = default_url_options.merge options user = password = nil @@ -677,7 +688,7 @@ module ActionDispatch options[:user] = user options[:password] = password - ActionDispatch::Http::URL.url_for(options) + url_strategy.call options end def call(env) -- cgit v1.2.3