]> granicus.if.org Git - python/commitdiff
#1440472: Explain that email parser/generator isn't *quite* "idempotent"
authorR David Murray <rdmurray@bitdance.com>
Wed, 16 May 2012 02:12:09 +0000 (22:12 -0400)
committerR David Murray <rdmurray@bitdance.com>
Wed, 16 May 2012 02:12:09 +0000 (22:12 -0400)
Doc/library/email.generator.rst

index f02e7d86a25f590eb64c458ec2f3e3e3c2e9b6f0..a7493bee4454ee72be767c9c56bb4f0038b560be 100644 (file)
@@ -17,7 +17,8 @@ yourself.  However the bundled generator knows how to generate most email in a
 standards-compliant way, should handle MIME and non-MIME email messages just
 fine, and is designed so that the transformation from flat text, to a message
 structure via the :class:`~email.parser.Parser` class, and back to flat text,
-is idempotent (the input is identical to the output).  On the other hand, using
+is idempotent (the input is identical to the output) [#]_.  On the other hand,
+using
 the Generator on a :class:`~email.message.Message` constructed by program may
 result in changes to the :class:`~email.message.Message` object as defaults are
 filled in.
@@ -125,3 +126,11 @@ representing the part.
 .. versionchanged:: 2.5
    The previously deprecated method :meth:`__call__` was removed.
 
+
+.. rubric:: Footnotes
+
+.. [#] This statement assumes that you use the appropriate setting for the
+       ``unixfrom`` argument, and that you set maxheaderlen=0 (which will
+       preserve whatever the input line lengths were).  It is also not strictly
+       true, since in many cases runs of whitespace in headers are collapsed
+       into single blanks.  The latter is a bug that will eventually be fixed.