NAME
mhshow - display nmh MIME messagesSYNOPSIS
mhshow
[-help] [-version] [+folder] [msgs] [-file
file] [-part number] ... [-type content]
... [-prefer content] ... [-noprefer] [-concat |
-noconcat] [-textonly | -notextonly] [-inlineonly
| -noinlineonly] [-header | -noheader] [-form
formfile] [-markform formfile]
DESCRIPTION
The mhshow command displays contents of a MIME (multi-media) message, or collection of messages. mhshow manipulates multi-media messages as specified in RFC 2045 to RFC 2049. Currently mhshow only supports encodings in message bodies, and does not support the encoding of message headers as specified in RFC 2047. By default, mhshow will display only the text parts of a message that are not marked as attachments. This behavior can be changed by the -notextonly and -noinlineonly switches. In addition, by using the -part, -type, and -prefer switches, you may limit and reorder the set of parts to be displayed, based on part number and/or content type. The inclusion of any -part or -type switches will override the default settings of -textonly and -inlineonly. The -header switch controls whether mhshow will print a message separator header before each message that it displays. The header format can be controlled using -headerform, to specify a file containing mh-format(5) instructions. A copy of the built-in default headerform can be found in /etc/nmh/mhshow.header, for reference. In addition to the normal set of mh-format(5) instructions, a "%{folder}" escape provides a string representing the current folder. By default, mhshow will concatenate all content under one pager. If you want each part to be displayed separately, you can override the default behavior with -noconcat. The -file file switch directs mhshow to use the specified file as the source message, rather than a message from a folder. If you specify this file as “-”, then mhshow will accept the source message on the standard input. Note that the file, or input from standard input, should be a validly formatted message, just like any other nmh message. It should not be in mail drop format (to convert a file in mail drop format to a folder of nmh messages, see inc(1)). The -part switch can be given (one or more times) to restrict the set of subparts that will be displayed. (Obviously with no -part switches, all parts will be considered.) If a -part switch specifies a specific subpart (i.e., a "leaf" in the tree of MIME parts), then that part will always be displayed. If a -part switch references a multipart/alternative part, then (in the absence of a -type switch) only the default subpart of that multipart will be displayed. A part specification consists of a series of numbers separated by dots. For example, in a multipart content containing three parts, these would be named as 1, 2, and 3, respectively. If part 2 was also a multipart content containing two parts, these would be named as 2.1 and 2.2, respectively. Note that the -part switch is effective only for messages containing a multipart content. If a message has some other kind of content, or if the part is itself another multipart content, the -part switch will not prevent the content from being acted upon. The -type switch can also be used to restrict (or, when used in conjunction with -part, to further restrict) the display of parts according to content type. One or more -type switches part will only select the first match from a multipart/alternative, even if there is more than one subpart that matches (one of) the given content type(s). Using either -part or -type switches alone will cause either switch to select the part(s) they match. Using them together will select only the part(s) matched by both (sets of) switches. In other words, the result is the intersection, and not the union, of their separate match results. A content specification consists of a content type and a subtype. The initial list of “standard” content types and subtypes can be found in RFC 2046. A list of commonly used contents is briefly reproduced here:Type Subtypes ---- -------- text plain, enriched multipart mixed, alternative, digest, parallel message rfc822, external-body application octet-stream, postscript image jpeg, gif, png audio basic video mpeg
Unseen Sequence
If the profile entry “Unseen-Sequence” is present and non-empty, then mhshow will remove each of the messages shown from each sequence named by the profile entry.Showing the Contents
The headers of each message are displayed with the mhlproc (usually mhl), using the standard format file, mhl.headers. You may specify an alternative format file with the -form formfile switch. If the format file mhl.null is specified, then the display of the message headers is suppressed. Next, the contents are extracted from the message and are stored in a temporary file. Usually, the name of the temporary file is the word “mhshow” followed by a string of characters. Occasionally, the method used to display a content (described next), requires that the file end in a specific suffix. For example, the soffice command (part of the StarOffice package) can be used to display Microsoft Word content, but it uses the suffix to determine how to display the file. If no suffix is present, the file is not correctly loaded. Similarly, older versions of the gs command append a “.ps” suffix to the filename if one was missing. As a result, these cannot be used to read the default temporary file. To get around this, your profile can contain lines of the form:mhshow-suffix-<type>/<subtype>:
<suffix>
or
mhshow-suffix-<type>:
<suffix>
to specify a suffix which can be automatically added to the temporary file
created for a specific content type. For example, the following lines might
appear in your profile:
mhshow-suffix-text: .txt mhshow-suffix-application/msword: .doc mhshow-suffix-application/PostScript: .ps
mhshow-show-<type>/<subtype>
If this isn't found, mhshow will search for an entry of the form:
mhshow-show-<type>
to determine the display string.
If a display string is found, any escapes (given below) will be expanded. The
result will be executed under “/bin/sh”, with the standard input
set to the content.
The display string may contain the following escapes:
%a Insert parameters from Content-Type field %{parameter} Insert the parameter value from the Content-Type field %f Insert filename containing content %F %f, and stdin is terminal not content %l display listing prior to displaying content %s Insert content subtype %d Insert content description %% Insert the character %
mhshow-show-text/html: charset="%{charset}"; w3m ${charset:+-I $charset} -T text/html %F
mhshow-show-text/plain: %lmoreproc %F mhshow-show-message/rfc822: %lshow -file %F
mhshow-show-audio/basic: raw2audio 2>/dev/null | play mhshow-show-image: xv %f mhshow-show-application/PostScript: lpr -Pps
Showing Alternate Character Sets
If mhshow was built with iconv(3), then all text/plain parts of the message(s) will be displayed using the character set of the current locale. See mhparam(1) for how to determine whether your nmh installation includes iconv(3) support. To convert text parts other than text/plain, or if mhshow was not built with iconv, an external program can be used, as described next. Because a content of type text might be in a non-ASCII character set, when mhshow encounters a “charset” parameter for this content, it checks if your terminal can display this character set natively. mhshow checks this by examining the current character set defined by the locale(1) environment variables. If the value of the locale character set is equal to the value of the charset parameter, then mhshow assumes it can display this content without any additional setup. If the locale is not set properly, mhshow will assume a value of “US-ASCII”. If the character set cannot be displayed natively, then mhshow will look for an entry of the form:mhshow-charset-<charset>
which should contain a command creating an environment to render the character
set. This command string should containing a single “%s”, which
will be filled-in with the command to display the content.
Example entries might be:
mhshow-charset-iso-8859-1: xterm -fn
'-*-*-medium-r-normal-*-*-120-*-*-c-*-iso8859-*' -e %s
or
mhshow-charset-iso-8859-1: '%s'
The first example tells mhshow to start xterm and load the
appropriate character set for that message content. The second example tells
mhshow that your pager (or other program handling that content type)
can handle that character set, and that no special processing is needed
beforehand.
Note that many pagers strip off the high-order bit, or have problems displaying
text with the high-order bit set. However, the pager less has support
for single-octet character sets. For example, messages encoded in the
ISO-8859-1 character set can be viewed using less, with these
environment variable settings:
LESSCHARSET latin1 LESS -f
External Access
For contents of type message/external-body, mhshow supports these access-types:- •
- afs
- •
- anon-ftp
- •
- ftp
- •
- local-file
- •
- mail-server
- •
- url
nmh-access-ftp: myftp.sh
to determine the pathname of a program to perform the FTP retrieval.
This program is invoked with these arguments:
domain name of FTP-site username password remote directory remote filename local filename “ascii” or “binary”
User Environment
Because the display environment in which mhshow operates may vary for different machines, mhshow will look for the environment variable MHSHOW. If present, this specifies the name of an additional user profile which should be read. Hence, when a user logs in on a particular display device, this environment variable should be set to refer to a file containing definitions useful for the given display device. Normally, only entries that deal with the methods to display different content type and subtypesmhshow-show-<type>/<subtype> mhshow-show-<type>
/etc/nmh/mhn.defaults
which is created automatically during nmh installation.
See "Profile Lookup" in mh-profile(5) for the profile search
order, and for how duplicate entries are treated.
Content-Type Marker
mhshow will display a marker containing information about the part being displayed next. The default marker can be changed using the -markform switch to specify a file containing mh-format(5) instructions to use when displaying the content marker. A copy of the default markform can be found in /etc/nmh/mhshow.marker, for reference. In addition to the normal set of mh-format(5) instructions, the following component escapes are supported:Escape Returns Description part string MIME part number content-type string MIME Content-Type of part description string Content-Description header disposition string Content disposition (attachment or inline) ctype-<PARAM> string Value of <PARAM> from Content-Type header cdispo-<PARAM> string Value of <PARAM> from Content-Disposition header %(size) integer The size of the decoded part, in bytes %(unseen) boolean Returns true for suppressed partsIn this context, the %(unseen) function indicates whether mhshow has decided to not display a particular part due to the -textonly or -inlineonly switches.
FILES
mhshow looks for all format files and mhn.defaults in multiple locations: absolute pathnames are accessed directly, tilde expansion is done on usernames, and files are searched for in the user's Mail directory, as specified in their profile. If not found there, the directory “/etc/nmh” is checked.^$HOME/.mh_profile~^The user profile ^$MHSHOW~^Additional profile entries ^/etc/nmh/mhn.defaults~^System default MIME profile entries ^/etc/nmh/mhl.headers~^The headers template ^/etc/nmh/mhshow.marker~^Example content marker ^/etc/nmh/mhshow.header~^Example message separator header
PROFILE COMPONENTS
^Path:~^To determine the user's nmh directory ^Current-Folder:~^To find the default current folder ^Unseen-Sequence:~^To name sequences denoting unseen messages ^mhlproc:~^Default program to display message headers ^nmh-access-ftp:~^Program to retrieve contents via FTP ^nmh-access-url:~^Program to retrieve contents via HTTP ^mhshow-charset-<charset>~^Template for environment to render character sets ^mhshow-show-<type>*~^Template for displaying contents ^moreproc:~^Default program to display text/plain content
SEE ALSO
iconv(3), mhbuild(1), mhl(1), mhlist(1), mhparam(1), mhstore(1), sendfiles(1)DEFAULTS
`+folder' defaults to the current folder `msgs' defaults to cur `-concat' `-textonly' `-inlineonly' `-form mhl.headers'
CONTEXT
If a folder is given, it will become the current folder. The last message selected will become the current message.2015-02-08 | nmh-1.8-RC2 |