提交 54208cbe 编写于 作者: J José Valim

Added invoke_if and make use of it on controller generators.

上级 e981aeb5
...@@ -45,7 +45,8 @@ def self.builtin ...@@ -45,7 +45,8 @@ def self.builtin
# "test_unit:generators:model", "test_unit:model" # "test_unit:generators:model", "test_unit:model"
# #
def self.find_by_namespace(name, base=nil, context=nil) def self.find_by_namespace(name, base=nil, context=nil)
attempts = [ ] name, attempts = name.to_s, []
attempts << "#{base}:generators:#{name}" if base && name.count(':') == 0 attempts << "#{base}:generators:#{name}" if base && name.count(':') == 0
attempts << "#{name}:generators:#{context}" if context && name.count(':') == 0 attempts << "#{name}:generators:#{context}" if context && name.count(':') == 0
attempts << name.sub(':', ':generators:') if name.count(':') == 1 attempts << name.sub(':', ':generators:') if name.count(':') == 1
......
...@@ -4,7 +4,8 @@ module Rails ...@@ -4,7 +4,8 @@ module Rails
module Generators module Generators
DEFAULTS = { DEFAULTS = {
:test_framework => 'test_unit', :test_framework => 'test_unit',
:template_engine => 'erb' :template_engine => 'erb',
:helper => true
} }
class Error < Thor::Error class Error < Thor::Error
...@@ -117,13 +118,15 @@ def self.add_shebang_option! ...@@ -117,13 +118,15 @@ def self.add_shebang_option!
end end
end end
# Invoke a generator based on the given name. If a class option does not # Invoke a generator based on the value supplied by the user to the
# exist for the current name, one created. # given option named "name". A class option is created when this method
# is invoked and you can set a hash to customize it, although type and
# default values cannot be given.
# #
# ==== Examples # ==== Examples
# #
# class ControllerGenerator < Rails::Generators::Base # class ControllerGenerator < Rails::Generators::Base
# invoke_for :test_framework # invoke_for :test_framework, :aliases => "-t"
# end # end
# #
# The example above will create a test framework option and will invoke # The example above will create a test framework option and will invoke
...@@ -139,13 +142,24 @@ def self.add_shebang_option! ...@@ -139,13 +142,24 @@ def self.add_shebang_option!
# This allows any test framework to hook into Rails as long as it # This allows any test framework to hook into Rails as long as it
# provides a "test_framework:generators:controller" generator. # provides a "test_framework:generators:controller" generator.
# #
# Finally, if the user don't want to use any test framework, he can do:
#
# ruby script/generate controller Account --skip-test-framework
#
# Or similarly:
#
# ruby script/generate controller Account --no-test-framework
#
def self.invoke_for(*names) def self.invoke_for(*names)
default_options = names.extract_options!
names.each do |name| names.each do |name|
unless class_options[name] options = default_options.dup
aliases = "-" + name.to_s.gsub(/_framework$/, '').split('_').last[0,1] options[:desc] ||= "#{name.to_s.humanize} to be used"
class_option name, :type => :default, :default => DEFAULTS[name], :banner => "NAME", :aliases => aliases, options[:banner] ||= "NAME"
:desc => "#{name.to_s.humanize} to be used" options[:aliases] ||= "-" + name.to_s.gsub(/_framework$/, '').split('_').last[0,1]
end
class_option name, options.merge!(:type => :default, :default => DEFAULTS[name])
class_eval <<-METHOD, __FILE__, __LINE__ class_eval <<-METHOD, __FILE__, __LINE__
def invoke_#{name} def invoke_#{name}
...@@ -165,6 +179,56 @@ def invoke_#{name} ...@@ -165,6 +179,56 @@ def invoke_#{name}
end end
end end
# Invoke a generator with the given name if the user requires it. The
# difference to invoke_for is that the class option here is boolean
# and the generator invoked is not based on user input.
#
# A class option is created when this method is invoked and you can set
# a hash to customize it, although type and default values cannot be
# given.
#
# ==== Examples
#
# class ControllerGenerator < Rails::Generators::Base
# invoke_if :webrat, :aliases => "-w"
# end
#
# The example above will create a helper option and will be invoked
# when the user requires so:
#
# ruby script/generate controller Account --webrat
#
# The controller generator will then try to invoke the following generators:
#
# "rails:generators:webrat", "webrat:generators:controller", "webrat"
#
def self.invoke_if(*names)
default_options = names.extract_options!
names.each do |name|
options = default_options.dup
options[:desc] ||= "Indicates when to use #{name.to_s.humanize}"
options[:aliases] ||= "-" + name.to_s.last[0,1]
class_option name, options.merge!(:type => :boolean, :default => DEFAULTS[name] || false)
class_eval <<-METHOD, __FILE__, __LINE__
def invoke_#{name}
return unless options[#{name.inspect}]
klass = Rails::Generators.find_by_namespace(#{name.inspect},
self.class.base_name, self.class.generator_name)
if klass
invoke klass
else
say "Could not find and invoke '#{name.inspect}'."
end
end
METHOD
end
end
end end
end end
end end
...@@ -9,10 +9,7 @@ def create_controller_files ...@@ -9,10 +9,7 @@ def create_controller_files
end end
invoke_for :template_engine, :test_framework invoke_for :template_engine, :test_framework
invoke_if :helper, :aliases => "-v"
def invoke_helper
invoke "rails:generators:helper"
end
end end
end end
end end
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册