add _massage_options() to simplify parse()

This commit is contained in:
Josh Holtrop 2013-01-21 22:11:57 -05:00
parent ef860a8eee
commit 40ecadd056

View File

@ -13,38 +13,29 @@ module Yawpa
module_function
def parse(params, options)
options = _massage_options(options)
opts = {}
args = []
i = 0
while i < params.length
param = params[i]
if param =~ /^(--?)([^=]+)(?:=(.+))?$/
leader, param_name, val = $1, $2, $3
case leader.length
when 2
param_key = if options[param_name]
param_name
elsif options[param_name.to_sym]
param_name.to_sym
else
nil
end
if param_key.nil?
if param =~ /^--([^=]+)(?:=(.+))?$/
param_name, val = $1, $2
if options[param_name].nil?
raise UnknownOptionException.new("Unknown option '#{param_name}'")
end
opt_config = options[param_key]
nargs = opt_config[:nargs] || 0
if nargs == 0
opt_config = options[param_name]
param_key = opt_config[:key]
if opt_config[:nargs].last == 0
opts[param_key] = true
else
nargs = (nargs..nargs) if nargs.class == Fixnum
opts[param_key] = []
opts[param_key] << val if val
if opts[param_key].length < nargs.last
gathered = _gather(i + 1, nargs.last - opts[param_key].length, params)
if opts[param_key].length < opt_config[:nargs].last
gathered = _gather(i + 1, opt_config[:nargs].last - opts[param_key].length, params)
i += gathered.length
opts[param_key] += gathered
if opts[param_key].length < nargs.first
if opts[param_key].length < opt_config[:nargs].first
raise InvalidArgumentsException.new("Not enough arguments supplied for option '#{param_name}'")
end
end
@ -52,7 +43,6 @@ module Yawpa
opts[param_key] = opts[param_key].first
end
end
end
else
args << params[i]
end
@ -73,4 +63,16 @@ module Yawpa
end
result
end
def _massage_options(options)
{}.tap do |newopts|
options.each_pair do |k, v|
newkey = k.to_s
newopts[newkey] = {key: k}
nargs = v[:nargs] || 0
nargs = (nargs..nargs) if nargs.class == Fixnum
newopts[newkey][:nargs] = nargs
end
end
end
end