aboutsummaryrefslogtreecommitdiffstats
path: root/railties/lib/rails/commands.rb
diff options
context:
space:
mode:
authorJosé Valim <jose.valim@gmail.com>2010-09-30 10:30:58 +0200
committerJosé Valim <jose.valim@gmail.com>2010-09-30 10:30:58 +0200
commit1ba22bcde1d5ee1e16e14d4d2dd23cbeb01cd59f (patch)
tree0c74273f34c20e56975a6b7845a034fa3df8c469 /railties/lib/rails/commands.rb
parent69f97f469747777ed1c457715f5361f6b8a0ab7b (diff)
parent9f569c60adb3505cd7ca1723481199bf26619038 (diff)
downloadrails-1ba22bcde1d5ee1e16e14d4d2dd23cbeb01cd59f.tar.gz
rails-1ba22bcde1d5ee1e16e14d4d2dd23cbeb01cd59f.tar.bz2
rails-1ba22bcde1d5ee1e16e14d4d2dd23cbeb01cd59f.zip
Merge remote branch 'drogus/engines'
Diffstat (limited to 'railties/lib/rails/commands.rb')
-rw-r--r--railties/lib/rails/commands.rb17
1 files changed, 16 insertions, 1 deletions
diff --git a/railties/lib/rails/commands.rb b/railties/lib/rails/commands.rb
index 60a93c9848..60b9a55d80 100644
--- a/railties/lib/rails/commands.rb
+++ b/railties/lib/rails/commands.rb
@@ -11,7 +11,17 @@ command = ARGV.shift
command = aliases[command] || command
case command
-when 'generate', 'destroy', 'plugin', 'benchmarker', 'profiler'
+when 'generate', 'destroy', 'plugin'
+ require APP_PATH
+ Rails.application.require_environment!
+
+ if defined?(ENGINE_PATH)
+ engine = Rails.application.railties.engines.find { |r| r.root.to_s == ENGINE_PATH }
+ Rails.application = engine
+ end
+ require "rails/commands/#{command}"
+
+when 'benchmarker', 'profiler'
require APP_PATH
Rails.application.require_environment!
require "rails/commands/#{command}"
@@ -23,8 +33,13 @@ when 'console'
Rails::Console.start(Rails.application)
when 'server'
+ # try to guess application's path if there is no config.ru file in current dir
+ # it allows to run script/rails server from other directories
+ Dir.chdir(File.expand_path('../../', APP_PATH)) unless File.exists?(File.expand_path("config.ru"))
+
require 'rails/commands/server'
Rails::Server.new.tap { |server|
+ # we need to require application after the server sets environment
require APP_PATH
Dir.chdir(Rails.application.root)
server.start