Class: Mercenary::Option

Inherits:
Object
  • Object
show all
Defined in:
lib/mercenary/option.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(config_key, info) ⇒ Option

Public: Create a new Option

config_key - the key in the config hash to which the value of this option

will map

info - an array containing first the switches, then an optional

return type (e.g. Array), then a description of the option

Returns nothing



13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# File 'lib/mercenary/option.rb', line 13

def initialize(config_key, info)
  @config_key  = config_key
  while arg = info.shift
    begin
      @return_type = Object.const_get("#{arg}")
      next
    rescue NameError
    end
    if arg.start_with?("-")
      if arg.start_with?("--")
        @long = arg
      else
        @short = arg
      end
      next
    end
    @description = arg
  end
end

Instance Attribute Details

#config_keyObject (readonly)

Returns the value of attribute config_key.



3
4
5
# File 'lib/mercenary/option.rb', line 3

def config_key
  @config_key
end

#descriptionObject (readonly)

Returns the value of attribute description.



3
4
5
# File 'lib/mercenary/option.rb', line 3

def description
  @description
end

#longObject (readonly)

Returns the value of attribute long.



3
4
5
# File 'lib/mercenary/option.rb', line 3

def long
  @long
end

#return_typeObject (readonly)

Returns the value of attribute return_type.



3
4
5
# File 'lib/mercenary/option.rb', line 3

def return_type
  @return_type
end

#shortObject (readonly)

Returns the value of attribute short.



3
4
5
# File 'lib/mercenary/option.rb', line 3

def short
  @short
end

Instance Method Details

#eql?(other) ⇒ Boolean

Public: Check equivalence of two Options based on equivalence of their

instance variables

Returns true if all the instance variables are equal, false otherwise

Returns:

  • (Boolean)


71
72
73
74
75
76
# File 'lib/mercenary/option.rb', line 71

def eql?(other)
  return false unless self.class.eql?(other.class)
  instance_variables.map do |var|
    instance_variable_get(var).eql?(other.instance_variable_get(var))
  end.all?
end

#for_option_parserObject

Public: Fetch the array containing the info OptionParser is interested in

Returns the array which OptionParser#on wants



36
37
38
# File 'lib/mercenary/option.rb', line 36

def for_option_parser
  [short, long, return_type, description].flatten.reject{ |o| o.to_s.empty? }
end

#formatted_switchesObject

Public: Build a beautifully-formatted string representation of the switches

Returns a formatted string representation of the switches



51
52
53
54
55
56
# File 'lib/mercenary/option.rb', line 51

def formatted_switches
  [
    switches.first.rjust(10),
    switches.last.ljust(13)
  ].join(", ").gsub(/ , /, '   ').gsub(/,   /, '    ')
end

#hashObject

Public: Hash based on the hash value of instance variables

Returns a Fixnum which is unique to this Option based on the instance variables



61
62
63
64
65
# File 'lib/mercenary/option.rb', line 61

def hash
  instance_variables.map do |var|
    instance_variable_get(var).hash
  end.reduce(:&)
end

#switchesObject

Public: Fetch an array of switches, including the short and long versions

Returns an array of two strings. An empty string represents no switch in that position.



82
83
84
# File 'lib/mercenary/option.rb', line 82

def switches
  [short, long].map(&:to_s)
end

#to_sObject

Public: Build a string representation of this option including the

switches and description

Returns a string representation of this option



44
45
46
# File 'lib/mercenary/option.rb', line 44

def to_s
  "#{formatted_switches}  #{description}"
end