diff options
author | Alex Johnson <notalexjohnson@gmail.com> | 2013-11-07 02:52:10 +0530 |
---|---|---|
committer | Alex Johnson <notalexjohnson@gmail.com> | 2013-11-07 02:52:10 +0530 |
commit | 919fafa54b7cc9c870b0138c4ec4cfd42edbace1 (patch) | |
tree | 9a041c23a50915550339d9659914bee015059fee /railties/lib/rails/commands | |
parent | f8e5022c73679f41db9bb6743179bab4571fb28e (diff) | |
download | rails-919fafa54b7cc9c870b0138c4ec4cfd42edbace1.tar.gz rails-919fafa54b7cc9c870b0138c4ec4cfd42edbace1.tar.bz2 rails-919fafa54b7cc9c870b0138c4ec4cfd42edbace1.zip |
Extract method refactoring for Rails::Server#start
Diffstat (limited to 'railties/lib/rails/commands')
-rw-r--r-- | railties/lib/rails/commands/server.rb | 62 |
1 files changed, 38 insertions, 24 deletions
diff --git a/railties/lib/rails/commands/server.rb b/railties/lib/rails/commands/server.rb index 4201dac42f..4b4cf74623 100644 --- a/railties/lib/rails/commands/server.rb +++ b/railties/lib/rails/commands/server.rb @@ -61,30 +61,10 @@ module Rails end def start - url = "#{options[:SSLEnable] ? 'https' : 'http'}://#{options[:Host]}:#{options[:Port]}" - puts "=> Booting #{ActiveSupport::Inflector.demodulize(server)}" - puts "=> Rails #{Rails.version} application starting in #{Rails.env} on #{url}" - puts "=> Run `rails server -h` for more startup options" - if options[:Host].to_s.match(/0\.0\.0\.0/) - puts "=> Notice: server is listening on all interfaces (#{options[:Host]}). Consider using 127.0.0.1 (--binding option)" - end - trap(:INT) { exit } - puts "=> Ctrl-C to shutdown server" unless options[:daemonize] - - #Create required tmp directories if not found - %w(cache pids sessions sockets).each do |dir_to_make| - FileUtils.mkdir_p(File.join(Rails.root, 'tmp', dir_to_make)) - end - - if options[:log_stdout] - wrapped_app # touch the app so the logger is set up - - console = ActiveSupport::Logger.new($stdout) - console.formatter = Rails.logger.formatter - console.level = Rails.logger.level - - Rails.logger.extend(ActiveSupport::Logger.broadcast(console)) - end + print_boot_information + trap_interrupt_and_print_interrupt_information + create_tmp_directories + log_to_stdout if options[:log_stdout] super ensure @@ -124,5 +104,39 @@ module Rails config: File.expand_path("config.ru") }) end + + private + + def print_boot_information + url = "#{ options[:SSLEnable] ? 'https' : 'http' }://#{ options[:Host] }:#{ options[:Port] }" + puts "=> Booting #{ ActiveSupport::Inflector.demodulize(server) }" + puts "=> Rails #{ Rails.version } application starting in #{ Rails.env } on #{ url }" + puts "=> Run `rails server -h` for more startup options" + + if options[:Host].to_s.match(/0\.0\.0\.0/) + puts "=> Notice: server is listening on all interfaces (#{ options[:Host] }). Consider using 127.0.0.1 (--binding option)" + end + end + + def trap_interrupt_and_print_interrupt_information + trap(:INT) { exit } + puts "=> Ctrl-C to shutdown server" unless options[:daemonize] + end + + def create_tmp_directories + %w(cache pids sessions sockets).each do |dir_to_make| + FileUtils.mkdir_p(File.join(Rails.root, 'tmp', dir_to_make)) + end + end + + def log_to_stdout + wrapped_app # touch the app so the logger is set up + + console = ActiveSupport::Logger.new($stdout) + console.formatter = Rails.logger.formatter + console.level = Rails.logger.level + + Rails.logger.extend(ActiveSupport::Logger.broadcast(console)) + end end end |