
Regexp::Compare - partial ordering for regular expressions

use Regexp::Compare qw(is_less_or_equal);
if (is_less_or_equal($rx[i], $rx[j])) {
print "duplicate: $rx[i]\n";
}

This module implements a function comparing regular expressions: it returns true if all strings matched by the first regexp are also matched by the second. It's meant to be used for optimization of blacklists implemented by regular expressions (like, for example, http://www.communitywiki.org/cw/BannedContent ).
Both arguments of is_less_or_equal are strings - IOW the call
$rv = is_less_or_equal($rx, /hardcoded/i);
probably won't do what you want - use
$rv = is_less_or_equal($rx, '(?i:hardcoded)');
instead.
False return value does not imply that there's a string matched by the first regexp which isn't matched by the second - many regular expressions (i.e. those containing Perl code) are impossible to compare, and this module doesn't even implement all possible comparisons.


Vaclav Barta, <vbar@comp.cz>

Copyright (C) 2006 - 2008 by Vaclav Barta
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.7 or, at your option, any later version of Perl 5 you may have available.
