summaryrefslogtreecommitdiff
path: root/regexec.c
diff options
context:
space:
mode:
authorKarl Williamson <public@khwilliamson.com>2010-10-31 13:31:13 -0600
committerFather Chrysostomos <sprout@cpan.org>2010-10-31 16:16:41 -0700
commite051a21d2458b5ce83206336c2ee2d39013b8d1b (patch)
treef6f243ace41117be2381d3f35922821a886012c4 /regexec.c
parent7cdde5444c9ad8cccf237ec340ddb54f58ce3cf0 (diff)
downloadperl-e051a21d2458b5ce83206336c2ee2d39013b8d1b.tar.gz
reginclass: Remove redundant test
The previous re-ordering of this function makes it clear that this test doesn't do anything. It is testing the charclass bitmap, but that was already done in the re-ordered block from a previous commit, so if it didn't succeed there, it won't succeed here. In fact, trying to understand why this code was here was what led me to figure out that it wasn't, and that things could be sped up by doing the reordering.
Diffstat (limited to 'regexec.c')
-rw-r--r--regexec.c9
1 files changed, 3 insertions, 6 deletions
diff --git a/regexec.c b/regexec.c
index 3ca84516b7..2c9b852754 100644
--- a/regexec.c
+++ b/regexec.c
@@ -6296,13 +6296,10 @@ S_reginclass(pTHX_ const regexp * const prog, register const regnode * const n,
/* If the bitmap didn't (or couldn't) match, and something outside the
* bitmap could match, try that */
if (! match && utf8_target || (flags & ANYOF_UNICODE)) {
- if (utf8_target && !ANYOF_RUNTIME(n)) {
- if (c < 256 && ANYOF_BITMAP_TEST(n, c))
- match = TRUE;
- }
- if (!match && utf8_target && (flags & ANYOF_UNICODE_ALL) && c >= 256)
+ if (utf8_target && (flags & ANYOF_UNICODE_ALL) && c >= 256) {
match = TRUE;
- if (!match) {
+ }
+ else {
AV *av;
SV * const sw = regclass_swash(prog, n, TRUE, 0, (SV**)&av);