blob: 8c8b7055c2d204fac64625e0f3d10908567c7204 [file] [log] [blame]
Fred Drake3a0351c1998-04-04 07:23:21 +00001\section{Standard Module \module{mailcap}}
Fred Drakeb91e9341998-07-23 17:59:49 +00002\declaremodule{standard}{mailcap}
3
4\modulesynopsis{Mailcap file handling.}
5
Guido van Rossum20af95b1997-03-25 22:01:35 +00006
7Mailcap files are used to configure how MIME-aware applications such
8as mail readers and Web browsers react to files with different MIME
9types. (The name ``mailcap'' is derived from the phrase ``mail
10capability''.) For example, a mailcap file might contain a line like
Fred Drake1656d171997-12-29 16:55:50 +000011\samp{video/mpeg; xmpeg \%s}. Then, if the user encounters an email
Fred Drake9e9c89e1998-04-02 15:53:07 +000012message or Web document with the MIME type \mimetype{video/mpeg},
13\samp{\%s} will be replaced by a filename (usually one belonging to a
14temporary file) and the \program{xmpeg} program can be automatically
15started to view the file.
Guido van Rossum20af95b1997-03-25 22:01:35 +000016
Fred Drakec5891241998-02-09 19:16:20 +000017The mailcap format is documented in \rfc{1524}, ``A User Agent
Fred Drake526467c1998-02-10 21:42:27 +000018Configuration Mechanism For Multimedia Mail Format Information,'' but
Guido van Rossum20af95b1997-03-25 22:01:35 +000019is not an Internet standard. However, mailcap files are supported on
Fred Drake6862b461998-01-13 19:03:36 +000020most \UNIX{} systems.
Guido van Rossum20af95b1997-03-25 22:01:35 +000021
Fred Drake9e9c89e1998-04-02 15:53:07 +000022\begin{funcdesc}{findmatch}{caps, MIMEtype%
23 \optional{, key\optional{,
24 filename\optional{, plist}}}}
Guido van Rossum20af95b1997-03-25 22:01:35 +000025Return a 2-tuple; the first element is a string containing the command
26line to be executed
27(which can be passed to \code{os.system()}), and the second element is
28the mailcap entry for a given MIME type. If no matching MIME
29type can be found, \code{(None, None)} is returned.
30
Fred Drakec5891241998-02-09 19:16:20 +000031\var{key} is the name of the field desired, which represents the type
32of activity to be performed; the default value is 'view', since in the
Guido van Rossum20af95b1997-03-25 22:01:35 +000033most common case you simply want to view the body of the MIME-typed
34data. Other possible values might be 'compose' and 'edit', if you
35wanted to create a new body of the given MIME type or alter the
Fred Drakec5891241998-02-09 19:16:20 +000036existing body data. See \rfc{1524} for a complete list of these
37fields.
Guido van Rossum20af95b1997-03-25 22:01:35 +000038
Fred Drake9e9c89e1998-04-02 15:53:07 +000039\var{filename} is the filename to be substituted for \samp{\%s} in the
Guido van Rossum20af95b1997-03-25 22:01:35 +000040command line; the default value is
Fred Drake9e9c89e1998-04-02 15:53:07 +000041\code{'/dev/null'} which is almost certainly not what you want, so
Guido van Rossum20af95b1997-03-25 22:01:35 +000042usually you'll override it by specifying a filename.
43
44\var{plist} can be a list containing named parameters; the default
45value is simply an empty list. Each entry in the list must be a
Fred Drake1656d171997-12-29 16:55:50 +000046string containing the parameter name, an equals sign (\code{=}), and the
Guido van Rossum20af95b1997-03-25 22:01:35 +000047parameter's value. Mailcap entries can contain
Fred Drake1656d171997-12-29 16:55:50 +000048named parameters like \code{\%\{foo\}}, which will be replaced by the
Guido van Rossum20af95b1997-03-25 22:01:35 +000049value of the parameter named 'foo'. For example, if the command line
Fred Drake9e9c89e1998-04-02 15:53:07 +000050\samp{showpartial \%\{id\}\ \%\{number\}\ \%\{total\}}
Guido van Rossum20af95b1997-03-25 22:01:35 +000051was in a mailcap file, and \var{plist} was set to \code{['id=1',
52'number=2', 'total=3']}, the resulting command line would be
53\code{"showpartial 1 2 3"}.
54
55In a mailcap file, the "test" field can optionally be specified to
56test some external condition (e.g., the machine architecture, or the
57window system in use) to determine whether or not the mailcap line
58applies. \code{findmatch()} will automatically check such conditions
59and skip the entry if the check fails.
60\end{funcdesc}
61
62\begin{funcdesc}{getcaps}{}
63Returns a dictionary mapping MIME types to a list of mailcap file
Fred Drake1656d171997-12-29 16:55:50 +000064entries. This dictionary must be passed to the \code{findmatch()}
Guido van Rossum20af95b1997-03-25 22:01:35 +000065function. An entry is stored as a list of dictionaries, but it
66shouldn't be necessary to know the details of this representation.
67
68The information is derived from all of the mailcap files found on the
69system. Settings in the user's mailcap file \file{\$HOME/.mailcap}
70will override settings in the system mailcap files
71\file{/etc/mailcap}, \file{/usr/etc/mailcap}, and
72\file{/usr/local/etc/mailcap}.
73\end{funcdesc}
74
75An example usage:
Fred Drake19479911998-02-13 06:58:54 +000076\begin{verbatim}
Guido van Rossum20af95b1997-03-25 22:01:35 +000077>>> import mailcap
78>>> d=mailcap.getcaps()
79>>> mailcap.findmatch(d, 'video/mpeg', filename='/tmp/tmp1223')
80('xmpeg /tmp/tmp1223', {'view': 'xmpeg %s'})
Fred Drake19479911998-02-13 06:58:54 +000081\end{verbatim}