Project

General

Profile

Actions

Bug #18010

open

Character class with single character gets case-folded with following string

Added by jirkamarsik (Jirka Marsik) over 3 years ago.

Status:
Open
Assignee:
-
Target version:
-
ruby -v:
ruby 3.0.1p64 (2021-04-05 revision 0fb782ee38) [x86_64-linux]
[ruby-core:104423]

Description

irb(main):001:0> /ff/i.match("\ufb00")
=> #<MatchData "ff">
irb(main):002:0> /[f]f/i.match("\ufb00")
=> #<MatchData "ff">
irb(main):003:0> /f[f]/i.match("\ufb00")
=> nil
irb(main):004:0> /[f][f]/i.match("\ufb00")
=> nil
irb(main):005:0> /(?:f)f/i.match("\ufb00")
=> nil
irb(main):006:0> /f(?:f)/i.match("\ufb00")
=> nil
irb(main):007:0> /(?:f)(?:f)/i.match("\ufb00")
=> nil

In the above, singleton character classes ([...]) and even parentheses ((?:...)) break up string literals, forcing each separate substring to be matched against separately. However, in the one case when a singleton character class precedes a string, it is joined with it as an optimization. However, this optimization ends up changing the semantics of the Regexp.


Related issues 1 (1 open0 closed)

Related to Ruby master - Bug #17989: Case insensitive Regexps do not handle characters with overlapping case foldingsOpenActions
Actions

Also available in: Atom PDF

Like0
Like0