Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

gh-102507 Remove invisible pagebreak characters #102531

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 6 commits into from
Mar 8, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 0 additions & 1 deletion 1 Lib/email/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@
]



# Some convenience routines. Don't import Parser and Message as side-effects
# of importing email since those cascadingly import most of the rest of the
# email package.
Expand Down
4 changes: 0 additions & 4 deletions 4 Lib/email/base64mime.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,6 @@
MISC_LEN = 7



# Helpers
def header_length(bytearray):
"""Return the length of s when it is encoded with base64."""
Expand All @@ -57,7 +56,6 @@ def header_length(bytearray):
return n



def header_encode(header_bytes, charset='iso-8859-1'):
"""Encode a single header line with Base64 encoding in a given charset.

Expand All @@ -72,7 +70,6 @@ def header_encode(header_bytes, charset='iso-8859-1'):
return '=?%s?b?%s?=' % (charset, encoded)



def body_encode(s, maxlinelen=76, eol=NL):
r"""Encode a string with base64.

Expand All @@ -98,7 +95,6 @@ def body_encode(s, maxlinelen=76, eol=NL):
return EMPTYSTRING.join(encvec)



def decode(string):
"""Decode a raw base64 string, returning a bytes object.

Expand Down
5 changes: 0 additions & 5 deletions 5 Lib/email/charset.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@
from email.encoders import encode_7or8bit



# Flags for types of header encodings
QP = 1 # Quoted-Printable
BASE64 = 2 # Base64
Expand All @@ -32,7 +31,6 @@
EMPTYSTRING = ''



# Defaults
CHARSETS = {
# input header enc body enc output conv
Expand Down Expand Up @@ -104,7 +102,6 @@
}



# Convenience functions for extending the above mappings
def add_charset(charset, header_enc=None, body_enc=None, output_charset=None):
"""Add character set properties to the global registry.
Expand Down Expand Up @@ -153,7 +150,6 @@ def add_codec(charset, codecname):
CODEC_MAP[charset] = codecname



# Convenience function for encoding strings, taking into account
# that they might be unknown-8bit (ie: have surrogate-escaped bytes)
def _encode(string, codec):
Expand All @@ -163,7 +159,6 @@ def _encode(string, codec):
return string.encode(codec)



class Charset:
"""Map character sets to their email properties.

Expand Down
4 changes: 0 additions & 4 deletions 4 Lib/email/encoders.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@
from quopri import encodestring as _encodestring



def _qencode(s):
enc = _encodestring(s, quotetabs=True)
# Must encode spaces, which quopri.encodestring() doesn't do
Expand All @@ -34,7 +33,6 @@ def encode_base64(msg):
msg['Content-Transfer-Encoding'] = 'base64'



def encode_quopri(msg):
"""Encode the message's payload in quoted-printable.

Expand All @@ -46,7 +44,6 @@ def encode_quopri(msg):
msg['Content-Transfer-Encoding'] = 'quoted-printable'



def encode_7or8bit(msg):
"""Set the Content-Transfer-Encoding header to 7bit or 8bit."""
orig = msg.get_payload(decode=True)
Expand All @@ -64,6 +61,5 @@ def encode_7or8bit(msg):
msg['Content-Transfer-Encoding'] = '7bit'



def encode_noop(msg):
"""Do nothing."""
2 changes: 0 additions & 2 deletions 2 Lib/email/feedparser.py
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,6 @@
NeedMoreData = object()



class BufferedSubFile(object):
"""A file-ish object that can have new data loaded into it.

Expand Down Expand Up @@ -132,7 +131,6 @@ def __next__(self):
return line



class FeedParser:
"""A feed-style parser of email."""

Expand Down
4 changes: 0 additions & 4 deletions 4 Lib/email/generator.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@
fcre = re.compile(r'^From ', re.MULTILINE)



class Generator:
"""Generates output from a Message object tree.

