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

* eval.c (rb_Array): exclude Kernel#to_a instead of Object#to_a.

(ruby-bugs-ja:PR#483)

* lib/optparse.rb (OptionParser::Switch#parse_arg): not splat.

* lib/optparse.rb (OptionParser::Switch#conv_arg): splat if no
  conversion supplied.

* lib/optparse.rb (OptionParser::Switch::PlacedArgument#parse):
  override next switch after argument conversion.


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@3884 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
nobu 2003-05-30 05:55:50 +00:00
parent f6dd3316eb
commit 7d9628ef02
3 changed files with 40 additions and 22 deletions

View file

@ -196,17 +196,17 @@ Individual switch class.
else
m = m.to_a
s = m[0]
return nil, *m unless String === s
return nil, m unless String === s
end
raise InvalidArgument, arg unless arg.rindex(s, 0)
return nil, *m if s.length == arg.length
return nil, m if s.length == arg.length
yield(InvalidArgument, arg) # didn't match whole arg
return arg[s.length..-1], *m
return arg[s.length..-1], m
end
private :parse_arg
=begin
--- OptionParser::Switch#parse(arg, val) {semi-error handler}
=begin private
--- OptionParser::Switch#conv_arg(arg, val) {semi-error handler}
Parses argument, convert and returns ((|arg|)), ((|block|)) and
result of conversion.
: Arguments to ((|@conv|))
@ -220,14 +220,19 @@ Individual switch class.
: (({block}))
(({yields})) at semi-error condition, instead of raises exception.
=end #'#"#`#
def parse(arg, *val)
def conv_arg(arg, val = nil)
if block
val = conv.call(*val) if conv
if conv
val = conv.call(*val)
else
val = *val
end
return arg, block, val
else
return arg, nil
end
end
private :conv_arg
=begin private
--- OptionParser::Switch#summarize(sdone, ldone, width, max, indent)
@ -294,7 +299,7 @@ Switch that takes no arguments.
class NoArgument < self
def parse(arg, argv, &error)
yield(NeedlessArgument, arg) if arg
super(arg)
conv_arg(arg)
end
def self.incompatible_argument_styles(*)
end
@ -318,7 +323,7 @@ Switch that takes an argument.
raise MissingArgument if argv.empty?
arg = argv.shift
end
super(*parse_arg(arg, &error))
conv_arg(*parse_arg(arg, &error))
end
end
@ -334,9 +339,9 @@ Switch that can omit argument.
class OptionalArgument < self
def parse(arg, argv, &error)
if arg
super(*parse_arg(arg, &error))
conv_arg(*parse_arg(arg, &error))
else
super(arg)
conv_arg(arg)
end
end
end
@ -346,13 +351,13 @@ Switch that can omit argument.
if !(val = arg) and (argv.empty? or /\A-/ =~ (val = argv[0]))
return nil, block, nil
end
if (val = parse_arg(val, &error))[1]
arg = nil
opt = (val = parse_arg(val, &error))[1]
val = conv_arg(*val)
if opt
argv.shift
else
val[0] = arg
val[0] = nil
end
*val = super(*val)
argv.shift unless arg
val
end
end