[3.1.0.rc1] Plugins inside engines not eager-loaded properly and their rake tasks ignored #1460

Merged
merged 1 commit into from Jun 16, 2011
Jump to file or symbol
Failed to load files and symbols.
+14 −9
Split
@@ -78,10 +78,6 @@ def require_environment! #:nodoc:
require environment if environment
end
- def eager_load! #:nodoc:
- railties.all(&:eager_load!)
- super
- end
def reload_routes!
routes_reloader.reload!
@@ -100,22 +96,18 @@ def initialize!
def load_tasks(app=self)
initialize_tasks
- railties.all { |r| r.load_tasks(app) }
super
self
end
def load_generators(app=self)
initialize_generators
- railties.all { |r| r.load_generators(app) }
-
super
self
end
def load_console(app=self)
initialize_console
- railties.all { |r| r.load_console(app) }
super
self
end
@@ -387,12 +387,25 @@ def find(path)
delegate :middleware, :root, :paths, :to => :config
delegate :engine_name, :isolated?, :to => "self.class"
- def load_tasks(*)
+ def load_tasks(app=self)
+ railties.all { |r| r.load_tasks(app) }
super
paths["lib/tasks"].existent.sort.each { |ext| load(ext) }
end
+
+ def load_generators(app=self)
+ railties.all { |r| r.load_generators(app) }
+ super
+ end
+ def load_console(app=self)
+ railties.all { |r| r.load_console(app) }
+ super
+ end
+
def eager_load!
+ railties.all(&:eager_load!)
+
config.eager_load_paths.each do |load_path|
matcher = /\A#{Regexp.escape(load_path)}\/(.*)\.rb\Z/
Dir.glob("#{load_path}/**/*.rb").sort.each do |file|