summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2013-08-19 19:53:04 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2013-08-19 19:53:04 (GMT)
commit20c3dd25c01d0154c611f5acea72a48f3e09b4d7 (patch)
tree9787c70465d8b7941304c04bc30581d907219b27
parent13aa7818ac01bbbc26e69108cda6f67993c69c5f (diff)
parent9d96542b6d1f5c470a60f21d0d8b4ee3edcb17f9 (diff)
downloadcpython-20c3dd25c01d0154c611f5acea72a48f3e09b4d7.zip
cpython-20c3dd25c01d0154c611f5acea72a48f3e09b4d7.tar.gz
cpython-20c3dd25c01d0154c611f5acea72a48f3e09b4d7.tar.bz2
Issue #18647: Correctly bound calculated min/max width of a subexpression.
Now max width is MAXREPEAT on 32- and 64-bit platforms when one of subexpressions is unbounded repetition.
-rw-r--r--Lib/sre_parse.py8
1 files changed, 4 insertions, 4 deletions
diff --git a/Lib/sre_parse.py b/Lib/sre_parse.py
index 9e0501f..f26229f 100644
--- a/Lib/sre_parse.py
+++ b/Lib/sre_parse.py
@@ -148,7 +148,7 @@ class SubPattern:
REPEATCODES = (MIN_REPEAT, MAX_REPEAT)
for op, av in self.data:
if op is BRANCH:
- i = sys.maxsize
+ i = MAXREPEAT - 1
j = 0
for av in av[1]:
l, h = av.getwidth()
@@ -166,14 +166,14 @@ class SubPattern:
hi = hi + j
elif op in REPEATCODES:
i, j = av[2].getwidth()
- lo = lo + int(i) * av[0]
- hi = hi + int(j) * av[1]
+ lo = lo + i * av[0]
+ hi = hi + j * av[1]
elif op in UNITCODES:
lo = lo + 1
hi = hi + 1
elif op == SUCCESS:
break
- self.width = int(min(lo, sys.maxsize)), int(min(hi, sys.maxsize))
+ self.width = min(lo, MAXREPEAT - 1), min(hi, MAXREPEAT)
return self.width
class Tokenizer: