mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
parent
f54aa6c5b2
commit
c9b28fd7ae
2 changed files with 12 additions and 2 deletions
|
@ -13,6 +13,8 @@ class OptionParser::AC < OptionParser
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
ARG_CONV = proc {|val| val.nil? ? true : val}
|
||||||
|
|
||||||
def _ac_arg_enable(prefix, name, help_string, block)
|
def _ac_arg_enable(prefix, name, help_string, block)
|
||||||
_check_ac_args(name, block)
|
_check_ac_args(name, block)
|
||||||
|
|
||||||
|
@ -20,8 +22,9 @@ class OptionParser::AC < OptionParser
|
||||||
ldesc = ["--#{prefix}-#{name}"]
|
ldesc = ["--#{prefix}-#{name}"]
|
||||||
desc = [help_string]
|
desc = [help_string]
|
||||||
q = name.downcase
|
q = name.downcase
|
||||||
enable = Switch::NoArgument.new(nil, proc {true}, sdesc, ldesc, nil, desc, block)
|
ac_block = proc {|val| block.call(ARG_CONV.call(val))}
|
||||||
disable = Switch::NoArgument.new(nil, proc {false}, sdesc, ldesc, nil, desc, block)
|
enable = Switch::PlacedArgument.new(nil, ARG_CONV, sdesc, ldesc, nil, desc, ac_block)
|
||||||
|
disable = Switch::NoArgument.new(nil, proc {false}, sdesc, ldesc, nil, desc, ac_block)
|
||||||
top.append(enable, [], ["enable-" + q], disable, ['disable-' + q])
|
top.append(enable, [], ["enable-" + q], disable, ['disable-' + q])
|
||||||
enable
|
enable
|
||||||
end
|
end
|
||||||
|
|
|
@ -32,6 +32,13 @@ class TestOptionParser::AutoConf < Test::Unit::TestCase
|
||||||
assert_equal(true, @bar)
|
assert_equal(true, @bar)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_enable_value
|
||||||
|
@opt.parse!(%w"--enable-foo=A")
|
||||||
|
assert_equal("A", @foo)
|
||||||
|
@opt.parse!(%w"--enable-bar=B")
|
||||||
|
assert_equal("B", @bar)
|
||||||
|
end
|
||||||
|
|
||||||
def test_disable
|
def test_disable
|
||||||
@opt.parse!(%w"--disable-foo")
|
@opt.parse!(%w"--disable-foo")
|
||||||
assert_equal(false, @foo)
|
assert_equal(false, @foo)
|
||||||
|
|
Loading…
Add table
Reference in a new issue