| | |
| | |
| | |
| |
|
| | """Class representing text/* type MIME documents.""" |
| |
|
| | __all__ = ['MIMEText'] |
| |
|
| | from email.charset import Charset |
| | from email.mime.nonmultipart import MIMENonMultipart |
| |
|
| |
|
| | |
| | class MIMEText(MIMENonMultipart): |
| | """Class for generating text/* type MIME documents.""" |
| |
|
| | def __init__(self, _text, _subtype='plain', _charset=None, *, policy=None): |
| | """Create a text/* type MIME document. |
| | |
| | _text is the string for this message object. |
| | |
| | _subtype is the MIME sub content type, defaulting to "plain". |
| | |
| | _charset is the character set parameter added to the Content-Type |
| | header. This defaults to "us-ascii". Note that as a side-effect, the |
| | Content-Transfer-Encoding header will also be set. |
| | """ |
| |
|
| | |
| | |
| | |
| | if _charset is None: |
| | try: |
| | _text.encode('us-ascii') |
| | _charset = 'us-ascii' |
| | except UnicodeEncodeError: |
| | _charset = 'utf-8' |
| |
|
| | MIMENonMultipart.__init__(self, 'text', _subtype, policy=policy, |
| | **{'charset': str(_charset)}) |
| |
|
| | self.set_payload(_text, _charset) |
| |
|