* nntp.el (nntp-send-string): The process-send-string call can,
[gnus] / texi / gnusref.tex
1 %% include file for the Gnus refcard and booklet
2
3 \def\progver{5.10}\def\refver{5.10-1} % program and refcard versions
4 \def\date{Jan, 2003}
5 \def\author{Gnus Bugfixing Girls + Boys $<$bugs@gnus.org$>$}
6
7 %%
8 \newlength{\keycolwidth}
9 \newenvironment{keys}[1]% #1 is the widest key
10 {\nopagebreak%\noindent%
11   \settowidth{\keycolwidth}{#1}%
12   \addtolength{\keycolwidth}{\tabcolsep}%
13   \addtolength{\keycolwidth}{-\columnwidth}%
14   \begin{supertabular}{@{}l@{\hspace{\tabcolsep}}p{-\keycolwidth}@{}}}%
15   {\end{supertabular}\\}
16
17 %% uncomment the first definition if you do not want pagebreaks in maps
18 %%\newcommand{\esamepage}{\samepage}
19 \newcommand{\esamepage}{}
20
21 \newcommand*{\B}[1]{{\bf#1})}    % bold l)etter
22
23 \newcommand{\Title}{%
24   \begin{center}
25     {\bf\LARGE Gnus \progver\ Reference \Guide\\}
26                                 %{\normalsize \Guide\ version \refver}
27   \end{center}
28   }
29
30 \newcommand*{\Logo}[1]{\centerline{%
31     \makebox[\logoscale\logowidth][l]{\vbox to \logoscale\logoheight
32       {\vfill\epsfig{figure=gnuslogo-#1}}\vspace{-\baselineskip}}}}
33
34 \newcommand{\Copyright}{%
35   \begin{center}
36     Copyright \copyright\ 1995 Free Software Foundation, Inc.\\*
37     Copyright \copyright\ 1995 Vladimir Alexiev
38     $<$vladimir@cs.ualberta.ca$>$.\\*
39     Copyright \copyright\ 2000 Felix Natter $<$fnatter@gmx.net$>$.\\*
40     Copyright \copyright\ 2001, 2002, 2003 \author.\\*
41     Created from the Gnus manual Copyright \copyright\ 1994 Lars Magne
42     Ingebrigtsen.\\*
43     and the Emacs Help Bindings feature (C-h b).\\*
44     Gnus logo copyright \copyright\ 1995 Luis Fernandes.\\*
45   \end{center}
46
47   Permission is granted to make and distribute copies of this reference
48   \guide{} provided the copyright notice and this permission are preserved on
49   all copies.  Please send corrections, additions and suggestions to the
50   current maintainer's email address. \Guide{} last edited on \date.
51   }
52
53 \newcommand{\Notes}{%
54   \subsection*{Notes}
55   {\esamepage
56     Gnus is complex. Currently it has some 876 interactive (user-callable)
57     functions. Of these 618 are in the two major modes (Group and
58     Summary/Article). Many of these functions have more than one binding, some
59     have 3 or even 4 bindings. The total number of keybindings is 677. So in
60     order to save 40\% space, every function is listed only once on this
61     \guide, under the ``more logical'' binding. Alternative bindings are given
62     in parentheses in the beginning of the description.
63
64     Many Gnus commands are affected by the numeric prefix. Normally you enter a
65     prefix by holding the Meta key and typing a number, but in most Gnus modes
66     you don't need to use Meta since the digits are not self-inserting. The
67     prefixed behavior of commands is given in [brackets]. Often the prefix is
68     used to specify:
69
70     \quad [distance] How many objects to move the point over.
71
72     \quad [scope] How many objects to operate on (including the current one).
73
74     \quad [p/p] The ``Process/Prefix Convention'': If a prefix is given then it
75     determines how many objects to operate on. Else if there are some objects
76     marked with the process mark \#, these are operated on. Else only the
77     current object is affected.
78
79     \quad [level] A group subscribedness level. Only groups with a lower or
80     equal level will be affected by the operation. If no prefix is given,
81     `gnus-group-default-list-level' is used.  If
82     `gnus-group-use-permanent-levels', then a prefix to the `g' and `l'
83     commands will also set the default level.
84
85     \quad [score] An article score. If no prefix is given,
86     `gnus-summary-default-score' is used. \\*[\baselineskip]
87                                 % some keys
88     Gnus startup-commands:
89     \begin{keys}{M-x gnus-unplugged}
90       M-x gnus           & start Gnus. \\
91       M-x gnus-no-server & start Gnus without connecting to server
92       (i.e. to read mail). \\
93     \end{keys}
94     Additionally, there are the two commands \texttt{gnus-plugged} and
95     \texttt{gnus-unplugged}, which are only used if you want to download
96     news and/or read previously downloaded news offline (see C-c C-i g Gnus
97     Unplugged RET). Note: \texttt{gnus-no-server} ignores the stuff in
98     \texttt{gnus-agent-directory}, and thus does not allow you to use Gnus
99     Unplugged.
100                                 %
101     \begin{keys}{C-c C-i}
102       C-c C-i & Go to the Gnus online {\bf info}.\\
103       C-c C-b & Send a Gnus {\bf bug} report.\\
104     \end{keys}
105     }}
106
107 \newcommand{\GroupLevels}{%
108   The table below assumes that you use the default Gnus levels.
109   Fill your user-specific levels in the blank cells.\\[1\baselineskip]
110   \begin{tabular}{|c|l|l|}
111     \hline
112     Level & Groups & Status \\
113     \hline
114     1 & draft/mail groups   &              \\
115     2 & mail groups         &              \\
116     3 &                     & subscribed   \\
117     4 &                     &              \\
118     5 & default list level  &              \\
119     \hline
120     6 &                     & unsubscribed \\
121     7 &                     &              \\
122     \hline
123     8 &                     & zombies      \\
124     \hline
125     9 &                     & killed       \\
126     \hline
127   \end{tabular}}
128
129 \newcommand{\MarkCharacters}{%
130   {\esamepage If a command directly sets a mark, it is shown in parentheses.\\*
131     \newlength{\markcolwidth}
132     \settowidth{\markcolwidth}{` '}% widest character
133     \addtolength{\markcolwidth}{4\tabcolsep}
134     \addtolength{\markcolwidth}{-\columnwidth}
135     \newlength{\markdblcolwidth}
136     \setlength{\markdblcolwidth}{\columnwidth}
137     \addtolength{\markdblcolwidth}{-2\tabcolsep}
138     \begin{tabular}{|c|p{-\markcolwidth}|}
139       \hline
140       \multicolumn{2}{|p{\markdblcolwidth}|}{{\bf ``Read'' Marks.}
141         All these marks appear in the first column of the summary line, and so
142         are mutually exclusive.}\\ 
143       \hline
144       ` ' & (M-u, M SPC, M c) Not read.\\
145       !   & (!, M !, M t) Ticked (interesting).\\
146       ?   & (?, M ?) Dormant (only followups are interesting).\\
147       E   & (E, M e, M x) {\bf Expirable}. Only has effect in mail groups.\\
148       G   & (C, B DEL) Canceled article (or deleted in mailgroups).\\
149       \hline\hline
150       \multicolumn{2}{|p{\markdblcolwidth}|}
151       {The marks below mean that the article
152         is read (killed, uninteresting), and have more or less the same effect.
153         Some commands however explicitly differentiate between them (e.g.\ M
154         M-C-r, adaptive scoring).}\\
155       \hline
156       r   & (d, M d, M r) Deleted (marked as {\bf read}).\\
157       C   & (M C; M C-c; M H; c, Z c; Z n; Z C) Killed by {\bf catch-up}.\\
158       F   & SOUPed article. See the manual.\\
159       O   & {\bf Old} (read in a previous session).\\
160       K   & (k, M k; C-k, M K) {\bf Killed}.\\
161       M   & Article marked as read by duplicate suppression.\\
162       Q   & Article is part of a sparse thread (see ``Threading''
163       in the manual).\\
164       R   & {\bf Read} (viewed in actuality).\\
165       X   & Killed by a kill file.\\
166       Y   & Killed due to low score.\\
167       \hline\multicolumn{2}{c}{\vspace{1ex}}\\\hline
168       \multicolumn{2}{|p{\markdblcolwidth}|}
169       {{\bf Marks not affecting visibility}}\\
170       \hline
171       \#  & (\#, M \#, M P p) Processable (will be affected by the next operation).
172       [2]\\
173       A   & {\bf Answered} (followed-up or replied). [2]\\
174       $\ast$  & Cached. [2]\\
175       S   & Saved. [2]\\
176       N   & Recently arrived. [2]\\
177       .   & Unseen. [2]\\
178       +   & Over default score. [3]\\
179       $-$ & Under default score. [3]\\
180       $=$ & Has children (thread underneath it). Add `\%e' to
181       `gnus-summary-line-format'. [3]\\
182       \hline
183     \end{tabular}
184     }}
185
186 \newcommand{\GroupModeGeneral}{%
187   \begin{keys}{C-c M-C-x}
188     RET     & (=) Enter this group. [Prefix: how many (read) articles to fetch.
189     Positive: newest articles, negative: oldest ones; non-numerical:
190     view all articles, not just unread]\\
191     M-RET   & Enter group quickly.\\
192     M-SPC   & Same as RET but does not expunge and hide dormants.\\
193     M-C-RET & Enter group without any processing, changes will not be permanent.\\
194     SPC     & Select this group and display the first (unread) article. [Same
195     prefix as above.]\\
196     ?       & Give a very short help message.\\
197     $<$     & Go to the beginning of the Group buffer.\\
198     $>$     & Go to the end of the Group buffer.\\
199     ,       & Jump to the lowest-level group with unread articles.\\
200     .       & Jump to the first group with unread articles.\\
201     \^{}      & Enter the Server buffer mode.\\
202     a       & Post an {\bf article} to a group
203               [Prefix: use group under point to find posting-style].\\
204     b       & Find {\bf bogus} groups and delete them.\\
205     c       & Mark all unticked articles in this group as read ({\bf catch-up}).
206     [p/p]\\ 
207     g       & Check the server for new articles ({\bf get}). [level]\\
208     M-g     & Check the server for new articles in this group ({\bf get}). [p/p]\\
209     j       & {\bf Jump} to a group.\\
210     m       & {\bf Mail} a message to someone
211               [Prefix: use group under point to find posting-style].\\
212     n       & Go to the {\bf next} group with unread articles. [distance]\\
213     M-n     & Go to the {\bf next} group on the same or lower level.
214     [distance]\\ 
215     p       & (DEL) Go to the {\bf previous} group with unread articles.
216     [distance]\\ 
217     M-p     & Go to the {\bf previous} group on the same or lower level. [distance]\\ 
218     q       & {\bf Quit} Gnus.\\
219     r       & Re-read the init file ({\bf reset}).\\
220     s       & {\bf Save} the `.newsrc.eld' file (and `.newsrc' if
221     `gnus-save-newsrc-file').\\ 
222     z       & Suspend (kill all buffers of) Gnus.\\
223     B       & {\bf Browse} a foreign server.\\
224     C       & Mark all articles in this group as read ({\bf Catch-up}). [p/p]\\
225     F       & {\bf Find} new groups and process them.\\
226     N       & Go to the {\bf next} group. [distance]\\
227     P       & Go to the {\bf previous} group. [distance]\\
228     Q       & {\bf Quit} Gnus without saving any startup (.newsrc) files.\\
229     R       & {\bf Restart} Gnus.\\
230     Z       & Clear the dribble buffer.\\
231     M-c     & Clear data from group (marks and list of read articles). \\
232     C-c C-s & {\bf Sort} the groups by name, number of unread articles, or level
233     (depending on `gnus-group-sort-function').\\
234     C-c C-x & Run all expirable articles in this group through the {\bf expiry} 
235     process.\\
236     C-c M-C-x & Run all articles in all groups through the {\bf expiry} process.\\
237     C-c M-g & Activate all {\bf groups}.\\
238     C-c C-i & Gnus online-manual ({\bf info}).\\
239     C-x C-t & {\bf Transpose} two groups.\\
240     H f     & Fetch this group's {\bf FAQ} (using ange-ftp).\\
241     H c     & Display this group's {\bf charter}. [Prefix: query for group]\\
242     H C     & Display this group's {\bf control message} (using
243     ange-ftp). [Prefix: query for group]\\
244     H v     & (V) Display the Gnus {\bf version} number.\\
245     H d     & (C-c C-d) Show the {\bf description} of this group
246     [Prefix: re-read from server].\\ 
247     M-d     & {\bf Describe} all groups. [Prefix: re-read from server]\\
248     D g     & Regenerate a Sieve script from group parameters.\\
249     D u     & Regenerate Sieve script and {\bf upload} to server.\\
250   \end{keys}
251   }
252
253 \newcommand{\ListGroups}{%
254   {\esamepage
255     \begin{keys}{A M}
256       A d     & (C-c C-M-a) List all groups whose names or {\bf descriptions} match a regexp.\\ 
257       A k     & (C-c C-l) List all {\bf killed} groups.
258       [Prefix: look at active-file from server]\\
259       A l     & List all groups on a specific level.
260       [Prefix: also list groups with no unread articles]\\
261       A a     & (C-c C-a) List all groups whose names match a regexp
262       ({\bf apropos}).\\ 
263       A A     & List the server's active-file.\\
264       A M     & List groups that {\bf match} a regexp.\\
265       A m     & List groups that {\bf match} a regexp and have unread articles. 
266       [level]\\ 
267       A s     & (l) List all {\bf subscribed} groups with unread articles.
268       [level; 5 and lower is the default]\\
269       A u     & (L) List all groups (including read and {\bf unsubscribed}).
270       [level; 7 and lower is the default]\\
271       A z     & List all {\bf zombie} groups.\\
272       A c     & List all groups with cached articles. [level]\\
273       A ?     & List all groups with dormant articles. [level]\\
274     \end{keys}
275     }
276
277   \newcommand{\CreateEditGroups}{%
278     {\esamepage
279       The select methods are indicated in parentheses.\\*
280       \begin{keys}{G DEL}
281         G a     & Make the Gnus list {\bf archive} group. (nndir over ange-ftp)\\
282         G c     & {\bf Customize} this group's parameters.\\
283         G d     & Make a {\bf directory} group (every file must be a posting and files
284         must have numeric names). (nndir)\\
285         G D     & Enter a {\bf directory} as a (temporary) group.
286         (nneething without recording articles read)\\
287         G e     & (M-e) {\bf Edit} this group's select method.\\
288         G E     & {\bf Edit} this group's info (select method, articles read, etc).\\
289         G f     & Make a group based on a {\bf file}. (nndoc)\\
290         G h     & Make the Gnus {\bf help} (documentation) group. (nndoc)\\
291         G k     & Make a {\bf kiboze} group. (nnkiboze)\\
292         G m     & {\bf Make} a new group.\\
293         G p     & Edit this group's {\bf parameters}.\\
294         G r     & Rename this group (does not work with read-only groups!).\\
295         G u     & Create one of the groups mentioned in gnus-{\bf useful}-groups.\\
296         G v     & Add this group to a {\bf virtual} group. [p/p]\\
297         G V     & Make a new empty {\bf virtual} group. (nnvirtual)\\
298         G w     & Create ephemeral group based on web-search. [Prefix: make solid group
299         instead]\\
300         G DEL   & {\bf Delete} group [Prefix: delete all articles as well].\\
301         G x     & Expunge all deleted articles in an nnimap mailbox.\\
302         G l     & Edit ACL (Access Control {\bf List}) for an nnimap mailbox.\\
303       \end{keys}
304       You can also create mail-groups and read your mail with Gnus (very useful
305       if you are subscribed to mailing lists), using one of the methods
306       nnmbox, nnbabyl, nnml, nnmh, or nnfolder. Read about it in the online info
307       (C-c C-i g Reading Mail RET).
308       }}
309
310                                 % TODO:
311   \newcommand{\SoupCommands}{%
312     \begin{keys}{G s w}
313       G s b   & gnus-group-brew-soup: not documented.\\
314       G s p   & gnus-soup-pack-packet: not documented.\\
315       G s r   & nnsoup-pack-replies: not documented.\\
316       G s s   & gnus-soup-send-replies: not documented.\\
317       G s w   & gnus-soup-save-areas: not documented.\\
318     \end{keys}}
319
320   \newcommand{\MarkGroups}{%
321     \begin{keys}{M m}
322       M m     & (\#) Set the process {\bf mark} on this group. [scope]\\
323       M r     & Mark all groups matching regular expression.\\
324       M u     & (M-\#) Remove the process mark from this group ({\bf unmark}).
325       [scope]\\ 
326       M U     & Remove the process mark from all groups (\textbf{umark all}).\\
327       M w     & Mark all groups in the current region. [prefix: unmark]\\
328       M b     & Mark all groups in the {\bf buffer}. [prefix: unmark]\\
329     \end{keys}}
330
331   \newcommand{\GroupTopicsGeneral}{%
332     {\esamepage
333       Topics are ``categories'' for groups. Press t in the group-buffer to
334       toggle gnus-topic-mode (C-c C-i g Group Topics RET).\\*
335       \begin{keys}{C-c C-x}
336         T n     & Prompt for topic {\bf name} and create it.\\
337         T m     & {\bf Move} the current group to some other topic [p/p].\\
338         T j     & {\bf Jump} to a topic.\\
339         T c     & {\bf Copy} the current group to some other topic [p/p].\\
340         T D     & Remove (not delete) the current group [p/p].\\
341         T M     & {\bf Move} all groups matching a regexp to a topic.\\
342         T C     & {\bf Copy} all groups matching a regexp to a topic.\\
343         T H     & Toggle {\bf hiding} of empty topics.\\
344         T r     & {\bf Rename} a topic.\\
345         T DEL   & Delete an empty topic.\\
346         T \#    & Mark all groups in the current topic with the process-mark.\\
347         T M-\#  & Remove the process-mark from all groups in the current topic.\\
348         T TAB   & (TAB) Indent current topic [Prefix: unindent].\\ 
349         M-TAB   & Unindent the current topic.\\
350         RET     & (SPC) Either unfold topic or enter group [level].\\
351         T s     & {\bf Show} the current topic. [Prefix: show permanently]\\
352         T h     & {\bf Hide} the current topic. [Prefix: hide permanently]\\
353         C-c C-x & Expire all articles in current group or topic.\\
354         C-k     & {\bf Kill} a group or topic.\\
355         C-y     & {\bf Yank} a group or topic.\\
356         A T     & List active-file using {\bf topics}.\\
357         G p     & Edit topic-{\bf parameters}.\\
358         T M-n   & Go to {\bf next} topic. [distance]\\
359         T M-p   & Go to {\bf previous} topic. [distance]\\
360       \end{keys}
361       }
362     }
363
364   \newcommand{\TopicSorting}{%
365     {\esamepage
366       \begin{keys}{T S m}
367         T S a  & Sort {\bf alphabetically}.\\
368         T S u  & Sort by number of {\bf unread} articles.\\
369         T S l  & Sort by group {\bf level}.\\
370         T S v  & Sort by group score ({\bf value}).\\
371         T S r  & Sort by group {\bf rank}.\\
372         T S m  & Sort by {\bf method}.\\
373         T S e  & Sort by {\bf server} name.\\
374         T S s  & Sort according to `gnus-group-sort-function'.\\
375       \end{keys}
376       With a prefix these commands will sort in reverse order.
377       }
378     }
379
380   \newcommand{\SubscribeKillYankGroups}{%
381     {\esamepage
382       \begin{keys}{S C-k}
383         S k     & (C-k) {\bf Kill} this group.\\
384         S l     & Set the {\bf level} of this group. [p/p]\\
385         S s     & (U) Prompt for a group and toggle its {\bf subscription}.\\
386         S t     & (u) {\bf Toggle} subscription to this group. [p/p]\\
387         S w     & (C-w) Kill all groups in the region.\\
388         S y     & (C-y) {\bf Yank} the last killed group.\\
389         S z     & Kill all {\bf zombie} groups.\\
390         S C-k   & Kill all groups on a certain level.\\
391       \end{keys}
392       }
393     }
394
395   \newcommand{\SummaryModeGeneral}{%
396     {\esamepage
397       \begin{keys}{M-RET}
398         SPC     & (A SPC, A n) Select an article, scroll it one page, move to the
399         next one.\\ 
400         DEL     & (A DEL, A p, b) Scroll this article one page back. [distance]\\
401         RET     & (A RET) Scroll this article one line forward. [distance]\\
402         M-RET   & (A M-RET) Scroll this article one line backward. [distance]\\
403         =       & Expand the Summary window (fullsize).
404         [Prefix: shrink to display article window]\\
405                                 %
406         \&      & Execute a command on all articles whose header matches a regexp.
407         [Prefix: move backwards]\\
408         M-\&    & Execute a command on all articles having the process mark.\\
409                                 %
410         M-n     & (G M-n) Go to the {\bf next} summary line of an unread article.
411         [distance]\\ 
412         M-p     & (G M-p) Go to the {\bf previous} summary line of an unread article. 
413         [distance]\\ 
414         M-s     & {\bf Search} through all subsequent articles for a regexp.\\
415         M-r     & Search through all previous articles for a regexp.\\
416                                 %
417         A P     & {\bf Postscript}-print current buffer.\\
418                                 %
419         M-k     & Edit this group's {\bf kill} file.\\
420         M-K     & Edit the general {\bf kill} file.\\
421                                 %
422         C-t     & Toggle {\bf truncation} of summary lines.\\
423         Y g     & Regenerate the summary-buffer.\\
424         Y c     & Insert all cached articles into the summary-buffer.\\
425                                 %
426         M-C-e   & {\bf Edit} the group-parameters.\\
427         M-C-g   & Customize the group-parameters.\\
428                                 %
429                                 % article handling
430                                 %
431         A $<$   & ($<$, A b) Scroll to the beginning of this article.\\
432         A $>$   & ($>$, A e) Scroll to the end of this article.\\
433         A s     & (s) Perform an i{\bf search} in the article buffer.\\
434                                 %
435         A D     & (C-d) Un{\bf digestify} this article into a separate group.
436         [Prefix: force digest]\\
437         M-C-d   & Like C-d, but open several documents in nndoc-groups, wrapped
438         in an nnvirtual group [p/p]\\
439                                 %
440         A g     & (g) (Re)fetch this article ({\bf get}). [Prefix: get raw version]\\ 
441         A r     & (\^{}, A \^{}) Fetch the parent(s) of this article.
442         [Prefix: if positive fetch \textit{n} ancestors;
443         negative: fetch only the \textit{n}th ancestor]\\
444         A t     & {\bf Translate} this article.\\
445         A R     & Fetch all articles mentioned in the {\bf References}-header.\\
446         A T     & Fetch full \textbf{thread} in which the current article appears.\\
447         M-\^{}  & Fetch the article with a given Message-ID.\\
448         S y     & {\bf Yank} the current article into an existing message-buffer.
449         [p/p]\\
450         A M     & Setup group parameters for {\bf mailing} lists from
451         headers. [Prefix: replace old settings]\\
452       \end{keys}
453       }
454     }
455
456   \newcommand{\MIMESummary}{%
457     {\esamepage
458       For the commands operating on one MIME part (a subset of gnus-article-*), a
459       prefix selects which part to operate on. If the point is placed over a
460       MIME button in the article buffer, use the corresponding bindings for the
461       article buffer instead.
462       \begin{keys}{W M w}
463         K v      & (b, W M b) {\bf View} the MIME-part.\\
464         K o      & {\bf Save} the MIME part.\\
465         K c      & {\bf Copy} the MIME part.\\
466         K e      & View the MIME part {\bf externally}.\\
467         K i      & View the MIME part {\bf internally}.\\
468         K $\mid$ & Pipe the MIME part to an external command.\\
469         K b      & Make all the MIME parts have buttons in front of them.\\
470         K m      & Try to repair {\bf multipart-headers}.\\
471         K C      & View the MIME part using a differenct {\bf charset}.\\
472         X m      & Save all parts matching a MIME type to a directory. [p/p]\\
473         M-t      & Toggle the buttonized display of the article buffer.\\
474         W M w    & Decode RFC2047-encoded words in the article headers.\\
475         W M c    & Decode encoded article bodies. [Prefix: prompt for charset]\\
476         W M v    & View all MIME parts in the current article.\\
477       \end{keys}
478       }
479     }
480
481   \newcommand{\SortSummary}{%
482     {\esamepage
483       \begin{keys}{C-c C-s C-a}
484         C-c C-s C-a & Sort the summary-buffer by {\bf author}.\\
485         C-c C-s C-d & Sort the summary-buffer by {\bf date}.\\
486         C-c C-s C-i & Sort the summary-buffer by article score.\\
487         C-c C-s C-l & Sort the summary-buffer by amount of {\bf lines}.\\
488         C-c C-s C-c & Sort the summary-buffer by length.\\
489         C-c C-s C-n & Sort the summary-buffer by article {\bf number}.\\
490         C-c C-s C-s & Sort the summary-buffer by {\bf subject}.\\
491         C-c C-s C-r & Sort the summary-buffer {\bf randomly}.\\
492         C-c C-s C-o & Sort the summary-buffer using the default method.\\
493       \end{keys}
494       With a prefix these functions sort in reverse order.
495       }
496     }
497
498   \newcommand{\MailGroups}{% formerly \Bsubmap
499     {\esamepage
500       These commands (except `B c') are only valid in a mail group.\\*
501       \begin{keys}{B M-C-e}
502         B DEL   & (B backspace, B delete) {\bf Delete} the mail article from disk (!).
503         [p/p]\\
504         B B     & Crosspost this article to another group.\\
505         B c     & {\bf Copy} this article from any group to a mail group. [p/p]\\
506         B e     & {\bf Expire} all expirable articles in this group. [p/p]\\
507         B i     & {\bf Import} a random file into this group.\\
508         B I     & Create an empty article in this group.\\
509         B m     & {\bf Move} the article from one mail group to another. [p/p]\\
510         B p     & Query whether the article was {\bf posted} as well.\\
511         B q     & {\bf Query} where the article will end up after fancy splitting\\
512         B r     & {\bf Respool} this mail article. [p/p]\\
513         B t     & {\bf Trace} the fancy splitting patterns applied to this article.\\
514         B w     & (e) Edit this article.\\
515         B M-C-e & {\bf Expunge} (delete from disk) all expirable articles in this group
516         (!). [p/p]\\ 
517         K E     & {\bf Encrypt} article body. [p/p]\\
518       \end{keys}
519       }
520     }
521
522   \newcommand{\DraftGroup}{% formerly \Dsubmap
523     {\esamepage
524       The ``drafts''-group contains messages that have been saved but not sent
525       and rejected articles. \\*
526       \begin{keys}{B DEL}
527         D e      & \textbf{edit} message.\\
528         D s      & \textbf{Send} message. [p/p]\\
529         D S      & \textbf{Send} all messages.\\
530         D t      & \textbf{Toggle} sending (mark as unsendable).\\
531         B DEL    & \textbf{Delete} message (like in mailgroup).\\
532       \end{keys}
533       }
534     }
535
536   \newcommand{\SelectArticles}{% formerly \Gsubmap
537     {\esamepage
538       These commands select the target article. They do not understand the prefix.\\*
539       \begin{keys}{G C-n}
540         h       & Enter article-buffer.\\
541         G b     & (,) Go to the {\bf best} article (the one with highest score).\\
542         G f     & (.) Go to the {\bf first} unread article.\\
543         G n     & (n) Go to the {\bf next} unread article.\\
544         G p     & (p) Go to the {\bf previous} unread article.\\
545                                 %
546         G N     & (N) Go to {\bf the} next article.\\
547         G P     & (P) Go to the {\bf previous} article.\\
548                                 %
549         G C-n   & (M-C-n) Go to the {\bf next} article with the same subject.\\
550         G C-p   & (M-C-p) Go to the {\bf previous} article with the same subject.\\
551                                 %
552         G l     & (l) Go to the previously read article ({\bf last-read-article}).\\
553         G o     & Pop an article off the summary history and go to it.\\
554                                 %
555         G g     & Search an article via subject.\\
556         G j     & (j) Search an article via Message-Id or subject.\\
557       \end{keys}
558       }
559     }
560
561   \newcommand{\ArticleModeGeneral}{%
562     {\esamepage
563       The normal navigation keys work in Article mode. Some additional keys are:\\
564       \begin{keys}{C-c RET}
565         C-c \^{} & Get the article with the Message-ID near point.\\
566         C-c RET & Send reply to address near point.\\
567         h       & Go to the \textbf{header}-line of the article in the
568         summary-buffer.\\
569         s       & Go to \textbf{summary}-buffer.\\
570         RET     & (middle mouse button) Activate the button at point to follow
571         an URL or Message-ID.\\
572         TAB     & Move the point to the next button.\\
573         M-TAB   & Move point to previous button.\\
574       \end{keys}
575       }
576     }
577
578   \newcommand{\WashArticle}{% formerly \Wsubmap
579     {\esamepage
580       \begin{keys}{W W H}
581         W 6     & Translate a base64 article.\\
582         W a     & Strip certain {\bf headers} from body.\\
583         W b     & Make Message-IDs and URLs in the article mouse-clickable
584         {\bf buttons}.\\  
585         W c     & Translate CRLF-pairs to LF and then the remaining CR's to LF's.\\
586         W d     & Treat {\bf dumbquotes}.\\
587         W e     & Treat {\bf emphasized} text.\\
588         W h     & Treat {\bf HTML}.\\
589         W k     & Deuglify broken Outlook (Express) articles and redisplay.\\
590         W l     & (w) Remove page breaks ({\bf\^{}L}) from the article.\\
591         W m     & Toggle {\bf MIME} processing.\\
592         W o     & Treat {\bf overstrike} or underline (\^{}H\_) in the article.\\
593         W p     & Verify X-{\bf PGP}-Sig header.\\
594         W q     & Treat {\bf quoted}-printable in the article.\\
595         W r     & (C-c C-r) Do a Caesar {\bf rotate} (rot13) on the article.\\
596         W s     & Verify (and decrypt) a {\bf signed} message.\\
597         W t     & (t) {\bf Toggle} display of all headers.\\
598         W u     & {\bf Unsplit} broken URLs.\\
599         W v     & (v) Toggle permanent {\bf verbose} displaying of all headers.\\
600         W w     & Do word {\bf wrap} in the article.\\
601         W B     & Add clickable {\bf buttons} to the article headers.\\
602         W C     & {\bf Capitalize} first word in each sentence.\\
603         W Q     & Fill long lines.\\
604         W Z     & Translate a HZ-encoded article.\\
605                                 %
606         W G u   & {\bf Unfold} folded header lines.\\
607         W G f   & {\bf Fold} all header lines.\\
608         W G n   & Unfold {\bf Newsgroups:} and Follow-Up-To:.\\
609       \end{keys}
610       }
611     }
612
613   \newcommand{\BlankAndWhitespace}{% 
614     {\esamepage
615       \begin{keys}{W E w}
616         W E l   & Strip blank {\bf lines} from the beginning of the article.\\
617         W E m   & Replace blank lines with empty lines and remove {\bf multiple}
618         blank lines.\\
619         W E t   & Remove {\bf trailing} blank lines.\\
620         W E a   & Strip blank lines at the beginning and the end
621         (W E l, W E m and W E t).\\
622         W E A   & Strip {\bf all} blank lines.\\
623         W E s   & Strip leading blank lines from the article body.\\
624         W E e   & Strip trailing blank lines from the article body.\\
625         W E w   & Remove leading {\bf whitespace} from all headers.\\
626       \end{keys}
627 &nbs