Bug #4245


Array index with Range inconsistency

Added by kristianpd (Kristian PD) over 11 years ago. Updated over 11 years ago.

Target version:
ruby -v:


I've come across what I believe to be a possible inconsistency in the implementation of the Range array index method. The following example describes my case:

array = [1,2,3,4,5]

a) array[0..5] // [1,2,3,4,5]
b) array[4..-1] // [5]
c) array[5..-1] // []
d) array[6..-1] // nil

additional tests
e) array[5..10] // []
f) array[6..10] // nil

I would have expected cases c and d to both return nil according to the docs: "Returns nil if the index (or starting index) are out of range."

Out of curiosity I also added tests e and f to make sure it was not related to the end of the range being -1.

Without having had a chance to check the code, my instinct here is that a comparison is possibly being done on the .count/.length of the array when building the result and comparing that to the first part of the range sequence.

Am I missing another reason for this?


Related issues 1 (0 open1 closed)

Has duplicate Ruby master - Feature #4541: Inconsistent Array.slice()Rejectedmatz (Yukihiro Matsumoto)Actions
Actions #1

Updated by marcandre (Marc-Andre Lafortune) over 11 years ago

  • Status changed from Open to Rejected

This is per spec.

Think of it this way:

[5..-1]: give me all elements after the 5th one and up to the last one. There are none, so []
[6..-1]: give me all elements after the 6th one and up to the last one. Say what? There is no 6th one, so returns nil as the given request is out of bounds.


Actions #2

Updated by sdsykes (Stephen Sykes) over 11 years ago

Yes, it's a bit odd, but it is clearly noted in the docs that this special case exists.

Marc-Andre: - For me at least I'm not sure that thinking about it as 'the element after the nth one' is totally helpful - eg:

a = []
=> []
=> nil
=> []

But whichever way you think about it, this is how it works.

From memory (it has been raised before) I think the reason was that it can make handling end conditions easier if an empty array is returned rather than nil if you hit the first non existing element after the end of the array.



Also available in: Atom PDF