diff options
author | José Valim <jose.valim@gmail.com> | 2010-08-15 16:35:59 -0300 |
---|---|---|
committer | José Valim <jose.valim@gmail.com> | 2010-08-15 16:36:12 -0300 |
commit | ada8c66ba06777177f9313198f404fdd1458d24d (patch) | |
tree | b8dff36f79bdd58c1f91c100cb3be9aa8a49d3c8 | |
parent | 99f399752092310224fbfae05bf3a0b37e8dd725 (diff) | |
download | rails-ada8c66ba06777177f9313198f404fdd1458d24d.tar.gz rails-ada8c66ba06777177f9313198f404fdd1458d24d.tar.bz2 rails-ada8c66ba06777177f9313198f404fdd1458d24d.zip |
Improve routes task code and print the application as :to => RackApp. [#5338 state:resolved]
-rw-r--r-- | railties/lib/rails/tasks/routes.rake | 36 |
1 files changed, 24 insertions, 12 deletions
diff --git a/railties/lib/rails/tasks/routes.rake b/railties/lib/rails/tasks/routes.rake index 8b041c96c5..c0a2fe38bd 100644 --- a/railties/lib/rails/tasks/routes.rake +++ b/railties/lib/rails/tasks/routes.rake @@ -1,23 +1,35 @@ desc 'Print out all defined routes in match order, with names. Target specific controller with CONTROLLER=x.' task :routes => :environment do Rails.application.reload_routes! - all_routes = ENV['CONTROLLER'] ? Rails.application.routes.routes.select { |route| route.defaults[:controller] == ENV['CONTROLLER'] } : Rails.application.routes.routes + + all_routes = Rails.application.routes.routes + named_routes = Rails.application.routes.named_routes.routes + + if ENV['CONTROLLER'] + all_routes = all_routes.select{ |route| route.defaults[:controller] == ENV['CONTROLLER'] } + end + routes = all_routes.collect do |route| # TODO: The :index method is deprecated in 1.9 in favor of :key # but we don't have :key in 1.8.7. We can remove this check when # stop supporting 1.8.x - key_method = Hash.method_defined?('key') ? 'key' : 'index' - name = Rails.application.routes.named_routes.routes.send(key_method, route).to_s - reqs = route.requirements.empty? ? "" : route.requirements.inspect - app = route.app.to_s =~ /ActionDispatch.*/ ? "" : route.app.to_s - {:name => name, :verb => route.verb.to_s, :path => route.path, :reqs => reqs, :app => app} + key = Hash.method_defined?('key') ? 'key' : 'index' + name = named_routes.send(key, route).to_s + + reqs = route.requirements.dup + reqs[:to] = route.app unless route.app.is_a?(ActionDispatch::Routing::RouteSet::Dispatcher) + reqs = reqs.empty? ? "" : reqs.inspect + + {:name => name, :verb => route.verb.to_s, :path => route.path, :reqs => reqs} end - routes.reject!{ |r| r[:path] == "/rails/info/properties" } # skip the route if it's internal info route - name_width = routes.collect {|r| r[:name]}.collect {|n| n.length}.max - verb_width = routes.collect {|r| r[:verb]}.collect {|v| v.length}.max - path_width = routes.collect {|r| r[:path]}.collect {|s| s.length}.max - app_width = routes.collect {|r| r[:app]}.collect {|a| a.length}.max + + routes.reject! { |r| r[:path] == "/rails/info/properties" } # Skip the route if it's internal info route + + name_width = routes.map{ |r| r[:name] }.map(&:length).max + verb_width = routes.map{ |r| r[:verb] }.map(&:length).max + path_width = routes.map{ |r| r[:path] }.map(&:length).max + routes.each do |r| - puts "#{r[:name].rjust(name_width)} #{r[:verb].ljust(verb_width)} #{r[:path].ljust(path_width)} #{r[:reqs]} #{(r[:app].length > 0 ? '=> ' + r[:app] : '').ljust(app_width)}" + puts "#{r[:name].rjust(name_width)} #{r[:verb].ljust(verb_width)} #{r[:path].ljust(path_width)} #{r[:reqs]}" end end
\ No newline at end of file |