Module: Rails::Generator::Lookup::ClassMethods
- Defined in:
- lib/rails_generator/lookup.rb
Instance Method Summary collapse
-
#append_sources(*args) ⇒ Object
Add a source to the end of the list.
-
#instance(generator_name, args = [], runtime_options = {}) ⇒ Object
Convenience method to lookup and instantiate a generator.
-
#lookup(generator_name) ⇒ Object
Lookup knows how to find generators’ Specs from a list of Sources.
-
#prepend_sources(*args) ⇒ Object
Add a source to the beginning of the list.
-
#reset_sources ⇒ Object
Reset the source list.
-
#sources ⇒ Object
The list of sources where we look, in order, for generators.
-
#use_application_sources! ⇒ Object
Use application generators (app, ?).
-
#use_component_sources! ⇒ Object
Use component generators (model, controller, etc).
Instance Method Details
#append_sources(*args) ⇒ Object
Add a source to the end of the list.
69 70 71 72 |
# File 'lib/rails_generator/lookup.rb', line 69 def append_sources(*args) sources.concat(args.flatten) invalidate_cache! end |
#instance(generator_name, args = [], runtime_options = {}) ⇒ Object
Convenience method to lookup and instantiate a generator.
128 129 130 |
# File 'lib/rails_generator/lookup.rb', line 128 def instance(generator_name, args = [], = {}) lookup(generator_name).klass.new(args, ()) end |
#lookup(generator_name) ⇒ Object
Lookup knows how to find generators’ Specs from a list of Sources. Searches the sources, in order, for the first matching name.
113 114 115 116 117 118 119 120 121 122 123 124 125 |
# File 'lib/rails_generator/lookup.rb', line 113 def lookup(generator_name) @found ||= {} generator_name = generator_name.to_s.downcase @found[generator_name] ||= cache.find { |spec| spec.name == generator_name } unless @found[generator_name] chars = generator_name.scan(/./).map{|c|"#{c}.*?"} rx = /^#{chars}$/ gns = cache.select{|spec| spec.name =~ rx } @found[generator_name] ||= gns.first if gns.length == 1 raise GeneratorError, "Pattern '#{generator_name}' matches more than one generator: #{gns.map{|sp|sp.name}.join(', ')}" if gns.length > 1 end @found[generator_name] or raise GeneratorError, "Couldn't find '#{generator_name}' generator" end |
#prepend_sources(*args) ⇒ Object
Add a source to the beginning of the list.
75 76 77 78 |
# File 'lib/rails_generator/lookup.rb', line 75 def prepend_sources(*args) write_inheritable_array(:sources, args.flatten + sources) invalidate_cache! end |
#reset_sources ⇒ Object
Reset the source list.
81 82 83 84 |
# File 'lib/rails_generator/lookup.rb', line 81 def reset_sources write_inheritable_attribute(:sources, []) invalidate_cache! end |
#sources ⇒ Object
The list of sources where we look, in order, for generators.
64 65 66 |
# File 'lib/rails_generator/lookup.rb', line 64 def sources read_inheritable_attribute(:sources) or use_component_sources! end |
#use_application_sources! ⇒ Object
Use application generators (app, ?).
87 88 89 90 |
# File 'lib/rails_generator/lookup.rb', line 87 def use_application_sources! reset_sources sources << PathSource.new(:builtin, "#{File.dirname(__FILE__)}/generators/applications") end |
#use_component_sources! ⇒ Object
Use component generators (model, controller, etc).
-
Rails application. If RAILS_ROOT is defined we know we’re generating in the context of a Rails application, so search RAILS_ROOT/generators.
-
User home directory. Search ~/.rails/generators.
-
RubyGems. Search for gems named *_generator.
-
Builtins. Model, controller, mailer, scaffold.
99 100 101 102 103 104 105 106 107 108 109 |
# File 'lib/rails_generator/lookup.rb', line 99 def use_component_sources! reset_sources if defined? ::RAILS_ROOT sources << PathSource.new(:lib, "#{::RAILS_ROOT}/lib/generators") sources << PathSource.new(:vendor, "#{::RAILS_ROOT}/vendor/generators") sources << PathSource.new(:plugins, "#{::RAILS_ROOT}/vendor/plugins/**/generators") end sources << PathSource.new(:user, "#{Dir.user_home}/.rails/generators") sources << GemSource.new if Object.const_defined?(:Gem) sources << PathSource.new(:builtin, "#{File.dirname(__FILE__)}/generators/components") end |