1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00

* lib/optparse/ac.rb: autoconf-like options.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@35214 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
nobu 2012-04-02 04:25:14 +00:00
parent 38b8afcf5a
commit a59bfa76e5
3 changed files with 117 additions and 0 deletions

View file

@ -1,3 +1,7 @@
Mon Apr 2 13:25:08 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
* lib/optparse/ac.rb: autoconf-like options.
Mon Apr 2 10:34:00 2012 eregon <eregontp@gmail.com>
* string.c (rb_str_start_with, rb_str_end_with): raise an error if

50
lib/optparse/ac.rb Normal file
View file

@ -0,0 +1,50 @@
require 'optparse'
class OptionParser::AC < OptionParser
private
def _check_ac_args(name, block)
unless /\A\w[-\w]*\z/ =~ name
raise ArgumentError, name
end
unless block
raise ArgumentError, "no block given", ParseError.filter_backtrace(caller)
end
end
def _ac_arg_enable(prefix, name, help_string, block)
_check_ac_args(name, block)
sdesc = []
ldesc = ["--#{prefix}-#{name}"]
desc = [help_string]
q = name.downcase
enable = Switch::NoArgument.new(nil, proc {true}, sdesc, ldesc, nil, desc, block)
disable = Switch::NoArgument.new(nil, proc {false}, sdesc, ldesc, nil, desc, block)
top.append(enable, [], ["enable-" + q], disable, ['disable-' + q])
enable
end
public
def ac_arg_enable(name, help_string, &block)
_ac_arg_enable("enable", name, help_string, block)
end
def ac_arg_disable(name, help_string, &block)
_ac_arg_enable("disable", name, help_string, block)
end
def ac_arg_with(name, help_string, &block)
_check_ac_args(name, block)
sdesc = []
ldesc = ["--with-#{name}"]
desc = [help_string]
q = name.downcase
with = Switch::PlacedArgument.new(*search(:atype, String), sdesc, ldesc, nil, desc, block)
without = Switch::NoArgument.new(nil, proc {}, sdesc, ldesc, nil, desc, block)
top.append(with, [], ["with-" + q], without, ['without-' + q])
with
end
end

View file

@ -0,0 +1,63 @@
require 'test/unit'
require 'optparse/ac'
class TestOptionParser < Test::Unit::TestCase; end
class TestOptionParser::AutoConf < Test::Unit::TestCase
def setup
@opt = OptionParser::AC.new
@foo = @bar = self.class
@opt.ac_arg_enable("foo", "foo option") {|x| @foo = x}
@opt.ac_arg_disable("bar", "bar option") {|x| @bar = x}
@opt.ac_arg_with("zot", "zot option") {|x| @zot = x}
end
class DummyOutput < String
alias write <<
end
def no_error(*args)
$stderr, stderr = DummyOutput.new, $stderr
assert_nothing_raised(*args) {return yield}
ensure
stderr, $stderr = $stderr, stderr
$!.backtrace.delete_if {|e| /\A#{Regexp.quote(__FILE__)}:#{__LINE__-2}/o =~ e} if $!
assert_empty(stderr)
end
def test_enable
@opt.parse!(%w"--enable-foo")
assert_equal(true, @foo)
@opt.parse!(%w"--enable-bar")
assert_equal(true, @bar)
end
def test_disable
@opt.parse!(%w"--disable-foo")
assert_equal(false, @foo)
@opt.parse!(%w"--disable-bar")
assert_equal(false, @bar)
end
def test_with
@opt.parse!(%w"--with-zot=foobar")
assert_equal("foobar", @zot)
@opt.parse!(%w"--without-zot")
assert_nil(@zot)
end
def test_without
@opt.parse!(%w"--without-zot")
assert_nil(@zot)
assert_raise(OptionParser::NeedlessArgument) {@opt.parse!(%w"--without-zot=foobar")}
end
def test_help
help = @opt.help
assert_match(/--enable-foo/, help)
assert_match(/--disable-bar/, help)
assert_match(/--with-zot/, help)
assert_not_match(/--disable-foo/, help)
assert_not_match(/--enable-bar/, help)
assert_not_match(/--without/, help)
end
end