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