Expand Down Expand Up @@ -392,7 +391,6 @@ def _make_boundary(cls, text=None):
def _compile_re(cls, s, flags):
return re.compile(s, flags)

AlexWaygood marked this conversation as resolved.
Show resolved Hide resolved

class BytesGenerator(Generator):
"""Generates a bytes version of a Message object tree.

Expand Down Expand Up @@ -443,7 +441,6 @@ def _compile_re(cls, s, flags):
return re.compile(s.encode('ascii'), flags)



_FMT = '[Non-text (%(type)s) part of message omitted, filename %(filename)s]'

class DecodedGenerator(Generator):
Expand Down Expand Up @@ -503,7 +500,6 @@ def _dispatch(self, msg):
}, file=self)



# Helper used by Generator._make_boundary
_width = len(repr(sys.maxsize-1))
_fmt = '%%0%dd' % _width
Expand Down
5 changes: 0 additions & 5 deletions 5 Lib/email/header.py
Original file line number Diff line number Diff line change
Expand Up @@ -52,12 +52,10 @@
_embedded_header = re.compile(r'\n[^ \t]+:')



# Helpers
_max_append = email.quoprimime._max_append



def decode_header(header):
"""Decode a message header value without converting charset.

Expand Down Expand Up @@ -152,7 +150,6 @@ def decode_header(header):
return collapsed



def make_header(decoded_seq, maxlinelen=None, header_name=None,
continuation_ws=' '):
"""Create a Header from a sequence of pairs as returned by decode_header()
Expand All @@ -175,7 +172,6 @@ def make_header(decoded_seq, maxlinelen=None, header_name=None,
return h



class Header:
def __init__(self, s=None, charset=None,
maxlinelen=None, header_name=None,
Expand Down Expand Up @@ -409,7 +405,6 @@ def _normalize(self):
self._chunks = chunks



class _ValueFormatter:
def __init__(self, headerlen, maxlen, continuation_ws, splitchars):
self._maxlen = maxlen
Expand Down
3 changes: 0 additions & 3 deletions 3 Lib/email/iterators.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@
from io import StringIO



# This function will become a method of the Message class
def walk(self):
"""Walk over the message tree, yielding each subpart.
Expand All @@ -29,7 +28,6 @@ def walk(self):
yield from subpart.walk()



