Bug #20421
closed
String#index and String#byteindex don't clear `$~` when offset > size (or bytesize)
Added by andrykonchin (Andrew Konchin) 8 months ago.
Updated 6 months ago.
Description
When String#index and String#byteindex are called with Regexp and offset they clear $~
(that contains result of the last Regexp matching) when offset < -size. But they don't clear $~
when offset > size what seems inconsistent:
"a".index(/a/)
p $~ # => #<MatchData "a">
string = "blablabla"
string.index(/bla/, string.length + 1)
p $~ # => #<MatchData "a">
- Description updated (diff)
- Status changed from Open to Closed
- Backport changed from 3.0: UNKNOWN, 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: UNKNOWN to 3.0: UNKNOWN, 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: DONTNEED
- Backport changed from 3.0: UNKNOWN, 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: DONTNEED to 3.0: REQUIRED, 3.1: REQUIRED, 3.2: REQUIRED, 3.3: DONTNEED
Given this is a clear bug (which can break programs' logic) I think it's good to backport.
We should also add a test so this doesn't regress on 3.3 & master, that seems fine as a ruby_bug
spec in ruby/spec.
- Backport changed from 3.0: REQUIRED, 3.1: REQUIRED, 3.2: REQUIRED, 3.3: DONTNEED to 3.1: REQUIRED, 3.2: REQUIRED, 3.3: DONTNEED
I got a ruby-bug spec at https://github.com/ruby/ruby/pull/10750
As for 9dcdffb8bf8a3654fd78bf1a58b30c8e13888a7a, it might make sense to make a more targeted fix for backport, as this is a more general refactor.
- Backport changed from 3.1: REQUIRED, 3.2: REQUIRED, 3.3: DONTNEED to 3.1: REQUIRED, 3.2: DONE, 3.3: DONTNEED
Thank you for the PR. I agree that the patch is good to backport. PR merged at 449899b38314d0ecbe61e42d34398bdf2561b8e9.
Also available in: Atom
PDF
Like0
Like0Like0Like0Like0Like0Like0Like0Like0