diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2020-10-16 18:29:29 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2020-10-29 10:43:08 +0900 |
| commit | d35677f213feb3d1a3fe38a763c3dd765e440549 (patch) | |
| tree | 07341e458e531d85943ec2c92078de2b526b5152 /mrbgems/mruby-range-ext/mrblib | |
| parent | 76eafa46082e43b33b107e845ebbfaa6ebae3155 (diff) | |
| download | mruby-d35677f213feb3d1a3fe38a763c3dd765e440549.tar.gz mruby-d35677f213feb3d1a3fe38a763c3dd765e440549.zip | |
Implement `Range#last` in `mruby-range-ext` in Ruby.
This reduce unnecessary calls of `mrb_funcall()`.
Diffstat (limited to 'mrbgems/mruby-range-ext/mrblib')
| -rw-r--r-- | mrbgems/mruby-range-ext/mrblib/range.rb | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/mrbgems/mruby-range-ext/mrblib/range.rb b/mrbgems/mruby-range-ext/mrblib/range.rb index 018bd7094..5eeb802c1 100644 --- a/mrbgems/mruby-range-ext/mrblib/range.rb +++ b/mrbgems/mruby-range-ext/mrblib/range.rb @@ -26,6 +26,32 @@ class Range ary end + ## + # call-seq: + # rng.last -> obj + # rng.last(n) -> an_array + # + # Returns the last object in the range, + # or an array of the last +n+ elements. + # + # Note that with no arguments +last+ will return the object that defines + # the end of the range even if #exclude_end? is +true+. + # + # (10..20).last #=> 20 + # (10...20).last #=> 20 + # (10..20).last(3) #=> [18, 19, 20] + # (10...20).last(3) #=> [17, 18, 19] + def last(*args) + raise RangeError, "cannot get the first element of beginless range" if self.end.nil? + return self.end if args.empty? + + raise ArgumentError, "wrong number of arguments (given #{args.length}, expected 1)" unless args.length == 1 + nv = args[0] + n = nv.__to_int + raise ArgumentError, "negative array size (or size too big)" unless 0 <= n + return self.to_a.last(nv) + end + def max(&block) val = self.begin last = self.end |
