Extends command line arguments array (ARGV) to parse itself.
Substitution of getopts is possible as follows. Also see Gem::OptionParser#getopts
.
def getopts(*args) ($OPT = ARGV.getopts(*args)).each do |opt, val| eval "$OPT_#{opt.gsub(/[^A-Za-z0-9_]/, '_')} = val" end rescue Gem::OptionParser::ParseError end
# File rubygems/optparse/lib/optparse.rb, line 2201 def getopts(*args) options.getopts(self, *args) end
Actual Gem::OptionParser
object, automatically created if nonexistent.
If called with a block, yields the Gem::OptionParser
object and returns the result of the block. If an Gem::OptionParser::ParseError
exception occurs in the block, it is rescued, a error message printed to STDERR and nil
returned.
# File rubygems/optparse/lib/optparse.rb, line 2160 def options @optparse ||= Gem::OptionParser.new @optparse.default_argv = self block_given? or return @optparse begin yield @optparse rescue ParseError @optparse.warn $! nil end end
Sets Gem::OptionParser
object, when opt
is false
or nil
, methods Gem::OptionParser::Arguable#options
and Gem::OptionParser::Arguable#options=
are undefined. Thus, there is no ways to access the Gem::OptionParser
object via the receiver object.
# File rubygems/optparse/lib/optparse.rb, line 2143 def options=(opt) unless @optparse = opt class << self undef_method(:options) undef_method(:options=) end end end
Parses self
destructively in order and returns self
containing the rest arguments left unparsed.
# File rubygems/optparse/lib/optparse.rb, line 2176 def order!(&blk) options.order!(self, &blk) end