diff --git a/mercurial/mail.py b/mercurial/mail.py --- a/mercurial/mail.py +++ b/mercurial/mail.py @@ -362,13 +362,13 @@ def headencode(ui, s, charsets=None, dis if not display: # split into words? s, cs = _encode(ui, s, charsets) - return str(email.header.Header(s, cs)) + return encoding.strtolocal(email.header.Header(s, cs).encode()) return s def _addressencode(ui, name, addr, charsets=None): assert isinstance(addr, bytes) - name = headencode(ui, name, charsets) + name = encoding.strfromlocal(headencode(ui, name, charsets)) try: acc, dom = addr.split(b'@') acc.decode('ascii') diff --git a/tests/test-patchbomb.t b/tests/test-patchbomb.t --- a/tests/test-patchbomb.t +++ b/tests/test-patchbomb.t @@ -512,7 +512,8 @@ mime encoded mbox (base64): X-Mercurial-Series-Id: <909a00e13e9d78b575ae.240@test-hostname> User-Agent: Mercurial-patchbomb/* (glob) Date: Thu, 01 Jan 1970 00:04:00 +0000 - From: Q + From: Q (no-py3 !) + From: =?iso-8859-1?q?Q?= (py3 !) To: foo Cc: bar @@ -2397,9 +2398,12 @@ test multi-address parsing: User-Agent: Mercurial-patchbomb/* (glob) Date: Tue, 01 Jan 1980 00:01:00 +0000 From: quux - To: spam , eggs, toast - Cc: foo, bar@example.com, "A, B <>" - Bcc: "Quux, A." + To: spam , eggs, toast (no-py3 !) + Cc: foo, bar@example.com, "A, B <>" (no-py3 !) + Bcc: "Quux, A." (no-py3 !) + To: =?iso-8859-1?q?spam?= , eggs, toast (py3 !) + Cc: foo, bar@example.com, =?iso-8859-1?q?A=2C_B_=3C=3E?= (py3 !) + Bcc: =?iso-8859-1?q?Quux=2C_A=2E?= (py3 !) # HG changeset patch # User test