diff options
| author | R David Murray <rdmurray@bitdance.com> | 2016-09-11 21:22:56 (GMT) |
|---|---|---|
| committer | R David Murray <rdmurray@bitdance.com> | 2016-09-11 21:22:56 (GMT) |
| commit | 0e0cfd71355accafd009916472ebb4d4fe0ab4ec (patch) | |
| tree | e34ff0e84d0a10b03d4a115b049bf974b99d7936 /Lib/email/generator.py | |
| parent | e4946e73c88ef5381382788800e9a287daaaf7dc (diff) | |
| download | cpython-0e0cfd71355accafd009916472ebb4d4fe0ab4ec.zip cpython-0e0cfd71355accafd009916472ebb4d4fe0ab4ec.tar.gz cpython-0e0cfd71355accafd009916472ebb4d4fe0ab4ec.tar.bz2 | |
#19003: Only replace \r and/or \n line endings in email.generator.
This is a further restoration of backward compatibility, as well as
being correct per the RFCs.
Diffstat (limited to 'Lib/email/generator.py')
| -rw-r--r-- | Lib/email/generator.py | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/Lib/email/generator.py b/Lib/email/generator.py index 6d283e9..256278d 100644 --- a/Lib/email/generator.py +++ b/Lib/email/generator.py @@ -18,6 +18,7 @@ from email.utils import _has_surrogates UNDERSCORE = '_' NL = '\n' # XXX: no longer used by the code below. +NLCRE = re.compile(r'\r\n|\r|\n') fcre = re.compile(r'^From ', re.MULTILINE) @@ -149,14 +150,17 @@ class Generator: # We have to transform the line endings. if not lines: return - lines = lines.splitlines(True) + lines = NLCRE.split(lines) for line in lines[:-1]: - self.write(line.rstrip('\r\n')) - self.write(self._NL) - laststripped = lines[-1].rstrip('\r\n') - self.write(laststripped) - if len(lines[-1]) != len(laststripped): + self.write(line) self.write(self._NL) + if lines[-1]: + self.write(lines[-1]) + # XXX logic tells me this else should be needed, but the tests fail + # with it and pass without it. (NLCRE.split ends with a blank element + # if and only if there was a trailing newline.) + #else: + # self.write(self._NL) def _write(self, msg): # We can't write the headers yet because of the following scenario: |
