]> diplodocus.org Git - nmh/blob - man/mhshow.man
Added note that suffixes were removed from filenames of temporary files.
[nmh] / man / mhshow.man
1 .TH MHSHOW %manext1% "May 4, 2013" "%nmhversion%"
2 .\"
3 .\" %nmhwarning%
4 .\"
5 .SH NAME
6 mhshow \- display MIME messages
7 .SH SYNOPSIS
8 .HP 5
9 .na
10 .B mhshow
11 .RI [ +folder ]
12 .RI [ msgs ]
13 .RB [ \-file
14 .IR file ]
15 .RB [ \-part
16 .IR number ]
17 \&...
18 .RB [ \-type
19 .IR content ]
20 \&...
21 .RB [ \-serialonly " | " \-noserialonly ]
22 .RB [ \-pause " | " \-nopause ]
23 .RB [ \-form
24 .IR formfile ]
25 .RB [ \-rcache
26 .IR policy ]
27 .RB [ \-wcache
28 .IR policy ]
29 .RB [ \-check " | " \-nocheck ]
30 .RB [ \-version ]
31 .RB [ \-help ]
32 .ad
33 .SH DESCRIPTION
34 The
35 .B mhshow
36 command display contents of a MIME (multi-media)
37 message or collection of messages.
38 .PP
39 .B mhshow
40 manipulates multi-media messages as specified in
41 RFC 2045 to RFC 2049. Currently
42 .B mhshow
43 only supports
44 encodings in message bodies, and does not support the encoding of
45 message headers as specified in RFC 2047.
46 .PP
47 By default
48 .B mhshow
49 will display all parts of a multipart
50 message. By using the
51 .B \-part
52 and
53 .B \-type
54 switches, you may
55 limit the scope of
56 .B mhshow
57 to particular subparts (of a
58 multipart content) and/or particular content types.
59 .PP
60 The option
61 .B \-file
62 .I file
63 directs
64 .B mhshow
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
68 .B mhshow
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
72 .B nmh
73 message. It should
74 .B NOT
75 be in mail drop format (to convert a file in
76 mail drop format to a folder of
77 .B nmh
78 messages, see
79 .IR inc (1)).
80 .PP
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
86 .B \-part
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
90 .B \-part
91 switch will not prevent the content from being acted upon.
92 .PP
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.
96 .PP
97 A list of commonly used contents is briefly reproduced here:
98 .PP
99 .RS 5
100 .nf
101 .ta \w'application 'u
102 Type Subtypes
103 ---- --------
104 text plain, enriched
105 multipart mixed, alternative, digest, parallel
106 message rfc822, partial, external-body
107 application octet-stream, postscript
108 image jpeg, gif, png
109 audio basic
110 video mpeg
111 .fi
112 .RE
113 .PP
114 A legal MIME message must contain a subtype specification.
115 .PP
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
127 non\-empty, then
128 .B mhshow
129 will remove each of the messages shown
130 from each sequence named by the profile entry.
131 .SS "Checking the Contents"
132 The
133 .B \-check
134 switch tells
135 .B mhshow
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
139 .B mhshow
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
144 .I mhlproc
145 (usually
146 .BR mhl ),
147 using the standard format file
148 .IR mhl.headers .
149 You may specify an alternate format file with the
150 .B \-form
151 .I formfile
152 switch. If the format file
153 .I mhl.null
154 is specified, then the display
155 of the message headers is suppressed.
156 .PP
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
162 .B soffice
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
167 .B gs
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.
171 .PP
172 To get around this, your profile can contain lines of the form:
173 .PP
174 .RS 5
175 mhshow-suffix-<type>/<subtype>: <suffix>
176 .RE
177 .PP
178 or
179 .PP
180 .RS 5
181 mhshow-suffix-<type>: <suffix>
182 .RE
183 .PP
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:
187 .PP
188 .RS 5
189 .nf
190 mhshow-suffix-text: .txt
191 mhshow-suffix-application/msword: .doc
192 mhshow-suffix-application/PostScript: .ps
193 .fi
194 .RE
195 .PP
196 to automatically append a suffix to the temporary files.
197 .PP
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
200 string,
201 .B mhshow
202 will first search your profile for an entry of the form:
203 .PP
204 .RS 5
205 mhshow-show-<type>/<subtype>
206 .RE
207 .PP
208 to determine the display string. If this isn't found,
209 .B mhshow
210 will search for an entry of the form:
211 .PP
212 .RS 5
213 mhshow-show-<type>
214 .RE
215 .PP
216 to determine the display string.
217 .PP
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
221 set to the content.
222 .PP
223 The display string may contain the following escapes:
224 .PP
225 .RS 5
226 .nf
227 .ta \w'%F 'u
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 %
237 .fi
238 .RE
239 .PP
240 For those display strings containing the e- or F-escape,
241 .B mhshow
242 will
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.
246 .PP
247 When the p-escape prompts for confirmation, typing INTR (usually
248 control-C) will tell
249 .B mhshow
250 not to display that content.
251 The p-escape can be disabled by specifying the switch
252 .BR \-nopause .
253 Further, when
254 .B mhshow
255 is display a content, typing QUIT (usually
256 control-\\) will tell
257 .B mhshow
258 to wrap things up immediately.
259 .PP
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.
264 .PP
265 If a display string is not found,
266 .B mhshow
267 behaves as if these profile entries were supplied and supported:
268 .PP
269 .RS 5
270 .nf
271 mhshow-show-text/plain: %pmoreproc '%F'
272 mhshow-show-message/rfc822: %pshow -file '%F'
273 .fi
274 .RE
275 .PP
276 Note that \*(lqmoreproc\*(rq is not supported in user profile display
277 strings.
278 .PP
279 If a subtype of type text doesn't have a profile entry, it will be
280 treated as text/plain.
281 .PP
282 .B mhshow
283 has default methods for handling multipart messages of subtype
284 mixed, alternative, parallel, and digest. Any unknown subtype of type
285 multipart (without a profile entry), will be treated as multipart/mixed.
286 .PP
287 If none of these apply, then
288 .B mhshow
289 will check to see if the message
290 has an application/octet-stream content with parameter \*(lqtype=tar\*(rq.
291 If so,
292 .B mhshow
293 will use an appropriate command. If not,
294 .B mhshow
295 will complain.
296 .PP
297 Example entries might be:
298 .PP
299 .RS 5
300 .nf
301 mhshow-show-audio/basic: raw2audio 2>/dev/null | play
302 mhshow-show-image: xv '%f'
303 mhshow-show-application/PostScript: lpr -Pps
304 .fi
305 .RE
306 .PP
307 Note that when using the f- or F-escape, it's a good idea to use
308 single-quotes around the escape. This prevents misinterpretation by
309 the shell of any funny characters that might be present in the filename.
310 .PP
311 Finally,
312 .B mhshow
313 will process each message serially\0--\0it won't start
314 showing the next message until all the commands executed to display the
315 current message have terminated. In the case of a multipart content
316 (of any subtype listed above), the content contains advice indicating if
317 the parts should be displayed serially or in parallel. Because this may
318 cause confusion, particularly on uni-window displays, the
319 .B \-serialonly
320 switch can be given to tell
321 .B mhshow
322 to never display parts in parallel.
323 .SS "Showing Alternate Character Sets"
324 Because a content of type text might be in a non-ASCII character
325 set, when
326 .B mhshow
327 encounters a \*(lqcharset\*(rq parameter for
328 this content, it checks if your terminal can display this character
329 set natively.
330 .B mhn
331 checks this by examining the current character set defined by the
332 .IR locale (1)
333 environment variables.
334 If the value of the locale character set is equal
335 to the value of the charset parameter, then
336 .B mhshow
337 assumes it can
338 display this content without any additional setup. If the locale is not
339 set properly,
340 .B mhshow
341 will assume a value of \*(lqUS-ASCII\*(rq.
342 If the character set cannot be displayed natively, then
343 .B mhshow
344 will look for an entry of the form:
345 .PP
346 .RS 5
347 mhshow-charset-<charset>
348 .RE
349 .PP
350 which should contain a command creating an environment to render
351 the character set. This command string should containing a single
352 \*(lq%s\*(rq, which will be filled-in with the command to display the
353 content.
354 .PP
355 Example entries might be:
356 .PP
357 .RS 5
358 mhshow-charset-iso-8859-1: xterm -fn '-*-*-medium-r-normal-*-*-120-*-*-c-*-iso8859-*' -e %s
359 .RE
360 .PP
361 or
362 .PP
363 .RS 5
364 mhshow-charset-iso-8859-1: '%s'
365 .RE
366 .PP
367 The first example tells
368 .B mhshow
369 to start
370 .B xterm
371 and load the
372 appropriate character set for that message content. The second example
373 tells
374 .B mhshow
375 that your pager (or other program handling that content
376 type) can handle that character set, and that no special processing is
377 needed beforehand.
378 .PP
379 Note that many pagers strip off the high-order bit or have problems
380 displaying text with the high-order bit set. However, the pager
381 .B less
382 has support for single-octet character sets. The source
383 to
384 .B less
385 is available on many ftp sites carrying free software.
386 In order to view messages sent in the ISO-8859-1 character set using
387 .BR less ,
388 .PP
389 put these lines in your
390 .I \&.login
391 file:
392 .PP
393 .RS 5
394 .nf
395 setenv LESSCHARSET latin1
396 setenv LESS "-f"
397 .fi
398 .RE
399 .PP
400 The first line tells
401 .B less
402 to use the ISO-8859-1 definition for
403 determining whether a character is \*(lqnormal\*(rq, \*(lqcontrol\*(lq,
404 or \*(lqbinary\*(rq. The second line tells
405 .B less
406 not to warn you
407 if it encounters a file that has non-ASCII characters. Then, simply
408 set the
409 .I moreproc
410 profile entry to
411 .BR less ,
412 and it will get
413 called automatically. (To handle other single-octet character sets,
414 look at the
415 .IR less (1)
416 manual entry for information about the
417 .B $LESSCHARDEF
418 environment variable.)
419 .SS "Messages of Type message/partial"
420 .B mhshow
421 cannot directly display messages of type partial.
422 You must reassemble them first into a normal message using
423 .BR mhstore .
424 Check the man page for
425 .IR mhstore (1)
426 for details.
427 .SS "External Access"
428 For contents of type message/external-body,
429 .B mhshow
430 supports these access-types:
431 .PP
432 .IP \(bu 4
433 afs
434 .IP \(bu 4
435 anon-ftp
436 .IP \(bu 4
437 ftp
438 .IP \(bu 4
439 local-file
440 .IP \(bu 4
441 mail-server
442 .IP \(bu 4
443 url
444 .PP
445 For the \*(lqanon-ftp\*(rq and \*(lqftp\*(rq access types,
446 .B mhshow
447 will look for the \*(lqnmh-access-ftp\*(rq
448 profile entry, e.g.,
449 .PP
450 .RS 5
451 nmh-access-ftp: myftp.sh
452 .RE
453 .PP
454 to determine the pathname of a program to perform the FTP retrieval.
455 .PP
456 This program is invoked with these arguments:
457 .PP
458 .RS 5
459 .nf
460 domain name of FTP-site
461 username
462 password
463 remote directory
464 remote filename
465 local filename
466 \*(lqascii\*(rq or \*(lqbinary\*(rq
467 .fi
468 .RE
469 .PP
470 The program should terminate with an exit status of zero if the
471 retrieval is successful, and a non-zero exit status otherwise.
472 .PP
473 For the \*(lqurl\*(rq access\-type,
474 .B mhshow
475 will look for the \*(lqnmh-access-url\*(rq
476 profile entry. See
477 .IR mhstore (1)
478 for more details.
479 .PP
480 .SS "The Content Cache"
481 When
482 .B mhshow
483 encounters an external content containing a
484 \*(lqContent-ID:\*(rq field, and if the content allows caching, then
485 depending on the caching behavior of
486 .BR mhshow ,
487 the content might be read from or written to a cache.
488 .PP
489 The caching behavior of
490 .B mhshow
491 is controlled with the
492 .B \-rcache
493 and
494 .B \-wcache
495 switches, which define the policy for reading from,
496 and writing to, the cache, respectively. One of four policies may be
497 specified: \*(lqpublic\*(rq, indicating that
498 .B mhshow
499 should make use
500 of a publically-accessible content cache; \*(lqprivate\*(rq, indicating
501 that
502 .B mhshow
503 should make use of the user's private content cache;
504 \*(lqnever\*(rq, indicating that
505 .B mhshow
506 should never make use of
507 caching; and, \*(lqask\*(rq, indicating that
508 .B mhshow
509 should ask the user.
510 .PP
511 There are two directories where contents may be cached: the profile entry
512 \*(lqnmh-cache\*(rq names a directory containing world-readable contents, and,
513 the profile entry \*(lqnmh-private-cache\*(rq names a directory containing
514 private contents. The former should be an absolute (rooted) directory
515 name.
516 .PP
517 For example,
518 .PP
519 .RS 5
520 nmh-cache: /tmp
521 .RE
522 .PP
523 might be used if you didn't care that the cache got wiped after each
524 reboot of the system. The latter is interpreted relative to the user's
525 nmh directory, if not rooted, e.g.,
526 .PP
527 .RS 5
528 nmh-private-cache: .cache
529 .RE
530 .PP
531 (which is the default value).
532 .SS "User Environment"
533 Because the display environment in which
534 .B mhshow
535 operates may vary for
536 different machines,
537 .B mhshow
538 will look for the environment variable
539 .BR $MHSHOW .
540 If present, this specifies the name of an additional
541 user profile which should be read. Hence, when a user logs in on a
542 particular display device, this environment variable should be set to
543 refer to a file containing definitions useful for the given display device.
544 Normally, only entries that deal with the methods to display different
545 content type and subtypes
546 .PP
547 .RS 5
548 .nf
549 mhshow-show-<type>/<subtype>
550 mhshow-show-<type>
551 .fi
552 .RE
553 .PP
554 need be present in this additional profile. Finally,
555 .B mhshow
556 will attempt to consult one other additional user profile,
557 e.g.,
558 .PP
559 .RS 5
560 %etcdir%/mhn.defaults
561 .RE
562 .PP
563 which is created automatically during
564 .B nmh
565 installation.
566 .SH FILES
567 .B mhshow
568 looks for all format files and mhn.defaults in multiple locations:
569 absolute pathnames are accessed directly, tilde expansion is done on
570 usernames, and files are searched for in the user's
571 .I Mail
572 directory as specified in their profile. If not found there, the directory
573 .RI \*(lq %etcdir% \*(rq
574 is checked.
575 .PP
576 .fc ^ ~
577 .nf
578 .ta \w'%etcdir%/ExtraBigFileName 'u
579 ^$HOME/\&.mh\(ruprofile~^The user profile
580 ^$MHSHOW~^Additional profile entries
581 ^%etcdir%/mhn.defaults~^System default MIME profile entries
582 ^%etcdir%/mhl.headers~^The headers template
583 .fi
584 .SH "PROFILE COMPONENTS"
585 .fc ^ ~
586 .nf
587 .ta 2.4i
588 .ta \w'ExtraBigProfileName 'u
589 ^Path:~^To determine the user's nmh directory
590 ^Current\-Folder:~^To find the default current folder
591 ^Unseen\-Sequence:~^To name sequences denoting unseen messages
592 ^mhlproc:~^Default program to display message headers
593 ^nmh-access-ftp:~^Program to retrieve contents via FTP
594 ^nmh-access-url:~^Program to retrieve contents via HTTP
595 ^nmh-cache~^Public directory to store cached external contents
596 ^nmh-private-cache~^Personal directory to store cached external contents
597 ^mhshow-charset-<charset>~^Template for environment to render character sets
598 ^mhshow-show-<type>*~^Template for displaying contents
599 ^moreproc:~^Default program to display text/plain content
600 .fi
601 .SH "SEE ALSO"
602 .IR mhbuild (1),
603 .IR mhl (1),
604 .IR mhlist (1),
605 .IR mhstore (1),
606 .IR sendfiles (1)
607 .SH DEFAULTS
608 .nf
609 .RB ` +folder "' defaults to the current folder"
610 .RB ` msgs "' defaults to cur"
611 .RB ` \-nocheck '
612 .RB ` \-form\ mhl.headers '
613 .RB ` \-pause '
614 .RB ` \-rcache\ ask '
615 .RB ` \-noserialonly '
616 .RB ` \-wcache\ ask '
617 .fi
618 .SH CONTEXT
619 If a folder is given, it will become the current folder. The last
620 message selected will become the current message.