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 enum_to_s

def enum_to_s
  if enum.respond_to? :join
    enum.join(", ")
  else
    "#{enum.first}..#{enum.last}"
  end
end

def initialize(name, options = {})

def initialize(name, options = {})
  class_name = self.class.name.split("::").last
  type = options[:type]
  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 = options[:desc]
  @required    = options.key?(:required) ? options[:required] : true
  @type        = (type || :string).to_sym
  @default     = options[:default]
  @banner      = options[:banner] || default_banner
  @enum        = options[:enum]
  validate! # Trigger specific validations
end

def print_default

def print_default
  if @type == :array and @default.is_a?(Array)
    @default.map { |x|
      p = x.gsub('"','\\"')
      "\"#{p}\""
    }.join(" ")
  else
    @default
  end
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)
  self.class::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?
  raise ArgumentError, "An argument cannot have an enum other than an enumerable." if @enum && !@enum.is_a?(Enumerable)
end