Guido van Rossum | 8b3febe | 2007-08-30 01:15:14 +0000 | [diff] [blame] | 1 | # Copyright (C) 2001-2006 Python Software Foundation |
| 2 | # Author: Barry Warsaw |
| 3 | # Contact: email-sig@python.org |
| 4 | |
| 5 | """Class representing text/* type MIME documents.""" |
| 6 | |
| 7 | __all__ = ['MIMEText'] |
| 8 | |
Berker Peksag | fe21e4d | 2014-09-27 00:57:29 +0300 | [diff] [blame] | 9 | from email.charset import Charset |
Guido van Rossum | 8b3febe | 2007-08-30 01:15:14 +0000 | [diff] [blame] | 10 | from email.mime.nonmultipart import MIMENonMultipart |
| 11 | |
| 12 | |
| 13 | |
| 14 | class MIMEText(MIMENonMultipart): |
| 15 | """Class for generating text/* type MIME documents.""" |
| 16 | |
R David Murray | 42243c4 | 2012-03-22 22:40:44 -0400 | [diff] [blame] | 17 | def __init__(self, _text, _subtype='plain', _charset=None): |
Guido van Rossum | 8b3febe | 2007-08-30 01:15:14 +0000 | [diff] [blame] | 18 | """Create a text/* type MIME document. |
| 19 | |
| 20 | _text is the string for this message object. |
| 21 | |
| 22 | _subtype is the MIME sub content type, defaulting to "plain". |
| 23 | |
| 24 | _charset is the character set parameter added to the Content-Type |
| 25 | header. This defaults to "us-ascii". Note that as a side-effect, the |
| 26 | Content-Transfer-Encoding header will also be set. |
| 27 | """ |
R David Murray | 8680bcc | 2012-03-22 22:17:51 -0400 | [diff] [blame] | 28 | |
Terry Jan Reedy | 0f84764 | 2013-03-11 18:34:00 -0400 | [diff] [blame] | 29 | # If no _charset was specified, check to see if there are non-ascii |
R David Murray | 42243c4 | 2012-03-22 22:40:44 -0400 | [diff] [blame] | 30 | # characters present. If not, use 'us-ascii', otherwise use utf-8. |
R David Murray | 8680bcc | 2012-03-22 22:17:51 -0400 | [diff] [blame] | 31 | # XXX: This can be removed once #7304 is fixed. |
R David Murray | 42243c4 | 2012-03-22 22:40:44 -0400 | [diff] [blame] | 32 | if _charset is None: |
R David Murray | 8680bcc | 2012-03-22 22:17:51 -0400 | [diff] [blame] | 33 | try: |
R David Murray | 42243c4 | 2012-03-22 22:40:44 -0400 | [diff] [blame] | 34 | _text.encode('us-ascii') |
| 35 | _charset = 'us-ascii' |
R David Murray | 8680bcc | 2012-03-22 22:17:51 -0400 | [diff] [blame] | 36 | except UnicodeEncodeError: |
| 37 | _charset = 'utf-8' |
Berker Peksag | fe21e4d | 2014-09-27 00:57:29 +0300 | [diff] [blame] | 38 | if isinstance(_charset, Charset): |
| 39 | _charset = str(_charset) |
R David Murray | 8680bcc | 2012-03-22 22:17:51 -0400 | [diff] [blame] | 40 | |
R David Murray | 42243c4 | 2012-03-22 22:40:44 -0400 | [diff] [blame] | 41 | MIMENonMultipart.__init__(self, 'text', _subtype, |
| 42 | **{'charset': _charset}) |
| 43 | |
Guido van Rossum | 8b3febe | 2007-08-30 01:15:14 +0000 | [diff] [blame] | 44 | self.set_payload(_text, _charset) |