This policy is not for everyone! If you are working in pure ASCII, then disable it now or you may see some false violations.

On the other hand many of us are working in a multilingual world with an extended character set, probably Unicode. In that world, patterns like m/[A-Z]/ can be a source of bugs when you really meant m/\p{Uppercase}/. This policy catches a selection of possible incorrect character class usage.

Specifically, the patterns are:

[\t\r\n\f\ ] vs. \s

[\t\r\n\ ] vs. \s (because many people forget \f)

[A-Za-z_] vs. \w

[A-Za-z] vs. \p{IsAlphabetic}

[A-Z] vs. \p{IsUppercase}

[a-z] vs. \p{IsLowercase}

[0-9] vs. \d

[^\w] vs. \W

[^\s] vs. \S


Initial development of this policy was supported by a grant from the Perl Foundation.


Chris Dolan <cdolan@cpan.org>


Copyright (c) 2007 Chris Dolan. Many rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. The full text of this license can be found in the LICENSE file included with this module