# These two functions are imported into the Iterators.py interface module.
def body_line_iterator(msg, decode=False):
"""Iterate over the parts, returning string payloads line-by-line.
Expand All @@ -55,7 +53,6 @@ def typed_subpart_iterator(msg, maintype='text', subtype=None):
yield subpart



def _structure(msg, fp=None, level=0, include_default=False):
"""A handy debugging aid"""
if fp is None:
Expand Down
1 change: 0 additions & 1 deletion 1 Lib/email/mime/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@
from email import message



class MIMEBase(message.Message):
"""Base class for MIME specializations."""

Expand Down
1 change: 0 additions & 1 deletion 1 Lib/email/mime/message.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@
from email.mime.nonmultipart import MIMENonMultipart



class MIMEMessage(MIMENonMultipart):
"""Class representing message/* MIME documents."""

Expand Down
1 change: 0 additions & 1 deletion 1 Lib/email/mime/multipart.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@
from email.mime.base import MIMEBase



class MIMEMultipart(MIMEBase):
"""Base class for MIME multipart/* type messages."""

Expand Down
1 change: 0 additions & 1 deletion 1 Lib/email/mime/nonmultipart.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@
from email.mime.base import MIMEBase



class MIMENonMultipart(MIMEBase):
"""Base class for MIME non-multipart type messages."""

Expand Down
1 change: 0 additions & 1 deletion 1 Lib/email/mime/text.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@
from email.mime.nonmultipart import MIMENonMultipart



class MIMEText(MIMENonMultipart):
"""Class for generating text/* type MIME documents."""

Expand Down
3 changes: 1 addition & 2 deletions 3 Lib/email/parser.py
Original file line number Diff line number Diff line change
Expand Up @@ -64,15 +64,14 @@ def parsestr(self, text, headersonly=False):
return self.parse(StringIO(text), headersonly=headersonly)



class HeaderParser(Parser):
def parse(self, fp, headersonly=True):
return Parser.parse(self, fp, True)

def parsestr(self, text, headersonly=True):
return Parser.parsestr(self, text, True)


class BytesParser:

def __init__(self, *args, **kw):
Expand Down
3 changes: 0 additions & 3 deletions 3 Modules/_io/bufferedio.c
Original file line number Diff line number Diff line change
Expand Up @@ -1742,7 +1742,6 @@ _bufferedreader_peek_unlocked(buffered *self)
self->pos = 0;
return PyBytes_FromStringAndSize(self->buffer, r);
}



/*
Expand Down Expand Up @@ -2052,7 +2051,6 @@ _io_BufferedWriter_write_impl(buffered *self, Py_buffer *buffer)
LEAVE_BUFFERED(self)
return res;
}



/*
Expand Down Expand Up @@ -2266,7 +2264,6 @@ bufferedrwpair_closed_get(rwpair *self, void *context)
}
return PyObject_GetAttr((PyObject *) self->writer, &_Py_ID(closed));
}



/*
Expand Down
12 changes: 3 additions & 9 deletions 12 Tools/i18n/pygettext.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
# Minimally patched to make it even more xgettext compatible
# by Peter Funk <pf@artcom-gmbh.de>
#
# 2002-11-22 J�rgen Hermann <jh@web.de>
# 2002-11-22 J�rgen Hermann <jh@web.de>
JosephSBoyle marked this conversation as resolved.
Show resolved Hide resolved
# Added checks that _() only contains string literals, and
# command line args are resolved to module lists, i.e. you
# can now pass a filename, a module or package name, or a
Expand Down Expand Up @@ -174,7 +174,6 @@
EMPTYSTRING = ''



# The normal pot-file header. msgmerge and Emacs's po-mode work better if it's
# there.
pot_header = _('''\
Expand All @@ -196,20 +195,18 @@

''')

AlexWaygood marked this conversation as resolved.
Show resolved Hide resolved

def usage(code, msg=''):
print(__doc__ % globals(), file=sys.stderr)
if msg:
print(msg, file=sys.stderr)
sys.exit(code)



def make_escapes(pass_nonascii):
global escapes, escape
if pass_nonascii:
# Allow non-ascii characters to pass through so that e.g. 'msgid
# "H�he"' would result not result in 'msgid "H\366he"'. Otherwise we
# "H�he"' would result not result in 'msgid "H\366he"'. Otherwise we
JosephSBoyle marked this conversation as resolved.
Show resolved Hide resolved
# escape any character outside the 32..126 range.
mod = 128
escape = escape_ascii
Expand Down Expand Up @@ -258,7 +255,7 @@ def normalize(s, encoding):
s = '""\n"' + lineterm.join(lines) + '"'
return s


def containsAny(str, set):
"""Check whether 'str' contains ANY of the chars in 'set'"""
return 1 in [c in str for c in set]
Expand Down Expand Up @@ -307,7 +304,6 @@ def getFilesForName(name):

return []

AlexWaygood marked this conversation as resolved.
Show resolved Hide resolved

class TokenEater:
def __init__(self, options):
self.__options = options
Expand Down Expand Up @@ -515,7 +511,6 @@ def write(self, fp):
print('msgstr ""\n', file=fp)



def main():
global default_keywords
try:
Expand Down Expand Up @@ -675,7 +670,6 @@ class Options:
if closep:
fp.close()

AlexWaygood marked this conversation as resolved.
Show resolved Hide resolved

if __name__ == '__main__':
main()
# some more test strings
Expand Down
Morty Proxy This is a proxified and sanitized view of the page, visit original site.