4 .TH MHSHOW %manext1% "%nmhdate%" MH.6.8 [%nmhversion%]
6 mhshow \- display MIME messages
21 .RB [ \-serialonly " | " \-noserialonly ]
22 .RB [ \-pause " | " \-nopause ]
29 .RB [ \-check " | " \-nocheck ]
36 command display contents of a MIME (multi-media)
37 message or collection of messages.
40 manipulates multi-media messages as specified in
41 RFC\-2045 thru RFC\-2049. Currently
44 encodings in message bodies, and does not support the encoding of
45 message headers as specified in RFC\-2047.
49 will display all parts of a multipart
57 to particular subparts (of a
58 multipart content) and/or particular content types.
65 to use the specified file as
66 the source message, rather than a message from a folder. If you specify
67 this file as \*(lq-\*(rq, then
69 will accept the source message
70 on the standard input. Note that the file, or input from standard input
71 should be a validly formatted message, just like any other
75 be in mail drop format (to convert a file in
76 mail drop format to a folder of
81 A part specification consists of a series of numbers separated by dots.
82 For example, in a multipart content containing three parts, these
83 would be named as 1, 2, and 3, respectively. If part 2 was also a
84 multipart content containing two parts, these would be named as 2.1 and
85 2.2, respectively. Note that the
87 switch is effective for only
88 messages containing a multipart content. If a message has some other
89 kind of content, or if the part is itself another multipart content, the
91 switch will not prevent the content from being acted upon.
93 A content specification consists of a content type and a subtype.
94 The initial list of \*(lqstandard\*(rq content types and subtypes can
95 be found in RFC\-2046.
97 A list of commonly used contents is briefly reproduced here:
101 .ta \w'application 'u
105 multipart mixed, alternative, digest, parallel
106 message rfc822, partial, external-body
107 application octet-stream, postscript
114 A legal MIME message must contain a subtype specification.
116 To specify a content, regardless of its subtype, just use the
117 name of the content, e.g., \*(lqaudio\*(rq. To specify a specific
118 subtype, separate the two with a slash, e.g., \*(lqaudio/basic\*(rq.
119 Note that regardless of the values given to the `\-type' switch, a
120 multipart content (of any subtype listed above) is always acted upon.
121 Further note that if the `\-type' switch is used, and it is desirable to
122 act on a message/external-body content, then the `\-type' switch must
123 be used twice: once for message/external-body and once for the content
124 externally referenced.
125 .SS "Unseen Sequence"
126 If the profile entry \*(lqUnseen\-Sequence\*(rq is present and
129 will remove each of the messages shown
130 from each sequence named by the profile entry.
131 .SS "Checking the Contents"
136 to check each content for an
137 integrity checksum. If a content has such a checksum (specified as a
138 Content-MD5 header field), then
140 will attempt to verify the
141 integrity of the content.
142 .SS "Showing the Contents"
143 The headers of each message are displayed with the
147 using the standard format file
149 You may specify an alternate format file with the
152 switch. If the format file
154 is specified, then the display
155 of the message headers is suppressed.
157 Next, the contents are extracted from the message and are stored in
158 a temporary file. Usually, the name of the temporary file is the
159 word \*(lqmhshow\*(rq followed by a string of characters. Occasionally,
160 the method used to display a content (described next), requires that
161 the file end in a specific suffix. For example, the
163 command (part of the StarOffice package) can be used to display
164 Microsoft Word content, but it uses the suffix to determine how to display
165 the file. If no suffix is present, the file is not correctly loaded.
166 Similarily, older versions of the
168 command append a \*(lq.ps\*(rq suffix to
169 the filename if one was missing. As a result, these cannot be used to read
170 the default temporary file.
172 To get around this, your profile can contain lines of the form:
175 mhshow-suffix-<type>/<subtype>: <suffix>
181 mhshow-suffix-<type>: <suffix>
184 to specify a suffix which can be automatically added to the temporary
185 file created for a specific content type. For example, the following
186 lines might appear in your profile:
190 mhshow-suffix-text: .txt
191 mhshow-suffix-application/msword: .doc
192 mhshow-suffix-application/PostScript: .ps
196 to automatically append a suffix to the temporary files.
198 The method used to display the different contents in the messages bodies
199 will be determined by a \*(lqdisplay string\*(rq. To find the display
202 will first search your profile for an entry of the form:
205 mhshow-show-<type>/<subtype>
208 to determine the display string. If this isn't found,
210 will search for an entry of the form:
216 to determine the display string.
218 If a display string is found, any escapes (given below) will be expanded.
219 The result will be executed under
220 \*(lq/bin/sh\*(rq, with the standard input
223 The display string may contain the following escapes:
228 %a Insert parameters from Content-Type field
229 %e exclusive execution
230 %f Insert filename containing content
231 %F %e, %f, and stdin is terminal not content
232 %l display listing prior to displaying content
233 %p %l, and ask for confirmation
234 %s Insert content subtype
235 %d Insert content description
236 %% Insert the character %
240 For those display strings containing the e- or F-escape,
243 execute at most one of these at any given time. Although the F-escape
244 expands to be the filename containing the content, the e-escape has no
245 expansion as far as the shell is concerned.
247 When the p-escape prompts for confirmation, typing INTR (usually
250 not to display that content.
251 The p-escape can be disabled by specifying the switch
255 is display a content, typing QUIT (usually
256 control-\\) will tell
258 to wrap things up immediately.
260 Note that if the content being displayed is multipart, but not one of
261 the subtypes listed above, then the f- and F-escapes expand to multiple
262 filenames, one for each subordinate content. Further, stdin is not
263 redirected from the terminal to the content.
265 If a display string is not found,
267 has several default values:
271 mhshow-show-text/plain: %pmoreproc '%F'
272 mhshow-show-message/rfc822: %pshow -file '%F'
276 If a subtype of type text doesn't have a profile entry, it will be
277 treated as text/plain.
280 has default methods for handling multipart messages of subtype
281 mixed, alternative, parallel, and digest. Any unknown subtype of type
282 multipart (without a profile entry), will be treated as multipart/mixed.
284 If none of these apply, then
286 will check to see if the message
287 has an application/octet-stream content with parameter \*(lqtype=tar\*(rq.
290 will use an appropriate command. If not,
294 Example entries might be:
298 mhshow-show-audio/basic: raw2audio 2>/dev/null | play
299 mhshow-show-image: xv '%f'
300 mhshow-show-application/PostScript: lpr -Pps
304 Note that when using the f- or F-escape, it's a good idea to use
305 single-quotes around the escape. This prevents misinterpretation by
306 the shell of any funny characters that might be present in the filename.
310 will process each message serially\0--\0it won't start
311 showing the next message until all the commands executed to display the
312 current message have terminated. In the case of a multipart content
313 (of any subtype listed above), the content contains advice indicating if
314 the parts should be displayed serially or in parallel. Because this may
315 cause confusion, particularly on uni-window displays, the
317 switch can be given to tell
319 to never display parts in parallel.
320 .SS "Showing Alternate Character Sets"
321 Because a content of type text might be in a non-ASCII character
324 encounters a \*(lqcharset\*(rq parameter for
325 this content, it checks if your terminal can display this character
328 checks this by examining the the environment
331 If the value of this environment variable is equal
332 to the value of the charset parameter, then
335 display this content without any additional setup. If this environment
338 will assume a value of \*(lqUS-ASCII\*(rq.
339 If the character set cannot be displayed natively, then
341 will look for an entry of the form:
344 mhshow-charset-<charset>
347 which should contain a command creating an environment to render
348 the character set. This command string should containing a single
349 \*(lq%s\*(rq, which will be filled-in with the command to display the
352 Example entries might be:
355 mhshow-charset-iso-8859-1: xterm -fn '-*-*-medium-r-normal-*-*-120-*-*-c-*-iso8859-*' -e %s
361 mhshow-charset-iso-8859-1: '%s'
364 The first example tells
369 appropriate character set for that message content. The second example
372 that your pager (or other program handling that content
373 type) can handle that character set, and that no special processing is
376 Note that many pagers strip off the high-order bit or have problems
377 displaying text with the high-order bit set. However, the pager
379 has support for single-octet character sets. The source
382 is available on many ftp sites carrying free software.
383 In order to view messages sent in the ISO-8859-1 character set using
386 put these lines in your
392 setenv LESSCHARSET latin1
399 to use the ISO-8859-1 definition for
400 determining whether a character is \*(lqnormal\*(rq, \*(lqcontrol\*(lq,
401 or \*(lqbinary\*(rq. The second line tells
404 if it encounters a file that has non-ASCII characters. Then, simply
410 called automatically. (To handle other single-octet character sets,
413 manual entry for information about the
415 environment variable.)
416 .SS "Messages of Type message/partial"
418 cannot directly display messages of type partial.
419 You must reassemble them first into a normal message using
421 Check the man page for
424 .SS "External Access"
425 For contents of type message/external-body,
427 supports these access-types:
440 For the \*(lqanon-ftp\*(rq and \*(lqftp\*(rq access types,
442 will look for the \*(lqnmh-access-ftp\*(rq
446 nmh-access-ftp: myftp.sh
449 to determine the pathname of a program to perform the FTP retrieval.
451 This program is invoked with these arguments:
455 domain name of FTP-site
461 \*(lqascii\*(rq or \*(lqbinary\*(rq
465 The program should terminate with an exit status of zero if the
466 retrieval is successful, and a non-zero exit status otherwise.
468 If this entry is not provided, then
471 built-in FTP client to perform the retrieval.
472 .SS "The Content Cache"
475 encounters an external content containing a
476 \*(lqContent-ID:\*(rq field, and if the content allows caching, then
477 depending on the caching behavior of
479 the content might be read from or written to a cache.
481 The caching behavior of
483 is controlled with the
487 switches, which define the policy for reading from,
488 and writing to, the cache, respectively. One of four policies may be
489 specified: \*(lqpublic\*(rq, indicating that
492 of a publically-accessible content cache; \*(lqprivate\*(rq, indicating
495 should make use of the user's private content cache;
496 \*(lqnever\*(rq, indicating that
498 should never make use of
499 caching; and, \*(lqask\*(rq, indicating that
503 There are two directories where contents may be cached: the profile entry
504 \*(lqnmh-cache\*(rq names a directory containing world-readable contents, and,
505 the profile entry \*(lqnmh-private-cache\*(rq names a directory containing
506 private contents. The former should be an absolute (rooted) directory
515 might be used if you didn't care that the cache got wiped after each
516 reboot of the system. The latter is interpreted relative to the user's
517 nmh directory, if not rooted, e.g.,
520 nmh-private-cache: .cache
523 (which is the default value).
524 .SS "User Environment"
525 Because the display environment in which
527 operates may vary for
530 will look for the environment variable
532 If present, this specifies the name of an additional
533 user profile which should be read. Hence, when a user logs in on a
534 particular display device, this environment variable should be set to
535 refer to a file containing definitions useful for the given display device.
536 Normally, only entries that deal with the methods to display different
537 content type and subtypes
541 mhshow-show-<type>/<subtype>
546 need be present in this additional profile. Finally,
548 will attempt to consult one other additional user profile,
552 %etcdir%/mhn.defaults
555 which is created automatically during
562 .ta \w'%etcdir%/ExtraBigFileName 'u
563 ^$HOME/\&.mh\(ruprofile~^The user profile
564 ^$MHSHOW~^Additional profile entries
565 ^%etcdir%/mhn.defaults~^System default MIME profile entries
566 ^%etcdir%/mhl.headers~^The headers template
569 .SH "PROFILE COMPONENTS"
573 .ta \w'ExtraBigProfileName 'u
574 ^Path:~^To determine the user's nmh directory
575 ^Current\-Folder:~^To find the default current folder
576 ^Unseen\-Sequence:~^To name sequences denoting unseen messages
577 ^mhlproc:~^Default program to display message headers
578 ^nmh-access-ftp:~^Program to retrieve contents via FTP
579 ^nmh-cache~^Public directory to store cached external contents
580 ^nmh-private-cache~^Personal directory to store cached external contents
581 ^mhshow-charset-<charset>~^Template for environment to render character sets
582 ^mhshow-show-<type>*~^Template for displaying contents
583 ^moreproc:~^Default program to display text/plain content
587 mhbuild(1), mhl(1), mhlist(1), mhstore(1), sendfiles(1)
591 .RB ` +folder "' defaults to the current folder"
592 .RB ` msgs "' defaults to cur"
594 .RB ` \-form\ mhl.headers '
596 .RB ` \-rcache\ ask '
598 .RB ` \-noserialonly '
599 .RB ` \-wcache\ ask '
603 If a folder is given, it will become the current folder. The last
604 message selected will become the current message.