in reply to Re^2: use locale behavior depends on charset of locale?
in thread use locale behavior depends on charset of locale?
The behaviour of \w shouldn't change based on whether it's in a char class or not.
But running with -Dr shows that these regexes compiled differently. And it looks like the problem is not in IO, I've tried the following:
if use locale is commented out it outputs:#use locale; use utf8; $a = 'é'; $a =~ m/\w/ and print "first re match\n"; $a =~ m/[\w]/ and print "second re match\n";
if use locale uncommented only:first re match second re match
My locale en_US.UTF-8 BTW.second re match
debugperl -Dr shows the following:
Without locale: Compiling REx "\w" Final program: 1: ALNUM (2) 2: END (0) stclass ALNUM minlen 1 Compiling REx "[\w]" Final program: 1: ANYOF[0-9A-Z_a-z+utf8::IsWord] (13) 13: END (0) stclass ANYOF[0-9A-Z_a-z+utf8::IsWord] minlen 1 with locale: Compiling REx "\w" Final program: 1: ALNUML (2) 2: END (0) stclass ALNUML minlen 1 Compiling REx "[\w]" Final program: 1: ANYOF{loc}[\w+utf8::IsWord] (13) 13: END (0) stclass ANYOF{loc}[\w+utf8::IsWord] minlen 1
I don't really understand this output very well, but it looks like it treats this regexes differently.
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^4: use locale behavior depends on charset of locale?
by ikegami (Patriarch) on Jul 10, 2009 at 18:35 UTC |