diff options
author | ara.t.howard <ara.t.howard@gmail.com> | 2012-04-04 16:28:19 -0600 |
---|---|---|
committer | ara.t.howard <ara.t.howard@gmail.com> | 2012-04-04 16:28:19 -0600 |
commit | 697991a20114ba409e8bc991bfba0a08a25ff60f (patch) | |
tree | 7436ba18d17c53b9174e9317ed35b1f236d09292 /actionpack/lib | |
parent | a9398a7da4fa845a0182bd53273c607dae55b1ee (diff) | |
download | rails-697991a20114ba409e8bc991bfba0a08a25ff60f.tar.gz rails-697991a20114ba409e8bc991bfba0a08a25ff60f.tar.bz2 rails-697991a20114ba409e8bc991bfba0a08a25ff60f.zip |
carefully and quickly merge url_for options
Diffstat (limited to 'actionpack/lib')
-rw-r--r-- | actionpack/lib/action_dispatch/routing/url_for.rb | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/actionpack/lib/action_dispatch/routing/url_for.rb b/actionpack/lib/action_dispatch/routing/url_for.rb index 94db36ce1f..f2773615a3 100644 --- a/actionpack/lib/action_dispatch/routing/url_for.rb +++ b/actionpack/lib/action_dispatch/routing/url_for.rb @@ -147,7 +147,7 @@ module ActionDispatch when String options when nil, Hash - _routes.url_for((options || {}).symbolize_keys.reverse_merge!(url_options)) + _routes.url_for(_merge_url_for_options(options, url_options)) else polymorphic_url(options) end @@ -155,6 +155,22 @@ module ActionDispatch protected + def _merge_url_for_options(h1, h2) + opts = {} + + h1.keys.each do |k| + s = k.to_sym + opts[s] = h1[k] unless opts.has_key?(s) + end if h1 + + h2.keys.each do |k| + s = k.to_sym + opts[s] = h2[k] unless opts.has_key?(s) + end if h2 + + opts + end + def optimize_routes_generation? return @_optimized_routes if defined?(@_optimized_routes) @_optimized_routes = _routes.optimize_routes_generation? && default_url_options.empty? |