Kaydet (Commit) 4982d5d0 authored tarafından Antoine Pitrou's avatar Antoine Pitrou

#2242: utf7 decoding crashes on bogus input on some Windows/MSVC versions

üst 5255cba4
...@@ -532,6 +532,9 @@ class UnicodeTest( ...@@ -532,6 +532,9 @@ class UnicodeTest(
self.assertEqual(unicode('+3ADYAA-', 'utf-7', 'replace'), u'\ufffd') self.assertEqual(unicode('+3ADYAA-', 'utf-7', 'replace'), u'\ufffd')
# Issue #2242: crash on some Windows/MSVC versions
self.assertRaises(UnicodeDecodeError, '+\xc1'.decode, 'utf-7')
def test_codecs_utf8(self): def test_codecs_utf8(self):
self.assertEqual(u''.encode('utf-8'), '') self.assertEqual(u''.encode('utf-8'), '')
self.assertEqual(u'\u20ac'.encode('utf-8'), '\xe2\x82\xac') self.assertEqual(u'\u20ac'.encode('utf-8'), '\xe2\x82\xac')
......
...@@ -1523,7 +1523,7 @@ PyObject *PyUnicode_DecodeUTF7Stateful(const char *s, ...@@ -1523,7 +1523,7 @@ PyObject *PyUnicode_DecodeUTF7Stateful(const char *s,
while (s < e) { while (s < e) {
Py_UNICODE ch; Py_UNICODE ch;
restart: restart:
ch = *s; ch = (unsigned char) *s;
if (inShift) { if (inShift) {
if ((ch == '-') || !B64CHAR(ch)) { if ((ch == '-') || !B64CHAR(ch)) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment