Merged revisions 80062 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/trunk

........
  r80062 | r.david.murray | 2010-04-13 16:57:40 -0400 (Tue, 13 Apr 2010) | 2 lines

  Issue #5277: Fix quote counting when parsing RFC 2231 encoded parameters.
........
This commit is contained in:
R. David Murray 2010-04-14 18:59:18 +00:00
parent a1bda34cba
commit d48739f32d
4 changed files with 13 additions and 1 deletions

View File

@ -63,7 +63,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)

View File

@ -322,6 +322,14 @@ class TestMessageAPI(TestEmailBase):
self.assertEqual(msg.get_param('name', unquote=False),
'"Jim&amp;&amp;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_field_containment(self):
unless = self.assertTrue
msg = email.message_from_string('Header: exists')

View File

@ -162,6 +162,7 @@ David Cournapeau
Steve Cousins
Alex Coventry
Matthew Dixon Cowles
Ryan Coyner
Christopher A. Craig
Laura Creighton
Simon Cross
@ -670,6 +671,7 @@ George Sakkis
Rich Salz
Kevin Samborn
Ilya Sandler
Mark Sapiro
Ty Sarna
Ben Sayer
Michael Scharf

View File

@ -312,6 +312,8 @@ C-API
Library
-------
- Issue #5277: Fix quote counting when parsing RFC 2231 encoded parameters.
- Issue #7316: the acquire() method of lock objects in the :mod:`threading`
module now takes an optional timeout argument in seconds. Timeout support
relies on the system threading library, so as to avoid a semi-busy wait