diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2013-08-19 23:19:49 +0300 |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2013-08-19 23:19:49 +0300 |
commit | 228c194596b8e357ae586a76ee392740107bd663 (patch) | |
tree | 5254ce79c68d6edbc4da2dc2a071064737d14a9d | |
parent | 75674ae8ddc9ab83200919de6f75ead695be9bcb (diff) | |
parent | 98985a1980304b3c8fee9b9efdac015c6098bd67 (diff) | |
download | cpython-git-228c194596b8e357ae586a76ee392740107bd663.tar.gz |
Issue #2537: Remove breaked check which prevented valid regular expressions.
Patch by Meador Inge.
See also issue #18647.
-rw-r--r-- | Lib/sre_compile.py | 2 | ||||
-rw-r--r-- | Lib/test/test_re.py | 10 |
2 files changed, 10 insertions, 2 deletions
diff --git a/Lib/sre_compile.py b/Lib/sre_compile.py index 429d7793b2..d6dc60c73e 100644 --- a/Lib/sre_compile.py +++ b/Lib/sre_compile.py @@ -351,8 +351,6 @@ def _optimize_unicode(charset, fixup): def _simple(av): # check if av is a "simple" operator lo, hi = av[2].getwidth() - #if lo == 0 and hi == MAXREPEAT: - # raise error("nothing to repeat") return lo == hi == 1 and av[2][0][0] != SUBPATTERN def _compile_info(code, pattern, flags): diff --git a/Lib/test/test_re.py b/Lib/test/test_re.py index c84d4edeb4..2104437408 100644 --- a/Lib/test/test_re.py +++ b/Lib/test/test_re.py @@ -1051,6 +1051,16 @@ class ReTests(unittest.TestCase): [b'xyz'], msg=pattern) + def test_bug_2537(self): + # issue 2537: empty submatches + for outer_op in ('{0,}', '*', '+', '{1,187}'): + for inner_op in ('{0,}', '*', '?'): + r = re.compile("^((x|y)%s)%s" % (inner_op, outer_op)) + m = r.match("xyyzy") + self.assertEqual(m.group(0), "xyy") + self.assertEqual(m.group(1), "") + self.assertEqual(m.group(2), "y") + def run_re_tests(): from test.re_tests import tests, SUCCEED, FAIL, SYNTAX_ERROR if verbose: |