aboutsummaryrefslogtreecommitdiffstats
path: root/railties/lib/rails/railtie.rb
diff options
context:
space:
mode:
authorJosé Valim <jose.valim@gmail.com>2010-01-23 16:59:32 +0100
committerJosé Valim <jose.valim@gmail.com>2010-01-23 16:59:37 +0100
commit13d66cdf2544af0d465d596383743b16b5005996 (patch)
tree32a44fbf28cc65679caa665acaefa6af2df38a64 /railties/lib/rails/railtie.rb
parent4f036032152518791d379f47260236f619713fbb (diff)
downloadrails-13d66cdf2544af0d465d596383743b16b5005996.tar.gz
rails-13d66cdf2544af0d465d596383743b16b5005996.tar.bz2
rails-13d66cdf2544af0d465d596383743b16b5005996.zip
Extract Railtie load from application.
Diffstat (limited to 'railties/lib/rails/railtie.rb')
-rw-r--r--railties/lib/rails/railtie.rb14
1 files changed, 8 insertions, 6 deletions
diff --git a/railties/lib/rails/railtie.rb b/railties/lib/rails/railtie.rb
index 5b97fabe40..84f7a86946 100644
--- a/railties/lib/rails/railtie.rb
+++ b/railties/lib/rails/railtie.rb
@@ -5,26 +5,30 @@ module Rails
ABSTRACT_RAILTIES = %w(Rails::Plugin Rails::Engine Rails::Application)
class << self
+ attr_reader :subclasses
+
def abstract_railtie?(base)
ABSTRACT_RAILTIES.include?(base.name)
end
def inherited(base)
- @@plugins ||= []
- @@plugins << base unless abstract_railtie?(base)
+ @subclasses ||= []
+ @subclasses << base unless abstract_railtie?(base)
end
- # This should be called railtie_name and engine_name
+ # TODO This should be called railtie_name and engine_name
def plugin_name(plugin_name = nil)
@plugin_name ||= name.demodulize.underscore
@plugin_name = plugin_name if plugin_name
@plugin_name
end
+ # TODO Deprecate me
def plugins
- @@plugins
+ @subclasses
end
+ # TODO Deprecate me
def plugin_names
plugins.map { |p| p.plugin_name }
end
@@ -59,12 +63,10 @@ module Rails
end
def load_tasks
- return unless rake_tasks
rake_tasks.each { |blk| blk.call }
end
def load_generators
- return unless generators
generators.each { |blk| blk.call }
end
end