class Thor::Argument
:nodoc:
def default_banner
def default_banner case type when :boolean nil when :string, :default human_name.upcase when :numeric "N" when :hash "key:value" when :array "one two three" end end
def initialize(name, description=nil, required=true, type=:string, default=nil, banner=nil)
def initialize(name, description=nil, required=true, type=:string, default=nil, banner=nil) class_name = self.class.name.split("::").last raise ArgumentError, "#{class_name} name can't be nil." if name.nil? raise ArgumentError, "Type :#{type} is not valid for #{class_name.downcase}s." if type && !valid_type?(type) @name = name.to_s @description = description @required = required || false @type = (type || :string).to_sym @default = default @banner = banner || default_banner validate! # Trigger specific validations end
def required?
def required? required end
def show_default?
def show_default? case default when Array, String, Hash !default.empty? else default end end
def usage
def usage required? ? banner : "[#{banner}]" end
def valid_type?(type)
def valid_type?(type) VALID_TYPES.include?(type.to_sym) end
def validate!
def validate! raise ArgumentError, "An argument cannot be required and have default value." if required? && !default.nil? end