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:
parent
38b8afcf5a
commit
a59bfa76e5
3 changed files with 117 additions and 0 deletions
|
@ -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>
|
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
|
* string.c (rb_str_start_with, rb_str_end_with): raise an error if
|
||||||
|
|
50
lib/optparse/ac.rb
Normal file
50
lib/optparse/ac.rb
Normal 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
|
63
test/optparse/test_autoconf.rb
Normal file
63
test/optparse/test_autoconf.rb
Normal 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
|
Loading…
Add table
Add a link
Reference in a new issue