aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJosé Valim <jose.valim@gmail.com>2010-08-15 16:35:59 -0300
committerJosé Valim <jose.valim@gmail.com>2010-08-15 16:36:12 -0300
commitada8c66ba06777177f9313198f404fdd1458d24d (patch)
treeb8dff36f79bdd58c1f91c100cb3be9aa8a49d3c8
parent99f399752092310224fbfae05bf3a0b37e8dd725 (diff)
downloadrails-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.rake36
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