summaryrefslogtreecommitdiffstats
path: root/Lib/email/Generator.py
diff options
context:
space:
mode:
authorBarry Warsaw <barry@python.org>2003-05-29 19:39:33 (GMT)
committerBarry Warsaw <barry@python.org>2003-05-29 19:39:33 (GMT)
commitdb6888b7dfa25e2b298f6e419673f137fdcce347 (patch)
tree9996c27cf14bfc0e6f9e1956813f2bb92c61c32b /Lib/email/Generator.py
parent65f8cedd4a9820e5d069ece0194b7da0b1e4e33c (diff)
downloadcpython-db6888b7dfa25e2b298f6e419673f137fdcce347.zip
cpython-db6888b7dfa25e2b298f6e419673f137fdcce347.tar.gz
cpython-db6888b7dfa25e2b298f6e419673f137fdcce347.tar.bz2
_make_boundary(): Fix for SF bug #745478, broken boundary calculation
in some locales. This code simplifies the boundary algorithm to use randint() which is what we wanted anyway. Bump package version to 2.5.3. Backport candidate for Python 2.2.3
Diffstat (limited to 'Lib/email/Generator.py')
-rw-r--r--Lib/email/Generator.py8
1 files changed, 6 insertions, 2 deletions
diff --git a/Lib/email/Generator.py b/Lib/email/Generator.py
index 9cce51c..6f17963 100644
--- a/Lib/email/Generator.py
+++ b/Lib/email/Generator.py
@@ -5,6 +5,7 @@
"""
import re
+import sys
import time
import locale
import random
@@ -356,11 +357,14 @@ class DecodedGenerator(Generator):
# Helper
+_width = len(repr(sys.maxint-1))
+_fmt = '%%0%dd' % _width
+
def _make_boundary(text=None):
# Craft a random boundary. If text is given, ensure that the chosen
# boundary doesn't appear in the text.
- dp = locale.localeconv().get('decimal_point', '.')
- boundary = ('=' * 15) + repr(random.random()).split(dp)[1] + '=='
+ token = random.randint(0, sys.maxint-1)
+ boundary = ('=' * 15) + (_fmt % token) + '=='
if text is None:
return boundary
b = boundary