class Rails::Server

def app

TODO: this is no longer required but we keep it for the moment to support older config.ru files.
def app
  @app ||= begin
    app = super
    app.respond_to?(:to_app) ? app.to_app : app
  end
end

def default_options

def default_options
  super.merge({
    Port:         3000,
    DoNotReverseLookup:  true,
    environment:  (ENV['RAILS_ENV'] || ENV['RACK_ENV'] || "development").dup,
    daemonize:    false,
    debugger:     false,
    pid:          File.expand_path("tmp/pids/server.pid"),
    config:       File.expand_path("config.ru")
  })
end

def initialize(*)

def initialize(*)
  super
  set_environment
end

def log_path

def log_path
  "log/#{options[:environment]}.log"
end

def middleware

def middleware
  middlewares = []
  middlewares << [Rails::Rack::Debugger]  if options[:debugger]
  middlewares << [::Rack::ContentLength]
  # FIXME: add Rack::Lock in the case people are using webrick.
  # This is to remain backwards compatible for those who are
  # running webrick in production. We should consider removing this
  # in development.
  if server.name == 'Rack::Handler::WEBrick'
    middlewares << [::Rack::Lock]
  end
  Hash.new(middlewares)
end

def opt_parser

def opt_parser
  Options.new
end

def set_environment

def set_environment
  ENV["RAILS_ENV"] ||= options[:environment]
end

def start

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"
  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
  unless options[:daemonize]
    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
  super
ensure
  # The '-h' option calls exit before @options is set.
  # If we call 'options' with it unset, we get double help banners.
  puts 'Exiting' unless @options && options[:daemonize]
end