Class: Thor::Argument
- Inherits:
-
Object
- Object
- Thor::Argument
- Defined in:
- lib/thor/parser/argument.rb
Overview
:nodoc:
Direct Known Subclasses
Constant Summary collapse
- VALID_TYPES =
[:numeric, :hash, :array, :string]
Instance Attribute Summary collapse
-
#banner ⇒ Object
readonly
Returns the value of attribute banner.
-
#default ⇒ Object
readonly
Returns the value of attribute default.
-
#description ⇒ Object
readonly
Returns the value of attribute description.
-
#enum ⇒ Object
readonly
Returns the value of attribute enum.
-
#name ⇒ Object
(also: #human_name)
readonly
Returns the value of attribute name.
-
#required ⇒ Object
readonly
Returns the value of attribute required.
-
#type ⇒ Object
readonly
Returns the value of attribute type.
Instance Method Summary collapse
- #default_banner ⇒ Object protected
-
#initialize(name, options = {}) ⇒ Argument
constructor
A new instance of Argument.
- #required? ⇒ Boolean
- #show_default? ⇒ Boolean
- #usage ⇒ Object
- #valid_type?(type) ⇒ Boolean protected
- #validate! ⇒ Object protected
Constructor Details
#initialize(name, options = {}) ⇒ Argument
Returns a new instance of Argument.
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/thor/parser/argument.rb', line 8 def initialize(name, = {}) class_name = self.class.name.split("::").last type = [: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 = [:desc] @required = .key?(:required) ? [:required] : true @type = (type || :string).to_sym @default = [:default] = [:banner] || @enum = [:enum] validate! # Trigger specific validations end |
Instance Attribute Details
#banner ⇒ Object (readonly)
Returns the value of attribute banner.
5 6 7 |
# File 'lib/thor/parser/argument.rb', line 5 def end |
#default ⇒ Object (readonly)
Returns the value of attribute default.
5 6 7 |
# File 'lib/thor/parser/argument.rb', line 5 def default @default end |
#description ⇒ Object (readonly)
Returns the value of attribute description.
5 6 7 |
# File 'lib/thor/parser/argument.rb', line 5 def description @description end |
#enum ⇒ Object (readonly)
Returns the value of attribute enum.
5 6 7 |
# File 'lib/thor/parser/argument.rb', line 5 def enum @enum end |
#name ⇒ Object (readonly) Also known as: human_name
Returns the value of attribute name.
5 6 7 |
# File 'lib/thor/parser/argument.rb', line 5 def name @name end |
#required ⇒ Object (readonly)
Returns the value of attribute required.
5 6 7 |
# File 'lib/thor/parser/argument.rb', line 5 def required @required end |
#type ⇒ Object (readonly)
Returns the value of attribute type.
5 6 7 |
# File 'lib/thor/parser/argument.rb', line 5 def type @type end |
Instance Method Details
#default_banner ⇒ Object (protected)
62 63 64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'lib/thor/parser/argument.rb', line 62 def 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 |
#required? ⇒ Boolean
31 32 33 |
# File 'lib/thor/parser/argument.rb', line 31 def required? required end |
#show_default? ⇒ Boolean
35 36 37 38 39 40 41 42 |
# File 'lib/thor/parser/argument.rb', line 35 def show_default? case default when Array, String, Hash !default.empty? else default end end |
#usage ⇒ Object
27 28 29 |
# File 'lib/thor/parser/argument.rb', line 27 def usage required? ? : "[#{banner}]" end |
#valid_type?(type) ⇒ Boolean (protected)
58 59 60 |
# File 'lib/thor/parser/argument.rb', line 58 def valid_type?(type) self.class::VALID_TYPES.include?(type.to_sym) end |
#validate! ⇒ Object (protected)
46 47 48 49 50 51 52 53 54 55 56 |
# File 'lib/thor/parser/argument.rb', line 46 def validate! if required? && !default.nil? raise ArgumentError, "An argument cannot be required and have default value." end if @enum && !@enum.is_a?(Array) raise ArgumentError, "An argument cannot have an enum other than an array." end end |