summaryrefslogtreecommitdiff
path: root/Lib/base64.py
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2013-05-19 11:41:15 +0300
committerSerhiy Storchaka <storchaka@gmail.com>2013-05-19 11:41:15 +0300
commit2c3f2f19df0939744774370369b55e3ca214040c (patch)
tree31fc9f9cf7dd55b27c1f9202c5eeb08a4f33e897 /Lib/base64.py
parent08231a9c6aeb8315803ede4ba3fecd378cfb1e3f (diff)
downloadcpython-git-2c3f2f19df0939744774370369b55e3ca214040c.tar.gz
Issue #17812: Fixed quadratic complexity of base64.b32encode().
Diffstat (limited to 'Lib/base64.py')
-rwxr-xr-xLib/base64.py12
1 files changed, 6 insertions, 6 deletions
diff --git a/Lib/base64.py b/Lib/base64.py
index 4042f004fd..6bcdff63d4 100755
--- a/Lib/base64.py
+++ b/Lib/base64.py
@@ -166,7 +166,7 @@ def b32encode(s):
if leftover:
s = s + bytes(5 - leftover) # Don't use += !
quanta += 1
- encoded = bytes()
+ encoded = bytearray()
for i in range(quanta):
# c1 and c2 are 16 bits wide, c3 is 8 bits wide. The intent of this
# code is to process the 40 bits in units of 5 bits. So we take the 1
@@ -187,14 +187,14 @@ def b32encode(s):
])
# Adjust for any leftover partial quanta
if leftover == 1:
- return encoded[:-6] + b'======'
+ encoded[-6:] = b'======'
elif leftover == 2:
- return encoded[:-4] + b'===='
+ encoded[-4:] = b'===='
elif leftover == 3:
- return encoded[:-3] + b'==='
+ encoded[-3:] = b'==='
elif leftover == 4:
- return encoded[:-1] + b'='
- return encoded
+ encoded[-1:] = b'='
+ return bytes(encoded)
def b32decode(s, casefold=False, map01=None):