Class: Thor::Option
Overview
:nodoc:
Constant Summary collapse
- VALID_TYPES =
[:boolean, :numeric, :hash, :array, :string]
Instance Attribute Summary collapse
-
#aliases ⇒ Object
readonly
Returns the value of attribute aliases.
-
#group ⇒ Object
readonly
Returns the value of attribute group.
-
#hide ⇒ Object
readonly
Returns the value of attribute hide.
-
#incremental ⇒ Object
readonly
Returns the value of attribute incremental.
-
#lazy_default ⇒ Object
readonly
Returns the value of attribute lazy_default.
Attributes inherited from Argument
#banner, #default, #description, #enum, #name, #required, #type
Class Method Summary collapse
-
.parse(key, value) ⇒ Object
This parse quick options given as method_options.
Instance Method Summary collapse
- #human_name ⇒ Object
-
#incremental? ⇒ Boolean
Is this numeric option incremental?.
-
#initialize(name, options = {}) ⇒ Option
constructor
A new instance of Option.
- #switch_name ⇒ Object
- #usage(padding = 0) ⇒ Object
Methods inherited from Argument
Constructor Details
#initialize(name, options = {}) ⇒ Option
Returns a new instance of Option.
7 8 9 10 11 12 13 14 15 |
# File 'lib/thor-plus/parser/option.rb', line 7 def initialize(name, = {}) [:required] = false unless .key?(:required) super @lazy_default = [:lazy_default] @group = [:group].to_s.capitalize if [:group] @aliases = Array([:aliases]) @hide = [:hide] @incremental = [:incremental] end |
Instance Attribute Details
#aliases ⇒ Object (readonly)
Returns the value of attribute aliases.
3 4 5 |
# File 'lib/thor-plus/parser/option.rb', line 3 def aliases @aliases end |
#group ⇒ Object (readonly)
Returns the value of attribute group.
3 4 5 |
# File 'lib/thor-plus/parser/option.rb', line 3 def group @group end |
#hide ⇒ Object (readonly)
Returns the value of attribute hide.
3 4 5 |
# File 'lib/thor-plus/parser/option.rb', line 3 def hide @hide end |
#incremental ⇒ Object (readonly)
Returns the value of attribute incremental.
3 4 5 |
# File 'lib/thor-plus/parser/option.rb', line 3 def incremental @incremental end |
#lazy_default ⇒ Object (readonly)
Returns the value of attribute lazy_default.
3 4 5 |
# File 'lib/thor-plus/parser/option.rb', line 3 def lazy_default @lazy_default end |
Class Method Details
.parse(key, value) ⇒ Object
This parse quick options given as method_options. It makes several assumptions, but you can be more specific using the option method.
parse :foo => "bar"
#=> Option foo with default value bar
parse [:foo, :baz] => "bar"
#=> Option foo with default value bar and alias :baz
parse :foo => :required
#=> Required option foo without default value
parse :foo => 2
#=> Option foo with default value 2 and type numeric
parse :foo => :numeric
#=> Option foo without default value and type numeric
parse :foo => true
#=> Option foo with default value true and type boolean
The valid types are :boolean, :numeric, :hash, :array and :string. If none is given a default type is assumed. This default type accepts arguments as string (–foo=value) or booleans (just –foo).
By default all options are optional, unless :required is given.
51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 |
# File 'lib/thor-plus/parser/option.rb', line 51 def self.parse(key, value) # rubocop:disable MethodLength if key.is_a?(Array) name, *aliases = key else name, aliases = key, [] end name = name.to_s default = value type = case value when Symbol default = nil if VALID_TYPES.include?(value) value elsif required = (value == :required) # rubocop:disable AssignmentInCondition :string end when TrueClass, FalseClass :boolean when Numeric :numeric when Hash, Array, String value.class.name.downcase.to_sym end new(name.to_s, :required => required, :type => type, :default => default, :aliases => aliases) end |
Instance Method Details
#human_name ⇒ Object
83 84 85 |
# File 'lib/thor-plus/parser/option.rb', line 83 def human_name @human_name ||= dasherized? ? undasherize(name) : name end |
#incremental? ⇒ Boolean
Is this numeric option incremental?
e.g. -vvv = 3
20 21 22 |
# File 'lib/thor-plus/parser/option.rb', line 20 def incremental? numeric? && incremental end |
#switch_name ⇒ Object
79 80 81 |
# File 'lib/thor-plus/parser/option.rb', line 79 def switch_name @switch_name ||= dasherized? ? name : dasherize(name) end |
#usage(padding = 0) ⇒ Object
87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 |
# File 'lib/thor-plus/parser/option.rb', line 87 def usage(padding = 0) sample = if && !.to_s.empty? "#{switch_name}=#{}" else switch_name end sample = "[#{sample}]" unless required? if boolean? sample << ", [#{dasherize("no-" + human_name)}]" unless name == "force" or name.start_with?("no-") end if aliases.empty? (" " * padding) << sample else "#{aliases.join(', ')}, #{sample}" end end |