2015-12-16 00:07:31 -05:00
|
|
|
# frozen_string_literal: false
|
2022-01-04 02:32:45 -05:00
|
|
|
require_relative '../optparse'
|
2012-04-02 00:25:14 -04:00
|
|
|
|
|
|
|
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
|
|
|
|
|
2019-05-15 04:22:25 -04:00
|
|
|
ARG_CONV = proc {|val| val.nil? ? true : val}
|
|
|
|
|
2012-04-02 00:25:14 -04:00
|
|
|
def _ac_arg_enable(prefix, name, help_string, block)
|
|
|
|
_check_ac_args(name, block)
|
|
|
|
|
|
|
|
sdesc = []
|
|
|
|
ldesc = ["--#{prefix}-#{name}"]
|
|
|
|
desc = [help_string]
|
|
|
|
q = name.downcase
|
2019-05-15 04:22:25 -04:00
|
|
|
ac_block = proc {|val| block.call(ARG_CONV.call(val))}
|
|
|
|
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)
|
2012-04-02 00:25:14 -04:00
|
|
|
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
|