diff options
| author | ksss <[email protected]> | 2014-04-24 21:03:00 +0900 |
|---|---|---|
| committer | ksss <[email protected]> | 2014-04-24 21:08:49 +0900 |
| commit | f961d7abeb5c31bb3e8b4260f0301e882c4e34c1 (patch) | |
| tree | 1993092bb1ad0968f91fac677fa6ac242e4a72dc /mrbgems/mruby-array-ext/mrblib | |
| parent | 18c4741883b69fbd35daf9ef79592a54cc03f0e9 (diff) | |
| download | mruby-f961d7abeb5c31bb3e8b4260f0301e882c4e34c1.tar.gz mruby-f961d7abeb5c31bb3e8b4260f0301e882c4e34c1.zip | |
Array#fill fix bug when argument use range object
Diffstat (limited to 'mrbgems/mruby-array-ext/mrblib')
| -rw-r--r-- | mrbgems/mruby-array-ext/mrblib/array.rb | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/mrbgems/mruby-array-ext/mrblib/array.rb b/mrbgems/mruby-array-ext/mrblib/array.rb index 49d0db0d5..6a52e4df9 100644 --- a/mrbgems/mruby-array-ext/mrblib/array.rb +++ b/mrbgems/mruby-array-ext/mrblib/array.rb @@ -313,7 +313,7 @@ class Array def fill(arg0=nil, arg1=nil, arg2=nil, &block) if arg0 == nil && arg1 == nil && arg2 == nil && !block - raise ArgumentError, "wrong number of arguments (0 for 1..3)" + raise ArgumentError, "wrong number of arguments (0 for 1..3)" end beg = len = 0 @@ -327,7 +327,9 @@ class Array # ary.fill(range) { |index| block } -> ary beg = arg0.begin beg += self.size if beg < 0 - len = arg0.end - beg + 1 + len = arg0.end + len += self.size if len < 0 + len += 1 unless arg0.exclude_end? elsif arg0 != nil # ary.fill(start [, length] ) { |index| block } -> ary beg = arg0 @@ -342,20 +344,22 @@ class Array if arg0 != nil && arg1 == nil && arg2 == nil # ary.fill(obj) -> ary beg = 0 - len = self.size + len = self.size elsif arg0 != nil && arg1 != nil && arg1.respond_to?(:begin) && arg1.respond_to?(:end) # ary.fill(obj, range ) -> ary - len = self.size beg = arg1.begin - len = arg1.end - beg + 1 + beg += self.size if beg < 0 + len = arg1.end + len += self.size if len < 0 + len += 1 unless arg1.exclude_end? elsif arg0 != nil && arg1 != nil # ary.fill(obj, start [, length]) -> ary beg = arg1 beg += self.size if beg < 0 - if arg2 == nil + if arg2 == nil len = self.size else - len = arg1 + arg2 + len = beg + arg2 end end end |
