From: R. David Murray Date: Tue, 13 Apr 2010 20:57:40 +0000 (+0000) Subject: Issue #5277: Fix quote counting when parsing RFC 2231 encoded parameters. X-Git-Tag: v2.7b2~286 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=661303f27e10abdb16450d96d8f55ac9c337246a;p=python Issue #5277: Fix quote counting when parsing RFC 2231 encoded parameters. --- diff --git a/Lib/email/message.py b/Lib/email/message.py index 6adb3f6343..993a1ac0f9 100644 --- a/Lib/email/message.py +++ b/Lib/email/message.py @@ -62,7 +62,7 @@ def _parseparam(s): while s[:1] == ';': s = s[1:] end = s.find(';') - while end > 0 and s.count('"', 0, end) % 2: + while end > 0 and (s.count('"', 0, end) - s.count('\\"', 0, end)) % 2: end = s.find(';', end + 1) if end < 0: end = len(s) diff --git a/Lib/email/test/test_email.py b/Lib/email/test/test_email.py index 36b308fd97..22eddd5940 100644 --- a/Lib/email/test/test_email.py +++ b/Lib/email/test/test_email.py @@ -351,6 +351,14 @@ class TestMessageAPI(TestEmailBase): self.assertEqual(msg.get_param('name', unquote=False), '"Jim&&Jill"') + def test_get_param_with_quotes(self): + msg = email.message_from_string( + 'Content-Type: foo; bar*0="baz\\"foobar"; bar*1="\\"baz"') + self.assertEqual(msg.get_param('bar'), 'baz"foobar"baz') + msg = email.message_from_string( + "Content-Type: foo; bar*0=\"baz\\\"foobar\"; bar*1=\"\\\"baz\"") + self.assertEqual(msg.get_param('bar'), 'baz"foobar"baz') + def test_has_key(self): msg = email.message_from_string('Header: exists') self.assertTrue(msg.has_key('header')) diff --git a/Misc/ACKS b/Misc/ACKS index 2a031e7153..9eeb9bb206 100644 --- a/Misc/ACKS +++ b/Misc/ACKS @@ -162,6 +162,7 @@ David Cournapeau Steve Cousins Alex Coventry Matthew Dixon Cowles +Ryan Coyner Christopher A. Craig Laura Creighton Simon Cross @@ -667,6 +668,7 @@ George Sakkis Rich Salz Kevin Samborn Ilya Sandler +Mark Sapiro Ty Sarna Ben Sayer Michael Scharf diff --git a/Misc/NEWS b/Misc/NEWS index d2b907eda5..3ea6fff835 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -83,6 +83,8 @@ Core and Builtins Library ------- +- Issue #5277: Fix quote counting when parsing RFC 2231 encoded parameters. + - Issue #8321: Give access to OpenSSL version numbers from the `ssl` module, using the new attributes `ssl.OPENSSL_VERSION`, `ssl.OPENSSL_VERSION_INFO` and `ssl.OPENSSL_VERSION_NUMBER`.