2007-08-15 11:28:22 -03:00
|
|
|
:mod:`uu` --- Encode and decode uuencode files
|
|
|
|
==============================================
|
|
|
|
|
|
|
|
.. module:: uu
|
|
|
|
:synopsis: Encode and decode files in uuencode format.
|
|
|
|
.. moduleauthor:: Lance Ellinghouse
|
|
|
|
|
|
|
|
|
|
|
|
This module encodes and decodes files in uuencode format, allowing arbitrary
|
|
|
|
binary data to be transferred over ASCII-only connections. Wherever a file
|
|
|
|
argument is expected, the methods accept a file-like object. For backwards
|
|
|
|
compatibility, a string containing a pathname is also accepted, and the
|
|
|
|
corresponding file will be opened for reading and writing; the pathname ``'-'``
|
|
|
|
is understood to mean the standard input or output. However, this interface is
|
|
|
|
deprecated; it's better for the caller to open the file itself, and be sure
|
|
|
|
that, when required, the mode is ``'rb'`` or ``'wb'`` on Windows.
|
|
|
|
|
|
|
|
.. index::
|
|
|
|
single: Jansen, Jack
|
|
|
|
single: Ellinghouse, Lance
|
|
|
|
|
|
|
|
This code was contributed by Lance Ellinghouse, and modified by Jack Jansen.
|
|
|
|
|
|
|
|
The :mod:`uu` module defines the following functions:
|
|
|
|
|
|
|
|
|
Merged revisions 74821,74828-74831,74833,74835 via svnmerge from
svn+ssh://svn.python.org/python/branches/py3k
................
r74821 | georg.brandl | 2009-09-16 11:42:19 +0200 (Mi, 16 Sep 2009) | 1 line
#6885: run python 3 as python3.
................
r74828 | georg.brandl | 2009-09-16 16:23:20 +0200 (Mi, 16 Sep 2009) | 1 line
Use true booleans.
................
r74829 | georg.brandl | 2009-09-16 16:24:29 +0200 (Mi, 16 Sep 2009) | 1 line
Small PEP8 correction.
................
r74830 | georg.brandl | 2009-09-16 16:36:22 +0200 (Mi, 16 Sep 2009) | 1 line
Use true booleans.
................
r74831 | georg.brandl | 2009-09-16 17:54:04 +0200 (Mi, 16 Sep 2009) | 1 line
Use true booleans and PEP8 for argdefaults.
................
r74833 | georg.brandl | 2009-09-16 17:58:14 +0200 (Mi, 16 Sep 2009) | 1 line
Last round of adapting style of documenting argument default values.
................
r74835 | georg.brandl | 2009-09-16 18:00:31 +0200 (Mi, 16 Sep 2009) | 33 lines
Merged revisions 74817-74820,74822-74824 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74817 | georg.brandl | 2009-09-16 11:05:11 +0200 (Mi, 16 Sep 2009) | 1 line
Make deprecation notices as visible as warnings are right now.
........
r74818 | georg.brandl | 2009-09-16 11:23:04 +0200 (Mi, 16 Sep 2009) | 1 line
#6880: add reference to classes section in exceptions section, which comes earlier.
........
r74819 | georg.brandl | 2009-09-16 11:24:57 +0200 (Mi, 16 Sep 2009) | 1 line
#6876: fix base class constructor invocation in example.
........
r74820 | georg.brandl | 2009-09-16 11:30:48 +0200 (Mi, 16 Sep 2009) | 1 line
#6891: comment out dead link to Unicode article.
........
r74822 | georg.brandl | 2009-09-16 12:12:06 +0200 (Mi, 16 Sep 2009) | 1 line
#5621: refactor description of how class/instance attributes interact on a.x=a.x+1 or augassign.
........
r74823 | georg.brandl | 2009-09-16 15:06:22 +0200 (Mi, 16 Sep 2009) | 1 line
Remove strange trailing commas.
........
r74824 | georg.brandl | 2009-09-16 15:11:06 +0200 (Mi, 16 Sep 2009) | 1 line
#6892: fix optparse example involving help option.
........
................
2009-09-16 13:05:59 -03:00
|
|
|
.. function:: encode(in_file, out_file, name=None, mode=None)
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2008-05-26 14:55:52 -03:00
|
|
|
Uuencode file *in_file* into file *out_file*. The uuencoded file will have
|
|
|
|
the header specifying *name* and *mode* as the defaults for the results of
|
|
|
|
decoding the file. The default defaults are taken from *in_file*, or ``'-'``
|
|
|
|
and ``0o666`` respectively.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
|
Merged revisions 74821,74828-74831,74833,74835 via svnmerge from
svn+ssh://svn.python.org/python/branches/py3k
................
r74821 | georg.brandl | 2009-09-16 11:42:19 +0200 (Mi, 16 Sep 2009) | 1 line
#6885: run python 3 as python3.
................
r74828 | georg.brandl | 2009-09-16 16:23:20 +0200 (Mi, 16 Sep 2009) | 1 line
Use true booleans.
................
r74829 | georg.brandl | 2009-09-16 16:24:29 +0200 (Mi, 16 Sep 2009) | 1 line
Small PEP8 correction.
................
r74830 | georg.brandl | 2009-09-16 16:36:22 +0200 (Mi, 16 Sep 2009) | 1 line
Use true booleans.
................
r74831 | georg.brandl | 2009-09-16 17:54:04 +0200 (Mi, 16 Sep 2009) | 1 line
Use true booleans and PEP8 for argdefaults.
................
r74833 | georg.brandl | 2009-09-16 17:58:14 +0200 (Mi, 16 Sep 2009) | 1 line
Last round of adapting style of documenting argument default values.
................
r74835 | georg.brandl | 2009-09-16 18:00:31 +0200 (Mi, 16 Sep 2009) | 33 lines
Merged revisions 74817-74820,74822-74824 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74817 | georg.brandl | 2009-09-16 11:05:11 +0200 (Mi, 16 Sep 2009) | 1 line
Make deprecation notices as visible as warnings are right now.
........
r74818 | georg.brandl | 2009-09-16 11:23:04 +0200 (Mi, 16 Sep 2009) | 1 line
#6880: add reference to classes section in exceptions section, which comes earlier.
........
r74819 | georg.brandl | 2009-09-16 11:24:57 +0200 (Mi, 16 Sep 2009) | 1 line
#6876: fix base class constructor invocation in example.
........
r74820 | georg.brandl | 2009-09-16 11:30:48 +0200 (Mi, 16 Sep 2009) | 1 line
#6891: comment out dead link to Unicode article.
........
r74822 | georg.brandl | 2009-09-16 12:12:06 +0200 (Mi, 16 Sep 2009) | 1 line
#5621: refactor description of how class/instance attributes interact on a.x=a.x+1 or augassign.
........
r74823 | georg.brandl | 2009-09-16 15:06:22 +0200 (Mi, 16 Sep 2009) | 1 line
Remove strange trailing commas.
........
r74824 | georg.brandl | 2009-09-16 15:11:06 +0200 (Mi, 16 Sep 2009) | 1 line
#6892: fix optparse example involving help option.
........
................
2009-09-16 13:05:59 -03:00
|
|
|
.. function:: decode(in_file, out_file=None, mode=None, quiet=False)
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
This call decodes uuencoded file *in_file* placing the result on file
|
|
|
|
*out_file*. If *out_file* is a pathname, *mode* is used to set the permission
|
|
|
|
bits if the file must be created. Defaults for *out_file* and *mode* are taken
|
|
|
|
from the uuencode header. However, if the file specified in the header already
|
|
|
|
exists, a :exc:`uu.Error` is raised.
|
|
|
|
|
|
|
|
:func:`decode` may print a warning to standard error if the input was produced
|
|
|
|
by an incorrect uuencoder and Python could recover from that error. Setting
|
|
|
|
*quiet* to a true value silences this warning.
|
|
|
|
|
|
|
|
|
|
|
|
.. exception:: Error()
|
|
|
|
|
|
|
|
Subclass of :exc:`Exception`, this can be raised by :func:`uu.decode` under
|
|
|
|
various situations, such as described above, but also including a badly
|
|
|
|
formatted header, or truncated input file.
|
|
|
|
|
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
|
|
|
|
Module :mod:`binascii`
|
|
|
|
Support module containing ASCII-to-binary and binary-to-ASCII conversions.
|
|
|
|
|