gnus-html.el: Add the new command gnus-html-show-images.
[bpt/emacs.git] / doc / misc / gnus.texi
CommitLineData
4009494e
GM
1\input texinfo
2
db78a8cb 3@setfilename ../../info/gnus
4009494e
GM
4@settitle Gnus Manual
5@syncodeindex fn cp
6@syncodeindex vr cp
7@syncodeindex pg cp
8
01c52d31
MB
9@documentencoding ISO-8859-1
10
4009494e 11@copying
e3e955fe 12Copyright @copyright{} 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
c57008f6 132003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc.
4009494e
GM
14
15@quotation
16Permission is granted to copy, distribute and/or modify this document
6a2c4aec 17under the terms of the GNU Free Documentation License, Version 1.3 or
4009494e 18any later version published by the Free Software Foundation; with no
debf4439
GM
19Invariant Sections, with the Front-Cover texts being ``A GNU Manual'',
20and with the Back-Cover Texts as in (a) below. A copy of the license
21is included in the section entitled ``GNU Free Documentation License''.
4009494e 22
6f093307
GM
23(a) The FSF's Back-Cover Text is: ``You have the freedom to copy and
24modify this GNU manual. Buying copies from the FSF supports it in
25developing GNU and promoting software freedom.''
4009494e
GM
26@end quotation
27@end copying
28
29@iftex
30@iflatex
31\documentclass[twoside,a4paper,openright,11pt]{book}
32\usepackage[latin1]{inputenc}
33\usepackage{pagestyle}
34\usepackage{epsfig}
35\usepackage{pixidx}
36\input{gnusconfig.tex}
37
38\ifx\pdfoutput\undefined
39\else
40\usepackage[pdftex,bookmarks,colorlinks=true]{hyperref}
41\usepackage{thumbpdf}
42\pdfcompresslevel=9
43\fi
44
45\makeindex
46\begin{document}
47
48% Adjust ../Makefile.in if you change the following line:
c7ff939a 49\newcommand{\gnusversionname}{Gnus v5.13}
4009494e
GM
50\newcommand{\gnuschaptername}{}
51\newcommand{\gnussectionname}{}
52
53\newcommand{\gnusbackslash}{/}
54
55\newcommand{\gnusref}[1]{``#1'' on page \pageref{#1}}
56\ifx\pdfoutput\undefined
57\newcommand{\gnusuref}[1]{\gnustt{#1}}
58\else
59\newcommand{\gnusuref}[1]{\href{#1}{\gnustt{#1}}}
60\fi
61\newcommand{\gnusxref}[1]{See ``#1'' on page \pageref{#1}}
62\newcommand{\gnuspxref}[1]{see ``#1'' on page \pageref{#1}}
63
64\newcommand{\gnuskindex}[1]{\index{#1}}
65\newcommand{\gnusindex}[1]{\index{#1}}
66
67\newcommand{\gnustt}[1]{{\gnusselectttfont{}#1}}
68\newcommand{\gnuscode}[1]{\gnustt{#1}}
69\newcommand{\gnusasis}[1]{\gnustt{#1}}
70\newcommand{\gnusurl}[1]{\gnustt{#1}}
71\newcommand{\gnuscommand}[1]{\gnustt{#1}}
72\newcommand{\gnusenv}[1]{\gnustt{#1}}
73\newcommand{\gnussamp}[1]{``{\fontencoding{OT1}\gnusselectttfont{}#1}''}
74\newcommand{\gnuslisp}[1]{\gnustt{#1}}
75\newcommand{\gnuskbd}[1]{`\gnustt{#1}'}
76\newcommand{\gnuskey}[1]{`\gnustt{#1}'}
77\newcommand{\gnusfile}[1]{`\gnustt{#1}'}
78\newcommand{\gnusdfn}[1]{\textit{#1}}
79\newcommand{\gnusi}[1]{\textit{#1}}
80\newcommand{\gnusr}[1]{\textrm{#1}}
81\newcommand{\gnusstrong}[1]{\textbf{#1}}
82\newcommand{\gnusemph}[1]{\textit{#1}}
83\newcommand{\gnusvar}[1]{{\fontsize{10pt}{10}\selectfont\textsl{\textsf{#1}}}}
84\newcommand{\gnussc}[1]{\textsc{#1}}
85\newcommand{\gnustitle}[1]{{\huge\textbf{#1}}}
86\newcommand{\gnusversion}[1]{{\small\textit{#1}}}
87\newcommand{\gnusauthor}[1]{{\large\textbf{#1}}}
88\newcommand{\gnusresult}[1]{\gnustt{=> #1}}
89\newcommand{\gnusacronym}[1]{\textsc{#1}}
90\newcommand{\gnusemail}[1]{\textit{#1}}
91
92\newcommand{\gnusbullet}{{${\bullet}$}}
93\newcommand{\gnusdollar}{\$}
94\newcommand{\gnusampersand}{\&}
95\newcommand{\gnuspercent}{\%}
96\newcommand{\gnushash}{\#}
97\newcommand{\gnushat}{\symbol{"5E}}
98\newcommand{\gnusunderline}{\symbol{"5F}}
99\newcommand{\gnusnot}{$\neg$}
100\newcommand{\gnustilde}{\symbol{"7E}}
101\newcommand{\gnusless}{{$<$}}
102\newcommand{\gnusgreater}{{$>$}}
103\newcommand{\gnusbraceleft}{{$>$}}
104\newcommand{\gnusbraceright}{{$>$}}
105
106\newcommand{\gnushead}{\raisebox{-1cm}{\epsfig{figure=ps/gnus-head,height=1cm}}}
107\newcommand{\gnusinteresting}{
108\marginpar[\mbox{}\hfill\gnushead]{\gnushead}
109}
110
111\newcommand{\gnuscleardoublepage}{\ifodd\count0\mbox{}\clearpage\thispagestyle{empty}\mbox{}\clearpage\else\clearpage\fi}
112
113\newcommand{\gnuspagechapter}[1]{
114{\mbox{}}
115}
116
117\newdimen{\gnusdimen}
118\gnusdimen 0pt
119
120\newcommand{\gnuschapter}[2]{
121\gnuscleardoublepage
122\ifdim \gnusdimen = 0pt\setcounter{page}{1}\pagestyle{gnus}\pagenumbering{arabic} \gnusdimen 1pt\fi
123\chapter{#2}
124\renewcommand{\gnussectionname}{}
125\renewcommand{\gnuschaptername}{#2}
126\thispagestyle{empty}
127\hspace*{-2cm}
128\begin{picture}(500,500)(0,0)
129\put(480,350){\makebox(0,0)[tr]{#1}}
130\put(40,300){\makebox(500,50)[bl]{{\Huge\bf{#2}}}}
131\end{picture}
132\clearpage
133}
134
135\newcommand{\gnusfigure}[3]{
136\begin{figure}
137\mbox{}\ifodd\count0\hspace*{-0.8cm}\else\hspace*{-3cm}\fi\begin{picture}(440,#2)
138#3
139\end{picture}
140\caption{#1}
141\end{figure}
142}
143
144\newcommand{\gnusicon}[1]{
145\marginpar[\mbox{}\hfill\raisebox{-1.5cm}{\epsfig{figure=ps/#1-up,height=1.5cm}}]{\raisebox{-1cm}{\epsfig{figure=ps/#1-up,height=1cm}}}
146}
147
148\newcommand{\gnuspicon}[1]{
149\margindex{\epsfig{figure=#1,width=2cm}}
150}
151
152\newcommand{\gnusxface}[2]{
153\margindex{\epsfig{figure=#1,width=1cm}\epsfig{figure=#2,width=1cm}}
154}
155
156\newcommand{\gnussmiley}[2]{
157\margindex{\makebox[2cm]{\hfill\epsfig{figure=#1,width=0.5cm}\hfill\epsfig{figure=#2,width=0.5cm}\hfill}}
158}
159
160\newcommand{\gnusitemx}[1]{\mbox{}\vspace*{-\itemsep}\vspace*{-\parsep}\item#1}
161
162\newcommand{\gnussection}[1]{
163\renewcommand{\gnussectionname}{#1}
164\section{#1}
165}
166
167\newenvironment{codelist}%
168{\begin{list}{}{
169}
170}{\end{list}}
171
172\newenvironment{asislist}%
173{\begin{list}{}{
174}
175}{\end{list}}
176
177\newenvironment{kbdlist}%
178{\begin{list}{}{
179\labelwidth=0cm
180}
181}{\end{list}}
182
183\newenvironment{dfnlist}%
184{\begin{list}{}{
185}
186}{\end{list}}
187
188\newenvironment{stronglist}%
189{\begin{list}{}{
190}
191}{\end{list}}
192
193\newenvironment{samplist}%
194{\begin{list}{}{
195}
196}{\end{list}}
197
198\newenvironment{varlist}%
199{\begin{list}{}{
200}
201}{\end{list}}
202
203\newenvironment{emphlist}%
204{\begin{list}{}{
205}
206}{\end{list}}
207
208\newlength\gnusheadtextwidth
209\setlength{\gnusheadtextwidth}{\headtextwidth}
210\addtolength{\gnusheadtextwidth}{1cm}
211
212\newpagestyle{gnuspreamble}%
213{
214{
215\ifodd\count0
216{
217\hspace*{-0.23cm}\underline{\makebox[\gnusheadtextwidth]{\mbox{}}\textbf{\hfill\roman{page}}}
218}
219\else
220{
221\hspace*{-3.25cm}\underline{\makebox[\gnusheadtextwidth]{\textbf{\roman{page}\hfill\mbox{}}}
222}
223}
224\fi
225}
226}
227{
228\ifodd\count0
229\mbox{} \hfill
230\raisebox{-0.5cm}{\epsfig{figure=ps/gnus-big-logo,height=1cm}}
231\else
232\raisebox{-0.5cm}{\epsfig{figure=ps/gnus-big-logo,height=1cm}}
233\hfill \mbox{}
234\fi
235}
236
237\newpagestyle{gnusindex}%
238{
239{
240\ifodd\count0
241{
242\hspace*{-0.23cm}\underline{\makebox[\gnusheadtextwidth]{\textbf{\gnuschaptername\hfill\arabic{page}}}}
243}
244\else
245{
246\hspace*{-3.25cm}\underline{\makebox[\gnusheadtextwidth]{\textbf{\arabic{page}\hfill\gnuschaptername}}}
247}
248\fi
249}
250}
251{
252\ifodd\count0
253\mbox{} \hfill
254\raisebox{-0.5cm}{\epsfig{figure=ps/gnus-big-logo,height=1cm}}
255\else
256\raisebox{-0.5cm}{\epsfig{figure=ps/gnus-big-logo,height=1cm}}
257\hfill \mbox{}
258\fi
259}
260
261\newpagestyle{gnus}%
262{
263{
264\ifodd\count0
265{
266\makebox[12cm]{\hspace*{3.1cm}\underline{\makebox[\gnusheadtextwidth]{\textbf{\arabic{chapter}.\arabic{section}} \textbf{\gnussectionname\hfill\arabic{page}}}}}
267}
268\else
269{
270\makebox[12cm]{\hspace*{-2.95cm}\underline{\makebox[\gnusheadtextwidth]{\textbf{\arabic{page}\hfill\gnuschaptername}}}}
271}
272\fi
273}
274}
275{
276\ifodd\count0
277\mbox{} \hfill
278\raisebox{-0.5cm}{\epsfig{figure=ps/gnus-big-logo,height=1cm}}
279\else
280\raisebox{-0.5cm}{\epsfig{figure=ps/gnus-big-logo,height=1cm}}
281\hfill \mbox{}
282\fi
283}
284
285\pagenumbering{roman}
286\pagestyle{gnuspreamble}
287
288@end iflatex
289@end iftex
290
291@iftex
292@iflatex
293
294\begin{titlepage}
295{
296
297%\addtolength{\oddsidemargin}{-5cm}
298%\addtolength{\evensidemargin}{-5cm}
299\parindent=0cm
300\addtolength{\textheight}{2cm}
301
302\gnustitle{\gnustitlename}\hfill\gnusversion{\gnusversionname}\\
303\rule{15cm}{1mm}\\
304\vfill
305\hspace*{0cm}\epsfig{figure=ps/gnus-big-logo,height=15cm}
306\vfill
307\rule{15cm}{1mm}\\
308\gnusauthor{by Lars Magne Ingebrigtsen}
309\newpage
310}
311
312\mbox{}
313\vfill
314
315\thispagestyle{empty}
316
317@c @insertcopying
318\newpage
319\end{titlepage}
320@end iflatex
321@end iftex
322
4009494e
GM
323@dircategory Emacs
324@direntry
62e034c2 325* Gnus: (gnus). The newsreader Gnus.
4009494e
GM
326@end direntry
327@iftex
328@finalout
329@end iftex
4009494e
GM
330
331
332@titlepage
333@title Gnus Manual
334
335@author by Lars Magne Ingebrigtsen
336@page
337@vskip 0pt plus 1filll
338@insertcopying
339@end titlepage
340
5dc584b5
KB
341@summarycontents
342@contents
4009494e
GM
343
344@node Top
345@top The Gnus Newsreader
346
347@ifinfo
348
349You can read news (and mail) from within Emacs by using Gnus. The news
350can be gotten by any nefarious means you can think of---@acronym{NNTP}, local
351spool or your mbox file. All at the same time, if you want to push your
352luck.
353
354@c Adjust ../Makefile.in if you change the following line:
c7ff939a 355This manual corresponds to Gnus v5.13
4009494e 356
5dc584b5
KB
357@ifnottex
358@insertcopying
359@end ifnottex
360
4009494e
GM
361@end ifinfo
362
363@iftex
364
365@iflatex
366\tableofcontents
367\gnuscleardoublepage
368@end iflatex
369
370Gnus is the advanced, self-documenting, customizable, extensible
371unreal-time newsreader for GNU Emacs.
372
373Oops. That sounds oddly familiar, so let's start over again to avoid
374being accused of plagiarism:
375
376Gnus is a message-reading laboratory. It will let you look at just
377about anything as if it were a newsgroup. You can read mail with it,
378you can browse directories with it, you can @code{ftp} with it---you
379can even read news with it!
380
381Gnus tries to empower people who read news the same way Emacs empowers
382people who edit text. Gnus sets no limits to what the user should be
383allowed to do. Users are encouraged to extend Gnus to make it behave
384like they want it to behave. A program should not control people;
385people should be empowered to do what they want by using (or abusing)
386the program.
387
9b3ebcb6 388@c Adjust ../Makefile.in if you change the following line:
2e4089ab 389This manual corresponds to Gnus v5.13
9b3ebcb6
MB
390
391@heading Other related manuals
392@itemize
393@item Message manual: Composing messages
394@item Emacs-MIME: Composing messages; @acronym{MIME}-specific parts.
395@item Sieve: Managing Sieve scripts in Emacs.
396@item PGG: @acronym{PGP/MIME} with Gnus.
2e4089ab 397@item SASL: @acronym{SASL} authentication in Emacs.
9b3ebcb6
MB
398@end itemize
399
4009494e
GM
400@end iftex
401
402@menu
403* Starting Up:: Finding news can be a pain.
404* Group Buffer:: Selecting, subscribing and killing groups.
405* Summary Buffer:: Reading, saving and posting articles.
406* Article Buffer:: Displaying and handling articles.
407* Composing Messages:: Information on sending mail and news.
408* Select Methods:: Gnus reads all messages from various select methods.
409* Scoring:: Assigning values to articles.
410* Various:: General purpose settings.
411* The End:: Farewell and goodbye.
412* Appendices:: Terminology, Emacs intro, @acronym{FAQ}, History, Internals.
413* GNU Free Documentation License:: The license for this documentation.
414* Index:: Variable, function and concept index.
415* Key Index:: Key Index.
416
417Other related manuals
418
419* Message:(message). Composing messages.
420* Emacs-MIME:(emacs-mime). Composing messages; @acronym{MIME}-specific parts.
421* Sieve:(sieve). Managing Sieve scripts in Emacs.
422* PGG:(pgg). @acronym{PGP/MIME} with Gnus.
01c52d31 423* SASL:(sasl). @acronym{SASL} authentication in Emacs.
4009494e
GM
424
425@detailmenu
426 --- The Detailed Node Listing ---
427
428Starting Gnus
429
430* Finding the News:: Choosing a method for getting news.
431* The First Time:: What does Gnus do the first time you start it?
432* The Server is Down:: How can I read my mail then?
433* Slave Gnusae:: You can have more than one Gnus active at a time.
434* Fetching a Group:: Starting Gnus just to read a group.
435* New Groups:: What is Gnus supposed to do with new groups?
436* Changing Servers:: You may want to move from one server to another.
437* Startup Files:: Those pesky startup files---@file{.newsrc}.
438* Auto Save:: Recovering from a crash.
439* The Active File:: Reading the active file over a slow line Takes Time.
440* Startup Variables:: Other variables you might change.
441
442New Groups
443
444* Checking New Groups:: Determining what groups are new.
445* Subscription Methods:: What Gnus should do with new groups.
446* Filtering New Groups:: Making Gnus ignore certain new groups.
447
448Group Buffer
449
450* Group Buffer Format:: Information listed and how you can change it.
451* Group Maneuvering:: Commands for moving in the group buffer.
452* Selecting a Group:: Actually reading news.
453* Subscription Commands:: Unsubscribing, killing, subscribing.
454* Group Data:: Changing the info for a group.
455* Group Levels:: Levels? What are those, then?
456* Group Score:: A mechanism for finding out what groups you like.
457* Marking Groups:: You can mark groups for later processing.
458* Foreign Groups:: Creating and editing groups.
459* Group Parameters:: Each group may have different parameters set.
460* Listing Groups:: Gnus can list various subsets of the groups.
461* Sorting Groups:: Re-arrange the group order.
462* Group Maintenance:: Maintaining a tidy @file{.newsrc} file.
463* Browse Foreign Server:: You can browse a server. See what it has to offer.
464* Exiting Gnus:: Stop reading news and get some work done.
465* Group Topics:: A folding group mode divided into topics.
01c52d31 466* Non-ASCII Group Names:: Accessing groups of non-English names.
4009494e
GM
467* Misc Group Stuff:: Other stuff that you can to do.
468
469Group Buffer Format
470
471* Group Line Specification:: Deciding how the group buffer is to look.
472* Group Mode Line Specification:: The group buffer mode line.
473* Group Highlighting:: Having nice colors in the group buffer.
474
475Group Topics
476
477* Topic Commands:: Interactive E-Z commands.
478* Topic Variables:: How to customize the topics the Lisp Way.
479* Topic Sorting:: Sorting each topic individually.
480* Topic Topology:: A map of the world.
481* Topic Parameters:: Parameters that apply to all groups in a topic.
482
483Misc Group Stuff
484
485* Scanning New Messages:: Asking Gnus to see whether new messages have arrived.
486* Group Information:: Information and help on groups and Gnus.
487* Group Timestamp:: Making Gnus keep track of when you last read a group.
488* File Commands:: Reading and writing the Gnus files.
489* Sieve Commands:: Managing Sieve scripts.
490
491Summary Buffer
492
493* Summary Buffer Format:: Deciding how the summary buffer is to look.
494* Summary Maneuvering:: Moving around the summary buffer.
495* Choosing Articles:: Reading articles.
496* Paging the Article:: Scrolling the current article.
497* Reply Followup and Post:: Posting articles.
498* Delayed Articles:: Send articles at a later time.
499* Marking Articles:: Marking articles as read, expirable, etc.
500* Limiting:: You can limit the summary buffer.
501* Threading:: How threads are made.
502* Sorting the Summary Buffer:: How articles and threads are sorted.
503* Asynchronous Fetching:: Gnus might be able to pre-fetch articles.
504* Article Caching:: You may store articles in a cache.
505* Persistent Articles:: Making articles expiry-resistant.
01c52d31 506* Sticky Articles:: Article buffers that are not reused.
4009494e
GM
507* Article Backlog:: Having already read articles hang around.
508* Saving Articles:: Ways of customizing article saving.
509* Decoding Articles:: Gnus can treat series of (uu)encoded articles.
510* Article Treatment:: The article buffer can be mangled at will.
511* MIME Commands:: Doing MIMEy things with the articles.
512* Charsets:: Character set issues.
513* Article Commands:: Doing various things with the article buffer.
514* Summary Sorting:: Sorting the summary buffer in various ways.
515* Finding the Parent:: No child support? Get the parent.
516* Alternative Approaches:: Reading using non-default summaries.
517* Tree Display:: A more visual display of threads.
518* Mail Group Commands:: Some commands can only be used in mail groups.
519* Various Summary Stuff:: What didn't fit anywhere else.
520* Exiting the Summary Buffer:: Returning to the Group buffer,
521 or reselecting the current group.
522* Crosspost Handling:: How crossposted articles are dealt with.
523* Duplicate Suppression:: An alternative when crosspost handling fails.
524* Security:: Decrypt and Verify.
525* Mailing List:: Mailing list minor mode.
526
527Summary Buffer Format
528
529* Summary Buffer Lines:: You can specify how summary lines should look.
530* To From Newsgroups:: How to not display your own name.
531* Summary Buffer Mode Line:: You can say how the mode line should look.
532* Summary Highlighting:: Making the summary buffer all pretty and nice.
533
534Choosing Articles
535
536* Choosing Commands:: Commands for choosing articles.
537* Choosing Variables:: Variables that influence these commands.
538
539Reply, Followup and Post
540
541* Summary Mail Commands:: Sending mail.
542* Summary Post Commands:: Sending news.
543* Summary Message Commands:: Other Message-related commands.
544* Canceling and Superseding::
545
546Marking Articles
547
548* Unread Articles:: Marks for unread articles.
549* Read Articles:: Marks for read articles.
550* Other Marks:: Marks that do not affect readedness.
551* Setting Marks:: How to set and remove marks.
552* Generic Marking Commands:: How to customize the marking.
553* Setting Process Marks:: How to mark articles for later processing.
554
555Threading
556
557* Customizing Threading:: Variables you can change to affect the threading.
558* Thread Commands:: Thread based commands in the summary buffer.
559
560Customizing Threading
561
562* Loose Threads:: How Gnus gathers loose threads into bigger threads.
563* Filling In Threads:: Making the threads displayed look fuller.
564* More Threading:: Even more variables for fiddling with threads.
565* Low-Level Threading:: You thought it was over@dots{} but you were wrong!
566
567Decoding Articles
568
569* Uuencoded Articles:: Uudecode articles.
570* Shell Archives:: Unshar articles.
571* PostScript Files:: Split PostScript.
572* Other Files:: Plain save and binhex.
573* Decoding Variables:: Variables for a happy decoding.
574* Viewing Files:: You want to look at the result of the decoding?
575
576Decoding Variables
577
578* Rule Variables:: Variables that say how a file is to be viewed.
579* Other Decode Variables:: Other decode variables.
580* Uuencoding and Posting:: Variables for customizing uuencoding.
581
582Article Treatment
583
584* Article Highlighting:: You want to make the article look like fruit salad.
585* Article Fontisizing:: Making emphasized text look nice.
586* Article Hiding:: You also want to make certain info go away.
587* Article Washing:: Lots of way-neat functions to make life better.
588* Article Header:: Doing various header transformations.
589* Article Buttons:: Click on URLs, Message-IDs, addresses and the like.
590* Article Button Levels:: Controlling appearance of buttons.
591* Article Date:: Grumble, UT!
592* Article Display:: Display various stuff---X-Face, Picons, Smileys
593* Article Signature:: What is a signature?
594* Article Miscellanea:: Various other stuff.
595
596Alternative Approaches
597
598* Pick and Read:: First mark articles and then read them.
599* Binary Groups:: Auto-decode all articles.
600
601Various Summary Stuff
602
603* Summary Group Information:: Information oriented commands.
604* Searching for Articles:: Multiple article commands.
605* Summary Generation Commands::
606* Really Various Summary Commands:: Those pesky non-conformant commands.
607
608Article Buffer
609
610* Hiding Headers:: Deciding what headers should be displayed.
611* Using MIME:: Pushing articles through @acronym{MIME} before reading them.
612* Customizing Articles:: Tailoring the look of the articles.
613* Article Keymap:: Keystrokes available in the article buffer.
614* Misc Article:: Other stuff.
615
616Composing Messages
617
618* Mail:: Mailing and replying.
619* Posting Server:: What server should you post and mail via?
620* POP before SMTP:: You cannot send a mail unless you read a mail.
621* Mail and Post:: Mailing and posting at the same time.
622* Archived Messages:: Where Gnus stores the messages you've sent.
623* Posting Styles:: An easier way to specify who you are.
624* Drafts:: Postponing messages and rejected messages.
625* Rejected Articles:: What happens if the server doesn't like your article?
626* Signing and encrypting:: How to compose secure messages.
627
628Select Methods
629
630* Server Buffer:: Making and editing virtual servers.
631* Getting News:: Reading USENET news with Gnus.
632* Getting Mail:: Reading your personal mail with Gnus.
633* Browsing the Web:: Getting messages from a plethora of Web sources.
634* IMAP:: Using Gnus as a @acronym{IMAP} client.
c4d82de8 635* Other Sources:: Reading directories, files.
4009494e
GM
636* Combined Groups:: Combining groups into one group.
637* Email Based Diary:: Using mails to manage diary events in Gnus.
638* Gnus Unplugged:: Reading news and mail offline.
639
640Server Buffer
641
642* Server Buffer Format:: You can customize the look of this buffer.
643* Server Commands:: Commands to manipulate servers.
644* Example Methods:: Examples server specifications.
645* Creating a Virtual Server:: An example session.
646* Server Variables:: Which variables to set.
647* Servers and Methods:: You can use server names as select methods.
648* Unavailable Servers:: Some servers you try to contact may be down.
649
650Getting News
651
652* NNTP:: Reading news from an @acronym{NNTP} server.
653* News Spool:: Reading news from the local spool.
654
655@acronym{NNTP}
656
657* Direct Functions:: Connecting directly to the server.
658* Indirect Functions:: Connecting indirectly to the server.
659* Common Variables:: Understood by several connection functions.
01c52d31 660* NNTP marks:: Storing marks for @acronym{NNTP} servers.
4009494e
GM
661
662Getting Mail
663
664* Mail in a Newsreader:: Important introductory notes.
665* Getting Started Reading Mail:: A simple cookbook example.
666* Splitting Mail:: How to create mail groups.
667* Mail Sources:: How to tell Gnus where to get mail from.
668* Mail Back End Variables:: Variables for customizing mail handling.
669* Fancy Mail Splitting:: Gnus can do hairy splitting of incoming mail.
670* Group Mail Splitting:: Use group customize to drive mail splitting.
671* Incorporating Old Mail:: What about the old mail you have?
672* Expiring Mail:: Getting rid of unwanted mail.
673* Washing Mail:: Removing cruft from the mail you get.
674* Duplicates:: Dealing with duplicated mail.
675* Not Reading Mail:: Using mail back ends for reading other files.
676* Choosing a Mail Back End:: Gnus can read a variety of mail formats.
677
678Mail Sources
679
680* Mail Source Specifiers:: How to specify what a mail source is.
681* Mail Source Customization:: Some variables that influence things.
682* Fetching Mail:: Using the mail source specifiers.
683
684Choosing a Mail Back End
685
686* Unix Mail Box:: Using the (quite) standard Un*x mbox.
bc79f9ab 687* Babyl:: Babyl was used by older versions of Rmail.
4009494e
GM
688* Mail Spool:: Store your mail in a private spool?
689* MH Spool:: An mhspool-like back end.
690* Maildir:: Another one-file-per-message format.
691* Mail Folders:: Having one file for each group.
692* Comparing Mail Back Ends:: An in-depth looks at pros and cons.
693
694Browsing the Web
695
696* Archiving Mail::
697* Web Searches:: Creating groups from articles that match a string.
4009494e
GM
698* RSS:: Reading RDF site summary.
699* Customizing W3:: Doing stuff to Emacs/W3 from Gnus.
700
701@acronym{IMAP}
702
703* Splitting in IMAP:: Splitting mail with nnimap.
704* Expiring in IMAP:: Expiring mail with nnimap.
705* Editing IMAP ACLs:: Limiting/enabling other users access to a mailbox.
706* Expunging mailboxes:: Equivalent of a ``compress mailbox'' button.
707* A note on namespaces:: How to (not) use @acronym{IMAP} namespace in Gnus.
708* Debugging IMAP:: What to do when things don't work.
709
710Other Sources
711
712* Directory Groups:: You can read a directory as if it was a newsgroup.
713* Anything Groups:: Dired? Who needs dired?
714* Document Groups:: Single files can be the basis of a group.
4009494e
GM
715* Mail-To-News Gateways:: Posting articles via mail-to-news gateways.
716
717Document Groups
718
719* Document Server Internals:: How to add your own document types.
720
4009494e
GM
721Combined Groups
722
723* Virtual Groups:: Combining articles from many groups.
4009494e
GM
724
725Email Based Diary
726
727* The NNDiary Back End:: Basic setup and usage.
728* The Gnus Diary Library:: Utility toolkit on top of nndiary.
729* Sending or Not Sending:: A final note on sending diary messages.
730
731The NNDiary Back End
732
733* Diary Messages:: What makes a message valid for nndiary.
734* Running NNDiary:: NNDiary has two modes of operation.
735* Customizing NNDiary:: Bells and whistles.
736
737The Gnus Diary Library
738
739* Diary Summary Line Format:: A nicer summary buffer line format.
740* Diary Articles Sorting:: A nicer way to sort messages.
741* Diary Headers Generation:: Not doing it manually.
742* Diary Group Parameters:: Not handling them manually.
743
744Gnus Unplugged
745
746* Agent Basics:: How it all is supposed to work.
747* Agent Categories:: How to tell the Gnus Agent what to download.
748* Agent Commands:: New commands for all the buffers.
749* Agent Visuals:: Ways that the agent may effect your summary buffer.
750* Agent as Cache:: The Agent is a big cache too.
751* Agent Expiry:: How to make old articles go away.
752* Agent Regeneration:: How to recover from lost connections and other accidents.
01c52d31 753* Agent and flags:: How the Agent maintains flags.
4009494e
GM
754* Agent and IMAP:: How to use the Agent with @acronym{IMAP}.
755* Outgoing Messages:: What happens when you post/mail something?
756* Agent Variables:: Customizing is fun.
757* Example Setup:: An example @file{~/.gnus.el} file for offline people.
758* Batching Agents:: How to fetch news from a @code{cron} job.
759* Agent Caveats:: What you think it'll do and what it does.
760
761Agent Categories
762
763* Category Syntax:: What a category looks like.
764* Category Buffer:: A buffer for maintaining categories.
765* Category Variables:: Customize'r'Us.
766
767Agent Commands
768
769* Group Agent Commands:: Configure groups and fetch their contents.
770* Summary Agent Commands:: Manually select then fetch specific articles.
771* Server Agent Commands:: Select the servers that are supported by the agent.
772
773Scoring
774
775* Summary Score Commands:: Adding score entries for the current group.
776* Group Score Commands:: General score commands.
777* Score Variables:: Customize your scoring. (My, what terminology).
778* Score File Format:: What a score file may contain.
779* Score File Editing:: You can edit score files by hand as well.
780* Adaptive Scoring:: Big Sister Gnus knows what you read.
781* Home Score File:: How to say where new score entries are to go.
782* Followups To Yourself:: Having Gnus notice when people answer you.
783* Scoring On Other Headers:: Scoring on non-standard headers.
784* Scoring Tips:: How to score effectively.
785* Reverse Scoring:: That problem child of old is not problem.
786* Global Score Files:: Earth-spanning, ear-splitting score files.
787* Kill Files:: They are still here, but they can be ignored.
788* Converting Kill Files:: Translating kill files to score files.
4009494e
GM
789* Advanced Scoring:: Using logical expressions to build score rules.
790* Score Decays:: It can be useful to let scores wither away.
791
4009494e
GM
792Advanced Scoring
793
794* Advanced Scoring Syntax:: A definition.
795* Advanced Scoring Examples:: What they look like.
796* Advanced Scoring Tips:: Getting the most out of it.
797
798Various
799
800* Process/Prefix:: A convention used by many treatment commands.
801* Interactive:: Making Gnus ask you many questions.
802* Symbolic Prefixes:: How to supply some Gnus functions with options.
803* Formatting Variables:: You can specify what buffers should look like.
804* Window Layout:: Configuring the Gnus buffer windows.
805* Faces and Fonts:: How to change how faces look.
806* Compilation:: How to speed Gnus up.
807* Mode Lines:: Displaying information in the mode lines.
808* Highlighting and Menus:: Making buffers look all nice and cozy.
809* Buttons:: Get tendinitis in ten easy steps!
810* Daemons:: Gnus can do things behind your back.
811* NoCeM:: How to avoid spam and other fatty foods.
812* Undo:: Some actions can be undone.
813* Predicate Specifiers:: Specifying predicates.
814* Moderation:: What to do if you're a moderator.
815* Image Enhancements:: Modern versions of Emacs/XEmacs can display images.
816* Fuzzy Matching:: What's the big fuzz?
817* Thwarting Email Spam:: Simple ways to avoid unsolicited commercial email.
818* Spam Package:: A package for filtering and processing spam.
64763fe3 819* The Gnus Registry:: A package for tracking messages by Message-ID.
4009494e
GM
820* Other modes:: Interaction with other modes.
821* Various Various:: Things that are really various.
822
823Formatting Variables
824
825* Formatting Basics:: A formatting variable is basically a format string.
826* Mode Line Formatting:: Some rules about mode line formatting variables.
827* Advanced Formatting:: Modifying output in various ways.
828* User-Defined Specs:: Having Gnus call your own functions.
829* Formatting Fonts:: Making the formatting look colorful and nice.
830* Positioning Point:: Moving point to a position after an operation.
831* Tabulation:: Tabulating your output.
832* Wide Characters:: Dealing with wide characters.
833
834Image Enhancements
835
836* X-Face:: Display a funky, teensy black-and-white image.
837* Face:: Display a funkier, teensier colored image.
838* Smileys:: Show all those happy faces the way they were
839 meant to be shown.
840* Picons:: How to display pictures of what you're reading.
841* XVarious:: Other XEmacsy Gnusey variables.
842
843Thwarting Email Spam
844
845* The problem of spam:: Some background, and some solutions
846* Anti-Spam Basics:: Simple steps to reduce the amount of spam.
847* SpamAssassin:: How to use external anti-spam tools.
848* Hashcash:: Reduce spam by burning CPU time.
849
850Spam Package
851
852* Spam Package Introduction::
853* Filtering Incoming Mail::
854* Detecting Spam in Groups::
855* Spam and Ham Processors::
856* Spam Package Configuration Examples::
857* Spam Back Ends::
858* Extending the Spam package::
859* Spam Statistics Package::
860
861Spam Statistics Package
862
863* Creating a spam-stat dictionary::
864* Splitting mail using spam-stat::
865* Low-level interface to the spam-stat dictionary::
866
867Appendices
868
869* XEmacs:: Requirements for installing under XEmacs.
870* History:: How Gnus got where it is today.
871* On Writing Manuals:: Why this is not a beginner's guide.
872* Terminology:: We use really difficult, like, words here.
873* Customization:: Tailoring Gnus to your needs.
874* Troubleshooting:: What you might try if things do not work.
875* Gnus Reference Guide:: Rilly, rilly technical stuff.
876* Emacs for Heathens:: A short introduction to Emacsian terms.
877* Frequently Asked Questions:: The Gnus FAQ
878
879History
880
881* Gnus Versions:: What Gnus versions have been released.
882* Other Gnus Versions:: Other Gnus versions that also have been released.
883* Why?:: What's the point of Gnus?
884* Compatibility:: Just how compatible is Gnus with @sc{gnus}?
885* Conformity:: Gnus tries to conform to all standards.
886* Emacsen:: Gnus can be run on a few modern Emacsen.
887* Gnus Development:: How Gnus is developed.
888* Contributors:: Oodles of people.
889* New Features:: Pointers to some of the new stuff in Gnus.
890
891New Features
892
893* ding Gnus:: New things in Gnus 5.0/5.1, the first new Gnus.
894* September Gnus:: The Thing Formally Known As Gnus 5.2/5.3.
895* Red Gnus:: Third time best---Gnus 5.4/5.5.
896* Quassia Gnus:: Two times two is four, or Gnus 5.6/5.7.
897* Pterodactyl Gnus:: Pentad also starts with P, AKA Gnus 5.8/5.9.
898* Oort Gnus:: It's big. It's far out. Gnus 5.10/5.11.
01c52d31 899* No Gnus:: Very punny.
4009494e
GM
900
901Customization
902
903* Slow/Expensive Connection:: You run a local Emacs and get the news elsewhere.
904* Slow Terminal Connection:: You run a remote Emacs.
905* Little Disk Space:: You feel that having large setup files is icky.
906* Slow Machine:: You feel like buying a faster machine.
907
908Gnus Reference Guide
909
910* Gnus Utility Functions:: Common functions and variable to use.
911* Back End Interface:: How Gnus communicates with the servers.
912* Score File Syntax:: A BNF definition of the score file standard.
913* Headers:: How Gnus stores headers internally.
914* Ranges:: A handy format for storing mucho numbers.
915* Group Info:: The group info format.
916* Extended Interactive:: Symbolic prefixes and stuff.
917* Emacs/XEmacs Code:: Gnus can be run under all modern Emacsen.
918* Various File Formats:: Formats of files that Gnus use.
919
920Back End Interface
921
922* Required Back End Functions:: Functions that must be implemented.
923* Optional Back End Functions:: Functions that need not be implemented.
924* Error Messaging:: How to get messages and report errors.
925* Writing New Back Ends:: Extending old back ends.
926* Hooking New Back Ends Into Gnus:: What has to be done on the Gnus end.
927* Mail-like Back Ends:: Some tips on mail back ends.
928
929Various File Formats
930
931* Active File Format:: Information on articles and groups available.
932* Newsgroups File Format:: Group descriptions.
933
934Emacs for Heathens
935
936* Keystrokes:: Entering text and executing commands.
937* Emacs Lisp:: The built-in Emacs programming language.
938
939@end detailmenu
940@end menu
941
942@node Starting Up
943@chapter Starting Gnus
944@cindex starting up
945
946If you haven't used Emacs much before using Gnus, read @ref{Emacs for
947Heathens} first.
948
949@kindex M-x gnus
950@findex gnus
951If your system administrator has set things up properly, starting Gnus
952and reading news is extremely easy---you just type @kbd{M-x gnus} in
953your Emacs. If not, you should customize the variable
954@code{gnus-select-method} as described in @ref{Finding the News}. For a
955minimal setup for posting should also customize the variables
956@code{user-full-name} and @code{user-mail-address}.
957
958@findex gnus-other-frame
959@kindex M-x gnus-other-frame
960If you want to start Gnus in a different frame, you can use the command
961@kbd{M-x gnus-other-frame} instead.
962
963If things do not go smoothly at startup, you have to twiddle some
964variables in your @file{~/.gnus.el} file. This file is similar to
965@file{~/.emacs}, but is read when Gnus starts.
966
967If you puzzle at any terms used in this manual, please refer to the
968terminology section (@pxref{Terminology}).
969
970@menu
971* Finding the News:: Choosing a method for getting news.
972* The First Time:: What does Gnus do the first time you start it?
973* The Server is Down:: How can I read my mail then?
974* Slave Gnusae:: You can have more than one Gnus active at a time.
975* New Groups:: What is Gnus supposed to do with new groups?
976* Changing Servers:: You may want to move from one server to another.
977* Startup Files:: Those pesky startup files---@file{.newsrc}.
978* Auto Save:: Recovering from a crash.
979* The Active File:: Reading the active file over a slow line Takes Time.
980* Startup Variables:: Other variables you might change.
981@end menu
982
983
984@node Finding the News
985@section Finding the News
986@cindex finding news
987
357e2d8e
KY
988First of all, you should know that there is a special buffer called
989@code{*Server*} that lists all the servers Gnus knows about. You can
990press @kbd{^} from the Group buffer to see it. In the Server buffer,
991you can press @kbd{RET} on a defined server to see all the groups it
992serves (subscribed or not!). You can also add or delete servers, edit
993a foreign server's definition, agentize or de-agentize a server, and
994do many other neat things. @xref{Server Buffer}.
995@xref{Foreign Groups}. @xref{Agent Basics}.
996
4009494e
GM
997@vindex gnus-select-method
998@c @head
999The @code{gnus-select-method} variable says where Gnus should look for
1000news. This variable should be a list where the first element says
1001@dfn{how} and the second element says @dfn{where}. This method is your
1002native method. All groups not fetched with this method are
1003foreign groups.
1004
1005For instance, if the @samp{news.somewhere.edu} @acronym{NNTP} server is where
1006you want to get your daily dosage of news from, you'd say:
1007
1008@lisp
1009(setq gnus-select-method '(nntp "news.somewhere.edu"))
1010@end lisp
1011
1012If you want to read directly from the local spool, say:
1013
1014@lisp
1015(setq gnus-select-method '(nnspool ""))
1016@end lisp
1017
1018If you can use a local spool, you probably should, as it will almost
1019certainly be much faster. But do not use the local spool if your
1020server is running Leafnode (which is a simple, standalone private news
1021server); in this case, use @code{(nntp "localhost")}.
1022
1023@vindex gnus-nntpserver-file
1024@cindex NNTPSERVER
1025@cindex @acronym{NNTP} server
1026If this variable is not set, Gnus will take a look at the
1027@env{NNTPSERVER} environment variable. If that variable isn't set,
1028Gnus will see whether @code{gnus-nntpserver-file}
1029(@file{/etc/nntpserver} by default) has any opinions on the matter.
1030If that fails as well, Gnus will try to use the machine running Emacs
1031as an @acronym{NNTP} server. That's a long shot, though.
1032
1033@vindex gnus-nntp-server
1034If @code{gnus-nntp-server} is set, this variable will override
1035@code{gnus-select-method}. You should therefore set
1036@code{gnus-nntp-server} to @code{nil}, which is what it is by default.
1037
1038@vindex gnus-secondary-servers
1039@vindex gnus-nntp-server
1040You can also make Gnus prompt you interactively for the name of an
1041@acronym{NNTP} server. If you give a non-numerical prefix to @code{gnus}
1042(i.e., @kbd{C-u M-x gnus}), Gnus will let you choose between the servers
1043in the @code{gnus-secondary-servers} list (if any). You can also just
1044type in the name of any server you feel like visiting. (Note that this
1045will set @code{gnus-nntp-server}, which means that if you then @kbd{M-x
1046gnus} later in the same Emacs session, Gnus will contact the same
1047server.)
1048
1049@findex gnus-group-browse-foreign-server
1050@kindex B (Group)
1051However, if you use one @acronym{NNTP} server regularly and are just
1052interested in a couple of groups from a different server, you would be
1053better served by using the @kbd{B} command in the group buffer. It will
1054let you have a look at what groups are available, and you can subscribe
1055to any of the groups you want to. This also makes @file{.newsrc}
1056maintenance much tidier. @xref{Foreign Groups}.
1057
1058@vindex gnus-secondary-select-methods
1059@c @head
1060A slightly different approach to foreign groups is to set the
1061@code{gnus-secondary-select-methods} variable. The select methods
1062listed in this variable are in many ways just as native as the
1063@code{gnus-select-method} server. They will also be queried for active
1064files during startup (if that's required), and new newsgroups that
1065appear on these servers will be subscribed (or not) just as native
1066groups are.
1067
1068For instance, if you use the @code{nnmbox} back end to read your mail,
1069you would typically set this variable to
1070
1071@lisp
1072(setq gnus-secondary-select-methods '((nnmbox "")))
1073@end lisp
1074
01c52d31
MB
1075Note: the @acronym{NNTP} back end stores marks in marks files
1076(@pxref{NNTP marks}). This feature makes it easy to share marks between
1077several Gnus installations, but may slow down things a bit when fetching
1078new articles. @xref{NNTP marks}, for more information.
1079
4009494e
GM
1080
1081@node The First Time
1082@section The First Time
1083@cindex first time usage
1084
1085If no startup files exist (@pxref{Startup Files}), Gnus will try to
1086determine what groups should be subscribed by default.
1087
1088@vindex gnus-default-subscribed-newsgroups
1089If the variable @code{gnus-default-subscribed-newsgroups} is set, Gnus
1090will subscribe you to just those groups in that list, leaving the rest
1091killed. Your system administrator should have set this variable to
1092something useful.
1093
1094Since she hasn't, Gnus will just subscribe you to a few arbitrarily
1095picked groups (i.e., @samp{*.newusers}). (@dfn{Arbitrary} is defined
1096here as @dfn{whatever Lars thinks you should read}.)
1097
1098You'll also be subscribed to the Gnus documentation group, which should
1099help you with most common problems.
1100
1101If @code{gnus-default-subscribed-newsgroups} is @code{t}, Gnus will just
1102use the normal functions for handling new groups, and not do anything
1103special.
1104
1105
1106@node The Server is Down
1107@section The Server is Down
1108@cindex server errors
1109
1110If the default server is down, Gnus will understandably have some
1111problems starting. However, if you have some mail groups in addition to
1112the news groups, you may want to start Gnus anyway.
1113
1114Gnus, being the trusting sort of program, will ask whether to proceed
1115without a native select method if that server can't be contacted. This
1116will happen whether the server doesn't actually exist (i.e., you have
1117given the wrong address) or the server has just momentarily taken ill
1118for some reason or other. If you decide to continue and have no foreign
1119groups, you'll find it difficult to actually do anything in the group
1120buffer. But, hey, that's your problem. Blllrph!
1121
1122@findex gnus-no-server
1123@kindex M-x gnus-no-server
1124@c @head
1125If you know that the server is definitely down, or you just want to read
1126your mail without bothering with the server at all, you can use the
1127@code{gnus-no-server} command to start Gnus. That might come in handy
1128if you're in a hurry as well. This command will not attempt to contact
1129your primary server---instead, it will just activate all groups on level
11301 and 2. (You should preferably keep no native groups on those two
1131levels.) Also @pxref{Group Levels}.
1132
1133
1134@node Slave Gnusae
1135@section Slave Gnusae
1136@cindex slave
1137
1138You might want to run more than one Emacs with more than one Gnus at the
1139same time. If you are using different @file{.newsrc} files (e.g., if you
1140are using the two different Gnusae to read from two different servers),
1141that is no problem whatsoever. You just do it.
1142
1143The problem appears when you want to run two Gnusae that use the same
1144@file{.newsrc} file.
1145
1146To work around that problem some, we here at the Think-Tank at the Gnus
1147Towers have come up with a new concept: @dfn{Masters} and
1148@dfn{slaves}. (We have applied for a patent on this concept, and have
1149taken out a copyright on those words. If you wish to use those words in
1150conjunction with each other, you have to send $1 per usage instance to
1151me. Usage of the patent (@dfn{Master/Slave Relationships In Computer
1152Applications}) will be much more expensive, of course.)
1153
1154@findex gnus-slave
1155Anyway, you start one Gnus up the normal way with @kbd{M-x gnus} (or
1156however you do it). Each subsequent slave Gnusae should be started with
1157@kbd{M-x gnus-slave}. These slaves won't save normal @file{.newsrc}
1158files, but instead save @dfn{slave files} that contain information only
1159on what groups have been read in the slave session. When a master Gnus
1160starts, it will read (and delete) these slave files, incorporating all
1161information from them. (The slave files will be read in the sequence
1162they were created, so the latest changes will have precedence.)
1163
1164Information from the slave files has, of course, precedence over the
1165information in the normal (i.e., master) @file{.newsrc} file.
1166
1167If the @file{.newsrc*} files have not been saved in the master when the
1168slave starts, you may be prompted as to whether to read an auto-save
1169file. If you answer ``yes'', the unsaved changes to the master will be
1170incorporated into the slave. If you answer ``no'', the slave may see some
1171messages as unread that have been read in the master.
1172
1173
1174
1175@node New Groups
1176@section New Groups
1177@cindex new groups
1178@cindex subscription
1179
1180@vindex gnus-check-new-newsgroups
1181If you are satisfied that you really never want to see any new groups,
1182you can set @code{gnus-check-new-newsgroups} to @code{nil}. This will
1183also save you some time at startup. Even if this variable is
1184@code{nil}, you can always subscribe to the new groups just by pressing
1185@kbd{U} in the group buffer (@pxref{Group Maintenance}). This variable
1186is @code{ask-server} by default. If you set this variable to
1187@code{always}, then Gnus will query the back ends for new groups even
1188when you do the @kbd{g} command (@pxref{Scanning New Messages}).
1189
1190@menu
1191* Checking New Groups:: Determining what groups are new.
1192* Subscription Methods:: What Gnus should do with new groups.
1193* Filtering New Groups:: Making Gnus ignore certain new groups.
1194@end menu
1195
1196
1197@node Checking New Groups
1198@subsection Checking New Groups
1199
1200Gnus normally determines whether a group is new or not by comparing the
1201list of groups from the active file(s) with the lists of subscribed and
1202dead groups. This isn't a particularly fast method. If
1203@code{gnus-check-new-newsgroups} is @code{ask-server}, Gnus will ask the
1204server for new groups since the last time. This is both faster and
1205cheaper. This also means that you can get rid of the list of killed
1206groups altogether, so you may set @code{gnus-save-killed-list} to
1207@code{nil}, which will save time both at startup, at exit, and all over.
1208Saves disk space, too. Why isn't this the default, then?
1209Unfortunately, not all servers support this command.
1210
1211I bet I know what you're thinking now: How do I find out whether my
1212server supports @code{ask-server}? No? Good, because I don't have a
1213fail-safe answer. I would suggest just setting this variable to
1214@code{ask-server} and see whether any new groups appear within the next
1215few days. If any do, then it works. If none do, then it doesn't
1216work. I could write a function to make Gnus guess whether the server
1217supports @code{ask-server}, but it would just be a guess. So I won't.
1218You could @code{telnet} to the server and say @code{HELP} and see
1219whether it lists @samp{NEWGROUPS} among the commands it understands. If
1220it does, then it might work. (But there are servers that lists
1221@samp{NEWGROUPS} without supporting the function properly.)
1222
1223This variable can also be a list of select methods. If so, Gnus will
1224issue an @code{ask-server} command to each of the select methods, and
1225subscribe them (or not) using the normal methods. This might be handy
1226if you are monitoring a few servers for new groups. A side effect is
1227that startup will take much longer, so you can meditate while waiting.
1228Use the mantra ``dingnusdingnusdingnus'' to achieve permanent bliss.
1229
1230
1231@node Subscription Methods
1232@subsection Subscription Methods
1233
1234@vindex gnus-subscribe-newsgroup-method
1235What Gnus does when it encounters a new group is determined by the
1236@code{gnus-subscribe-newsgroup-method} variable.
1237
1238This variable should contain a function. This function will be called
1239with the name of the new group as the only parameter.
1240
1241Some handy pre-fab functions are:
1242
1243@table @code
1244
1245@item gnus-subscribe-zombies
1246@vindex gnus-subscribe-zombies
1247Make all new groups zombies. This is the default. You can browse the
1248zombies later (with @kbd{A z}) and either kill them all off properly
1249(with @kbd{S z}), or subscribe to them (with @kbd{u}).
1250
1251@item gnus-subscribe-randomly
1252@vindex gnus-subscribe-randomly
1253Subscribe all new groups in arbitrary order. This really means that all
1254new groups will be added at ``the top'' of the group buffer.
1255
1256@item gnus-subscribe-alphabetically
1257@vindex gnus-subscribe-alphabetically
1258Subscribe all new groups in alphabetical order.
1259
1260@item gnus-subscribe-hierarchically
1261@vindex gnus-subscribe-hierarchically
1262Subscribe all new groups hierarchically. The difference between this
1263function and @code{gnus-subscribe-alphabetically} is slight.
1264@code{gnus-subscribe-alphabetically} will subscribe new groups in a strictly
1265alphabetical fashion, while this function will enter groups into its
1266hierarchy. So if you want to have the @samp{rec} hierarchy before the
1267@samp{comp} hierarchy, this function will not mess that configuration
1268up. Or something like that.
1269
1270@item gnus-subscribe-interactively
1271@vindex gnus-subscribe-interactively
1272Subscribe new groups interactively. This means that Gnus will ask
1273you about @strong{all} new groups. The groups you choose to subscribe
1274to will be subscribed hierarchically.
1275
1276@item gnus-subscribe-killed
1277@vindex gnus-subscribe-killed
1278Kill all new groups.
1279
1280@item gnus-subscribe-topics
1281@vindex gnus-subscribe-topics
1282Put the groups into the topic that has a matching @code{subscribe} topic
1283parameter (@pxref{Topic Parameters}). For instance, a @code{subscribe}
1284topic parameter that looks like
1285
1286@example
77ae8989 1287"nnml"
4009494e
GM
1288@end example
1289
1290will mean that all groups that match that regex will be subscribed under
1291that topic.
1292
1293If no topics match the groups, the groups will be subscribed in the
1294top-level topic.
1295
1296@end table
1297
1298@vindex gnus-subscribe-hierarchical-interactive
1299A closely related variable is
1300@code{gnus-subscribe-hierarchical-interactive}. (That's quite a
1301mouthful.) If this variable is non-@code{nil}, Gnus will ask you in a
1302hierarchical fashion whether to subscribe to new groups or not. Gnus
1303will ask you for each sub-hierarchy whether you want to descend the
1304hierarchy or not.
1305
1306One common mistake is to set the variable a few paragraphs above
1307(@code{gnus-subscribe-newsgroup-method}) to
1308@code{gnus-subscribe-hierarchical-interactive}. This is an error. This
1309will not work. This is ga-ga. So don't do it.
1310
1311
1312@node Filtering New Groups
1313@subsection Filtering New Groups
1314
1315A nice and portable way to control which new newsgroups should be
1316subscribed (or ignored) is to put an @dfn{options} line at the start of
1317the @file{.newsrc} file. Here's an example:
1318
1319@example
1320options -n !alt.all !rec.all sci.all
1321@end example
1322
1323@vindex gnus-subscribe-options-newsgroup-method
1324This line obviously belongs to a serious-minded intellectual scientific
1325person (or she may just be plain old boring), because it says that all
1326groups that have names beginning with @samp{alt} and @samp{rec} should
1327be ignored, and all groups with names beginning with @samp{sci} should
1328be subscribed. Gnus will not use the normal subscription method for
1329subscribing these groups.
1330@code{gnus-subscribe-options-newsgroup-method} is used instead. This
1331variable defaults to @code{gnus-subscribe-alphabetically}.
1332
1333@vindex gnus-options-not-subscribe
1334@vindex gnus-options-subscribe
1335If you don't want to mess with your @file{.newsrc} file, you can just
1336set the two variables @code{gnus-options-subscribe} and
1337@code{gnus-options-not-subscribe}. These two variables do exactly the
1338same as the @file{.newsrc} @samp{options -n} trick. Both are regexps,
1339and if the new group matches the former, it will be unconditionally
1340subscribed, and if it matches the latter, it will be ignored.
1341
1342@vindex gnus-auto-subscribed-groups
1343Yet another variable that meddles here is
1344@code{gnus-auto-subscribed-groups}. It works exactly like
1345@code{gnus-options-subscribe}, and is therefore really superfluous,
1346but I thought it would be nice to have two of these. This variable is
1347more meant for setting some ground rules, while the other variable is
1348used more for user fiddling. By default this variable makes all new
1349groups that come from mail back ends (@code{nnml}, @code{nnbabyl},
1350@code{nnfolder}, @code{nnmbox}, @code{nnmh}, and @code{nnmaildir})
1351subscribed. If you don't like that, just set this variable to
1352@code{nil}.
1353
1354New groups that match this regexp are subscribed using
1355@code{gnus-subscribe-options-newsgroup-method}.
1356
1357
1358@node Changing Servers
1359@section Changing Servers
1360@cindex changing servers
1361
1362Sometimes it is necessary to move from one @acronym{NNTP} server to another.
1363This happens very rarely, but perhaps you change jobs, or one server is
1364very flaky and you want to use another.
1365
1366Changing the server is pretty easy, right? You just change
1367@code{gnus-select-method} to point to the new server?
1368
1369@emph{Wrong!}
1370
1371Article numbers are not (in any way) kept synchronized between different
1372@acronym{NNTP} servers, and the only way Gnus keeps track of what articles
1373you have read is by keeping track of article numbers. So when you
1374change @code{gnus-select-method}, your @file{.newsrc} file becomes
1375worthless.
1376
4009494e
GM
1377@kindex M-x gnus-group-clear-data-on-native-groups
1378@findex gnus-group-clear-data-on-native-groups
f02566ce
KY
1379You can use the @kbd{M-x gnus-group-clear-data-on-native-groups}
1380command to clear out all data that you have on your native groups.
1381Use with caution.
4009494e
GM
1382
1383@kindex M-x gnus-group-clear-data
1384@findex gnus-group-clear-data
1385Clear the data from the current group only---nix out marks and the
1386list of read articles (@code{gnus-group-clear-data}).
1387
1388After changing servers, you @strong{must} move the cache hierarchy away,
1389since the cached articles will have wrong article numbers, which will
1390affect which articles Gnus thinks are read.
1391@code{gnus-group-clear-data-on-native-groups} will ask you if you want
1392to have it done automatically; for @code{gnus-group-clear-data}, you
1393can use @kbd{M-x gnus-cache-move-cache} (but beware, it will move the
1394cache for all groups).
1395
1396
1397@node Startup Files
1398@section Startup Files
1399@cindex startup files
1400@cindex .newsrc
1401@cindex .newsrc.el
1402@cindex .newsrc.eld
1403
1404Most common Unix news readers use a shared startup file called
1405@file{.newsrc}. This file contains all the information about what
1406groups are subscribed, and which articles in these groups have been
1407read.
1408
1409Things got a bit more complicated with @sc{gnus}. In addition to
1410keeping the @file{.newsrc} file updated, it also used a file called
1411@file{.newsrc.el} for storing all the information that didn't fit into
1412the @file{.newsrc} file. (Actually, it also duplicated everything in
1413the @file{.newsrc} file.) @sc{gnus} would read whichever one of these
1414files was the most recently saved, which enabled people to swap between
1415@sc{gnus} and other newsreaders.
1416
1417That was kinda silly, so Gnus went one better: In addition to the
1418@file{.newsrc} and @file{.newsrc.el} files, Gnus also has a file called
1419@file{.newsrc.eld}. It will read whichever of these files that are most
1420recent, but it will never write a @file{.newsrc.el} file. You should
1421never delete the @file{.newsrc.eld} file---it contains much information
1422not stored in the @file{.newsrc} file.
1423
1424@vindex gnus-save-newsrc-file
1425@vindex gnus-read-newsrc-file
1426You can turn off writing the @file{.newsrc} file by setting
1427@code{gnus-save-newsrc-file} to @code{nil}, which means you can delete
1428the file and save some space, as well as exiting from Gnus faster.
1429However, this will make it impossible to use other newsreaders than
1430Gnus. But hey, who would want to, right? Similarly, setting
1431@code{gnus-read-newsrc-file} to @code{nil} makes Gnus ignore the
1432@file{.newsrc} file and any @file{.newsrc-SERVER} files, which can be
1433convenient if you use a different news reader occasionally, and you
1434want to read a different subset of the available groups with that
1435news reader.
1436
1437@vindex gnus-save-killed-list
1438If @code{gnus-save-killed-list} (default @code{t}) is @code{nil}, Gnus
1439will not save the list of killed groups to the startup file. This will
1440save both time (when starting and quitting) and space (on disk). It
1441will also mean that Gnus has no record of what groups are new or old,
1442so the automatic new groups subscription methods become meaningless.
1443You should always set @code{gnus-check-new-newsgroups} to @code{nil} or
1444@code{ask-server} if you set this variable to @code{nil} (@pxref{New
1445Groups}). This variable can also be a regular expression. If that's
1446the case, remove all groups that do not match this regexp before
1447saving. This can be useful in certain obscure situations that involve
1448several servers where not all servers support @code{ask-server}.
1449
1450@vindex gnus-startup-file
1451@vindex gnus-backup-startup-file
1452@vindex version-control
1453The @code{gnus-startup-file} variable says where the startup files are.
1454The default value is @file{~/.newsrc}, with the Gnus (El Dingo) startup
1455file being whatever that one is, with a @samp{.eld} appended.
1456If you want version control for this file, set
1457@code{gnus-backup-startup-file}. It respects the same values as the
1458@code{version-control} variable.
1459
1460@vindex gnus-save-newsrc-hook
1461@vindex gnus-save-quick-newsrc-hook
1462@vindex gnus-save-standard-newsrc-hook
1463@code{gnus-save-newsrc-hook} is called before saving any of the newsrc
1464files, while @code{gnus-save-quick-newsrc-hook} is called just before
1465saving the @file{.newsrc.eld} file, and
1466@code{gnus-save-standard-newsrc-hook} is called just before saving the
1467@file{.newsrc} file. The latter two are commonly used to turn version
1468control on or off. Version control is on by default when saving the
1469startup files. If you want to turn backup creation off, say something like:
1470
1471@lisp
1472(defun turn-off-backup ()
1473 (set (make-local-variable 'backup-inhibited) t))
1474
1475(add-hook 'gnus-save-quick-newsrc-hook 'turn-off-backup)
1476(add-hook 'gnus-save-standard-newsrc-hook 'turn-off-backup)
1477@end lisp
1478
1479@vindex gnus-init-file
1480@vindex gnus-site-init-file
1481When Gnus starts, it will read the @code{gnus-site-init-file}
1482(@file{.../site-lisp/gnus-init} by default) and @code{gnus-init-file}
1483(@file{~/.gnus} by default) files. These are normal Emacs Lisp files
1484and can be used to avoid cluttering your @file{~/.emacs} and
1485@file{site-init} files with Gnus stuff. Gnus will also check for files
1486with the same names as these, but with @file{.elc} and @file{.el}
1487suffixes. In other words, if you have set @code{gnus-init-file} to
1488@file{~/.gnus}, it will look for @file{~/.gnus.elc}, @file{~/.gnus.el},
1489and finally @file{~/.gnus} (in this order). If Emacs was invoked with
1490the @option{-q} or @option{--no-init-file} options (@pxref{Initial
1491Options, ,Initial Options, emacs, The Emacs Manual}), Gnus doesn't read
1492@code{gnus-init-file}.
1493
1494
1495@node Auto Save
1496@section Auto Save
1497@cindex dribble file
1498@cindex auto-save
1499
1500Whenever you do something that changes the Gnus data (reading articles,
1501catching up, killing/subscribing groups), the change is added to a
1502special @dfn{dribble buffer}. This buffer is auto-saved the normal
1503Emacs way. If your Emacs should crash before you have saved the
1504@file{.newsrc} files, all changes you have made can be recovered from
1505this file.
1506
1507If Gnus detects this file at startup, it will ask the user whether to
1508read it. The auto save file is deleted whenever the real startup file is
1509saved.
1510
1511@vindex gnus-use-dribble-file
1512If @code{gnus-use-dribble-file} is @code{nil}, Gnus won't create and
1513maintain a dribble buffer. The default is @code{t}.
1514
1515@vindex gnus-dribble-directory
1516Gnus will put the dribble file(s) in @code{gnus-dribble-directory}. If
1517this variable is @code{nil}, which it is by default, Gnus will dribble
1518into the directory where the @file{.newsrc} file is located. (This is
1519normally the user's home directory.) The dribble file will get the same
1520file permissions as the @file{.newsrc} file.
1521
1522@vindex gnus-always-read-dribble-file
1523If @code{gnus-always-read-dribble-file} is non-@code{nil}, Gnus will
1524read the dribble file on startup without querying the user.
1525
1526
1527@node The Active File
1528@section The Active File
1529@cindex active file
1530@cindex ignored groups
1531
1532When Gnus starts, or indeed whenever it tries to determine whether new
1533articles have arrived, it reads the active file. This is a very large
1534file that lists all the active groups and articles on the server.
1535
1536@vindex gnus-ignored-newsgroups
1537Before examining the active file, Gnus deletes all lines that match the
1538regexp @code{gnus-ignored-newsgroups}. This is done primarily to reject
1539any groups with bogus names, but you can use this variable to make Gnus
1540ignore hierarchies you aren't ever interested in. However, this is not
1541recommended. In fact, it's highly discouraged. Instead, @pxref{New
1542Groups} for an overview of other variables that can be used instead.
1543
1544@c This variable is
1545@c @code{nil} by default, and will slow down active file handling somewhat
1546@c if you set it to anything else.
1547
1548@vindex gnus-read-active-file
1549@c @head
1550The active file can be rather Huge, so if you have a slow network, you
1551can set @code{gnus-read-active-file} to @code{nil} to prevent Gnus from
1552reading the active file. This variable is @code{some} by default.
1553
1554Gnus will try to make do by getting information just on the groups that
1555you actually subscribe to.
1556
1557Note that if you subscribe to lots and lots of groups, setting this
1558variable to @code{nil} will probably make Gnus slower, not faster. At
1559present, having this variable @code{nil} will slow Gnus down
1560considerably, unless you read news over a 2400 baud modem.
1561
1562This variable can also have the value @code{some}. Gnus will then
1563attempt to read active info only on the subscribed groups. On some
1564servers this is quite fast (on sparkling, brand new INN servers that
1565support the @code{LIST ACTIVE group} command), on others this isn't fast
1566at all. In any case, @code{some} should be faster than @code{nil}, and
1567is certainly faster than @code{t} over slow lines.
1568
1569Some news servers (old versions of Leafnode and old versions of INN, for
1570instance) do not support the @code{LIST ACTIVE group}. For these
1571servers, @code{nil} is probably the most efficient value for this
1572variable.
1573
1574If this variable is @code{nil}, Gnus will ask for group info in total
1575lock-step, which isn't very fast. If it is @code{some} and you use an
1576@acronym{NNTP} server, Gnus will pump out commands as fast as it can, and
1577read all the replies in one swoop. This will normally result in better
1578performance, but if the server does not support the aforementioned
1579@code{LIST ACTIVE group} command, this isn't very nice to the server.
1580
1581If you think that starting up Gnus takes too long, try all the three
1582different values for this variable and see what works best for you.
1583
1584In any case, if you use @code{some} or @code{nil}, you should definitely
1585kill all groups that you aren't interested in to speed things up.
1586
1587Note that this variable also affects active file retrieval from
1588secondary select methods.
1589
1590
1591@node Startup Variables
1592@section Startup Variables
1593
1594@table @code
1595
1596@item gnus-load-hook
1597@vindex gnus-load-hook
1598A hook run while Gnus is being loaded. Note that this hook will
1599normally be run just once in each Emacs session, no matter how many
1600times you start Gnus.
1601
1602@item gnus-before-startup-hook
1603@vindex gnus-before-startup-hook
e3e955fe 1604A hook called as the first thing when Gnus is started.
4009494e
GM
1605
1606@item gnus-startup-hook
1607@vindex gnus-startup-hook
1608A hook run as the very last thing after starting up Gnus
1609
1610@item gnus-started-hook
1611@vindex gnus-started-hook
1612A hook that is run as the very last thing after starting up Gnus
1613successfully.
1614
1615@item gnus-setup-news-hook
1616@vindex gnus-setup-news-hook
1617A hook that is run after reading the @file{.newsrc} file(s), but before
1618generating the group buffer.
1619
1620@item gnus-check-bogus-newsgroups
1621@vindex gnus-check-bogus-newsgroups
1622If non-@code{nil}, Gnus will check for and delete all bogus groups at
1623startup. A @dfn{bogus group} is a group that you have in your
1624@file{.newsrc} file, but doesn't exist on the news server. Checking for
1625bogus groups can take quite a while, so to save time and resources it's
1626best to leave this option off, and do the checking for bogus groups once
1627in a while from the group buffer instead (@pxref{Group Maintenance}).
1628
1629@item gnus-inhibit-startup-message
1630@vindex gnus-inhibit-startup-message
1631If non-@code{nil}, the startup message won't be displayed. That way,
1632your boss might not notice as easily that you are reading news instead
1633of doing your job. Note that this variable is used before
1634@file{~/.gnus.el} is loaded, so it should be set in @file{.emacs} instead.
1635
1636@item gnus-no-groups-message
1637@vindex gnus-no-groups-message
1638Message displayed by Gnus when no groups are available.
1639
1640@item gnus-play-startup-jingle
1641@vindex gnus-play-startup-jingle
1642If non-@code{nil}, play the Gnus jingle at startup.
1643
1644@item gnus-startup-jingle
1645@vindex gnus-startup-jingle
1646Jingle to be played if the above variable is non-@code{nil}. The
1647default is @samp{Tuxedomoon.Jingle4.au}.
1648
1649@end table
1650
1651
1652@node Group Buffer
1653@chapter Group Buffer
1654@cindex group buffer
1655
1656@c Alex Schroeder suggests to rearrange this as follows:
1657@c
1658@c <kensanata> ok, just save it for reference. I'll go to bed in a minute.
1659@c 1. Selecting a Group, 2. (new) Finding a Group, 3. Group Levels,
1660@c 4. Subscription Commands, 5. Group Maneuvering, 6. Group Data,
1661@c 7. Group Score, 8. Group Buffer Format
1662@c <kensanata> Group Levels should have more information on levels 5 to 9. I
1663@c suggest to split the 4th paragraph ("Gnus considers groups...") as follows:
1664@c <kensanata> First, "Gnus considers groups... (default 9)."
1665@c <kensanata> New, a table summarizing what levels 1 to 9 mean.
1666@c <kensanata> Third, "Gnus treats subscribed ... reasons of efficiency"
1667@c <kensanata> Then expand the next paragraph or add some more to it.
1668@c This short one sentence explains levels 1 and 2, therefore I understand
1669@c that I should keep important news at 3 and boring news at 4.
1670@c Say so! Then go on to explain why I should bother with levels 6 to 9.
1671@c Maybe keep those that you don't want to read temporarily at 6,
1672@c those that you never want to read at 8, those that offend your
1673@c human rights at 9...
1674
1675
1676The @dfn{group buffer} lists all (or parts) of the available groups. It
1677is the first buffer shown when Gnus starts, and will never be killed as
1678long as Gnus is active.
1679
1680@iftex
1681@iflatex
1682\gnusfigure{The Group Buffer}{320}{
1683\put(75,50){\epsfig{figure=ps/group,height=9cm}}
1684\put(120,37){\makebox(0,0)[t]{Buffer name}}
1685\put(120,38){\vector(1,2){10}}
1686\put(40,60){\makebox(0,0)[r]{Mode line}}
1687\put(40,58){\vector(1,0){30}}
1688\put(200,28){\makebox(0,0)[t]{Native select method}}
1689\put(200,26){\vector(-1,2){15}}
1690}
1691@end iflatex
1692@end iftex
1693
1694@menu
1695* Group Buffer Format:: Information listed and how you can change it.
1696* Group Maneuvering:: Commands for moving in the group buffer.
1697* Selecting a Group:: Actually reading news.
1698* Subscription Commands:: Unsubscribing, killing, subscribing.
1699* Group Data:: Changing the info for a group.
1700* Group Levels:: Levels? What are those, then?
1701* Group Score:: A mechanism for finding out what groups you like.
1702* Marking Groups:: You can mark groups for later processing.
1703* Foreign Groups:: Creating and editing groups.
1704* Group Parameters:: Each group may have different parameters set.
1705* Listing Groups:: Gnus can list various subsets of the groups.
1706* Sorting Groups:: Re-arrange the group order.
1707* Group Maintenance:: Maintaining a tidy @file{.newsrc} file.
1708* Browse Foreign Server:: You can browse a server. See what it has to offer.
1709* Exiting Gnus:: Stop reading news and get some work done.
1710* Group Topics:: A folding group mode divided into topics.
01c52d31 1711* Non-ASCII Group Names:: Accessing groups of non-English names.
e6d2d263 1712* Searching:: Mail search engines.
4009494e
GM
1713* Misc Group Stuff:: Other stuff that you can to do.
1714@end menu
1715
1716
1717@node Group Buffer Format
1718@section Group Buffer Format
1719
1720@menu
1721* Group Line Specification:: Deciding how the group buffer is to look.
1722* Group Mode Line Specification:: The group buffer mode line.
1723* Group Highlighting:: Having nice colors in the group buffer.
1724@end menu
1725
1726You can customize the Group Mode tool bar, see @kbd{M-x
1727customize-apropos RET gnus-group-tool-bar}. This feature is only
1728available in Emacs.
1729
1730The tool bar icons are now (de)activated correctly depending on the
1731cursor position. Therefore, moving around in the Group Buffer is
1732slower. You can disable this via the variable
1733@code{gnus-group-update-tool-bar}. Its default value depends on your
1734Emacs version.
1735
1736@node Group Line Specification
1737@subsection Group Line Specification
1738@cindex group buffer format
1739
1740The default format of the group buffer is nice and dull, but you can
1741make it as exciting and ugly as you feel like.
1742
1743Here's a couple of example group lines:
1744
1745@example
1746 25: news.announce.newusers
1747 * 0: alt.fan.andrea-dworkin
1748@end example
1749
1750Quite simple, huh?
1751
1752You can see that there are 25 unread articles in
1753@samp{news.announce.newusers}. There are no unread articles, but some
1754ticked articles, in @samp{alt.fan.andrea-dworkin} (see that little
1755asterisk at the beginning of the line?).
1756
1757@vindex gnus-group-line-format
1758You can change that format to whatever you want by fiddling with the
1759@code{gnus-group-line-format} variable. This variable works along the
1760lines of a @code{format} specification, which is pretty much the same as
1761a @code{printf} specifications, for those of you who use (feh!) C.
1762@xref{Formatting Variables}.
1763
1764@samp{%M%S%5y:%B%(%g%)\n} is the value that produced those lines above.
1765
1766There should always be a colon on the line; the cursor always moves to
1767the colon after performing an operation. @xref{Positioning
1768Point}. Nothing else is required---not even the group name. All
1769displayed text is just window dressing, and is never examined by Gnus.
1770Gnus stores all real information it needs using text properties.
1771
1772(Note that if you make a really strange, wonderful, spreadsheet-like
1773layout, everybody will believe you are hard at work with the accounting
1774instead of wasting time reading news.)
1775
1776Here's a list of all available format characters:
1777
1778@table @samp
1779
1780@item M
1781An asterisk if the group only has marked articles.
1782
1783@item S
1784Whether the group is subscribed.
1785
1786@item L
1787Level of subscribedness.
1788
1789@item N
1790Number of unread articles.
1791
1792@item I
1793Number of dormant articles.
1794
1795@item T
1796Number of ticked articles.
1797
1798@item R
1799Number of read articles.
1800
1801@item U
1802Number of unseen articles.
1803
1804@item t
1805Estimated total number of articles. (This is really @var{max-number}
1806minus @var{min-number} plus 1.)
1807
1808Gnus uses this estimation because the @acronym{NNTP} protocol provides
1809efficient access to @var{max-number} and @var{min-number} but getting
1810the true unread message count is not possible efficiently. For
1811hysterical raisins, even the mail back ends, where the true number of
1812unread messages might be available efficiently, use the same limited
1813interface. To remove this restriction from Gnus means that the back
01c52d31
MB
1814end interface has to be changed, which is not an easy job.
1815
1816The nnml backend (@pxref{Mail Spool}) has a feature called ``group
1817compaction'' which circumvents this deficiency: the idea is to
1818renumber all articles from 1, removing all gaps between numbers, hence
1819getting a correct total count. Other backends may support this in the
1820future. In order to keep your total article count relatively up to
1821date, you might want to compact your groups (or even directly your
1822server) from time to time. @xref{Misc Group Stuff}, @xref{Server Commands}.
4009494e
GM
1823
1824@item y
1825Number of unread, unticked, non-dormant articles.
1826
1827@item i
1828Number of ticked and dormant articles.
1829
1830@item g
1831Full group name.
1832
1833@item G
1834Group name.
1835
1836@item C
1837Group comment (@pxref{Group Parameters}) or group name if there is no
1838comment element in the group parameters.
1839
1840@item D
1841Newsgroup description. You need to read the group descriptions
1842before these will appear, and to do that, you either have to set
1843@code{gnus-read-active-file} or use the group buffer @kbd{M-d}
1844command.
1845
1846@item o
1847@samp{m} if moderated.
1848
1849@item O
1850@samp{(m)} if moderated.
1851
1852@item s
1853Select method.
1854
1855@item B
1856If the summary buffer for the group is open or not.
1857
1858@item n
1859Select from where.
1860
1861@item z
1862A string that looks like @samp{<%s:%n>} if a foreign select method is
1863used.
1864
1865@item P
1866Indentation based on the level of the topic (@pxref{Group Topics}).
1867
1868@item c
1869@vindex gnus-group-uncollapsed-levels
1870Short (collapsed) group name. The @code{gnus-group-uncollapsed-levels}
1871variable says how many levels to leave at the end of the group name.
1872The default is 1---this will mean that group names like
1873@samp{gnu.emacs.gnus} will be shortened to @samp{g.e.gnus}.
1874
1875@item m
1876@vindex gnus-new-mail-mark
1877@cindex %
1878@samp{%} (@code{gnus-new-mail-mark}) if there has arrived new mail to
1879the group lately.
1880
1881@item p
1882@samp{#} (@code{gnus-process-mark}) if the group is process marked.
1883
1884@item d
1885A string that says when you last read the group (@pxref{Group
1886Timestamp}).
1887
01c52d31
MB
1888@item F
1889The disk space used by the articles fetched by both the cache and
1890agent. The value is automatically scaled to bytes(B), kilobytes(K),
1891megabytes(M), or gigabytes(G) to minimize the column width. A format
1892of %7F is sufficient for a fixed-width column.
1893
4009494e
GM
1894@item u
1895User defined specifier. The next character in the format string should
1896be a letter. Gnus will call the function
1897@code{gnus-user-format-function-}@samp{X}, where @samp{X} is the letter
1898following @samp{%u}. The function will be passed a single dummy
1899parameter as argument. The function should return a string, which will
1900be inserted into the buffer just like information from any other
1901specifier.
1902@end table
1903
1904@cindex *
1905All the ``number-of'' specs will be filled with an asterisk (@samp{*})
1906if no info is available---for instance, if it is a non-activated foreign
1907group, or a bogus native group.
1908
1909
1910@node Group Mode Line Specification
1911@subsection Group Mode Line Specification
1912@cindex group mode line
1913
1914@vindex gnus-group-mode-line-format
1915The mode line can be changed by setting
1916@code{gnus-group-mode-line-format} (@pxref{Mode Line Formatting}). It
1917doesn't understand that many format specifiers:
1918
1919@table @samp
1920@item S
1921The native news server.
1922@item M
1923The native select method.
1924@end table
1925
1926
1927@node Group Highlighting
1928@subsection Group Highlighting
1929@cindex highlighting
1930@cindex group highlighting
1931
1932@vindex gnus-group-highlight
1933Highlighting in the group buffer is controlled by the
1934@code{gnus-group-highlight} variable. This is an alist with elements
1935that look like @code{(@var{form} . @var{face})}. If @var{form} evaluates to
1936something non-@code{nil}, the @var{face} will be used on the line.
1937
1938Here's an example value for this variable that might look nice if the
1939background is dark:
1940
1941@lisp
1942(cond (window-system
1943 (setq custom-background-mode 'light)
1944 (defface my-group-face-1
1945 '((t (:foreground "Red" :bold t))) "First group face")
1946 (defface my-group-face-2
1947 '((t (:foreground "DarkSeaGreen4" :bold t)))
1948 "Second group face")
1949 (defface my-group-face-3
1950 '((t (:foreground "Green4" :bold t))) "Third group face")
1951 (defface my-group-face-4
1952 '((t (:foreground "SteelBlue" :bold t))) "Fourth group face")
1953 (defface my-group-face-5
1954 '((t (:foreground "Blue" :bold t))) "Fifth group face")))
1955
1956(setq gnus-group-highlight
1957 '(((> unread 200) . my-group-face-1)
1958 ((and (< level 3) (zerop unread)) . my-group-face-2)
1959 ((< level 3) . my-group-face-3)
1960 ((zerop unread) . my-group-face-4)
1961 (t . my-group-face-5)))
1962@end lisp
1963
1964Also @pxref{Faces and Fonts}.
1965
1966Variables that are dynamically bound when the forms are evaluated
1967include:
1968
1969@table @code
1970@item group
1971The group name.
1972@item unread
1973The number of unread articles in the group.
1974@item method
1975The select method.
1976@item mailp
1977Whether the group is a mail group.
1978@item level
1979The level of the group.
1980@item score
1981The score of the group.
1982@item ticked
1983The number of ticked articles in the group.
1984@item total
1985The total number of articles in the group. Or rather,
1986@var{max-number} minus @var{min-number} plus one.
1987@item topic
1988When using the topic minor mode, this variable is bound to the current
1989topic being inserted.
1990@end table
1991
1992When the forms are @code{eval}ed, point is at the beginning of the line
1993of the group in question, so you can use many of the normal Gnus
1994functions for snarfing info on the group.
1995
1996@vindex gnus-group-update-hook
1997@findex gnus-group-highlight-line
1998@code{gnus-group-update-hook} is called when a group line is changed.
1999It will not be called when @code{gnus-visual} is @code{nil}. This hook
2000calls @code{gnus-group-highlight-line} by default.
2001
2002
2003@node Group Maneuvering
2004@section Group Maneuvering
2005@cindex group movement
2006
2007All movement commands understand the numeric prefix and will behave as
2008expected, hopefully.
2009
2010@table @kbd
2011
2012@item n
2013@kindex n (Group)
2014@findex gnus-group-next-unread-group
2015Go to the next group that has unread articles
2016(@code{gnus-group-next-unread-group}).
2017
2018@item p
2019@itemx DEL
2020@kindex DEL (Group)
2021@kindex p (Group)
2022@findex gnus-group-prev-unread-group
2023Go to the previous group that has unread articles
2024(@code{gnus-group-prev-unread-group}).
2025
2026@item N
2027@kindex N (Group)
2028@findex gnus-group-next-group
2029Go to the next group (@code{gnus-group-next-group}).
2030
2031@item P
2032@kindex P (Group)
2033@findex gnus-group-prev-group
2034Go to the previous group (@code{gnus-group-prev-group}).
2035
2036@item M-n
2037@kindex M-n (Group)
2038@findex gnus-group-next-unread-group-same-level
2039Go to the next unread group on the same (or lower) level
2040(@code{gnus-group-next-unread-group-same-level}).
2041
2042@item M-p
2043@kindex M-p (Group)
2044@findex gnus-group-prev-unread-group-same-level
2045Go to the previous unread group on the same (or lower) level
2046(@code{gnus-group-prev-unread-group-same-level}).
2047@end table
2048
2049Three commands for jumping to groups:
2050
2051@table @kbd
2052
2053@item j
2054@kindex j (Group)
2055@findex gnus-group-jump-to-group
2056Jump to a group (and make it visible if it isn't already)
2057(@code{gnus-group-jump-to-group}). Killed groups can be jumped to, just
2058like living groups.
2059
2060@item ,
2061@kindex , (Group)
2062@findex gnus-group-best-unread-group
2063Jump to the unread group with the lowest level
2064(@code{gnus-group-best-unread-group}).
2065
2066@item .
2067@kindex . (Group)
2068@findex gnus-group-first-unread-group
2069Jump to the first group with unread articles
2070(@code{gnus-group-first-unread-group}).
2071@end table
2072
2073@vindex gnus-group-goto-unread
2074If @code{gnus-group-goto-unread} is @code{nil}, all the movement
2075commands will move to the next group, not the next unread group. Even
2076the commands that say they move to the next unread group. The default
2077is @code{t}.
2078
01c52d31
MB
2079@vindex gnus-summary-next-group-on-exit
2080If @code{gnus-summary-next-group-on-exit} is @code{t}, when a summary is
2081exited, the point in the group buffer is moved to the next unread group.
2082Otherwise, the point is set to the group just exited. The default is
2083@code{t}.
4009494e
GM
2084
2085@node Selecting a Group
2086@section Selecting a Group
2087@cindex group selection
2088
2089@table @kbd
2090
2091@item SPACE
2092@kindex SPACE (Group)
2093@findex gnus-group-read-group
2094Select the current group, switch to the summary buffer and display the
2095first unread article (@code{gnus-group-read-group}). If there are no
2096unread articles in the group, or if you give a non-numerical prefix to
2097this command, Gnus will offer to fetch all the old articles in this
2098group from the server. If you give a numerical prefix @var{n}, @var{n}
2099determines the number of articles Gnus will fetch. If @var{n} is
2100positive, Gnus fetches the @var{n} newest articles, if @var{n} is
2101negative, Gnus fetches the @code{abs(@var{n})} oldest articles.
2102
2103Thus, @kbd{SPC} enters the group normally, @kbd{C-u SPC} offers old
2104articles, @kbd{C-u 4 2 SPC} fetches the 42 newest articles, and @kbd{C-u
2105- 4 2 SPC} fetches the 42 oldest ones.
2106
2107When you are in the group (in the Summary buffer), you can type
2108@kbd{M-g} to fetch new articles, or @kbd{C-u M-g} to also show the old
2109ones.
2110
2111@item RET
2112@kindex RET (Group)
2113@findex gnus-group-select-group
2114Select the current group and switch to the summary buffer
2115(@code{gnus-group-select-group}). Takes the same arguments as
2116@code{gnus-group-read-group}---the only difference is that this command
2117does not display the first unread article automatically upon group
2118entry.
2119
2120@item M-RET
2121@kindex M-RET (Group)
2122@findex gnus-group-quick-select-group
2123This does the same as the command above, but tries to do it with the
2124minimum amount of fuzz (@code{gnus-group-quick-select-group}). No
2125scoring/killing will be performed, there will be no highlights and no
2126expunging. This might be useful if you're in a real hurry and have to
2127enter some humongous group. If you give a 0 prefix to this command
2128(i.e., @kbd{0 M-RET}), Gnus won't even generate the summary buffer,
2129which is useful if you want to toggle threading before generating the
2130summary buffer (@pxref{Summary Generation Commands}).
2131
2132@item M-SPACE
2133@kindex M-SPACE (Group)
2134@findex gnus-group-visible-select-group
2135This is yet one more command that does the same as the @kbd{RET}
2136command, but this one does it without expunging and hiding dormants
2137(@code{gnus-group-visible-select-group}).
2138
2139@item C-M-RET
2140@kindex C-M-RET (Group)
2141@findex gnus-group-select-group-ephemerally
2142Finally, this command selects the current group ephemerally without
2143doing any processing of its contents
2144(@code{gnus-group-select-group-ephemerally}). Even threading has been
2145turned off. Everything you do in the group after selecting it in this
2146manner will have no permanent effects.
2147
2148@end table
2149
2150@vindex gnus-large-newsgroup
2151The @code{gnus-large-newsgroup} variable says what Gnus should
2152consider to be a big group. If it is @code{nil}, no groups are
2153considered big. The default value is 200. If the group has more
2154(unread and/or ticked) articles than this, Gnus will query the user
2155before entering the group. The user can then specify how many
2156articles should be fetched from the server. If the user specifies a
2157negative number (@var{-n}), the @var{n} oldest articles will be
2158fetched. If it is positive, the @var{n} articles that have arrived
2159most recently will be fetched.
2160
2161@vindex gnus-large-ephemeral-newsgroup
2162@code{gnus-large-ephemeral-newsgroup} is the same as
2163@code{gnus-large-newsgroup}, but is only used for ephemeral
2164newsgroups.
2165
4b70e299 2166@vindex gnus-newsgroup-maximum-articles
4009494e
GM
2167In groups in some news servers, there might be a big gap between a few
2168very old articles that will never be expired and the recent ones. In
2169such a case, the server will return the data like @code{(1 . 30000000)}
2170for the @code{LIST ACTIVE group} command, for example. Even if there
2171are actually only the articles 1-10 and 29999900-30000000, Gnus doesn't
2172know it at first and prepares for getting 30000000 articles. However,
2173it will consume hundreds megabytes of memories and might make Emacs get
2174stuck as the case may be. If you use such news servers, set the
4b70e299
MB
2175variable @code{gnus-newsgroup-maximum-articles} to a positive number.
2176The value means that Gnus ignores articles other than this number of the
2177latest ones in every group. For instance, the value 10000 makes Gnus
2178get only the articles 29990001-30000000 (if the latest article number is
217930000000 in a group). Note that setting this variable to a number might
2180prevent you from reading very old articles. The default value of the
2181variable @code{gnus-newsgroup-maximum-articles} is @code{nil}, which
2182means Gnus never ignores old articles.
4009494e
GM
2183
2184@vindex gnus-select-group-hook
2185@vindex gnus-auto-select-first
2186@vindex gnus-auto-select-subject
2187If @code{gnus-auto-select-first} is non-@code{nil}, select an article
2188automatically when entering a group with the @kbd{SPACE} command.
867d4bb3 2189Which article this is controlled by the
4009494e
GM
2190@code{gnus-auto-select-subject} variable. Valid values for this
2191variable are:
2192
2193@table @code
2194
2195@item unread
2196Place point on the subject line of the first unread article.
2197
2198@item first
2199Place point on the subject line of the first article.
2200
2201@item unseen
2202Place point on the subject line of the first unseen article.
2203
2204@item unseen-or-unread
2205Place point on the subject line of the first unseen article, and if
2206there is no such article, place point on the subject line of the first
2207unread article.
2208
2209@item best
2210Place point on the subject line of the highest-scored unread article.
2211
2212@end table
2213
2214This variable can also be a function. In that case, that function
2215will be called to place point on a subject line.
2216
2217If you want to prevent automatic selection in some group (say, in a
2218binary group with Huge articles) you can set the
2219@code{gnus-auto-select-first} variable to @code{nil} in
2220@code{gnus-select-group-hook}, which is called when a group is
2221selected.
2222
2223
2224@node Subscription Commands
2225@section Subscription Commands
2226@cindex subscription
2227
2228@table @kbd
2229
2230@item S t
2231@itemx u
2232@kindex S t (Group)
2233@kindex u (Group)
2234@findex gnus-group-unsubscribe-current-group
2235@c @icon{gnus-group-unsubscribe}
2236Toggle subscription to the current group
2237(@code{gnus-group-unsubscribe-current-group}).
2238
2239@item S s
2240@itemx U
2241@kindex S s (Group)
2242@kindex U (Group)
2243@findex gnus-group-unsubscribe-group
2244Prompt for a group to subscribe, and then subscribe it. If it was
2245subscribed already, unsubscribe it instead
2246(@code{gnus-group-unsubscribe-group}).
2247
2248@item S k
2249@itemx C-k
2250@kindex S k (Group)
2251@kindex C-k (Group)
2252@findex gnus-group-kill-group
2253@c @icon{gnus-group-kill-group}
2254Kill the current group (@code{gnus-group-kill-group}).
2255
2256@item S y
2257@itemx C-y
2258@kindex S y (Group)
2259@kindex C-y (Group)
2260@findex gnus-group-yank-group
2261Yank the last killed group (@code{gnus-group-yank-group}).
2262
2263@item C-x C-t
2264@kindex C-x C-t (Group)
2265@findex gnus-group-transpose-groups
2266Transpose two groups (@code{gnus-group-transpose-groups}). This isn't
2267really a subscription command, but you can use it instead of a
2268kill-and-yank sequence sometimes.
2269
2270@item S w
2271@itemx C-w
2272@kindex S w (Group)
2273@kindex C-w (Group)
2274@findex gnus-group-kill-region
2275Kill all groups in the region (@code{gnus-group-kill-region}).
2276
2277@item S z
2278@kindex S z (Group)
2279@findex gnus-group-kill-all-zombies
2280Kill all zombie groups (@code{gnus-group-kill-all-zombies}).
2281
2282@item S C-k
2283@kindex S C-k (Group)
2284@findex gnus-group-kill-level
2285Kill all groups on a certain level (@code{gnus-group-kill-level}).
2286These groups can't be yanked back after killing, so this command should
2287be used with some caution. The only time where this command comes in
2288really handy is when you have a @file{.newsrc} with lots of unsubscribed
2289groups that you want to get rid off. @kbd{S C-k} on level 7 will
2290kill off all unsubscribed groups that do not have message numbers in the
2291@file{.newsrc} file.
2292
2293@end table
2294
2295Also @pxref{Group Levels}.
2296
2297
2298@node Group Data
2299@section Group Data
2300
2301@table @kbd
2302
2303@item c
2304@kindex c (Group)
2305@findex gnus-group-catchup-current
2306@vindex gnus-group-catchup-group-hook
2307@c @icon{gnus-group-catchup-current}
2308Mark all unticked articles in this group as read
2309(@code{gnus-group-catchup-current}).
2310@code{gnus-group-catchup-group-hook} is called when catching up a group from
2311the group buffer.
2312
2313@item C
2314@kindex C (Group)
2315@findex gnus-group-catchup-current-all
2316Mark all articles in this group, even the ticked ones, as read
2317(@code{gnus-group-catchup-current-all}).
2318
2319@item M-c
2320@kindex M-c (Group)
2321@findex gnus-group-clear-data
2322Clear the data from the current group---nix out marks and the list of
2323read articles (@code{gnus-group-clear-data}).
2324
2325@item M-x gnus-group-clear-data-on-native-groups
2326@kindex M-x gnus-group-clear-data-on-native-groups
2327@findex gnus-group-clear-data-on-native-groups
2328If you have switched from one @acronym{NNTP} server to another, all your marks
2329and read ranges have become worthless. You can use this command to
2330clear out all data that you have on your native groups. Use with
2331caution.
2332
2333@end table
2334
2335
2336@node Group Levels
2337@section Group Levels
2338@cindex group level
2339@cindex level
2340
2341All groups have a level of @dfn{subscribedness}. For instance, if a
2342group is on level 2, it is more subscribed than a group on level 5. You
2343can ask Gnus to just list groups on a given level or lower
2344(@pxref{Listing Groups}), or to just check for new articles in groups on
2345a given level or lower (@pxref{Scanning New Messages}).
2346
2347Remember: The higher the level of the group, the less important it is.
2348
2349@table @kbd
2350
2351@item S l
2352@kindex S l (Group)
2353@findex gnus-group-set-current-level
2354Set the level of the current group. If a numeric prefix is given, the
2355next @var{n} groups will have their levels set. The user will be
2356prompted for a level.
2357@end table
2358
2359@vindex gnus-level-killed
2360@vindex gnus-level-zombie
2361@vindex gnus-level-unsubscribed
2362@vindex gnus-level-subscribed
2363Gnus considers groups from levels 1 to
2364@code{gnus-level-subscribed} (inclusive) (default 5) to be subscribed,
2365@code{gnus-level-subscribed} (exclusive) and
2366@code{gnus-level-unsubscribed} (inclusive) (default 7) to be
2367unsubscribed, @code{gnus-level-zombie} to be zombies (walking dead)
2368(default 8) and @code{gnus-level-killed} to be killed (completely dead)
2369(default 9). Gnus treats subscribed and unsubscribed groups exactly the
2370same, but zombie and killed groups have no information on what articles
2371you have read, etc, stored. This distinction between dead and living
2372groups isn't done because it is nice or clever, it is done purely for
2373reasons of efficiency.
2374
2375It is recommended that you keep all your mail groups (if any) on quite
2376low levels (e.g. 1 or 2).
2377
2378Maybe the following description of the default behavior of Gnus helps to
2379understand what these levels are all about. By default, Gnus shows you
2380subscribed nonempty groups, but by hitting @kbd{L} you can have it show
2381empty subscribed groups and unsubscribed groups, too. Type @kbd{l} to
2382go back to showing nonempty subscribed groups again. Thus, unsubscribed
2383groups are hidden, in a way.
2384
2385Zombie and killed groups are similar to unsubscribed groups in that they
2386are hidden by default. But they are different from subscribed and
2387unsubscribed groups in that Gnus doesn't ask the news server for
2388information (number of messages, number of unread messages) on zombie
2389and killed groups. Normally, you use @kbd{C-k} to kill the groups you
2390aren't interested in. If most groups are killed, Gnus is faster.
2391
2392Why does Gnus distinguish between zombie and killed groups? Well, when
2393a new group arrives on the server, Gnus by default makes it a zombie
2394group. This means that you are normally not bothered with new groups,
2395but you can type @kbd{A z} to get a list of all new groups. Subscribe
2396the ones you like and kill the ones you don't want. (@kbd{A k} shows a
2397list of killed groups.)
2398
2399If you want to play with the level variables, you should show some care.
2400Set them once, and don't touch them ever again. Better yet, don't touch
2401them at all unless you know exactly what you're doing.
2402
2403@vindex gnus-level-default-unsubscribed
2404@vindex gnus-level-default-subscribed
2405Two closely related variables are @code{gnus-level-default-subscribed}
2406(default 3) and @code{gnus-level-default-unsubscribed} (default 6),
2407which are the levels that new groups will be put on if they are
2408(un)subscribed. These two variables should, of course, be inside the
2409relevant valid ranges.
2410
2411@vindex gnus-keep-same-level
2412If @code{gnus-keep-same-level} is non-@code{nil}, some movement commands
2413will only move to groups of the same level (or lower). In
2414particular, going from the last article in one group to the next group
2415will go to the next group of the same level (or lower). This might be
2416handy if you want to read the most important groups before you read the
2417rest.
2418
2419If this variable is @code{best}, Gnus will make the next newsgroup the
2420one with the best level.
2421
2422@vindex gnus-group-default-list-level
2423All groups with a level less than or equal to
2424@code{gnus-group-default-list-level} will be listed in the group buffer
2425by default.
2426
2427@vindex gnus-group-list-inactive-groups
2428If @code{gnus-group-list-inactive-groups} is non-@code{nil}, non-active
2429groups will be listed along with the unread groups. This variable is
2430@code{t} by default. If it is @code{nil}, inactive groups won't be
2431listed.
2432
2433@vindex gnus-group-use-permanent-levels
2434If @code{gnus-group-use-permanent-levels} is non-@code{nil}, once you
2435give a level prefix to @kbd{g} or @kbd{l}, all subsequent commands will
2436use this level as the ``work'' level.
2437
2438@vindex gnus-activate-level
2439Gnus will normally just activate (i. e., query the server about) groups
2440on level @code{gnus-activate-level} or less. If you don't want to
2441activate unsubscribed groups, for instance, you might set this variable
2442to 5. The default is 6.
2443
2444
2445@node Group Score
2446@section Group Score
2447@cindex group score
2448@cindex group rank
2449@cindex rank
2450
2451You would normally keep important groups on high levels, but that scheme
2452is somewhat restrictive. Don't you wish you could have Gnus sort the
2453group buffer according to how often you read groups, perhaps? Within
2454reason?
2455
2456This is what @dfn{group score} is for. You can have Gnus assign a score
2457to each group through the mechanism described below. You can then sort
2458the group buffer based on this score. Alternatively, you can sort on
2459score and then level. (Taken together, the level and the score is
2460called the @dfn{rank} of the group. A group that is on level 4 and has
2461a score of 1 has a higher rank than a group on level 5 that has a score
2462of 300. (The level is the most significant part and the score is the
2463least significant part.))
2464
2465@findex gnus-summary-bubble-group
2466If you want groups you read often to get higher scores than groups you
2467read seldom you can add the @code{gnus-summary-bubble-group} function to
2468the @code{gnus-summary-exit-hook} hook. This will result (after
2469sorting) in a bubbling sort of action. If you want to see that in
2470action after each summary exit, you can add
2471@code{gnus-group-sort-groups-by-rank} or
2472@code{gnus-group-sort-groups-by-score} to the same hook, but that will
2473slow things down somewhat.
2474
2475
2476@node Marking Groups
2477@section Marking Groups
2478@cindex marking groups
2479
2480If you want to perform some command on several groups, and they appear
2481subsequently in the group buffer, you would normally just give a
2482numerical prefix to the command. Most group commands will then do your
2483bidding on those groups.
2484
2485However, if the groups are not in sequential order, you can still
2486perform a command on several groups. You simply mark the groups first
2487with the process mark and then execute the command.
2488
2489@table @kbd
2490
2491@item #
2492@kindex # (Group)
2493@itemx M m
2494@kindex M m (Group)
2495@findex gnus-group-mark-group
2496Set the mark on the current group (@code{gnus-group-mark-group}).
2497
2498@item M-#
2499@kindex M-# (Group)
2500@itemx M u
2501@kindex M u (Group)
2502@findex gnus-group-unmark-group
2503Remove the mark from the current group
2504(@code{gnus-group-unmark-group}).
2505
2506@item M U
2507@kindex M U (Group)
2508@findex gnus-group-unmark-all-groups
2509Remove the mark from all groups (@code{gnus-group-unmark-all-groups}).
2510
2511@item M w
2512@kindex M w (Group)
2513@findex gnus-group-mark-region
2514Mark all groups between point and mark (@code{gnus-group-mark-region}).
2515
2516@item M b
2517@kindex M b (Group)
2518@findex gnus-group-mark-buffer
2519Mark all groups in the buffer (@code{gnus-group-mark-buffer}).
2520
2521@item M r
2522@kindex M r (Group)
2523@findex gnus-group-mark-regexp
2524Mark all groups that match some regular expression
2525(@code{gnus-group-mark-regexp}).
2526@end table
2527
2528Also @pxref{Process/Prefix}.
2529
2530@findex gnus-group-universal-argument
2531If you want to execute some command on all groups that have been marked
2532with the process mark, you can use the @kbd{M-&}
2533(@code{gnus-group-universal-argument}) command. It will prompt you for
2534the command to be executed.
2535
2536
2537@node Foreign Groups
2538@section Foreign Groups
2539@cindex foreign groups
2540
2541Below are some group mode commands for making and editing general foreign
2542groups, as well as commands to ease the creation of a few
2543special-purpose groups. All these commands insert the newly created
2544groups under point---@code{gnus-subscribe-newsgroup-method} is not
2545consulted.
2546
2547Changes from the group editing commands are stored in
2548@file{~/.newsrc.eld} (@code{gnus-startup-file}). An alternative is the
2549variable @code{gnus-parameters}, @xref{Group Parameters}.
2550
2551@table @kbd
2552
2553@item G m
2554@kindex G m (Group)
2555@findex gnus-group-make-group
2556@cindex making groups
2557Make a new group (@code{gnus-group-make-group}). Gnus will prompt you
2558for a name, a method and possibly an @dfn{address}. For an easier way
2559to subscribe to @acronym{NNTP} groups (@pxref{Browse Foreign Server}).
2560
2561@item G M
2562@kindex G M (Group)
2563@findex gnus-group-read-ephemeral-group
2564Make an ephemeral group (@code{gnus-group-read-ephemeral-group}). Gnus
2565will prompt you for a name, a method and an @dfn{address}.
2566
2567@item G r
2568@kindex G r (Group)
2569@findex gnus-group-rename-group
2570@cindex renaming groups
2571Rename the current group to something else
2572(@code{gnus-group-rename-group}). This is valid only on some
2573groups---mail groups mostly. This command might very well be quite slow
2574on some back ends.
2575
2576@item G c
2577@kindex G c (Group)
2578@cindex customizing
2579@findex gnus-group-customize
2580Customize the group parameters (@code{gnus-group-customize}).
2581
2582@item G e
2583@kindex G e (Group)
2584@findex gnus-group-edit-group-method
2585@cindex renaming groups
2586Enter a buffer where you can edit the select method of the current
2587group (@code{gnus-group-edit-group-method}).
2588
2589@item G p
2590@kindex G p (Group)
2591@findex gnus-group-edit-group-parameters
2592Enter a buffer where you can edit the group parameters
2593(@code{gnus-group-edit-group-parameters}).
2594
2595@item G E
2596@kindex G E (Group)
2597@findex gnus-group-edit-group
2598Enter a buffer where you can edit the group info
2599(@code{gnus-group-edit-group}).
2600
2601@item G d
2602@kindex G d (Group)
2603@findex gnus-group-make-directory-group
2604@cindex nndir
2605Make a directory group (@pxref{Directory Groups}). You will be prompted
2606for a directory name (@code{gnus-group-make-directory-group}).
2607
2608@item G h
2609@kindex G h (Group)
2610@cindex help group
2611@findex gnus-group-make-help-group
2612Make the Gnus help group (@code{gnus-group-make-help-group}).
2613
2614@item G a
2615@kindex G a (Group)
2616@cindex (ding) archive
2617@cindex archive group
2618@findex gnus-group-make-archive-group
2619@vindex gnus-group-archive-directory
2620@vindex gnus-group-recent-archive-directory
2621Make a Gnus archive group (@code{gnus-group-make-archive-group}). By
2622default a group pointing to the most recent articles will be created
2623(@code{gnus-group-recent-archive-directory}), but given a prefix, a full
2624group will be created from @code{gnus-group-archive-directory}.
2625
4009494e
GM
2626@item G D
2627@kindex G D (Group)
2628@findex gnus-group-enter-directory
2629@cindex nneething
2630Read an arbitrary directory as if it were a newsgroup with the
2631@code{nneething} back end (@code{gnus-group-enter-directory}).
2632@xref{Anything Groups}.
2633
2634@item G f
2635@kindex G f (Group)
2636@findex gnus-group-make-doc-group
2637@cindex ClariNet Briefs
2638@cindex nndoc
2639Make a group based on some file or other
2640(@code{gnus-group-make-doc-group}). If you give a prefix to this
2641command, you will be prompted for a file name and a file type.
2642Currently supported types are @code{mbox}, @code{babyl},
2643@code{digest}, @code{news}, @code{rnews}, @code{mmdf}, @code{forward},
2644@code{rfc934}, @code{rfc822-forward}, @code{mime-parts},
2645@code{standard-digest}, @code{slack-digest}, @code{clari-briefs},
2646@code{nsmail}, @code{outlook}, @code{oe-dbx}, and @code{mailman}. If
2647you run this command without a prefix, Gnus will guess at the file
2648type. @xref{Document Groups}.
2649
2650@item G u
2651@kindex G u (Group)
2652@vindex gnus-useful-groups
2653@findex gnus-group-make-useful-group
2654Create one of the groups mentioned in @code{gnus-useful-groups}
2655(@code{gnus-group-make-useful-group}).
2656
2657@item G w
2658@kindex G w (Group)
2659@findex gnus-group-make-web-group
2660@cindex Google
2661@cindex nnweb
2662@cindex gmane
2663Make an ephemeral group based on a web search
2664(@code{gnus-group-make-web-group}). If you give a prefix to this
2665command, make a solid group instead. You will be prompted for the
2666search engine type and the search string. Valid search engine types
2667include @code{google}, @code{dejanews}, and @code{gmane}.
2668@xref{Web Searches}.
2669
2670If you use the @code{google} search engine, you can limit the search
2671to a particular group by using a match string like
2672@samp{shaving group:alt.sysadmin.recovery}.
2673
2674@item G R
2675@kindex G R (Group)
2676@findex gnus-group-make-rss-group
2677Make a group based on an @acronym{RSS} feed
2678(@code{gnus-group-make-rss-group}). You will be prompted for an URL.
2679@xref{RSS}.
2680
2681@item G DEL
2682@kindex G DEL (Group)
2683@findex gnus-group-delete-group
2684This function will delete the current group
2685(@code{gnus-group-delete-group}). If given a prefix, this function will
2686actually delete all the articles in the group, and forcibly remove the
2687group itself from the face of the Earth. Use a prefix only if you are
2688absolutely sure of what you are doing. This command can't be used on
2689read-only groups (like @code{nntp} groups), though.
2690
2691@item G V
2692@kindex G V (Group)
2693@findex gnus-group-make-empty-virtual
2694Make a new, fresh, empty @code{nnvirtual} group
2695(@code{gnus-group-make-empty-virtual}). @xref{Virtual Groups}.
2696
2697@item G v
2698@kindex G v (Group)
2699@findex gnus-group-add-to-virtual
2700Add the current group to an @code{nnvirtual} group
2701(@code{gnus-group-add-to-virtual}). Uses the process/prefix convention.
2702@end table
2703
2704@xref{Select Methods}, for more information on the various select
2705methods.
2706
2707@vindex gnus-activate-foreign-newsgroups
2708If @code{gnus-activate-foreign-newsgroups} is a positive number,
2709Gnus will check all foreign groups with this level or lower at startup.
2710This might take quite a while, especially if you subscribe to lots of
2711groups from different @acronym{NNTP} servers. Also @pxref{Group Levels};
2712@code{gnus-activate-level} also affects activation of foreign
2713newsgroups.
2714
2715
9b3ebcb6
MB
2716The following commands create ephemeral groups. They can be called not
2717only from the Group buffer, but in any Gnus buffer.
2718
2719@table @code
2720@item gnus-read-ephemeral-gmane-group
2721@findex gnus-read-ephemeral-gmane-group
2722@vindex gnus-gmane-group-download-format
2723Read an ephemeral group on Gmane.org. The articles are downloaded via
2724HTTP using the URL specified by @code{gnus-gmane-group-download-format}.
2725Gnus will prompt you for a group name, the start article number and an
2726the article range.
2727
2728@item gnus-read-ephemeral-gmane-group-url
2729@findex gnus-read-ephemeral-gmane-group-url
2730This command is similar to @code{gnus-read-ephemeral-gmane-group}, but
2731the group name and the article number and range are constructed from a
2732given @acronym{URL}. Supported @acronym{URL} formats include e.g.
2733@url{http://thread.gmane.org/gmane.foo.bar/12300/focus=12399},
2734@url{http://thread.gmane.org/gmane.foo.bar/12345/},
2735@url{http://article.gmane.org/gmane.foo.bar/12345/},
2736@url{http://permalink.gmane.org/gmane.foo.bar/12345/}, and
2737@url{http://news.gmane.org/group/gmane.foo.bar/thread=12345}.
2738
2739@item gnus-read-ephemeral-emacs-bug-group
2740@findex gnus-read-ephemeral-emacs-bug-group
2741Read an Emacs bug report in an ephemeral group. Gnus will prompt for a
2742bug number. The default is the number at point. The @acronym{URL} is
2743specified in @code{gnus-bug-group-download-format-alist}.
2744
2745@item gnus-read-ephemeral-debian-bug-group
2746@findex gnus-read-ephemeral-debian-bug-group
2747Read a Debian bug report in an ephemeral group. Analog to
2748@code{gnus-read-ephemeral-emacs-bug-group}.
2749@end table
2750
2751Some of these command are also useful for article buttons, @xref{Article
2752Buttons}.
2753
2754Here is an example:
2755@lisp
2756(require 'gnus-art)
2757(add-to-list
2758 'gnus-button-alist
2759 '("#\\([0-9]+\\)\\>" 1
2760 (string-match "\\<emacs\\>" (or gnus-newsgroup-name ""))
2761 gnus-read-ephemeral-emacs-bug-group 1))
2762@end lisp
2763
2764
4009494e
GM
2765@node Group Parameters
2766@section Group Parameters
2767@cindex group parameters
2768
2769The group parameters store information local to a particular group.
87035689
MB
2770
2771Use the @kbd{G p} or the @kbd{G c} command to edit group parameters of a
2772group. (@kbd{G p} presents you with a Lisp-based interface, @kbd{G c}
2773presents you with a Customize-like interface. The latter helps avoid
2774silly Lisp errors.) You might also be interested in reading about topic
2775parameters (@pxref{Topic Parameters}).
2776Additionally, you can set group parameters via the
2777@code{gnus-parameters} variable, see below.
2778
4009494e
GM
2779Here's an example group parameter list:
2780
2781@example
2782((to-address . "ding@@gnus.org")
2783 (auto-expire . t))
2784@end example
2785
2786We see that each element consists of a ``dotted pair''---the thing before
2787the dot is the key, while the thing after the dot is the value. All the
2788parameters have this form @emph{except} local variable specs, which are
2789not dotted pairs, but proper lists.
2790
2791Some parameters have correspondent customizable variables, each of which
2792is an alist of regexps and values.
2793
2794The following group parameters can be used:
2795
2796@table @code
2797@item to-address
2798@cindex to-address
2799Address used by when doing followups and new posts.
2800
2801@example
2802(to-address . "some@@where.com")
2803@end example
2804
2805This is primarily useful in mail groups that represent closed mailing
2806lists---mailing lists where it's expected that everybody that writes to
2807the mailing list is subscribed to it. Since using this parameter
2808ensures that the mail only goes to the mailing list itself, it means
2809that members won't receive two copies of your followups.
2810
2811Using @code{to-address} will actually work whether the group is foreign
2812or not. Let's say there's a group on the server that is called
2813@samp{fa.4ad-l}. This is a real newsgroup, but the server has gotten
2814the articles from a mail-to-news gateway. Posting directly to this
2815group is therefore impossible---you have to send mail to the mailing
2816list address instead.
2817
2818See also @code{gnus-parameter-to-address-alist}.
2819
2820@item to-list
2821@cindex to-list
2822Address used when doing @kbd{a} in that group.
2823
2824@example
2825(to-list . "some@@where.com")
2826@end example
2827
2828It is totally ignored
2829when doing a followup---except that if it is present in a news group,
2830you'll get mail group semantics when doing @kbd{f}.
2831
2832If you do an @kbd{a} command in a mail group and you have neither a
2833@code{to-list} group parameter nor a @code{to-address} group parameter,
2834then a @code{to-list} group parameter will be added automatically upon
2835sending the message if @code{gnus-add-to-list} is set to @code{t}.
2836@vindex gnus-add-to-list
2837
2838@findex gnus-mailing-list-mode
2839@cindex mail list groups
2840If this variable is set, @code{gnus-mailing-list-mode} is turned on when
2841entering summary buffer.
2842
2843See also @code{gnus-parameter-to-list-alist}.
2844
2845@anchor{subscribed}
2846@item subscribed
2847@cindex subscribed
2848@cindex Mail-Followup-To
2849@findex gnus-find-subscribed-addresses
2850If this parameter is set to @code{t}, Gnus will consider the
2851to-address and to-list parameters for this group as addresses of
2852mailing lists you are subscribed to. Giving Gnus this information is
2853(only) a first step in getting it to generate correct Mail-Followup-To
2854headers for your posts to these lists. The second step is to put the
2855following in your @file{.gnus.el}
2856
2857@lisp
2858(setq message-subscribed-address-functions
2859 '(gnus-find-subscribed-addresses))
2860@end lisp
2861
2862@xref{Mailing Lists, ,Mailing Lists, message, The Message Manual}, for
2863a complete treatment of available MFT support.
2864
2865@item visible
2866@cindex visible
2867If the group parameter list has the element @code{(visible . t)},
2868that group will always be visible in the Group buffer, regardless
2869of whether it has any unread articles.
2870
2871This parameter cannot be set via @code{gnus-parameters}. See
2872@code{gnus-permanently-visible-groups} as an alternative.
2873
2874@item broken-reply-to
2875@cindex broken-reply-to
2876Elements like @code{(broken-reply-to . t)} signals that @code{Reply-To}
2877headers in this group are to be ignored, and for the header to be hidden
2878if @code{reply-to} is part of @code{gnus-boring-article-headers}. This
2879can be useful if you're reading a mailing list group where the listserv
2880has inserted @code{Reply-To} headers that point back to the listserv
2881itself. That is broken behavior. So there!
2882
2883@item to-group
2884@cindex to-group
2885Elements like @code{(to-group . "some.group.name")} means that all
2886posts in that group will be sent to @code{some.group.name}.
2887
2888@item newsgroup
2889@cindex newsgroup
2890If you have @code{(newsgroup . t)} in the group parameter list, Gnus
2891will treat all responses as if they were responses to news articles.
2892This can be useful if you have a mail group that's really a mirror of a
2893news group.
2894
2895@item gcc-self
2896@cindex gcc-self
2897If @code{(gcc-self . t)} is present in the group parameter list, newly
2898composed messages will be @code{Gcc}'d to the current group. If
2899@code{(gcc-self . none)} is present, no @code{Gcc:} header will be
2900generated, if @code{(gcc-self . "string")} is present, this string will
2901be inserted literally as a @code{gcc} header. This parameter takes
2902precedence over any default @code{Gcc} rules as described later
2903(@pxref{Archived Messages}).
2904
2905@strong{Caveat}: Adding @code{(gcc-self . t)} to the parameter list of
2906@code{nntp} groups (or the like) isn't valid. An @code{nntp} server
2907doesn't accept articles.
2908
2909@item auto-expire
2910@cindex auto-expire
2911@cindex expiring mail
2912If the group parameter has an element that looks like @code{(auto-expire
2913. t)}, all articles read will be marked as expirable. For an
2914alternative approach, @pxref{Expiring Mail}.
2915
2916See also @code{gnus-auto-expirable-newsgroups}.
2917
2918@item total-expire
2919@cindex total-expire
2920@cindex expiring mail
2921If the group parameter has an element that looks like
2922@code{(total-expire . t)}, all read articles will be put through the
2923expiry process, even if they are not marked as expirable. Use with
2924caution. Unread, ticked and dormant articles are not eligible for
2925expiry.
2926
2927See also @code{gnus-total-expirable-newsgroups}.
2928
2929@item expiry-wait
2930@cindex expiry-wait
2931@vindex nnmail-expiry-wait-function
2932If the group parameter has an element that looks like
2933@code{(expiry-wait . 10)}, this value will override any
2934@code{nnmail-expiry-wait} and @code{nnmail-expiry-wait-function}
2935(@pxref{Expiring Mail}) when expiring expirable messages. The value
2936can either be a number of days (not necessarily an integer) or the
2937symbols @code{never} or @code{immediate}.
2938
2939@item expiry-target
2940@cindex expiry-target
2941Where expired messages end up. This parameter overrides
2942@code{nnmail-expiry-target}.
2943
2944@item score-file
2945@cindex score file group parameter
2946Elements that look like @code{(score-file . "file")} will make
2947@file{file} into the current score file for the group in question. All
2948interactive score entries will be put into this file.
2949
2950@item adapt-file
2951@cindex adapt file group parameter
2952Elements that look like @code{(adapt-file . "file")} will make
2953@file{file} into the current adaptive file for the group in question.
2954All adaptive score entries will be put into this file.
2955
2956@item admin-address
2957@cindex admin-address
2958When unsubscribing from a mailing list you should never send the
2959unsubscription notice to the mailing list itself. Instead, you'd send
2960messages to the administrative address. This parameter allows you to
2961put the admin address somewhere convenient.
2962
2963@item display
2964@cindex display
2965Elements that look like @code{(display . MODE)} say which articles to
2966display on entering the group. Valid values are:
2967
2968@table @code
2969@item all
2970Display all articles, both read and unread.
2971
2972@item an integer
2973Display the last @var{integer} articles in the group. This is the same as
2974entering the group with @kbd{C-u @var{integer}}.
2975
2976@item default
2977Display the default visible articles, which normally includes unread and
2978ticked articles.
2979
2980@item an array
2981Display articles that satisfy a predicate.
2982
2983Here are some examples:
2984
2985@table @code
2986@item [unread]
2987Display only unread articles.
2988
2989@item [not expire]
2990Display everything except expirable articles.
2991
2992@item [and (not reply) (not expire)]
2993Display everything except expirable and articles you've already
2994responded to.
2995@end table
2996
2997The available operators are @code{not}, @code{and} and @code{or}.
2998Predicates include @code{tick}, @code{unsend}, @code{undownload},
2999@code{unread}, @code{dormant}, @code{expire}, @code{reply},
3000@code{killed}, @code{bookmark}, @code{score}, @code{save},
3001@code{cache}, @code{forward}, @code{unseen} and @code{recent}.
3002
3003@end table
3004
3005The @code{display} parameter works by limiting the summary buffer to
3006the subset specified. You can pop the limit by using the @kbd{/ w}
3007command (@pxref{Limiting}).
3008
3009@item comment
3010@cindex comment
3011Elements that look like @code{(comment . "This is a comment")} are
3012arbitrary comments on the group. You can display comments in the
3013group line (@pxref{Group Line Specification}).
3014
3015@item charset
3016@cindex charset
3017Elements that look like @code{(charset . iso-8859-1)} will make
3018@code{iso-8859-1} the default charset; that is, the charset that will be
3019used for all articles that do not specify a charset.
3020
3021See also @code{gnus-group-charset-alist}.
3022
3023@item ignored-charsets
3024@cindex ignored-charset
3025Elements that look like @code{(ignored-charsets x-unknown iso-8859-1)}
3026will make @code{iso-8859-1} and @code{x-unknown} ignored; that is, the
3027default charset will be used for decoding articles.
3028
3029See also @code{gnus-group-ignored-charsets-alist}.
3030
3031@item posting-style
3032@cindex posting-style
3033You can store additional posting style information for this group
3034here (@pxref{Posting Styles}). The format is that of an entry in the
3035@code{gnus-posting-styles} alist, except that there's no regexp matching
3036the group name (of course). Style elements in this group parameter will
3037take precedence over the ones found in @code{gnus-posting-styles}.
3038
3039For instance, if you want a funky name and signature in this group only,
3040instead of hacking @code{gnus-posting-styles}, you could put something
3041like this in the group parameters:
3042
3043@example
3044(posting-style
3045 (name "Funky Name")
3046 ("X-My-Header" "Funky Value")
3047 (signature "Funky Signature"))
3048@end example
3049
01c52d31
MB
3050If you're using topics to organize your group buffer
3051(@pxref{Group Topics}), note that posting styles can also be set in
3052the topics parameters. Posting styles in topic parameters apply to all
3053groups in this topic. More precisely, the posting-style settings for a
3054group result from the hierarchical merging of all posting-style
3055entries in the parameters of this group and all the topics it belongs
3056to.
3057
3058
4009494e
GM
3059@item post-method
3060@cindex post-method
3061If it is set, the value is used as the method for posting message
3062instead of @code{gnus-post-method}.
3063
a1da1e37
MB
3064@item mail-source
3065@cindex mail-source
3066If it is set, and the setting of @code{mail-sources} includes a
3067@code{group} mail source (@pxref{Mail Sources}), the value is a
3068mail source for this group.
3069
4009494e
GM
3070@item banner
3071@cindex banner
3072An item like @code{(banner . @var{regexp})} causes any part of an article
3073that matches the regular expression @var{regexp} to be stripped. Instead of
3074@var{regexp}, you can also use the symbol @code{signature} which strips the
3075last signature or any of the elements of the alist
3076@code{gnus-article-banner-alist}.
3077
3078@item sieve
3079@cindex sieve
3080This parameter contains a Sieve test that should match incoming mail
3081that should be placed in this group. From this group parameter, a
3082Sieve @samp{IF} control structure is generated, having the test as the
3083condition and @samp{fileinto "group.name";} as the body.
3084
3085For example, if the @samp{INBOX.list.sieve} group has the @code{(sieve
3086address "sender" "sieve-admin@@extundo.com")} group parameter, when
3087translating the group parameter into a Sieve script (@pxref{Sieve
3088Commands}) the following Sieve code is generated:
3089
3090@example
01c52d31
MB
3091if address "sender" "sieve-admin@@extundo.com" @{
3092 fileinto "INBOX.list.sieve";
3093@}
3094@end example
3095
3096To generate tests for multiple email-addresses use a group parameter
3097like @code{(sieve address "sender" ("name@@one.org" else@@two.org"))}.
3098When generating a sieve script (@pxref{Sieve Commands}) Sieve code
3099like the following is generated:
3100
3101@example
3102if address "sender" ["name@@one.org", "else@@two.org"] @{
3103 fileinto "INBOX.list.sieve";
4009494e
GM
3104@}
3105@end example
3106
01c52d31
MB
3107See @pxref{Sieve Commands} for commands and variables that might be of
3108interest in relation to the sieve parameter.
3109
4009494e
GM
3110The Sieve language is described in RFC 3028. @xref{Top, Emacs Sieve,
3111Top, sieve, Emacs Sieve}.
3112
3113@item (agent parameters)
3114If the agent has been enabled, you can set any of the its parameters
3115to control the behavior of the agent in individual groups. See Agent
3116Parameters in @ref{Category Syntax}. Most users will choose to set
3117agent parameters in either an agent category or group topic to
3118minimize the configuration effort.
3119
3120@item (@var{variable} @var{form})
3121You can use the group parameters to set variables local to the group you
3122are entering. If you want to turn threading off in @samp{news.answers},
3123you could put @code{(gnus-show-threads nil)} in the group parameters of
3124that group. @code{gnus-show-threads} will be made into a local variable
3125in the summary buffer you enter, and the form @code{nil} will be
3126@code{eval}ed there.
3127
e3e955fe
MB
3128Note that this feature sets the variable locally to the summary buffer
3129if and only if @var{variable} has been bound as a variable. Otherwise,
3130only evaluating the form will take place. So, you may want to bind the
3131variable in advance using @code{defvar} or other if the result of the
3132form needs to be set to it.
3133
4009494e
GM
3134But some variables are evaluated in the article buffer, or in the
3135message buffer (of a reply or followup or otherwise newly created
3136message). As a workaround, it might help to add the variable in
3137question to @code{gnus-newsgroup-variables}. @xref{Various Summary
3138Stuff}. So if you want to set @code{message-from-style} via the group
3139parameters, then you may need the following statement elsewhere in your
e6d2d263 3140@file{~/.gnus.el} file:
4009494e
GM
3141
3142@lisp
3143(add-to-list 'gnus-newsgroup-variables 'message-from-style)
3144@end lisp
3145
3146@vindex gnus-list-identifiers
3147A use for this feature is to remove a mailing list identifier tag in
3148the subject fields of articles. E.g. if the news group
3149
3150@example
3151nntp+news.gnus.org:gmane.text.docbook.apps
3152@end example
3153
3154has the tag @samp{DOC-BOOK-APPS:} in the subject of all articles, this
3155tag can be removed from the article subjects in the summary buffer for
3156the group by putting @code{(gnus-list-identifiers "DOCBOOK-APPS:")}
3157into the group parameters for the group.
3158
3159This can also be used as a group-specific hook function. If you want to
3160hear a beep when you enter a group, you could put something like
e3e955fe
MB
3161@code{(dummy-variable (ding))} in the parameters of that group. If
3162@code{dummy-variable} has been bound (see above), it will be set to the
3163(meaningless) result of the @code{(ding)} form.
4009494e
GM
3164
3165Alternatively, since the VARIABLE becomes local to the group, this
3166pattern can be used to temporarily change a hook. For example, if the
3167following is added to a group parameter
3168
3169@lisp
3170(gnus-summary-prepared-hook
3171 '(lambda nil (local-set-key "d" (local-key-binding "n"))))
3172@end lisp
3173
3174when the group is entered, the 'd' key will not mark the article as
3175expired.
3176
3177@end table
3178
4009494e
GM
3179@vindex gnus-parameters
3180Group parameters can be set via the @code{gnus-parameters} variable too.
3181But some variables, such as @code{visible}, have no effect (For this
3182case see @code{gnus-permanently-visible-groups} as an alternative.).
3183For example:
3184
3185@lisp
3186(setq gnus-parameters
3187 '(("mail\\..*"
3188 (gnus-show-threads nil)
3189 (gnus-use-scoring nil)
3190 (gnus-summary-line-format
3191 "%U%R%z%I%(%[%d:%ub%-23,23f%]%) %s\n")
3192 (gcc-self . t)
3193 (display . all))
3194
3195 ("^nnimap:\\(foo.bar\\)$"
3196 (to-group . "\\1"))
3197
3198 ("mail\\.me"
3199 (gnus-use-scoring t))
3200
3201 ("list\\..*"
3202 (total-expire . t)
3203 (broken-reply-to . t))))
3204@end lisp
3205
3206String value of parameters will be subjected to regexp substitution, as
3207the @code{to-group} example shows.
3208
3209@vindex gnus-parameters-case-fold-search
3210By default, whether comparing the group name and one of those regexps
3211specified in @code{gnus-parameters} is done in a case-sensitive manner
3212or a case-insensitive manner depends on the value of
3213@code{case-fold-search} at the time when the comparison is done. The
3214value of @code{case-fold-search} is typically @code{t}; it means, for
3215example, the element @code{("INBOX\\.FOO" (total-expire . t))} might be
3216applied to both the @samp{INBOX.FOO} group and the @samp{INBOX.foo}
3217group. If you want to make those regexps always case-sensitive, set the
3218value of the @code{gnus-parameters-case-fold-search} variable to
3219@code{nil}. Otherwise, set it to @code{t} if you want to compare them
3220always in a case-insensitive manner.
3221
01c52d31
MB
3222You can define different sorting to different groups via
3223@code{gnus-parameters}. Here is an example to sort an @acronym{NNTP}
3224group by reverse date to see the latest news at the top and an
3225@acronym{RSS} group by subject. In this example, the first group is the
3226Debian daily news group @code{gmane.linux.debian.user.news} from
3227news.gmane.org. The @acronym{RSS} group corresponds to the Debian
3228weekly news RSS feed
3229@url{http://packages.debian.org/unstable/newpkg_main.en.rdf},
3230@xref{RSS}.
3231
3232@lisp
3233(setq
3234 gnus-parameters
3235 '(("nntp.*gmane\\.debian\\.user\\.news"
3236 (gnus-show-threads nil)
3237 (gnus-article-sort-functions '((not gnus-article-sort-by-date)))
3238 (gnus-use-adaptive-scoring nil)
3239 (gnus-use-scoring nil))
3240 ("nnrss.*debian"
3241 (gnus-show-threads nil)
3242 (gnus-article-sort-functions 'gnus-article-sort-by-subject)
3243 (gnus-use-adaptive-scoring nil)
3244 (gnus-use-scoring t)
3245 (gnus-score-find-score-files-function 'gnus-score-find-single)
3246 (gnus-summary-line-format "%U%R%z%d %I%(%[ %s %]%)\n"))))
3247@end lisp
3248
4009494e
GM
3249
3250@node Listing Groups
3251@section Listing Groups
3252@cindex group listing
3253
3254These commands all list various slices of the groups available.
3255
3256@table @kbd
3257
3258@item l
3259@itemx A s
3260@kindex A s (Group)
3261@kindex l (Group)
3262@findex gnus-group-list-groups
3263List all groups that have unread articles
3264(@code{gnus-group-list-groups}). If the numeric prefix is used, this
3265command will list only groups of level ARG and lower. By default, it
3266only lists groups of level five (i.e.,
3267@code{gnus-group-default-list-level}) or lower (i.e., just subscribed
3268groups).
3269
3270@item L
3271@itemx A u
3272@kindex A u (Group)
3273@kindex L (Group)
3274@findex gnus-group-list-all-groups
3275List all groups, whether they have unread articles or not
3276(@code{gnus-group-list-all-groups}). If the numeric prefix is used,
3277this command will list only groups of level ARG and lower. By default,
3278it lists groups of level seven or lower (i.e., just subscribed and
3279unsubscribed groups).
3280
3281@item A l
3282@kindex A l (Group)
3283@findex gnus-group-list-level
3284List all unread groups on a specific level
3285(@code{gnus-group-list-level}). If given a prefix, also list the groups
3286with no unread articles.
3287
3288@item A k
3289@kindex A k (Group)
3290@findex gnus-group-list-killed
3291List all killed groups (@code{gnus-group-list-killed}). If given a
3292prefix argument, really list all groups that are available, but aren't
3293currently (un)subscribed. This could entail reading the active file
3294from the server.
3295
3296@item A z
3297@kindex A z (Group)
3298@findex gnus-group-list-zombies
3299List all zombie groups (@code{gnus-group-list-zombies}).
3300
3301@item A m
3302@kindex A m (Group)
3303@findex gnus-group-list-matching
3304List all unread, subscribed groups with names that match a regexp
3305(@code{gnus-group-list-matching}).
3306
3307@item A M
3308@kindex A M (Group)
3309@findex gnus-group-list-all-matching
3310List groups that match a regexp (@code{gnus-group-list-all-matching}).
3311
3312@item A A
3313@kindex A A (Group)
3314@findex gnus-group-list-active
3315List absolutely all groups in the active file(s) of the
3316server(s) you are connected to (@code{gnus-group-list-active}). This
3317might very well take quite a while. It might actually be a better idea
3318to do a @kbd{A M} to list all matching, and just give @samp{.} as the
3319thing to match on. Also note that this command may list groups that
3320don't exist (yet)---these will be listed as if they were killed groups.
3321Take the output with some grains of salt.
3322
3323@item A a
3324@kindex A a (Group)
3325@findex gnus-group-apropos
3326List all groups that have names that match a regexp
3327(@code{gnus-group-apropos}).
3328
3329@item A d
3330@kindex A d (Group)
3331@findex gnus-group-description-apropos
3332List all groups that have names or descriptions that match a regexp
3333(@code{gnus-group-description-apropos}).
3334
3335@item A c
3336@kindex A c (Group)
3337@findex gnus-group-list-cached
3338List all groups with cached articles (@code{gnus-group-list-cached}).
3339
3340@item A ?
3341@kindex A ? (Group)
3342@findex gnus-group-list-dormant
3343List all groups with dormant articles (@code{gnus-group-list-dormant}).
3344
3345@item A /
3346@kindex A / (Group)
3347@findex gnus-group-list-limit
3348List groups limited within the current selection
3349(@code{gnus-group-list-limit}).
3350
3351@item A f
3352@kindex A f (Group)
3353@findex gnus-group-list-flush
3354Flush groups from the current selection (@code{gnus-group-list-flush}).
3355
3356@item A p
3357@kindex A p (Group)
3358@findex gnus-group-list-plus
3359List groups plus the current selection (@code{gnus-group-list-plus}).
3360
3361@end table
3362
3363@vindex gnus-permanently-visible-groups
3364@cindex visible group parameter
3365Groups that match the @code{gnus-permanently-visible-groups} regexp will
3366always be shown, whether they have unread articles or not. You can also
3367add the @code{visible} element to the group parameters in question to
3368get the same effect.
3369
3370@vindex gnus-list-groups-with-ticked-articles
3371Groups that have just ticked articles in it are normally listed in the
3372group buffer. If @code{gnus-list-groups-with-ticked-articles} is
3373@code{nil}, these groups will be treated just like totally empty
3374groups. It is @code{t} by default.
3375
3376
3377@node Sorting Groups
3378@section Sorting Groups
3379@cindex sorting groups
3380
3381@kindex C-c C-s (Group)
3382@findex gnus-group-sort-groups
3383@vindex gnus-group-sort-function
3384The @kbd{C-c C-s} (@code{gnus-group-sort-groups}) command sorts the
3385group buffer according to the function(s) given by the
3386@code{gnus-group-sort-function} variable. Available sorting functions
3387include:
3388
3389@table @code
3390
3391@item gnus-group-sort-by-alphabet
3392@findex gnus-group-sort-by-alphabet
3393Sort the group names alphabetically. This is the default.
3394
3395@item gnus-group-sort-by-real-name
3396@findex gnus-group-sort-by-real-name
3397Sort the group alphabetically on the real (unprefixed) group names.
3398
3399@item gnus-group-sort-by-level
3400@findex gnus-group-sort-by-level
3401Sort by group level.
3402
3403@item gnus-group-sort-by-score
3404@findex gnus-group-sort-by-score
3405Sort by group score. @xref{Group Score}.
3406
3407@item gnus-group-sort-by-rank
3408@findex gnus-group-sort-by-rank
3409Sort by group score and then the group level. The level and the score
3410are, when taken together, the group's @dfn{rank}. @xref{Group Score}.
3411
3412@item gnus-group-sort-by-unread
3413@findex gnus-group-sort-by-unread
3414Sort by number of unread articles.
3415
3416@item gnus-group-sort-by-method
3417@findex gnus-group-sort-by-method
3418Sort alphabetically on the select method.
3419
3420@item gnus-group-sort-by-server
3421@findex gnus-group-sort-by-server
3422Sort alphabetically on the Gnus server name.
3423
3424
3425@end table
3426
3427@code{gnus-group-sort-function} can also be a list of sorting
3428functions. In that case, the most significant sort key function must be
3429the last one.
3430
3431
3432There are also a number of commands for sorting directly according to
3433some sorting criteria:
3434
3435@table @kbd
3436@item G S a
3437@kindex G S a (Group)
3438@findex gnus-group-sort-groups-by-alphabet
3439Sort the group buffer alphabetically by group name
3440(@code{gnus-group-sort-groups-by-alphabet}).
3441
3442@item G S u
3443@kindex G S u (Group)
3444@findex gnus-group-sort-groups-by-unread
3445Sort the group buffer by the number of unread articles
3446(@code{gnus-group-sort-groups-by-unread}).
3447
3448@item G S l
3449@kindex G S l (Group)
3450@findex gnus-group-sort-groups-by-level
3451Sort the group buffer by group level
3452(@code{gnus-group-sort-groups-by-level}).
3453
3454@item G S v
3455@kindex G S v (Group)
3456@findex gnus-group-sort-groups-by-score
3457Sort the group buffer by group score
3458(@code{gnus-group-sort-groups-by-score}). @xref{Group Score}.
3459
3460@item G S r
3461@kindex G S r (Group)
3462@findex gnus-group-sort-groups-by-rank
3463Sort the group buffer by group rank
3464(@code{gnus-group-sort-groups-by-rank}). @xref{Group Score}.
3465
3466@item G S m
3467@kindex G S m (Group)
3468@findex gnus-group-sort-groups-by-method
3469Sort the group buffer alphabetically by back end name@*
3470(@code{gnus-group-sort-groups-by-method}).
3471
3472@item G S n
3473@kindex G S n (Group)
3474@findex gnus-group-sort-groups-by-real-name
3475Sort the group buffer alphabetically by real (unprefixed) group name
3476(@code{gnus-group-sort-groups-by-real-name}).
3477
3478@end table
3479
3480All the commands below obey the process/prefix convention
3481(@pxref{Process/Prefix}).
3482
3483When given a symbolic prefix (@pxref{Symbolic Prefixes}), all these
3484commands will sort in reverse order.
3485
3486You can also sort a subset of the groups:
3487
3488@table @kbd
3489@item G P a
3490@kindex G P a (Group)
3491@findex gnus-group-sort-selected-groups-by-alphabet
3492Sort the groups alphabetically by group name
3493(@code{gnus-group-sort-selected-groups-by-alphabet}).
3494
3495@item G P u
3496@kindex G P u (Group)
3497@findex gnus-group-sort-selected-groups-by-unread
3498Sort the groups by the number of unread articles
3499(@code{gnus-group-sort-selected-groups-by-unread}).
3500
3501@item G P l
3502@kindex G P l (Group)
3503@findex gnus-group-sort-selected-groups-by-level
3504Sort the groups by group level
3505(@code{gnus-group-sort-selected-groups-by-level}).
3506
3507@item G P v
3508@kindex G P v (Group)
3509@findex gnus-group-sort-selected-groups-by-score
3510Sort the groups by group score
3511(@code{gnus-group-sort-selected-groups-by-score}). @xref{Group Score}.
3512
3513@item G P r
3514@kindex G P r (Group)
3515@findex gnus-group-sort-selected-groups-by-rank
3516Sort the groups by group rank
3517(@code{gnus-group-sort-selected-groups-by-rank}). @xref{Group Score}.
3518
3519@item G P m
3520@kindex G P m (Group)
3521@findex gnus-group-sort-selected-groups-by-method
3522Sort the groups alphabetically by back end name@*
3523(@code{gnus-group-sort-selected-groups-by-method}).
3524
3525@item G P n
3526@kindex G P n (Group)
3527@findex gnus-group-sort-selected-groups-by-real-name
3528Sort the groups alphabetically by real (unprefixed) group name
3529(@code{gnus-group-sort-selected-groups-by-real-name}).
3530
3531@item G P s
3532@kindex G P s (Group)
3533@findex gnus-group-sort-selected-groups
3534Sort the groups according to @code{gnus-group-sort-function}.
3535
3536@end table
3537
3538And finally, note that you can use @kbd{C-k} and @kbd{C-y} to manually
3539move groups around.
3540
3541
3542@node Group Maintenance
3543@section Group Maintenance
3544@cindex bogus groups
3545
3546@table @kbd
3547@item b
3548@kindex b (Group)
3549@findex gnus-group-check-bogus-groups
3550Find bogus groups and delete them
3551(@code{gnus-group-check-bogus-groups}).
3552
3553@item F
3554@kindex F (Group)
3555@findex gnus-group-find-new-groups
3556Find new groups and process them (@code{gnus-group-find-new-groups}).
3557With 1 @kbd{C-u}, use the @code{ask-server} method to query the server
3558for new groups. With 2 @kbd{C-u}'s, use most complete method possible
3559to query the server for new groups, and subscribe the new groups as
3560zombies.
3561
3562@item C-c C-x
3563@kindex C-c C-x (Group)
3564@findex gnus-group-expire-articles
3565@cindex expiring mail
3566Run all expirable articles in the current group through the expiry
3567process (if any) (@code{gnus-group-expire-articles}). That is, delete
3568all expirable articles in the group that have been around for a while.
3569(@pxref{Expiring Mail}).
3570
3571@item C-c C-M-x
3572@kindex C-c C-M-x (Group)
3573@findex gnus-group-expire-all-groups
3574@cindex expiring mail
3575Run all expirable articles in all groups through the expiry process
3576(@code{gnus-group-expire-all-groups}).
3577
3578@end table
3579
3580
3581@node Browse Foreign Server
3582@section Browse Foreign Server
3583@cindex foreign servers
3584@cindex browsing servers
3585
3586@table @kbd
3587@item B
3588@kindex B (Group)
3589@findex gnus-group-browse-foreign-server
3590You will be queried for a select method and a server name. Gnus will
3591then attempt to contact this server and let you browse the groups there
3592(@code{gnus-group-browse-foreign-server}).
3593@end table
3594
3595@findex gnus-browse-mode
3596A new buffer with a list of available groups will appear. This buffer
3597will use the @code{gnus-browse-mode}. This buffer looks a bit (well,
3598a lot) like a normal group buffer.
3599
3600Here's a list of keystrokes available in the browse mode:
3601
3602@table @kbd
3603@item n
3604@kindex n (Browse)
3605@findex gnus-group-next-group
3606Go to the next group (@code{gnus-group-next-group}).
3607
3608@item p
3609@kindex p (Browse)
3610@findex gnus-group-prev-group
3611Go to the previous group (@code{gnus-group-prev-group}).
3612
3613@item SPACE
3614@kindex SPACE (Browse)
3615@findex gnus-browse-read-group
3616Enter the current group and display the first article
3617(@code{gnus-browse-read-group}).
3618
3619@item RET
3620@kindex RET (Browse)
3621@findex gnus-browse-select-group
3622Enter the current group (@code{gnus-browse-select-group}).
3623
3624@item u
3625@kindex u (Browse)
3626@findex gnus-browse-unsubscribe-current-group
3627Unsubscribe to the current group, or, as will be the case here,
3628subscribe to it (@code{gnus-browse-unsubscribe-current-group}).
3629
3630@item l
3631@itemx q
3632@kindex q (Browse)
3633@kindex l (Browse)
3634@findex gnus-browse-exit
3635Exit browse mode (@code{gnus-browse-exit}).
3636
3637@item d
3638@kindex d (Browse)
3639@findex gnus-browse-describe-group
3640Describe the current group (@code{gnus-browse-describe-group}).
3641
3642@item ?
3643@kindex ? (Browse)
3644@findex gnus-browse-describe-briefly
3645Describe browse mode briefly (well, there's not much to describe, is
3646there) (@code{gnus-browse-describe-briefly}).
3647@end table
3648
3649
3650@node Exiting Gnus
3651@section Exiting Gnus
3652@cindex exiting Gnus
3653
3654Yes, Gnus is ex(c)iting.
3655
3656@table @kbd
3657@item z
3658@kindex z (Group)
3659@findex gnus-group-suspend
3660Suspend Gnus (@code{gnus-group-suspend}). This doesn't really exit Gnus,
3661but it kills all buffers except the Group buffer. I'm not sure why this
3662is a gain, but then who am I to judge?
3663
3664@item q
3665@kindex q (Group)
3666@findex gnus-group-exit
3667@c @icon{gnus-group-exit}
3668Quit Gnus (@code{gnus-group-exit}).
3669
3670@item Q
3671@kindex Q (Group)
3672@findex gnus-group-quit
3673Quit Gnus without saving the @file{.newsrc} files (@code{gnus-group-quit}).
3674The dribble file will be saved, though (@pxref{Auto Save}).
3675@end table
3676
3677@vindex gnus-exit-gnus-hook
3678@vindex gnus-suspend-gnus-hook
3679@vindex gnus-after-exiting-gnus-hook
3680@code{gnus-suspend-gnus-hook} is called when you suspend Gnus and
3681@code{gnus-exit-gnus-hook} is called when you quit Gnus, while
3682@code{gnus-after-exiting-gnus-hook} is called as the final item when
3683exiting Gnus.
3684
3685Note:
3686
3687@quotation
3688Miss Lisa Cannifax, while sitting in English class, felt her feet go
3689numbly heavy and herself fall into a hazy trance as the boy sitting
3690behind her drew repeated lines with his pencil across the back of her
3691plastic chair.
3692@end quotation
3693
3694
3695@node Group Topics
3696@section Group Topics
3697@cindex topics
3698
3699If you read lots and lots of groups, it might be convenient to group
3700them hierarchically according to topics. You put your Emacs groups over
3701here, your sex groups over there, and the rest (what, two groups or so?)
3702you put in some misc section that you never bother with anyway. You can
3703even group the Emacs sex groups as a sub-topic to either the Emacs
3704groups or the sex groups---or both! Go wild!
3705
3706@iftex
3707@iflatex
3708\gnusfigure{Group Topics}{400}{
3709\put(75,50){\epsfig{figure=ps/group-topic,height=9cm}}
3710}
3711@end iflatex
3712@end iftex
3713
3714Here's an example:
3715
3716@example
3717Gnus
3718 Emacs -- I wuw it!
3719 3: comp.emacs
3720 2: alt.religion.emacs
3721 Naughty Emacs
3722 452: alt.sex.emacs
3723 0: comp.talk.emacs.recovery
3724 Misc
3725 8: comp.binaries.fractals
3726 13: comp.sources.unix
3727@end example
3728
3729@findex gnus-topic-mode
3730@kindex t (Group)
3731To get this @emph{fab} functionality you simply turn on (ooh!) the
3732@code{gnus-topic} minor mode---type @kbd{t} in the group buffer. (This
3733is a toggling command.)
3734
3735Go ahead, just try it. I'll still be here when you get back. La de
3736dum@dots{} Nice tune, that@dots{} la la la@dots{} What, you're back?
3737Yes, and now press @kbd{l}. There. All your groups are now listed
3738under @samp{misc}. Doesn't that make you feel all warm and fuzzy?
3739Hot and bothered?
3740
3741If you want this permanently enabled, you should add that minor mode to
3742the hook for the group mode. Put the following line in your
3743@file{~/.gnus.el} file:
3744
3745@lisp
3746(add-hook 'gnus-group-mode-hook 'gnus-topic-mode)
3747@end lisp
3748
3749@menu
3750* Topic Commands:: Interactive E-Z commands.
3751* Topic Variables:: How to customize the topics the Lisp Way.
3752* Topic Sorting:: Sorting each topic individually.
3753* Topic Topology:: A map of the world.
3754* Topic Parameters:: Parameters that apply to all groups in a topic.
3755@end menu
3756
3757
3758@node Topic Commands
3759@subsection Topic Commands
3760@cindex topic commands
3761
3762When the topic minor mode is turned on, a new @kbd{T} submap will be
3763available. In addition, a few of the standard keys change their
3764definitions slightly.
3765
3766In general, the following kinds of operations are possible on topics.
3767First of all, you want to create topics. Secondly, you want to put
3768groups in topics and to move them around until you have an order you
3769like. The third kind of operation is to show/hide parts of the whole
3770shebang. You might want to hide a topic including its subtopics and
3771groups, to get a better overview of the other groups.
3772
3773Here is a list of the basic keys that you might need to set up topics
3774the way you like.
3775
3776@table @kbd
3777
3778@item T n
3779@kindex T n (Topic)
3780@findex gnus-topic-create-topic
3781Prompt for a new topic name and create it
3782(@code{gnus-topic-create-topic}).
3783
3784@item T TAB
3785@itemx TAB
3786@kindex T TAB (Topic)
3787@kindex TAB (Topic)
3788@findex gnus-topic-indent
3789``Indent'' the current topic so that it becomes a sub-topic of the
3790previous topic (@code{gnus-topic-indent}). If given a prefix,
3791``un-indent'' the topic instead.
3792
3793@item M-TAB
3794@kindex M-TAB (Topic)
3795@findex gnus-topic-unindent
3796``Un-indent'' the current topic so that it becomes a sub-topic of the
3797parent of its current parent (@code{gnus-topic-unindent}).
3798
3799@end table
3800
3801The following two keys can be used to move groups and topics around.
3802They work like the well-known cut and paste. @kbd{C-k} is like cut and
3803@kbd{C-y} is like paste. Of course, this being Emacs, we use the terms
3804kill and yank rather than cut and paste.
3805
3806@table @kbd
3807
3808@item C-k
3809@kindex C-k (Topic)
3810@findex gnus-topic-kill-group
3811Kill a group or topic (@code{gnus-topic-kill-group}). All groups in the
3812topic will be removed along with the topic.
3813
3814@item C-y
3815@kindex C-y (Topic)
3816@findex gnus-topic-yank-group
3817Yank the previously killed group or topic
3818(@code{gnus-topic-yank-group}). Note that all topics will be yanked
3819before all groups.
3820
3821So, to move a topic to the beginning of the list of topics, just hit
3822@kbd{C-k} on it. This is like the ``cut'' part of cut and paste. Then,
3823move the cursor to the beginning of the buffer (just below the ``Gnus''
3824topic) and hit @kbd{C-y}. This is like the ``paste'' part of cut and
3825paste. Like I said -- E-Z.
3826
3827You can use @kbd{C-k} and @kbd{C-y} on groups as well as on topics. So
3828you can move topics around as well as groups.
3829
3830@end table
3831
3832After setting up the topics the way you like them, you might wish to
3833hide a topic, or to show it again. That's why we have the following
3834key.
3835
3836@table @kbd
3837
3838@item RET
3839@kindex RET (Topic)
3840@findex gnus-topic-select-group
3841@itemx SPACE
3842Either select a group or fold a topic (@code{gnus-topic-select-group}).
3843When you perform this command on a group, you'll enter the group, as
3844usual. When done on a topic line, the topic will be folded (if it was
3845visible) or unfolded (if it was folded already). So it's basically a
3846toggling command on topics. In addition, if you give a numerical
3847prefix, group on that level (and lower) will be displayed.
3848
3849@end table
3850
3851Now for a list of other commands, in no particular order.
3852
3853@table @kbd
3854
3855@item T m
3856@kindex T m (Topic)
3857@findex gnus-topic-move-group
3858Move the current group to some other topic
3859(@code{gnus-topic-move-group}). This command uses the process/prefix
3860convention (@pxref{Process/Prefix}).
3861
3862@item T j
3863@kindex T j (Topic)
3864@findex gnus-topic-jump-to-topic
3865Go to a topic (@code{gnus-topic-jump-to-topic}).
3866
3867@item T c
3868@kindex T c (Topic)
3869@findex gnus-topic-copy-group
3870Copy the current group to some other topic
3871(@code{gnus-topic-copy-group}). This command uses the process/prefix
3872convention (@pxref{Process/Prefix}).
3873
3874@item T h
3875@kindex T h (Topic)
3876@findex gnus-topic-hide-topic
3877Hide the current topic (@code{gnus-topic-hide-topic}). If given
3878a prefix, hide the topic permanently.
3879
3880@item T s
3881@kindex T s (Topic)
3882@findex gnus-topic-show-topic
3883Show the current topic (@code{gnus-topic-show-topic}). If given
3884a prefix, show the topic permanently.
3885
3886@item T D
3887@kindex T D (Topic)
3888@findex gnus-topic-remove-group
3889Remove a group from the current topic (@code{gnus-topic-remove-group}).
3890This command is mainly useful if you have the same group in several
3891topics and wish to remove it from one of the topics. You may also
3892remove a group from all topics, but in that case, Gnus will add it to
3893the root topic the next time you start Gnus. In fact, all new groups
3894(which, naturally, don't belong to any topic) will show up in the root
3895topic.
3896
3897This command uses the process/prefix convention
3898(@pxref{Process/Prefix}).
3899
3900@item T M
3901@kindex T M (Topic)
3902@findex gnus-topic-move-matching
3903Move all groups that match some regular expression to a topic
3904(@code{gnus-topic-move-matching}).
3905
3906@item T C
3907@kindex T C (Topic)
3908@findex gnus-topic-copy-matching
3909Copy all groups that match some regular expression to a topic
3910(@code{gnus-topic-copy-matching}).
3911
3912@item T H
3913@kindex T H (Topic)
3914@findex gnus-topic-toggle-display-empty-topics
3915Toggle hiding empty topics
3916(@code{gnus-topic-toggle-display-empty-topics}).
3917
3918@item T #
3919@kindex T # (Topic)
3920@findex gnus-topic-mark-topic
3921Mark all groups in the current topic with the process mark
3922(@code{gnus-topic-mark-topic}). This command works recursively on
3923sub-topics unless given a prefix.
3924
3925@item T M-#
3926@kindex T M-# (Topic)
3927@findex gnus-topic-unmark-topic
3928Remove the process mark from all groups in the current topic
3929(@code{gnus-topic-unmark-topic}). This command works recursively on
3930sub-topics unless given a prefix.
3931
3932@item C-c C-x
3933@kindex C-c C-x (Topic)
3934@findex gnus-topic-expire-articles
3935@cindex expiring mail
3936Run all expirable articles in the current group or topic through the
3937expiry process (if any)
3938(@code{gnus-topic-expire-articles}). (@pxref{Expiring Mail}).
3939
3940@item T r
3941@kindex T r (Topic)
3942@findex gnus-topic-rename
3943Rename a topic (@code{gnus-topic-rename}).
3944
3945@item T DEL
3946@kindex T DEL (Topic)
3947@findex gnus-topic-delete
3948Delete an empty topic (@code{gnus-topic-delete}).
3949
3950@item A T
3951@kindex A T (Topic)
3952@findex gnus-topic-list-active
3953List all groups that Gnus knows about in a topics-ified way
3954(@code{gnus-topic-list-active}).
3955
3956@item T M-n
3957@kindex T M-n (Topic)
3958@findex gnus-topic-goto-next-topic
3959Go to the next topic (@code{gnus-topic-goto-next-topic}).
3960
3961@item T M-p
3962@kindex T M-p (Topic)
3963@findex gnus-topic-goto-previous-topic
01c52d31 3964Go to the previous topic (@code{gnus-topic-goto-previous-topic}).
4009494e
GM
3965
3966@item G p
3967@kindex G p (Topic)
3968@findex gnus-topic-edit-parameters
3969@cindex group parameters
3970@cindex topic parameters
3971@cindex parameters
3972Edit the topic parameters (@code{gnus-topic-edit-parameters}).
3973@xref{Topic Parameters}.
3974
3975@end table
3976
3977
3978@node Topic Variables
3979@subsection Topic Variables
3980@cindex topic variables
3981
3982The previous section told you how to tell Gnus which topics to display.
3983This section explains how to tell Gnus what to display about each topic.
3984
3985@vindex gnus-topic-line-format
3986The topic lines themselves are created according to the
3987@code{gnus-topic-line-format} variable (@pxref{Formatting Variables}).
3988Valid elements are:
3989
3990@table @samp
3991@item i
3992Indentation.
3993@item n
3994Topic name.
3995@item v
3996Visibility.
3997@item l
3998Level.
3999@item g
4000Number of groups in the topic.
4001@item a
4002Number of unread articles in the topic.
4003@item A
4004Number of unread articles in the topic and all its subtopics.
4005@end table
4006
4007@vindex gnus-topic-indent-level
4008Each sub-topic (and the groups in the sub-topics) will be indented with
4009@code{gnus-topic-indent-level} times the topic level number of spaces.
4010The default is 2.
4011
4012@vindex gnus-topic-mode-hook
4013@code{gnus-topic-mode-hook} is called in topic minor mode buffers.
4014
4015@vindex gnus-topic-display-empty-topics
4016The @code{gnus-topic-display-empty-topics} says whether to display even
4017topics that have no unread articles in them. The default is @code{t}.
4018
4019
4020@node Topic Sorting
4021@subsection Topic Sorting
4022@cindex topic sorting
4023
4024You can sort the groups in each topic individually with the following
4025commands:
4026
4027
4028@table @kbd
4029@item T S a
4030@kindex T S a (Topic)
4031@findex gnus-topic-sort-groups-by-alphabet
4032Sort the current topic alphabetically by group name
4033(@code{gnus-topic-sort-groups-by-alphabet}).
4034
4035@item T S u
4036@kindex T S u (Topic)
4037@findex gnus-topic-sort-groups-by-unread
4038Sort the current topic by the number of unread articles
4039(@code{gnus-topic-sort-groups-by-unread}).
4040
4041@item T S l
4042@kindex T S l (Topic)
4043@findex gnus-topic-sort-groups-by-level
4044Sort the current topic by group level
4045(@code{gnus-topic-sort-groups-by-level}).
4046
4047@item T S v
4048@kindex T S v (Topic)
4049@findex gnus-topic-sort-groups-by-score
4050Sort the current topic by group score
4051(@code{gnus-topic-sort-groups-by-score}). @xref{Group Score}.
4052
4053@item T S r
4054@kindex T S r (Topic)
4055@findex gnus-topic-sort-groups-by-rank
4056Sort the current topic by group rank
4057(@code{gnus-topic-sort-groups-by-rank}). @xref{Group Score}.
4058
4059@item T S m
4060@kindex T S m (Topic)
4061@findex gnus-topic-sort-groups-by-method
4062Sort the current topic alphabetically by back end name
4063(@code{gnus-topic-sort-groups-by-method}).
4064
4065@item T S e
4066@kindex T S e (Topic)
4067@findex gnus-topic-sort-groups-by-server
4068Sort the current topic alphabetically by server name
4069(@code{gnus-topic-sort-groups-by-server}).
4070
4071@item T S s
4072@kindex T S s (Topic)
4073@findex gnus-topic-sort-groups
4074Sort the current topic according to the function(s) given by the
4075@code{gnus-group-sort-function} variable
4076(@code{gnus-topic-sort-groups}).
4077
4078@end table
4079
4080When given a prefix argument, all these commands will sort in reverse
4081order. @xref{Sorting Groups}, for more information about group
4082sorting.
4083
4084
4085@node Topic Topology
4086@subsection Topic Topology
4087@cindex topic topology
4088@cindex topology
4089
4090So, let's have a look at an example group buffer:
4091
4092@example
4093@group
4094Gnus
4095 Emacs -- I wuw it!
4096 3: comp.emacs
4097 2: alt.religion.emacs
4098 Naughty Emacs
4099 452: alt.sex.emacs
4100 0: comp.talk.emacs.recovery
4101 Misc
4102 8: comp.binaries.fractals
4103 13: comp.sources.unix
4104@end group
4105@end example
4106
4107So, here we have one top-level topic (@samp{Gnus}), two topics under
4108that, and one sub-topic under one of the sub-topics. (There is always
4109just one (1) top-level topic). This topology can be expressed as
4110follows:
4111
4112@lisp
4113(("Gnus" visible)
4114 (("Emacs -- I wuw it!" visible)
4115 (("Naughty Emacs" visible)))
4116 (("Misc" visible)))
4117@end lisp
4118
4119@vindex gnus-topic-topology
4120This is in fact how the variable @code{gnus-topic-topology} would look
4121for the display above. That variable is saved in the @file{.newsrc.eld}
4122file, and shouldn't be messed with manually---unless you really want
4123to. Since this variable is read from the @file{.newsrc.eld} file,
4124setting it in any other startup files will have no effect.
4125
4126This topology shows what topics are sub-topics of what topics (right),
4127and which topics are visible. Two settings are currently
4128allowed---@code{visible} and @code{invisible}.
4129
4130
4131@node Topic Parameters
4132@subsection Topic Parameters
4133@cindex topic parameters
4134
4135All groups in a topic will inherit group parameters from the parent
4136(and ancestor) topic parameters. All valid group parameters are valid
4137topic parameters (@pxref{Group Parameters}). When the agent is
4138enabled, all agent parameters (See Agent Parameters in @ref{Category
4139Syntax}) are also valid topic parameters.
4140
4141In addition, the following parameters are only valid as topic
4142parameters:
4143
4144@table @code
4145@item subscribe
4146When subscribing new groups by topic (@pxref{Subscription Methods}), the
4147@code{subscribe} topic parameter says what groups go in what topic. Its
4148value should be a regexp to match the groups that should go in that
4149topic.
4150
4151@item subscribe-level
4152When subscribing new groups by topic (see the @code{subscribe} parameter),
4153the group will be subscribed with the level specified in the
4154@code{subscribe-level} instead of @code{gnus-level-default-subscribed}.
4155
4156@end table
4157
4158Group parameters (of course) override topic parameters, and topic
4159parameters in sub-topics override topic parameters in super-topics. You
4160know. Normal inheritance rules. (@dfn{Rules} is here a noun, not a
4161verb, although you may feel free to disagree with me here.)
4162
4163@example
4164@group
4165Gnus
4166 Emacs
4167 3: comp.emacs
4168 2: alt.religion.emacs
4169 452: alt.sex.emacs
4170 Relief
4171 452: alt.sex.emacs
4172 0: comp.talk.emacs.recovery
4173 Misc
4174 8: comp.binaries.fractals
4175 13: comp.sources.unix
4176 452: alt.sex.emacs
4177@end group
4178@end example
4179
4180The @samp{Emacs} topic has the topic parameter @code{(score-file
4181. "emacs.SCORE")}; the @samp{Relief} topic has the topic parameter
4182@code{(score-file . "relief.SCORE")}; and the @samp{Misc} topic has the
4183topic parameter @code{(score-file . "emacs.SCORE")}. In addition,
4184@* @samp{alt.religion.emacs} has the group parameter @code{(score-file
4185. "religion.SCORE")}.
4186
4187Now, when you enter @samp{alt.sex.emacs} in the @samp{Relief} topic, you
4188will get the @file{relief.SCORE} home score file. If you enter the same
4189group in the @samp{Emacs} topic, you'll get the @file{emacs.SCORE} home
4190score file. If you enter the group @samp{alt.religion.emacs}, you'll
4191get the @file{religion.SCORE} home score file.
4192
4193This seems rather simple and self-evident, doesn't it? Well, yes. But
4194there are some problems, especially with the @code{total-expiry}
4195parameter. Say you have a mail group in two topics; one with
4196@code{total-expiry} and one without. What happens when you do @kbd{M-x
4197gnus-expire-all-expirable-groups}? Gnus has no way of telling which one
4198of these topics you mean to expire articles from, so anything may
4199happen. In fact, I hereby declare that it is @dfn{undefined} what
4200happens. You just have to be careful if you do stuff like that.
4201
4202
01c52d31
MB
4203@node Non-ASCII Group Names
4204@section Accessing groups of non-English names
4205@cindex non-ascii group names
4206
4207There are some news servers that provide groups of which the names are
4208expressed with their native languages in the world. For instance, in a
4209certain news server there are some newsgroups of which the names are
4210spelled in Chinese, where people are talking in Chinese. You can, of
4211course, subscribe to such news groups using Gnus. Currently Gnus
4212supports non-@acronym{ASCII} group names not only with the @code{nntp}
4213back end but also with the @code{nnml} back end and the @code{nnrss}
4214back end.
4215
4216Every such group name is encoded by a certain charset in the server
4217side (in an @acronym{NNTP} server its administrator determines the
4218charset, but for groups in the other back ends it is determined by you).
4219Gnus has to display the decoded ones for you in the group buffer and the
4220article buffer, and needs to use the encoded ones when communicating
4221with servers. However, Gnus doesn't know what charset is used for each
4222non-@acronym{ASCII} group name. The following two variables are just
4223the ones for telling Gnus what charset should be used for each group:
4224
4225@table @code
4226@item gnus-group-name-charset-method-alist
4227@vindex gnus-group-name-charset-method-alist
4228An alist of select methods and charsets. The default value is
4229@code{nil}. The names of groups in the server specified by that select
4230method are all supposed to use the corresponding charset. For example:
4231
4232@lisp
4233(setq gnus-group-name-charset-method-alist
4234 '(((nntp "news.com.cn") . cn-gb-2312)))
4235@end lisp
4236
4237Charsets specified for groups with this variable are preferred to the
4238ones specified for the same groups with the
4239@code{gnus-group-name-charset-group-alist} variable (see below).
4240
4241A select method can be very long, like:
4242
4243@lisp
4244(nntp "gmane"
4245 (nntp-address "news.gmane.org")
4246 (nntp-end-of-line "\n")
4247 (nntp-open-connection-function
4248 nntp-open-via-rlogin-and-telnet)
4249 (nntp-via-rlogin-command "ssh")
4250 (nntp-via-rlogin-command-switches
4251 ("-C" "-t" "-e" "none"))
4252 (nntp-via-address @dots{}))
4253@end lisp
4254
4255In that case, you can truncate it into @code{(nntp "gmane")} in this
4256variable. That is, it is enough to contain only the back end name and
4257the server name.
4258
4259@item gnus-group-name-charset-group-alist
4260@cindex UTF-8 group names
4261@vindex gnus-group-name-charset-group-alist
4262An alist of regexp of group name and the charset for group names.
4263@code{((".*" . utf-8))} is the default value if UTF-8 is supported,
4264otherwise the default is @code{nil}. For example:
4265
4266@lisp
4267(setq gnus-group-name-charset-group-alist
4268 '(("\\.com\\.cn:" . cn-gb-2312)
4269 (".*" . utf-8)))
4270@end lisp
4271
4272Note that this variable is ignored if the match is made with
4273@code{gnus-group-name-charset-method-alist}.
4274@end table
4275
4276Those two variables are used also to determine the charset for encoding
4277and decoding non-@acronym{ASCII} group names that are in the back ends
4278other than @code{nntp}. It means that it is you who determine it. If
4279you do nothing, the charset used for group names in those back ends will
4280all be @code{utf-8} because of the last element of
4281@code{gnus-group-name-charset-group-alist}.
4282
4283There is one more important variable for non-@acronym{ASCII} group
26b9f88d 4284names:
01c52d31
MB
4285
4286@table @code
4287@item nnmail-pathname-coding-system
26b9f88d
MB
4288@vindex nnmail-pathname-coding-system
4289The value of this variable should be a coding system or @code{nil}. The
4290default is @code{nil} in Emacs, or is the aliasee of the coding system
4291named @code{file-name} (a certain coding system of which an alias is
4292@code{file-name}) in XEmacs.
4293
4294The @code{nnml} back end, the @code{nnrss} back end, the @acronym{NNTP}
4295marks feature (@pxref{NNTP marks}), the agent, and the cache use
4296non-@acronym{ASCII} group names in those files and directories. This
4297variable overrides the value of @code{file-name-coding-system} which
4298specifies the coding system used when encoding and decoding those file
4299names and directory names.
01c52d31
MB
4300
4301In XEmacs (with the @code{mule} feature), @code{file-name-coding-system}
4302is the only means to specify the coding system used to encode and decode
26b9f88d 4303file names. On the other hand, Emacs uses the value of
01c52d31 4304@code{default-file-name-coding-system} if @code{file-name-coding-system}
26b9f88d
MB
4305is @code{nil} or it is bound to the value of
4306@code{nnmail-pathname-coding-system} which is @code{nil}.
4307
4308Normally the value of @code{default-file-name-coding-system} in Emacs or
4309@code{nnmail-pathname-coding-system} in XEmacs is initialized according
4310to the locale, so you will need to do nothing if the value is suitable
4311to encode and decode non-@acronym{ASCII} group names.
01c52d31
MB
4312
4313The value of this variable (or @code{default-file-name-coding-system})
4314does not necessarily need to be the same value that is determined by
4315@code{gnus-group-name-charset-method-alist} and
4316@code{gnus-group-name-charset-group-alist}.
4317
26b9f88d
MB
4318If @code{default-file-name-coding-system} or this variable is
4319initialized by default to @code{iso-latin-1} for example, although you
4320want to subscribe to the groups spelled in Chinese, that is the most
4321typical case where you have to customize
4322@code{nnmail-pathname-coding-system}. The @code{utf-8} coding system is
4323a good candidate for it. Otherwise, you may change the locale in your
4324system so that @code{default-file-name-coding-system} or this variable
4325may be initialized to an appropriate value.
01c52d31
MB
4326@end table
4327
4328Note that when you copy or move articles from a non-@acronym{ASCII}
4329group to another group, the charset used to encode and decode group
4330names should be the same in both groups. Otherwise the Newsgroups
4331header will be displayed incorrectly in the article buffer.
4332
4333
e6d2d263
MB
4334@node Searching
4335@section Searching
4336
4337@menu
4338* nnir:: Searching on IMAP, with swish, namazu, etc.
4339* nnmairix:: Searching maildir, MH or mbox with Mairix.
4340@end menu
4341
4342@cindex Searching
4343
4344FIXME: This node is a stub.
4345
4346FIXME: Add a brief overview of Gnus search capabilities. A brief
4347comparison of nnir, nnmairix, contrib/gnus-namazu would be nice
4348as well.
4349
4350FIXME: Explain difference to @ref{Searching for Articles}, add reference
4351and back-reference.
4352
4353@node nnir
4354@subsection nnir
4355
4356FIXME: As a first step, convert the commentary of @file{nnir} to texi.
4357@cindex nnir
4358
4359@node nnmairix
4360@subsection nnmairix
4361
867d4bb3 4362@cindex mairix
e6d2d263
MB
4363@cindex nnmairix
4364This paragraph describes how to set up mairix and the back end
4365@code{nnmairix} for indexing and searching your mail from within
4366Gnus. Additionally, you can create permanent ``smart'' groups which are
4367bound to mairix searches and are automatically updated.
4368
4369@menu
4370* About mairix:: About the mairix mail search engine
4371* nnmairix requirements:: What you will need for using nnmairix
4372* What nnmairix does:: What does nnmairix actually do?
4373* Setting up mairix:: Set up your mairix installation
4374* Configuring nnmairix:: Set up the nnmairix back end
4375* nnmairix keyboard shortcuts:: List of available keyboard shortcuts
4376* Propagating marks:: How to propagate marks from nnmairix groups
4377* nnmairix tips and tricks:: Some tips, tricks and examples
4378* nnmairix caveats:: Some more stuff you might want to know
4379@end menu
4380
2b968687
MB
4381@c FIXME: The markup in this section might need improvement.
4382@c E.g. adding @samp, @var, @file, @command, etc.
4383@c Cf. (info "(texinfo)Indicating")
e6d2d263
MB
4384
4385@node About mairix
4386@subsubsection About mairix
4387
4388Mairix is a tool for indexing and searching words in locally stored
4389mail. It was written by Richard Curnow and is licensed under the
4390GPL. Mairix comes with most popular GNU/Linux distributions, but it also
4391runs under Windows (with cygwin), Mac OS X and Solaris. The homepage can
4392be found at
4393@uref{http://www.rpcurnow.force9.co.uk/mairix/index.html}
4394
4395Though mairix might not be as flexible as other search tools like
4396swish++ or namazu, which you can use via the @code{nnir} back end, it
4397has the prime advantage of being incredibly fast. On current systems, it
4398can easily search through headers and message bodies of thousands and
4399thousands of mails in well under a second. Building the database
4400necessary for searching might take a minute or two, but only has to be
4401done once fully. Afterwards, the updates are done incrementally and
4402therefore are really fast, too. Additionally, mairix is very easy to set
4403up.
4404
4405For maximum speed though, mairix should be used with mails stored in
4406@code{Maildir} or @code{MH} format (this includes the @code{nnml} back
4407end), although it also works with mbox. Mairix presents the search
4408results by populating a @emph{virtual} maildir/MH folder with symlinks
4409which point to the ``real'' message files (if mbox is used, copies are
4410made). Since mairix already presents search results in such a virtual
4411mail folder, it is very well suited for using it as an external program
4412for creating @emph{smart} mail folders, which represent certain mail
f7362445 4413searches.
e6d2d263
MB
4414
4415@node nnmairix requirements
4416@subsubsection nnmairix requirements
4417
2b968687 4418Mairix searches local mail---that means, mairix absolutely must have
e6d2d263
MB
4419direct access to your mail folders. If your mail resides on another
4420server (e.g. an @acronym{IMAP} server) and you happen to have shell
4421access, @code{nnmairix} supports running mairix remotely, e.g. via ssh.
4422
4423Additionally, @code{nnmairix} only supports the following Gnus back
2b968687
MB
4424ends: @code{nnml}, @code{nnmaildir}, and @code{nnimap}. You must use
4425one of these back ends for using @code{nnmairix}. Other back ends, like
4426@code{nnmbox}, @code{nnfolder} or @code{nnmh}, won't work.
e6d2d263
MB
4427
4428If you absolutely must use mbox and still want to use @code{nnmairix},
4429you can set up a local @acronym{IMAP} server, which you then access via
4430@code{nnimap}. This is a rather massive setup for accessing some mbox
030cca00
MB
4431files, so just change to MH or Maildir already... However, if you're
4432really, really passionate about using mbox, you might want to look into
4433the package @file{mairix.el}, which comes with Emacs 23.
e6d2d263
MB
4434
4435@node What nnmairix does
4436@subsubsection What nnmairix does
4437
4438The back end @code{nnmairix} enables you to call mairix from within Gnus,
4439either to query mairix with a search term or to update the
4440database. While visiting a message in the summary buffer, you can use
4441several pre-defined shortcuts for calling mairix, e.g. to quickly
4442search for all mails from the sender of the current message or to
4443display the whole thread associated with the message, even if the
4444mails are in different folders.
4445
4446Additionally, you can create permanent @code{nnmairix} groups which are bound
4447to certain mairix searches. This way, you can easily create a group
4448containing mails from a certain sender, with a certain subject line or
4449even for one specific thread based on the Message-ID. If you check for
4450new mail in these folders (e.g. by pressing @kbd{g} or @kbd{M-g}), they
867d4bb3 4451automatically update themselves by calling mairix.
e6d2d263
MB
4452
4453You might ask why you need @code{nnmairix} at all, since mairix already
4454creates the group, populates it with links to the mails so that you can
030cca00 4455then access it with Gnus, right? Well, this @emph{might} work, but often
2b968687 4456does not---at least not without problems. Most probably you will get
e6d2d263
MB
4457strange article counts, and sometimes you might see mails which Gnus
4458claims have already been canceled and are inaccessible. This is due to
4459the fact that Gnus isn't really amused when things are happening behind
4460its back. Another problem can be the mail back end itself, e.g. if you
4461use mairix with an @acronym{IMAP} server (I had Dovecot complaining
4462about corrupt index files when mairix changed the contents of the search
4463group). Using @code{nnmairix} should circumvent these problems.
4464
030cca00
MB
4465@code{nnmairix} is not really a mail back end---it's actually more like
4466a wrapper, sitting between a ``real'' mail back end where mairix stores
4467the searches and the Gnus front end. You can choose between three
4468different mail back ends for the mairix folders: @code{nnml},
4469@code{nnmaildir} or @code{nnimap}. @code{nnmairix} will call the mairix
4470binary so that the search results are stored in folders named
e6d2d263 4471@code{zz_mairix-<NAME>-<NUMBER>} on this mail back end, but it will
030cca00
MB
4472present these folders in the Gnus front end only with @code{<NAME>}.
4473You can use an existing mail back end where you already store your mail,
4474but if you're uncomfortable with @code{nnmairix} creating new mail
4475groups alongside your other mail, you can also create e.g. a new
4476@code{nnmaildir} or @code{nnml} server exclusively for mairix, but then
4477make sure those servers do not accidentally receive your new mail
4478(@pxref{nnmairix caveats}). A special case exists if you want to use
4479mairix remotely on an IMAP server with @code{nnimap}---here the mairix
4480folders and your other mail must be on the same @code{nnimap} back end.
e6d2d263
MB
4481
4482@node Setting up mairix
4483@subsubsection Setting up mairix
4484
4485First: create a backup of your mail folders (@pxref{nnmairix caveats}).
4486
4487Setting up mairix is easy: simply create a @file{.mairixrc} file with
4488(at least) the following entries:
4489
4490@example
4491# Your Maildir/MH base folder
4492base=~/Maildir
4493@end example
4494
2b968687
MB
4495This is the base folder for your mails. All the following directories
4496are relative to this base folder. If you want to use @code{nnmairix}
4497with @code{nnimap}, this base directory has to point to the mail
4498directory where the @acronym{IMAP} server stores the mail folders!
e6d2d263 4499
e6d2d263
MB
4500@example
4501maildir= ... your maildir folders which should be indexed ...
4502mh= ... your nnml/mh folders which should be indexed ...
4503mbox = ... your mbox files which should be indexed ...
4504@end example
4505
9e601b8d
MB
4506This specifies all your mail folders and mbox files (relative to the
4507base directory!) you want to index with mairix. Note that the
4508@code{nnml} back end saves mails in MH format, so you have to put those
4509directories in the @code{mh} line. See the example at the end of this
4510section and mairixrc's man-page for further details.
e6d2d263
MB
4511
4512@example
4513omit=zz_mairix-*
4514@end example
4515
4516@vindex nnmairix-group-prefix
4517This should make sure that you don't accidentally index the mairix
4518search results. You can change the prefix of these folders with the
4519variable @code{nnmairix-group-prefix}.
4520
e6d2d263
MB
4521@example
4522mformat= ... 'maildir' or 'mh' ...
4523database= ... location of database file ...
4524@end example
4525
4526The @code{format} setting specifies the output format for the mairix
4527search folder. Set this to @code{mh} if you want to access search results
4528with @code{nnml}. Otherwise choose @code{maildir}.
4529
2b968687
MB
4530To summarize, here is my shortened @file{.mairixrc} file as an example:
4531
4532@example
4533base=~/Maildir
4534maildir=.personal:.work:.logcheck:.sent
4535mh=../Mail/nnml/*...
4536mbox=../mboxmail/mailarchive_year*
4537mformat=maildir
4538omit=zz_mairix-*
4539database=~/.mairixdatabase
4540@end example
4541
4542In this case, the base directory is @file{~/Maildir}, where all my Maildir
4543folders are stored. As you can see, the folders are separated by
4544colons. If you wonder why every folder begins with a dot: this is
4545because I use Dovecot as @acronym{IMAP} server, which again uses
4546@code{Maildir++} folders. For testing nnmairix, I also have some
4547@code{nnml} mail, which is saved in @file{~/Mail/nnml}. Since this has
4548to be specified relative to the @code{base} directory, the @code{../Mail}
4549notation is needed. Note that the line ends in @code{*...}, which means
4550to recursively scan all files under this directory. Without the three
4551dots, the wildcard @code{*} will not work recursively. I also have some
4552old mbox files with archived mail lying around in @file{~/mboxmail}.
4553The other lines should be obvious.
4554
4555See the man page for @code{mairixrc} for details and further options,
4556especially regarding wildcard usage, which may be a little different
4557than you are used to.
4558
4559Now simply call @code{mairix} to create the index for the first time.
4560Note that this may take a few minutes, but every following index will do
4561the updates incrementally and hence is very fast.
e6d2d263
MB
4562
4563@node Configuring nnmairix
4564@subsubsection Configuring nnmairix
4565
4566In group mode, type @kbd{G b c}
4567(@code{nnmairix-create-server-and-default-group}). This will ask you for all
4568necessary information and create a @code{nnmairix} server as a foreign
4569server. You will have to specify the following:
4570
4571@itemize @bullet
4572
4573@item
2b968687 4574The @strong{name} of the @code{nnmairix} server---choose whatever you
e6d2d263
MB
4575want.
4576
4577@item
9e601b8d
MB
4578The name of the @strong{back end server} where mairix should store its
4579searches. This must be a full server name, like @code{nnml:mymail}.
4580Just hit @kbd{TAB} to see the available servers. Currently, servers
4581which are accessed through @code{nnmaildir}, @code{nnimap} and
4582@code{nnml} are supported. As explained above, for locally stored
4583mails, this can be an existing server where you store your mails.
030cca00
MB
4584However, you can also create e.g. a new @code{nnmaildir} or @code{nnml}
4585server exclusively for @code{nnmairix} in your secondary select methods
4586(@pxref{Finding the News}). If you use a secondary @code{nnml} server
4587just for mairix, make sure that you explicitly set the server variable
4588@code{nnml-get-new-mail} to @code{nil}, or you might loose mail
4589(@pxref{nnmairix caveats}). If you want to use mairix remotely on an
9e601b8d
MB
4590@acronym{IMAP} server, you have to choose the corresponding
4591@code{nnimap} server here.
e6d2d263
MB
4592
4593@item
4594@vindex nnmairix-mairix-search-options
4595The @strong{command} to call the mairix binary. This will usually just
4596be @code{mairix}, but you can also choose something like @code{ssh
4597SERVER mairix} if you want to call mairix remotely, e.g. on your
4598@acronym{IMAP} server. If you want to add some default options to
4599mairix, you could do this here, but better use the variable
4600@code{nnmairix-mairix-search-options} instead.
4601
4602@item
4603The name of the @strong{default search group}. This will be the group
4604where all temporary mairix searches are stored, i.e. all searches which
4605are not bound to permanent @code{nnmairix} groups. Choose whatever you
4606like.
4607
4608@item
4609If the mail back end is @code{nnimap} or @code{nnmaildir}, you will be
4610asked if you work with @strong{Maildir++}, i.e. with hidden maildir
4611folders (=beginning with a dot). For example, you have to answer
4612@samp{yes} here if you work with the Dovecot @acronym{IMAP}
4613server. Otherwise, you should answer @samp{no} here.
4614
4615@end itemize
4616
4617@node nnmairix keyboard shortcuts
4618@subsubsection nnmairix keyboard shortcuts
4619
4620In group mode:
4621
4622@table @kbd
4623
4624@item G b c
4625@kindex G b c (Group)
4626@findex nnmairix-create-server-and-default-group
4627Creates @code{nnmairix} server and default search group for this server
4628(@code{nnmairix-create-server-and-default-group}). You should have done
4629this by now (@pxref{Configuring nnmairix}).
4630
4631@item G b s
4632@kindex G b s (Group)
4633@findex nnmairix-search
4634Prompts for query which is then sent to the mairix binary. Search
4635results are put into the default search group which is automatically
4636displayed (@code{nnmairix-search}).
4637
4638@item G b m
4639@kindex G b m (Group)
4640@findex nnmairix-widget-search
4641Allows you to create a mairix search or a permanent group more
4642comfortably using graphical widgets, similar to a customization
4643group. Just try it to see how it works (@code{nnmairix-widget-search}).
4644
4645@item G b i
4646@kindex G b i (Group)
4647@findex nnmairix-search-interactive
4648Another command for creating a mairix query more comfortably, but uses
4649only the minibuffer (@code{nnmairix-search-interactive}).
4650
4651@item G b g
4652@kindex G b g (Group)
4653@findex nnmairix-create-search-group
4654Creates a permanent group which is associated with a search query
4655(@code{nnmairix-create-search-group}). The @code{nnmairix} back end
4656automatically calls mairix when you update this group with @kbd{g} or
4657@kbd{M-g}.
4658
4659@item G b q
4660@kindex G b q (Group)
4661@findex nnmairix-group-change-query-this-group
4662Changes the search query for the @code{nnmairix} group under cursor
4663(@code{nnmairix-group-change-query-this-group}).
4664
4665@item G b t
4666@kindex G b t (Group)
4667@findex nnmairix-group-toggle-threads-this-group
4668Toggles the 'threads' parameter for the @code{nnmairix} group under cursor,
4669i.e. if you want see the whole threads of the found messages
4670(@code{nnmairix-group-toggle-threads-this-group}).
4671
4672@item G b u
4673@kindex G b u (Group)
4674@findex nnmairix-update-database
4675@vindex nnmairix-mairix-update-options
4676Calls mairix binary for updating the database
4677(@code{nnmairix-update-database}). The default parameters are @code{-F}
4678and @code{-Q} for making this as fast as possible (see variable
4679@code{nnmairix-mairix-update-options} for defining these default
4680options).
4681
4682@item G b r
4683@kindex G b r (Group)
4684@findex nnmairix-group-toggle-readmarks-this-group
4685Keep articles in this @code{nnmairix} group always read or unread, or leave the
4686marks unchanged (@code{nnmairix-group-toggle-readmarks-this-group}).
4687
4688@item G b d
4689@kindex G b d (Group)
4690@findex nnmairix-group-delete-recreate-this-group
4691Recreate @code{nnmairix} group on the ``real'' mail back end
4692(@code{nnmairix-group-delete-recreate-this-group}). You can do this if
4693you always get wrong article counts with a @code{nnmairix} group.
4694
4695@item G b a
4696@kindex G b a (Group)
4697@findex nnmairix-group-toggle-allowfast-this-group
4698Toggles the @code{allow-fast} parameters for group under cursor
4699(@code{nnmairix-group-toggle-allowfast-this-group}). The default
4700behavior of @code{nnmairix} is to do a mairix search every time you
4701update or enter the group. With the @code{allow-fast} parameter set,
4702mairix will only be called when you explicitly update the group, but not
4703upon entering. This makes entering the group faster, but it may also
4704lead to dangling symlinks if something changed between updating and
4705entering the group which is not yet in the mairix database.
4706
4707@item G b p
4708@kindex G b p (Group)
4709@findex nnmairix-group-toggle-propmarks-this-group
4710Toggle marks propagation for this group
4711(@code{nnmairix-group-toggle-propmarks-this-group}). (@pxref{Propagating
4712marks}).
4713
4714@item G b o
4715@kindex G b o (Group)
4716@findex nnmairix-propagate-marks
4717Manually propagate marks (@code{nnmairix-propagate-marks}); needed only when
4718@code{nnmairix-propagate-marks-upon-close} is set to @code{nil}.
4719
4720@end table
4721
4722In summary mode:
4723
4724@table @kbd
4725
4726@item $ m
4727@kindex $ m (Summary)
4728@findex nnmairix-widget-search-from-this-article
4729Allows you to create a mairix query or group based on the current
4730message using graphical widgets (same as @code{nnmairix-widget-search})
4731(@code{nnmairix-widget-search-from-this-article}).
4732
4733@item $ g
4734@kindex $ g (Summary)
4735@findex nnmairix-create-search-group-from-message
4736Interactively creates a new search group with query based on the current
4737message, but uses the minibuffer instead of graphical widgets
4738(@code{nnmairix-create-search-group-from-message}).
4739
4740@item $ t
4741@kindex $ t (Summary)
4742@findex nnmairix-search-thread-this-article
4743Searches thread for the current article
4744(@code{nnmairix-search-thread-this-article}). This is effectively a
4745shortcut for calling @code{nnmairix-search} with @samp{m:msgid} of the
4746current article and enabled threads.
4747
4748@item $ f
4749@kindex $ f (Summary)
4750@findex nnmairix-search-from-this-article
4751Searches all messages from sender of the current article
4752(@code{nnmairix-search-from-this-article}). This is a shortcut for
4753calling @code{nnmairix-search} with @samp{f:From}.
4754
4755@item $ o
4756@kindex $ o (Summary)
4757@findex nnmairix-goto-original-article
4758(Only in @code{nnmairix} groups!) Tries determine the group this article
4759originally came from and displays the article in this group, so that
4760e.g. replying to this article the correct posting styles/group
4761parameters are applied (@code{nnmairix-goto-original-article}). This
4762function will use the registry if available, but can also parse the
2b968687 4763article file name as a fallback method.
e6d2d263
MB
4764
4765@item $ u
4766@kindex $ u (Summary)
4767@findex nnmairix-remove-tick-mark-original-article
4768Remove possibly existing tick mark from original article
4769(@code{nnmairix-remove-tick-mark-original-article}). (@pxref{nnmairix
4770tips and tricks}).
4771
4772@end table
4773
4774@node Propagating marks
4775@subsubsection Propagating marks
4776
4777First of: you really need a patched mairix binary for using the marks
4778propagation feature efficiently. Otherwise, you would have to update
4779the mairix database all the time. You can get the patch at
4780
030cca00 4781@uref{http://www.randomsample.de/mairix-maildir-patch.tar}
e6d2d263
MB
4782
4783You need the mairix v0.21 source code for this patch; everything else
4784is explained in the accompanied readme file. If you don't want to use
4785marks propagation, you don't have to apply these patches, but they also
4786fix some annoyances regarding changing maildir flags, so it might still
4787be useful to you.
4788
4789With the patched mairix binary, you can use @code{nnmairix} as an
4790alternative to mail splitting (@pxref{Fancy Mail Splitting}). For
4791example, instead of splitting all mails from @samp{david@@foobar.com}
4792into a group, you can simply create a search group with the query
4793@samp{f:david@@foobar.com}. This is actually what ``smart folders'' are
4794all about: simply put everything in one mail folder and dynamically
4795create searches instead of splitting. This is more flexible, since you
4796can dynamically change your folders any time you want to. This also
4797implies that you will usually read your mails in the @code{nnmairix}
4798groups instead of your ``real'' mail groups.
4799
4800There is one problem, though: say you got a new mail from
2b968687 4801@samp{david@@foobar.com}; it will now show up in two groups, the
e6d2d263
MB
4802``real'' group (your INBOX, for example) and in the @code{nnmairix}
4803search group (provided you have updated the mairix database). Now you
4804enter the @code{nnmairix} group and read the mail. The mail will be
2b968687 4805marked as read, but only in the @code{nnmairix} group---in the ``real''
e6d2d263
MB
4806mail group it will be still shown as unread.
4807
4808You could now catch up the mail group (@pxref{Group Data}), but this is
4809tedious and error prone, since you may overlook mails you don't have
4810created @code{nnmairix} groups for. Of course, you could first use
4811@code{nnmairix-goto-original-article} (@pxref{nnmairix keyboard
4812shortcuts}) and then read the mail in the original group, but that's
4813even more cumbersome.
4814
4815Clearly, the easiest way would be if marks could somehow be
4816automatically set for the original article. This is exactly what
4817@emph{marks propagation} is about.
4818
4819Marks propagation is deactivated by default. You can activate it for a
4820certain @code{nnmairix} group with
4821@code{nnmairix-group-toggle-propmarks-this-group} (bound to @kbd{G b
4822p}). This function will warn you if you try to use it with your default
4823search group; the reason is that the default search group is used for
4824temporary searches, and it's easy to accidentally propagate marks from
4825this group. However, you can ignore this warning if you really want to.
4826
4827With marks propagation enabled, all the marks you set in a @code{nnmairix}
4828group should now be propagated to the original article. For example,
4829you can now tick an article (by default with @kbd{!}) and this mark should
4830magically be set for the original article, too.
4831
4832A few more remarks which you may or may not want to know:
4833
4834@vindex nnmairix-propagate-marks-upon-close
4835Marks will not be set immediately, but only upon closing a group. This
4836not only makes marks propagation faster, it also avoids problems with
4837dangling symlinks when dealing with maildir files (since changing flags
4838will change the file name). You can also control when to propagate marks
4839via @code{nnmairix-propagate-marks-upon-close} (see the doc-string for
4840details).
4841
4842Obviously, @code{nnmairix} will have to look up the original group for every
4843article you want to set marks for. If available, @code{nnmairix} will first use
4844the registry for determining the original group. The registry is very
4845fast, hence you should really, really enable the registry when using
4846marks propagation. If you don't have to worry about RAM and disc space,
4847set @code{gnus-registry-max-entries} to a large enough value; to be on
4848the safe side, choose roughly the amount of mails you index with mairix.
4849
4850@vindex nnmairix-only-use-registry
4851If you don't want to use the registry or the registry hasn't seen the
2b968687
MB
4852original article yet, @code{nnmairix} will use an additional mairix
4853search for determining the file name of the article. This, of course, is
4854way slower than the registry---if you set hundreds or even thousands of
4855marks this way, it might take some time. You can avoid this situation by
4856setting @code{nnmairix-only-use-registry} to t.
e6d2d263
MB
4857
4858Maybe you also want to propagate marks the other way round, i.e. if you
4859tick an article in a "real" mail group, you'd like to have the same
4860article in a @code{nnmairix} group ticked, too. For several good
4861reasons, this can only be done efficiently if you use maildir. To
4862immediately contradict myself, let me mention that it WON'T work with
4863@code{nnmaildir}, since @code{nnmaildir} stores the marks externally and
4864not in the file name. Therefore, propagating marks to @code{nnmairix}
4865groups will usually only work if you use an IMAP server which uses
4866maildir as its file format.
4867
4868@vindex nnmairix-propagate-marks-to-nnmairix-groups
4869If you work with this setup, just set
4870@code{nnmairix-propagate-marks-to-nnmairix-groups} to @code{t} and see what
4871happens. If you don't like what you see, just set it to @code{nil} again. One
4872problem might be that you get a wrong number of unread articles; this
4873usually happens when you delete or expire articles in the original
4874groups. When this happens, you can recreate the @code{nnmairix} group on the
4875back end using @kbd{G b d}.
4876
4877@node nnmairix tips and tricks
4878@subsubsection nnmairix tips and tricks
4879
4880@itemize
4881@item
4882Checking Mail
4883
4884@findex nnmairix-update-groups
4885I put all my important mail groups at group level 1. The mairix groups
4886have group level 5, so they do not get checked at start up (@pxref{Group
4887Levels}).
4888
4889I use the following to check for mails:
4890
4891@lisp
4892(defun my-check-mail-mairix-update (level)
4893 (interactive "P")
4894 ;; if no prefix given, set level=1
4895 (gnus-group-get-new-news (or level 1))
4896 (nnmairix-update-groups "mairixsearch" t t)
4897 (gnus-group-list-groups))
4898
4899(define-key gnus-group-mode-map "g" 'my-check-mail-mairix-update)
4900@end lisp
4901
4902Instead of @samp{"mairixsearch"} use the name of your @code{nnmairix}
4903server. See the doc string for @code{nnmairix-update-groups} for
4904details.
4905
4906@item
4907Example: search group for ticked articles
4908
4909For example, you can create a group for all ticked articles, where the
4910articles always stay unread:
4911
4912Hit @kbd{G b g}, enter group name (e.g. @samp{important}), use
4913@samp{F:f} as query and do not include threads.
4914
4915Now activate marks propagation for this group by using @kbd{G b p}. Then
4916activate the always-unread feature by using @kbd{G b r} twice.
4917
2b968687 4918So far so good---but how do you remove the tick marks in the @code{nnmairix}
e6d2d263
MB
4919group? There are two options: You may simply use
4920@code{nnmairix-remove-tick-mark-original-article} (bound to @kbd{$ u}) to remove
4921tick marks from the original article. The other possibility is to set
4922@code{nnmairix-propagate-marks-to-nnmairix-groups} to @code{t}, but see the above
4923comments about this option. If it works for you, the tick marks should
4924also exist in the @code{nnmairix} group and you can remove them as usual,
4925e.g. by marking an article as read.
4926
4927When you have removed a tick mark from the original article, this
4928article should vanish from the @code{nnmairix} group after you have updated the
4929mairix database and updated the group. Fortunately, there is a function
4930for doing exactly that: @code{nnmairix-update-groups}. See the previous code
4931snippet and the doc string for details.
4932
4933@item
4934Dealing with auto-subscription of mail groups
4935
4936As described before, all @code{nnmairix} groups are in fact stored on
4937the mail back end in the form @samp{zz_mairix-<NAME>-<NUMBER>}. You can
4938see them when you enter the back end server in the server buffer. You
4939should not subscribe these groups! Unfortunately, these groups will
2b968687 4940usually get @emph{auto-subscribed} when you use @code{nnmaildir} or
e6d2d263
MB
4941@code{nnml}, i.e. you will suddenly see groups of the form
4942@samp{zz_mairix*} pop up in your group buffer. If this happens to you,
4943simply kill these groups with C-k. For avoiding this, turn off
4944auto-subscription completely by setting the variable
4945@code{gnus-auto-subscribed-groups} to @code{nil} (@pxref{Filtering New
4946Groups}), or if you like to keep this feature use the following kludge
4947for turning it off for all groups beginning with @samp{zz_}:
4948
4949@lisp
4950(setq gnus-auto-subscribed-groups
4951 "^\\(nnml\\|nnfolder\\|nnmbox\\|nnmh\\|nnbabyl\\|nnmaildir\\).*:\\([^z]\\|z$\\|\\z[^z]\\|zz$\\|zz[^_]\\|zz_$\\).*")
4952@end lisp
4953
4954@end itemize
4955
4956@node nnmairix caveats
4957@subsubsection nnmairix caveats
4958
4959@itemize
4960@item
030cca00
MB
4961You can create a secondary @code{nnml} server just for nnmairix, but then
4962you have to explicitly set the corresponding server variable
4963@code{nnml-get-new-mail} to @code{nil}. Otherwise, new mail might get
4964put into this secondary server (and would never show up again). Here's
4965an example server definition:
4966
4967@lisp
4968(nnml "mairix" (nnml-directory "mairix") (nnml-get-new-mail nil))
4969@end lisp
4970
4971(The @code{nnmaildir} back end also has a server variabe
4972@code{get-new-mail}, but its default value is @code{nil}, so you don't
4973have to explicitly set it if you use a @code{nnmaildir} server just for
4974mairix.)
e6d2d263
MB
4975
4976@item
4977If you use the Gnus registry: don't use the registry with
4978@code{nnmairix} groups (put them in
2b968687
MB
4979@code{gnus-registry-unfollowed-groups}). Be @emph{extra careful} if
4980you use @code{gnus-registry-split-fancy-with-parent}; mails which are
e6d2d263
MB
4981split into @code{nnmairix} groups are usually gone for good as soon as
4982you check the group for new mail (yes, it has happened to me...).
4983
4984@item
2b968687 4985Therefore: @emph{Never ever} put ``real'' mails into @code{nnmairix}
e6d2d263
MB
4986groups (you shouldn't be able to, anyway).
4987
030cca00
MB
4988@item
4989If you use the Gnus agent (@pxref{Gnus Unplugged}): don't agentize
4990@code{nnmairix} groups (though I have no idea what happens if you do).
4991
e6d2d263
MB
4992@item
4993mairix does only support us-ascii characters.
4994
4995@item
4996@code{nnmairix} uses a rather brute force method to force Gnus to
4997completely reread the group on the mail back end after mairix was
2b968687 4998called---it simply deletes and re-creates the group on the mail
e6d2d263
MB
4999back end. So far, this has worked for me without any problems, and I
5000don't see how @code{nnmairix} could delete other mail groups than its
5001own, but anyway: you really should have a backup of your mail
5002folders.
5003
5004@item
5005All necessary information is stored in the group parameters
5006(@pxref{Group Parameters}). This has the advantage that no active file
5007is needed, but also implies that when you kill a @code{nnmairix} group,
5008it is gone for good.
5009
5010@item
5011@findex nnmairix-purge-old-groups
5012If you create and kill a lot of @code{nnmairix} groups, the
5013``zz_mairix-*'' groups will accumulate on the mail back end server. To
5014delete old groups which are no longer needed, call
5015@code{nnmairix-purge-old-groups}. Note that this assumes that you don't
5016save any ``real'' mail in folders of the form
5017@code{zz_mairix-<NAME>-<NUMBER>}. You can change the prefix of
5018@code{nnmairix} groups by changing the variable
5019@code{nnmairix-group-prefix}.
5020
5021@item
2b968687 5022The following only applies if you @emph{don't} use the mentioned patch
e6d2d263
MB
5023for mairix (@pxref{Propagating marks}):
5024
5025A problem can occur when using @code{nnmairix} with maildir folders and
5026comes with the fact that maildir stores mail flags like @samp{Seen} or
5027@samp{Replied} by appending chars @samp{S} and @samp{R} to the message
5028file name, respectively. This implies that currently you would have to
5029update the mairix database not only when new mail arrives, but also when
5030mail flags are changing. The same applies to new mails which are indexed
5031while they are still in the @samp{new} folder but then get moved to
5032@samp{cur} when Gnus has seen the mail. If you don't update the database
5033after this has happened, a mairix query can lead to symlinks pointing to
5034non-existing files. In Gnus, these messages will usually appear with
5035``(none)'' entries in the header and can't be accessed. If this happens
5036to you, using @kbd{G b u} and updating the group will usually fix this.
5037
5038@end itemize
5039
4009494e
GM
5040@node Misc Group Stuff
5041@section Misc Group Stuff
5042
5043@menu
5044* Scanning New Messages:: Asking Gnus to see whether new messages have arrived.
5045* Group Information:: Information and help on groups and Gnus.
5046* Group Timestamp:: Making Gnus keep track of when you last read a group.
5047* File Commands:: Reading and writing the Gnus files.
5048* Sieve Commands:: Managing Sieve scripts.
5049@end menu
5050
5051@table @kbd
5052
5053@item v
5054@kindex v (Group)
5055@cindex keys, reserved for users (Group)
5056The key @kbd{v} is reserved for users. You can bind it to some
5057command or better use it as a prefix key. For example:
5058
5059@lisp
5060(define-key gnus-group-mode-map (kbd "v j d")
5061 (lambda ()
5062 (interactive)
5063 (gnus-group-jump-to-group "nndraft:drafts")))
5064@end lisp
5065
5066On keys reserved for users in Emacs and on keybindings in general
5067@xref{Keymaps, Keymaps, , emacs, The Emacs Editor}.
5068
5069@item ^
5070@kindex ^ (Group)
5071@findex gnus-group-enter-server-mode
5072Enter the server buffer (@code{gnus-group-enter-server-mode}).
5073@xref{Server Buffer}.
5074
5075@item a
5076@kindex a (Group)
5077@findex gnus-group-post-news
5078Start composing a message (a news by default)
5079(@code{gnus-group-post-news}). If given a prefix, post to the group
5080under the point. If the prefix is 1, prompt for a group to post to.
5081Contrary to what the name of this function suggests, the prepared
5082article might be a mail instead of a news, if a mail group is specified
5083with the prefix argument. @xref{Composing Messages}.
5084
5085@item m
5086@kindex m (Group)
5087@findex gnus-group-mail
5088Mail a message somewhere (@code{gnus-group-mail}). If given a prefix,
5089use the posting style of the group under the point. If the prefix is 1,
5090prompt for a group name to find the posting style.
5091@xref{Composing Messages}.
5092
5093@item i
5094@kindex i (Group)
5095@findex gnus-group-news
5096Start composing a news (@code{gnus-group-news}). If given a prefix,
5097post to the group under the point. If the prefix is 1, prompt
5098for group to post to. @xref{Composing Messages}.
5099
5100This function actually prepares a news even when using mail groups.
5101This is useful for ``posting'' messages to mail groups without actually
5102sending them over the network: they're just saved directly to the group
5103in question. The corresponding back end must have a request-post method
5104for this to work though.
5105
01c52d31
MB
5106@item G z
5107@kindex G z (Group)
5108@findex gnus-group-compact-group
5109
5110Compact the group under point (@code{gnus-group-compact-group}).
5111Currently implemented only in nnml (@pxref{Mail Spool}). This removes
5112gaps between article numbers, hence getting a correct total article
5113count.
5114
4009494e
GM
5115@end table
5116
5117Variables for the group buffer:
5118
5119@table @code
5120
5121@item gnus-group-mode-hook
5122@vindex gnus-group-mode-hook
5123is called after the group buffer has been
5124created.
5125
5126@item gnus-group-prepare-hook
5127@vindex gnus-group-prepare-hook
5128is called after the group buffer is
5129generated. It may be used to modify the buffer in some strange,
5130unnatural way.
5131
5132@item gnus-group-prepared-hook
5133@vindex gnus-group-prepare-hook
5134is called as the very last thing after the group buffer has been
5135generated. It may be used to move point around, for instance.
5136
5137@item gnus-permanently-visible-groups
5138@vindex gnus-permanently-visible-groups
5139Groups matching this regexp will always be listed in the group buffer,
5140whether they are empty or not.
5141
4009494e
GM
5142@end table
5143
5144@node Scanning New Messages
5145@subsection Scanning New Messages
5146@cindex new messages
5147@cindex scanning new news
5148
5149@table @kbd
5150
5151@item g
5152@kindex g (Group)
5153@findex gnus-group-get-new-news
5154@c @icon{gnus-group-get-new-news}
5155Check the server(s) for new articles. If the numerical prefix is used,
5156this command will check only groups of level @var{arg} and lower
5157(@code{gnus-group-get-new-news}). If given a non-numerical prefix, this
5158command will force a total re-reading of the active file(s) from the
5159back end(s).
5160
5161@item M-g
5162@kindex M-g (Group)
5163@findex gnus-group-get-new-news-this-group
5164@vindex gnus-goto-next-group-when-activating
5165@c @icon{gnus-group-get-new-news-this-group}
5166Check whether new articles have arrived in the current group
5167(@code{gnus-group-get-new-news-this-group}).
5168@code{gnus-goto-next-group-when-activating} says whether this command is
5169to move point to the next group or not. It is @code{t} by default.
5170
5171@findex gnus-activate-all-groups
5172@cindex activating groups
5173@item C-c M-g
5174@kindex C-c M-g (Group)
5175Activate absolutely all groups (@code{gnus-activate-all-groups}).
5176
5177@item R
5178@kindex R (Group)
5179@cindex restarting
5180@findex gnus-group-restart
5181Restart Gnus (@code{gnus-group-restart}). This saves the @file{.newsrc}
5182file(s), closes the connection to all servers, clears up all run-time
5183Gnus variables, and then starts Gnus all over again.
5184
5185@end table
5186
5187@vindex gnus-get-new-news-hook
5188@code{gnus-get-new-news-hook} is run just before checking for new news.
5189
5190@vindex gnus-after-getting-new-news-hook
5191@code{gnus-after-getting-new-news-hook} is run after checking for new
5192news.
5193
5194
5195@node Group Information
5196@subsection Group Information
5197@cindex group information
5198@cindex information on groups
5199
5200@table @kbd
5201
5202
5203@item H f
5204@kindex H f (Group)
5205@findex gnus-group-fetch-faq
5206@vindex gnus-group-faq-directory
5207@cindex FAQ
5208@cindex ange-ftp
5209Try to fetch the @acronym{FAQ} for the current group
5210(@code{gnus-group-fetch-faq}). Gnus will try to get the @acronym{FAQ}
5211from @code{gnus-group-faq-directory}, which is usually a directory on
5212a remote machine. This variable can also be a list of directories.
5213In that case, giving a prefix to this command will allow you to choose
5214between the various sites. @code{ange-ftp} (or @code{efs}) will be
5215used for fetching the file.
5216
5217If fetching from the first site is unsuccessful, Gnus will attempt to go
5218through @code{gnus-group-faq-directory} and try to open them one by one.
5219
5220@item H c
5221@kindex H c (Group)
5222@findex gnus-group-fetch-charter
5223@vindex gnus-group-charter-alist
5224@cindex charter
5225Try to open the charter for the current group in a web browser
5226(@code{gnus-group-fetch-charter}). Query for a group if given a
5227prefix argument.
5228
5229Gnus will use @code{gnus-group-charter-alist} to find the location of
5230the charter. If no location is known, Gnus will fetch the control
5231messages for the group, which in some cases includes the charter.
5232
5233@item H C
5234@kindex H C (Group)
5235@findex gnus-group-fetch-control
5236@vindex gnus-group-fetch-control-use-browse-url
5237@cindex control message
5238Fetch the control messages for the group from the archive at
5239@code{ftp.isc.org} (@code{gnus-group-fetch-control}). Query for a
5240group if given a prefix argument.
5241
5242If @code{gnus-group-fetch-control-use-browse-url} is non-@code{nil},
5243Gnus will open the control messages in a browser using
5244@code{browse-url}. Otherwise they are fetched using @code{ange-ftp}
5245and displayed in an ephemeral group.
5246
5247Note that the control messages are compressed. To use this command
5248you need to turn on @code{auto-compression-mode} (@pxref{Compressed
5249Files, ,Compressed Files, emacs, The Emacs Manual}).
5250
5251@item H d
5252@itemx C-c C-d
5253@c @icon{gnus-group-describe-group}
5254@kindex H d (Group)
5255@kindex C-c C-d (Group)
5256@cindex describing groups
5257@cindex group description
5258@findex gnus-group-describe-group
5259Describe the current group (@code{gnus-group-describe-group}). If given
5260a prefix, force Gnus to re-read the description from the server.
5261
5262@item M-d
5263@kindex M-d (Group)
5264@findex gnus-group-describe-all-groups
5265Describe all groups (@code{gnus-group-describe-all-groups}). If given a
5266prefix, force Gnus to re-read the description file from the server.
5267
5268@item H v
5269@itemx V
5270@kindex V (Group)
5271@kindex H v (Group)
5272@cindex version
5273@findex gnus-version
5274Display current Gnus version numbers (@code{gnus-version}).
5275
5276@item ?
5277@kindex ? (Group)
5278@findex gnus-group-describe-briefly
5279Give a very short help message (@code{gnus-group-describe-briefly}).
5280
5281@item C-c C-i
5282@kindex C-c C-i (Group)
5283@cindex info
5284@cindex manual
5285@findex gnus-info-find-node
5286Go to the Gnus info node (@code{gnus-info-find-node}).
5287@end table
5288
5289
5290@node Group Timestamp
5291@subsection Group Timestamp
5292@cindex timestamps
5293@cindex group timestamps
5294
5295It can be convenient to let Gnus keep track of when you last read a
5296group. To set the ball rolling, you should add
5297@code{gnus-group-set-timestamp} to @code{gnus-select-group-hook}:
5298
5299@lisp
5300(add-hook 'gnus-select-group-hook 'gnus-group-set-timestamp)
5301@end lisp
5302
5303After doing this, each time you enter a group, it'll be recorded.
5304
5305This information can be displayed in various ways---the easiest is to
5306use the @samp{%d} spec in the group line format:
5307
5308@lisp
5309(setq gnus-group-line-format
5310 "%M\%S\%p\%P\%5y: %(%-40,40g%) %d\n")
5311@end lisp
5312
5313This will result in lines looking like:
5314
5315@example
5316* 0: mail.ding 19961002T012943
5317 0: custom 19961002T012713
5318@end example
5319
5320As you can see, the date is displayed in compact ISO 8601 format. This
5321may be a bit too much, so to just display the date, you could say
5322something like:
5323
5324@lisp
5325(setq gnus-group-line-format
5326 "%M\%S\%p\%P\%5y: %(%-40,40g%) %6,6~(cut 2)d\n")
5327@end lisp
5328
5329If you would like greater control of the time format, you can use a
5330user-defined format spec. Something like the following should do the
5331trick:
5332
5333@lisp
5334(setq gnus-group-line-format
5335 "%M\%S\%p\%P\%5y: %(%-40,40g%) %ud\n")
5336(defun gnus-user-format-function-d (headers)
5337 (let ((time (gnus-group-timestamp gnus-tmp-group)))
5338 (if time
5339 (format-time-string "%b %d %H:%M" time)
5340 "")))
5341@end lisp
5342
5343
5344@node File Commands
5345@subsection File Commands
5346@cindex file commands
5347
5348@table @kbd
5349
5350@item r
5351@kindex r (Group)
5352@findex gnus-group-read-init-file
5353@vindex gnus-init-file
5354@cindex reading init file
5355Re-read the init file (@code{gnus-init-file}, which defaults to
5356@file{~/.gnus.el}) (@code{gnus-group-read-init-file}).
5357
5358@item s
5359@kindex s (Group)
5360@findex gnus-group-save-newsrc
5361@cindex saving .newsrc
5362Save the @file{.newsrc.eld} file (and @file{.newsrc} if wanted)
5363(@code{gnus-group-save-newsrc}). If given a prefix, force saving the
5364file(s) whether Gnus thinks it is necessary or not.
5365
5366@c @item Z
5367@c @kindex Z (Group)
5368@c @findex gnus-group-clear-dribble
5369@c Clear the dribble buffer (@code{gnus-group-clear-dribble}).
5370
5371@end table
5372
5373
5374@node Sieve Commands
5375@subsection Sieve Commands
5376@cindex group sieve commands
5377
5378Sieve is a server-side mail filtering language. In Gnus you can use
5379the @code{sieve} group parameter (@pxref{Group Parameters}) to specify
5380sieve rules that should apply to each group. Gnus provides two
5381commands to translate all these group parameters into a proper Sieve
5382script that can be transfered to the server somehow.
5383
5384@vindex gnus-sieve-file
5385@vindex gnus-sieve-region-start
5386@vindex gnus-sieve-region-end
5387The generated Sieve script is placed in @code{gnus-sieve-file} (by
5388default @file{~/.sieve}). The Sieve code that Gnus generate is placed
5389between two delimiters, @code{gnus-sieve-region-start} and
5390@code{gnus-sieve-region-end}, so you may write additional Sieve code
5391outside these delimiters that will not be removed the next time you
5392regenerate the Sieve script.
5393
5394@vindex gnus-sieve-crosspost
5395The variable @code{gnus-sieve-crosspost} controls how the Sieve script
5396is generated. If it is non-@code{nil} (the default) articles is
5397placed in all groups that have matching rules, otherwise the article
5398is only placed in the group with the first matching rule. For
5399example, the group parameter @samp{(sieve address "sender"
5400"owner-ding@@hpc.uh.edu")} will generate the following piece of Sieve
5401code if @code{gnus-sieve-crosspost} is @code{nil}. (When
5402@code{gnus-sieve-crosspost} is non-@code{nil}, it looks the same
5403except that the line containing the call to @code{stop} is removed.)
5404
5405@example
5406if address "sender" "owner-ding@@hpc.uh.edu" @{
5407 fileinto "INBOX.ding";
5408 stop;
5409@}
5410@end example
5411
5412@xref{Top, Emacs Sieve, Top, sieve, Emacs Sieve}.
5413
5414@table @kbd
5415
5416@item D g
5417@kindex D g (Group)
5418@findex gnus-sieve-generate
5419@vindex gnus-sieve-file
5420@cindex generating sieve script
5421Regenerate a Sieve script from the @code{sieve} group parameters and
5422put you into the @code{gnus-sieve-file} without saving it.
5423
5424@item D u
5425@kindex D u (Group)
5426@findex gnus-sieve-update
5427@vindex gnus-sieve-file
5428@cindex updating sieve script
5429Regenerates the Gnus managed part of @code{gnus-sieve-file} using the
5430@code{sieve} group parameters, save the file and upload it to the
5431server using the @code{sieveshell} program.
5432
5433@end table
5434
5435
5436@node Summary Buffer
5437@chapter Summary Buffer
5438@cindex summary buffer
5439
5440A line for each article is displayed in the summary buffer. You can
5441move around, read articles, post articles and reply to articles.
5442
5443The most common way to a summary buffer is to select a group from the
5444group buffer (@pxref{Selecting a Group}).
5445
5446You can have as many summary buffers open as you wish.
5447
5448You can customize the Summary Mode tool bar, see @kbd{M-x
5449customize-apropos RET gnus-summary-tool-bar}. This feature is only
5450available in Emacs.
5451
5452@kindex v (Summary)
5453@cindex keys, reserved for users (Summary)
5454The key @kbd{v} is reserved for users. You can bind it to some
5455command or better use it as a prefix key. For example:
5456@lisp
5457(define-key gnus-summary-mode-map (kbd "v -") "LrS") ;; lower subthread
5458@end lisp
5459
5460@menu
5461* Summary Buffer Format:: Deciding how the summary buffer is to look.
5462* Summary Maneuvering:: Moving around the summary buffer.
5463* Choosing Articles:: Reading articles.
5464* Paging the Article:: Scrolling the current article.
5465* Reply Followup and Post:: Posting articles.
5466* Delayed Articles:: Send articles at a later time.
5467* Marking Articles:: Marking articles as read, expirable, etc.
5468* Limiting:: You can limit the summary buffer.
5469* Threading:: How threads are made.
5470* Sorting the Summary Buffer:: How articles and threads are sorted.
5471* Asynchronous Fetching:: Gnus might be able to pre-fetch articles.
5472* Article Caching:: You may store articles in a cache.
5473* Persistent Articles:: Making articles expiry-resistant.
01c52d31 5474* Sticky Articles:: Article buffers that are not reused.
4009494e
GM
5475* Article Backlog:: Having already read articles hang around.
5476* Saving Articles:: Ways of customizing article saving.
5477* Decoding Articles:: Gnus can treat series of (uu)encoded articles.
5478* Article Treatment:: The article buffer can be mangled at will.
5479* MIME Commands:: Doing MIMEy things with the articles.
5480* Charsets:: Character set issues.
5481* Article Commands:: Doing various things with the article buffer.
5482* Summary Sorting:: Sorting the summary buffer in various ways.
5483* Finding the Parent:: No child support? Get the parent.
5484* Alternative Approaches:: Reading using non-default summaries.
5485* Tree Display:: A more visual display of threads.
5486* Mail Group Commands:: Some commands can only be used in mail groups.
5487* Various Summary Stuff:: What didn't fit anywhere else.
5488* Exiting the Summary Buffer:: Returning to the Group buffer,
5489 or reselecting the current group.
5490* Crosspost Handling:: How crossposted articles are dealt with.
5491* Duplicate Suppression:: An alternative when crosspost handling fails.
5492* Security:: Decrypt and Verify.
5493* Mailing List:: Mailing list minor mode.
5494@end menu
5495
5496
5497@node Summary Buffer Format
5498@section Summary Buffer Format
5499@cindex summary buffer format
5500
5501@iftex
5502@iflatex
5503\gnusfigure{The Summary Buffer}{180}{
5504\put(0,0){\epsfig{figure=ps/summary,width=7.5cm}}
5505\put(445,0){\makebox(0,0)[br]{\epsfig{figure=ps/summary-article,width=7.5cm}}}
5506}
5507@end iflatex
5508@end iftex
5509
5510@menu
5511* Summary Buffer Lines:: You can specify how summary lines should look.
5512* To From Newsgroups:: How to not display your own name.
5513* Summary Buffer Mode Line:: You can say how the mode line should look.
5514* Summary Highlighting:: Making the summary buffer all pretty and nice.
5515@end menu
5516
5517@findex mail-extract-address-components
5518@findex gnus-extract-address-components
5519@vindex gnus-extract-address-components
5520Gnus will use the value of the @code{gnus-extract-address-components}
5521variable as a function for getting the name and address parts of a
5522@code{From} header. Two pre-defined functions exist:
5523@code{gnus-extract-address-components}, which is the default, quite
5524fast, and too simplistic solution; and
5525@code{mail-extract-address-components}, which works very nicely, but is
5526slower. The default function will return the wrong answer in 5% of the
5527cases. If this is unacceptable to you, use the other function instead:
5528
5529@lisp
5530(setq gnus-extract-address-components
5531 'mail-extract-address-components)
5532@end lisp
5533
5534@vindex gnus-summary-same-subject
5535@code{gnus-summary-same-subject} is a string indicating that the current
5536article has the same subject as the previous. This string will be used
5537with those specs that require it. The default is @code{""}.
5538
5539
5540@node Summary Buffer Lines
5541@subsection Summary Buffer Lines
5542
5543@vindex gnus-summary-line-format
5544You can change the format of the lines in the summary buffer by changing
5545the @code{gnus-summary-line-format} variable. It works along the same
5546lines as a normal @code{format} string, with some extensions
5547(@pxref{Formatting Variables}).
5548
5549There should always be a colon or a point position marker on the line;
5550the cursor always moves to the point position marker or the colon after
5551performing an operation. (Of course, Gnus wouldn't be Gnus if it wasn't
5552possible to change this. Just write a new function
5553@code{gnus-goto-colon} which does whatever you like with the cursor.)
5554@xref{Positioning Point}.
5555
5556The default string is @samp{%U%R%z%I%(%[%4L: %-23,23f%]%) %s\n}.
5557
5558The following format specification characters and extended format
5559specification(s) are understood:
5560
5561@table @samp
5562@item N
5563Article number.
5564@item S
5565Subject string. List identifiers stripped,
5566@code{gnus-list-identifiers}. @xref{Article Hiding}.
5567@item s
5568Subject if the article is the root of the thread or the previous article
5569had a different subject, @code{gnus-summary-same-subject} otherwise.
5570(@code{gnus-summary-same-subject} defaults to @code{""}.)
5571@item F
5572Full @code{From} header.
5573@item n
5574The name (from the @code{From} header).
5575@item f
5576The name, @code{To} header or the @code{Newsgroups} header (@pxref{To
5577From Newsgroups}).
5578@item a
5579The name (from the @code{From} header). This differs from the @code{n}
5580spec in that it uses the function designated by the
5581@code{gnus-extract-address-components} variable, which is slower, but
5582may be more thorough.
5583@item A
5584The address (from the @code{From} header). This works the same way as
5585the @code{a} spec.
5586@item L
5587Number of lines in the article.
5588@item c
5589Number of characters in the article. This specifier is not supported
5590in some methods (like nnfolder).
5591@item k
5592Pretty-printed version of the number of characters in the article;
5593for example, @samp{1.2k} or @samp{0.4M}.
5594@item I
5595Indentation based on thread level (@pxref{Customizing Threading}).
5596@item B
5597A complex trn-style thread tree, showing response-connecting trace
5598lines. A thread could be drawn like this:
5599
5600@example
5601>
5602+->
5603| +->
5604| | \->
5605| | \->
5606| \->
5607+->
5608\->
5609@end example
5610
5611You can customize the appearance with the following options. Note
5612that it is possible to make the thread display look really neat by
5613replacing the default @acronym{ASCII} characters with graphic
5614line-drawing glyphs.
5615@table @code
5616@item gnus-sum-thread-tree-root
5617@vindex gnus-sum-thread-tree-root
5618Used for the root of a thread. If @code{nil}, use subject
5619instead. The default is @samp{> }.
5620
5621@item gnus-sum-thread-tree-false-root
5622@vindex gnus-sum-thread-tree-false-root
5623Used for the false root of a thread (@pxref{Loose Threads}). If
5624@code{nil}, use subject instead. The default is @samp{> }.
5625
5626@item gnus-sum-thread-tree-single-indent
5627@vindex gnus-sum-thread-tree-single-indent
5628Used for a thread with just one message. If @code{nil}, use subject
5629instead. The default is @samp{}.
5630
5631@item gnus-sum-thread-tree-vertical
5632@vindex gnus-sum-thread-tree-vertical
5633Used for drawing a vertical line. The default is @samp{| }.
5634
5635@item gnus-sum-thread-tree-indent
5636@vindex gnus-sum-thread-tree-indent
5637Used for indenting. The default is @samp{ }.
5638
5639@item gnus-sum-thread-tree-leaf-with-other
5640@vindex gnus-sum-thread-tree-leaf-with-other
5641Used for a leaf with brothers. The default is @samp{+-> }.
5642
5643@item gnus-sum-thread-tree-single-leaf
5644@vindex gnus-sum-thread-tree-single-leaf
5645Used for a leaf without brothers. The default is @samp{\-> }
5646
5647@end table
5648
5649@item T
5650Nothing if the article is a root and lots of spaces if it isn't (it
5651pushes everything after it off the screen).
5652@item [
5653Opening bracket, which is normally @samp{[}, but can also be @samp{<}
5654for adopted articles (@pxref{Customizing Threading}).
5655@item ]
5656Closing bracket, which is normally @samp{]}, but can also be @samp{>}
5657for adopted articles.
5658@item >
5659One space for each thread level.
5660@item <
5661Twenty minus thread level spaces.
5662@item U
5663Unread. @xref{Read Articles}.
5664
5665@item R
5666This misleadingly named specifier is the @dfn{secondary mark}. This
5667mark will say whether the article has been replied to, has been cached,
5668or has been saved. @xref{Other Marks}.
5669
5670@item i
5671Score as a number (@pxref{Scoring}).
5672@item z
5673@vindex gnus-summary-zcore-fuzz
5674Zcore, @samp{+} if above the default level and @samp{-} if below the
5675default level. If the difference between
5676@code{gnus-summary-default-score} and the score is less than
5677@code{gnus-summary-zcore-fuzz}, this spec will not be used.
5678@item V
5679Total thread score.
5680@item x
5681@code{Xref}.
5682@item D
5683@code{Date}.
5684@item d
5685The @code{Date} in @code{DD-MMM} format.
5686@item o
5687The @code{Date} in @var{YYYYMMDD}@code{T}@var{HHMMSS} format.
5688@item M
5689@code{Message-ID}.
5690@item r
5691@code{References}.
5692@item t
5693Number of articles in the current sub-thread. Using this spec will slow
5694down summary buffer generation somewhat.
5695@item e
5696An @samp{=} (@code{gnus-not-empty-thread-mark}) will be displayed if the
5697article has any children.
5698@item P
5699The line number.
5700@item O
5701Download mark.
5702@item *
5703Desired cursor position (instead of after first colon).
5704@item &user-date;
5705Age sensitive date format. Various date format is defined in
5706@code{gnus-user-date-format-alist}.
5707@item u
5708User defined specifier. The next character in the format string should
5709be a letter. Gnus will call the function
5710@code{gnus-user-format-function-@var{x}}, where @var{x} is the letter
5711following @samp{%u}. The function will be passed the current header as
5712argument. The function should return a string, which will be inserted
5713into the summary just like information from any other summary specifier.
5714@end table
5715
5716Text between @samp{%(} and @samp{%)} will be highlighted with
5717@code{gnus-mouse-face} when the mouse point is placed inside the area.
5718There can only be one such area.
5719
5720The @samp{%U} (status), @samp{%R} (replied) and @samp{%z} (zcore) specs
5721have to be handled with care. For reasons of efficiency, Gnus will
5722compute what column these characters will end up in, and ``hard-code''
5723that. This means that it is invalid to have these specs after a
5724variable-length spec. Well, you might not be arrested, but your summary
5725buffer will look strange, which is bad enough.
5726
5727The smart choice is to have these specs as far to the left as possible.
5728(Isn't that the case with everything, though? But I digress.)
5729
5730This restriction may disappear in later versions of Gnus.
5731
5732
5733@node To From Newsgroups
5734@subsection To From Newsgroups
5735@cindex To
5736@cindex Newsgroups
5737
5738In some groups (particularly in archive groups), the @code{From} header
5739isn't very interesting, since all the articles there are written by
5740you. To display the information in the @code{To} or @code{Newsgroups}
5741headers instead, you need to decide three things: What information to
5742gather; where to display it; and when to display it.
5743
5744@enumerate
5745@item
5746@vindex gnus-extra-headers
5747The reading of extra header information is controlled by the
5748@code{gnus-extra-headers}. This is a list of header symbols. For
5749instance:
5750
5751@lisp
5752(setq gnus-extra-headers
5753 '(To Newsgroups X-Newsreader))
5754@end lisp
5755
5756This will result in Gnus trying to obtain these three headers, and
5757storing it in header structures for later easy retrieval.
5758
5759@item
5760@findex gnus-extra-header
5761The value of these extra headers can be accessed via the
5762@code{gnus-extra-header} function. Here's a format line spec that will
5763access the @code{X-Newsreader} header:
5764
5765@example
5766"%~(form (gnus-extra-header 'X-Newsreader))@@"
5767@end example
5768
5769@item
5770@vindex gnus-ignored-from-addresses
5771The @code{gnus-ignored-from-addresses} variable says when the @samp{%f}
5772summary line spec returns the @code{To}, @code{Newsreader} or
5773@code{From} header. If this regexp matches the contents of the
5774@code{From} header, the value of the @code{To} or @code{Newsreader}
5775headers are used instead.
5776
01c52d31
MB
5777To distinguish regular articles from those where the @code{From} field
5778has been swapped, a string is prefixed to the @code{To} or
5779@code{Newsgroups} header in the summary line. By default the string is
5780@samp{-> } for @code{To} and @samp{=> } for @code{Newsgroups}, you can
5781customize these strings with @code{gnus-summary-to-prefix} and
5782@code{gnus-summary-newsgroup-prefix}.
5783
4009494e
GM
5784@end enumerate
5785
5786@vindex nnmail-extra-headers
5787A related variable is @code{nnmail-extra-headers}, which controls when
5788to include extra headers when generating overview (@acronym{NOV}) files.
5789If you have old overview files, you should regenerate them after
5790changing this variable, by entering the server buffer using @kbd{^},
5791and then @kbd{g} on the appropriate mail server (e.g. nnml) to cause
5792regeneration.
5793
5794@vindex gnus-summary-line-format
5795You also have to instruct Gnus to display the data by changing the
5796@code{%n} spec to the @code{%f} spec in the
5797@code{gnus-summary-line-format} variable.
5798
5799In summary, you'd typically put something like the following in
5800@file{~/.gnus.el}:
5801
5802@lisp
5803(setq gnus-extra-headers
5804 '(To Newsgroups))
5805(setq nnmail-extra-headers gnus-extra-headers)
5806(setq gnus-summary-line-format
5807 "%U%R%z%I%(%[%4L: %-23,23f%]%) %s\n")
5808(setq gnus-ignored-from-addresses
5809 "Your Name Here")
5810@end lisp
5811
5812(The values listed above are the default values in Gnus. Alter them
5813to fit your needs.)
5814
5815A note for news server administrators, or for users who wish to try to
5816convince their news server administrator to provide some additional
5817support:
5818
5819The above is mostly useful for mail groups, where you have control over
5820the @acronym{NOV} files that are created. However, if you can persuade your
5821nntp admin to add (in the usual implementation, notably INN):
5822
5823@example
5824Newsgroups:full
5825@end example
5826
5827to the end of her @file{overview.fmt} file, then you can use that just
5828as you would the extra headers from the mail groups.
5829
5830
5831@node Summary Buffer Mode Line
5832@subsection Summary Buffer Mode Line
5833
5834@vindex gnus-summary-mode-line-format
5835You can also change the format of the summary mode bar (@pxref{Mode Line
5836Formatting}). Set @code{gnus-summary-mode-line-format} to whatever you
5837like. The default is @samp{Gnus: %%b [%A] %Z}.
5838
5839Here are the elements you can play with:
5840
5841@table @samp
5842@item G
5843Group name.
5844@item p
5845Unprefixed group name.
5846@item A
5847Current article number.
5848@item z
5849Current article score.
5850@item V
5851Gnus version.
5852@item U
5853Number of unread articles in this group.
5854@item e
5855Number of unread articles in this group that aren't displayed in the
5856summary buffer.
5857@item Z
5858A string with the number of unread and unselected articles represented
5859either as @samp{<%U(+%e) more>} if there are both unread and unselected
5860articles, and just as @samp{<%U more>} if there are just unread articles
5861and no unselected ones.
5862@item g
5863Shortish group name. For instance, @samp{rec.arts.anime} will be
5864shortened to @samp{r.a.anime}.
5865@item S
5866Subject of the current article.
5867@item u
5868User-defined spec (@pxref{User-Defined Specs}).
5869@item s
5870Name of the current score file (@pxref{Scoring}).
5871@item d
5872Number of dormant articles (@pxref{Unread Articles}).
5873@item t
5874Number of ticked articles (@pxref{Unread Articles}).
5875@item r
5876Number of articles that have been marked as read in this session.
5877@item E
5878Number of articles expunged by the score files.
5879@end table
5880
5881
5882@node Summary Highlighting
5883@subsection Summary Highlighting
5884
5885@table @code
5886
5887@item gnus-visual-mark-article-hook
5888@vindex gnus-visual-mark-article-hook
5889This hook is run after selecting an article. It is meant to be used for
5890highlighting the article in some way. It is not run if
5891@code{gnus-visual} is @code{nil}.
5892
5893@item gnus-summary-update-hook
5894@vindex gnus-summary-update-hook
5895This hook is called when a summary line is changed. It is not run if
5896@code{gnus-visual} is @code{nil}.
5897
5898@item gnus-summary-selected-face
5899@vindex gnus-summary-selected-face
5900This is the face (or @dfn{font} as some people call it) used to
5901highlight the current article in the summary buffer.
5902
5903@item gnus-summary-highlight
5904@vindex gnus-summary-highlight
5905Summary lines are highlighted according to this variable, which is a
5906list where the elements are of the format @code{(@var{form}
5907. @var{face})}. If you would, for instance, like ticked articles to be
5908italic and high-scored articles to be bold, you could set this variable
5909to something like
5910@lisp
5911(((eq mark gnus-ticked-mark) . italic)
5912 ((> score default) . bold))
5913@end lisp
5914As you may have guessed, if @var{form} returns a non-@code{nil} value,
5915@var{face} will be applied to the line.
5916@end table
5917
5918
5919@node Summary Maneuvering
5920@section Summary Maneuvering
5921@cindex summary movement
5922
5923All the straight movement commands understand the numeric prefix and
5924behave pretty much as you'd expect.
5925
5926None of these commands select articles.
5927
5928@table @kbd
5929@item G M-n
5930@itemx M-n
5931@kindex M-n (Summary)
5932@kindex G M-n (Summary)
5933@findex gnus-summary-next-unread-subject
5934Go to the next summary line of an unread article
5935(@code{gnus-summary-next-unread-subject}).
5936
5937@item G M-p
5938@itemx M-p
5939@kindex M-p (Summary)
5940@kindex G M-p (Summary)
5941@findex gnus-summary-prev-unread-subject
5942Go to the previous summary line of an unread article
5943(@code{gnus-summary-prev-unread-subject}).
5944
5945@item G g
5946@kindex G g (Summary)
5947@findex gnus-summary-goto-subject
5948Ask for an article number and then go to the summary line of that article
5949without displaying the article (@code{gnus-summary-goto-subject}).
5950@end table
5951
5952If Gnus asks you to press a key to confirm going to the next group, you
5953can use the @kbd{C-n} and @kbd{C-p} keys to move around the group
5954buffer, searching for the next group to read without actually returning
5955to the group buffer.
5956
5957Variables related to summary movement:
5958
5959@table @code
5960
5961@vindex gnus-auto-select-next
5962@item gnus-auto-select-next
5963If you issue one of the movement commands (like @kbd{n}) and there are
5964no more unread articles after the current one, Gnus will offer to go to
5965the next group. If this variable is @code{t} and the next group is
5966empty, Gnus will exit summary mode and return to the group buffer. If
5967this variable is neither @code{t} nor @code{nil}, Gnus will select the
5968next group with unread articles. As a special case, if this variable
5969is @code{quietly}, Gnus will select the next group without asking for
5970confirmation. If this variable is @code{almost-quietly}, the same
5971will happen only if you are located on the last article in the group.
5972Finally, if this variable is @code{slightly-quietly}, the @kbd{Z n}
5973command will go to the next group without confirmation. Also
5974@pxref{Group Levels}.
5975
5976@item gnus-auto-select-same
5977@vindex gnus-auto-select-same
5978If non-@code{nil}, all the movement commands will try to go to the next
5979article with the same subject as the current. (@dfn{Same} here might
5980mean @dfn{roughly equal}. See @code{gnus-summary-gather-subject-limit}
5981for details (@pxref{Customizing Threading}).) If there are no more
5982articles with the same subject, go to the first unread article.
5983
5984This variable is not particularly useful if you use a threaded display.
5985
5986@item gnus-summary-check-current
5987@vindex gnus-summary-check-current
5988If non-@code{nil}, all the ``unread'' movement commands will not proceed
5989to the next (or previous) article if the current article is unread.
5990Instead, they will choose the current article.
5991
5992@item gnus-auto-center-summary
5993@vindex gnus-auto-center-summary
5994If non-@code{nil}, Gnus will keep the point in the summary buffer
5995centered at all times. This makes things quite tidy, but if you have a
5996slow network connection, or simply do not like this un-Emacsism, you can
5997set this variable to @code{nil} to get the normal Emacs scrolling
5998action. This will also inhibit horizontal re-centering of the summary
5999buffer, which might make it more inconvenient to read extremely long
6000threads.
6001
6002This variable can also be a number. In that case, center the window at
6003the given number of lines from the top.
6004
85115796
KY
6005@item gnus-summary-stop-at-end-of-message
6006@vindex gnus-summary-stop-at-end-of-message
6007If non-@code{nil}, don't go to the next article when hitting
6008@kbd{SPC}, and you're at the end of the article.
6009
4009494e
GM
6010@end table
6011
6012
6013@node Choosing Articles
6014@section Choosing Articles
6015@cindex selecting articles
6016
6017@menu
6018* Choosing Commands:: Commands for choosing articles.
6019* Choosing Variables:: Variables that influence these commands.
6020@end menu
6021
6022
6023@node Choosing Commands
6024@subsection Choosing Commands
6025
6026None of the following movement commands understand the numeric prefix,
6027and they all select and display an article.
6028
6029If you want to fetch new articles or redisplay the group, see
6030@ref{Exiting the Summary Buffer}.
6031
6032@table @kbd
6033@item SPACE
6034@kindex SPACE (Summary)
6035@findex gnus-summary-next-page
6036Select the current article, or, if that one's read already, the next
6037unread article (@code{gnus-summary-next-page}).
6038
6039If you have an article window open already and you press @kbd{SPACE}
6040again, the article will be scrolled. This lets you conveniently
6041@kbd{SPACE} through an entire newsgroup. @xref{Paging the Article}.
6042
6043@item G n
6044@itemx n
6045@kindex n (Summary)
6046@kindex G n (Summary)
6047@findex gnus-summary-next-unread-article
6048@c @icon{gnus-summary-next-unread}
6049Go to next unread article (@code{gnus-summary-next-unread-article}).
6050
6051@item G p
6052@itemx p
6053@kindex p (Summary)
6054@findex gnus-summary-prev-unread-article
6055@c @icon{gnus-summary-prev-unread}
6056Go to previous unread article (@code{gnus-summary-prev-unread-article}).
6057
6058@item G N
6059@itemx N
6060@kindex N (Summary)
6061@kindex G N (Summary)
6062@findex gnus-summary-next-article
6063Go to the next article (@code{gnus-summary-next-article}).
6064
6065@item G P
6066@itemx P
6067@kindex P (Summary)
6068@kindex G P (Summary)
6069@findex gnus-summary-prev-article
6070Go to the previous article (@code{gnus-summary-prev-article}).
6071
6072@item G C-n
6073@kindex G C-n (Summary)
6074@findex gnus-summary-next-same-subject
6075Go to the next article with the same subject
6076(@code{gnus-summary-next-same-subject}).
6077
6078@item G C-p
6079@kindex G C-p (Summary)
6080@findex gnus-summary-prev-same-subject
6081Go to the previous article with the same subject
6082(@code{gnus-summary-prev-same-subject}).
6083
6084@item G f
6085@itemx .
6086@kindex G f (Summary)
6087@kindex . (Summary)
6088@findex gnus-summary-first-unread-article
6089Go to the first unread article
6090(@code{gnus-summary-first-unread-article}).
6091
6092@item G b
6093@itemx ,
6094@kindex G b (Summary)
6095@kindex , (Summary)
6096@findex gnus-summary-best-unread-article
6097Go to the unread article with the highest score
6098(@code{gnus-summary-best-unread-article}). If given a prefix argument,
6099go to the first unread article that has a score over the default score.
6100
6101@item G l
6102@itemx l
6103@kindex l (Summary)
6104@kindex G l (Summary)
6105@findex gnus-summary-goto-last-article
6106Go to the previous article read (@code{gnus-summary-goto-last-article}).
6107
6108@item G o
6109@kindex G o (Summary)
6110@findex gnus-summary-pop-article
6111@cindex history
6112@cindex article history
6113Pop an article off the summary history and go to this article
6114(@code{gnus-summary-pop-article}). This command differs from the
6115command above in that you can pop as many previous articles off the
6116history as you like, while @kbd{l} toggles the two last read articles.
6117For a somewhat related issue (if you use these commands a lot),
6118@pxref{Article Backlog}.
6119
6120@item G j
6121@itemx j
6122@kindex j (Summary)
6123@kindex G j (Summary)
6124@findex gnus-summary-goto-article
6125Ask for an article number or @code{Message-ID}, and then go to that
6126article (@code{gnus-summary-goto-article}).
6127
6128@end table
6129
6130
6131@node Choosing Variables
6132@subsection Choosing Variables
6133
6134Some variables relevant for moving and selecting articles:
6135
6136@table @code
6137@item gnus-auto-extend-newsgroup
6138@vindex gnus-auto-extend-newsgroup
6139All the movement commands will try to go to the previous (or next)
6140article, even if that article isn't displayed in the Summary buffer if
6141this variable is non-@code{nil}. Gnus will then fetch the article from
6142the server and display it in the article buffer.
6143
6144@item gnus-select-article-hook
6145@vindex gnus-select-article-hook
6146This hook is called whenever an article is selected. The default is
6147@code{nil}. If you would like each article to be saved in the Agent as
6148you read it, putting @code{gnus-agent-fetch-selected-article} on this
6149hook will do so.
6150
6151@item gnus-mark-article-hook
6152@vindex gnus-mark-article-hook
6153@findex gnus-summary-mark-unread-as-read
6154@findex gnus-summary-mark-read-and-unread-as-read
6155@findex gnus-unread-mark
6156This hook is called whenever an article is selected. It is intended to
6157be used for marking articles as read. The default value is
6158@code{gnus-summary-mark-read-and-unread-as-read}, and will change the
6159mark of almost any article you read to @code{gnus-read-mark}. The only
6160articles not affected by this function are ticked, dormant, and
6161expirable articles. If you'd instead like to just have unread articles
6162marked as read, you can use @code{gnus-summary-mark-unread-as-read}
6163instead. It will leave marks like @code{gnus-low-score-mark},
6164@code{gnus-del-mark} (and so on) alone.
6165
6166@end table
6167
6168
6169@node Paging the Article
6170@section Scrolling the Article
6171@cindex article scrolling
6172
6173@table @kbd
6174
6175@item SPACE
6176@kindex SPACE (Summary)
6177@findex gnus-summary-next-page
6178Pressing @kbd{SPACE} will scroll the current article forward one page,
6179or, if you have come to the end of the current article, will choose the
6180next article (@code{gnus-summary-next-page}).
6181
6182@vindex gnus-article-boring-faces
6183@vindex gnus-article-skip-boring
6184If @code{gnus-article-skip-boring} is non-@code{nil} and the rest of
6185the article consists only of citations and signature, then it will be
6186skipped; the next article will be shown instead. You can customize
6187what is considered uninteresting with
6188@code{gnus-article-boring-faces}. You can manually view the article's
6189pages, no matter how boring, using @kbd{C-M-v}.
6190
6191@item DEL
6192@kindex DEL (Summary)
6193@findex gnus-summary-prev-page
6194Scroll the current article back one page (@code{gnus-summary-prev-page}).
6195
6196@item RET
6197@kindex RET (Summary)
6198@findex gnus-summary-scroll-up
6199Scroll the current article one line forward
6200(@code{gnus-summary-scroll-up}).
6201
6202@item M-RET
6203@kindex M-RET (Summary)
6204@findex gnus-summary-scroll-down
6205Scroll the current article one line backward
6206(@code{gnus-summary-scroll-down}).
6207
6208@item A g
6209@itemx g
6210@kindex A g (Summary)
6211@kindex g (Summary)
6212@findex gnus-summary-show-article
6213@vindex gnus-summary-show-article-charset-alist
6214(Re)fetch the current article (@code{gnus-summary-show-article}). If
6215given a prefix, fetch the current article, but don't run any of the
6216article treatment functions. This will give you a ``raw'' article, just
6217the way it came from the server.
6218
e3e955fe 6219@cindex charset, view article with different charset
4009494e
GM
6220If given a numerical prefix, you can do semi-manual charset stuff.
6221@kbd{C-u 0 g cn-gb-2312 RET} will decode the message as if it were
6222encoded in the @code{cn-gb-2312} charset. If you have
6223
6224@lisp
6225(setq gnus-summary-show-article-charset-alist
6226 '((1 . cn-gb-2312)
6227 (2 . big5)))
6228@end lisp
6229
6230then you can say @kbd{C-u 1 g} to get the same effect.
6231
6232@item A <
6233@itemx <
6234@kindex < (Summary)
6235@kindex A < (Summary)
6236@findex gnus-summary-beginning-of-article
6237Scroll to the beginning of the article
6238(@code{gnus-summary-beginning-of-article}).
6239
6240@item A >
6241@itemx >
6242@kindex > (Summary)
6243@kindex A > (Summary)
6244@findex gnus-summary-end-of-article
6245Scroll to the end of the article (@code{gnus-summary-end-of-article}).
6246
6247@item A s
6248@itemx s
6249@kindex A s (Summary)
6250@kindex s (Summary)
6251@findex gnus-summary-isearch-article
6252Perform an isearch in the article buffer
6253(@code{gnus-summary-isearch-article}).
6254
6255@item h
6256@kindex h (Summary)
6257@findex gnus-summary-select-article-buffer
6258Select the article buffer (@code{gnus-summary-select-article-buffer}).
6259
6260@end table
6261
6262
6263@node Reply Followup and Post
6264@section Reply, Followup and Post
6265
6266@menu
6267* Summary Mail Commands:: Sending mail.
6268* Summary Post Commands:: Sending news.
6269* Summary Message Commands:: Other Message-related commands.
6270* Canceling and Superseding::
6271@end menu
6272
6273
6274@node Summary Mail Commands
6275@subsection Summary Mail Commands
6276@cindex mail
6277@cindex composing mail
6278
6279Commands for composing a mail message:
6280
6281@table @kbd
6282
6283@item S r
6284@itemx r
6285@kindex S r (Summary)
6286@kindex r (Summary)
6287@findex gnus-summary-reply
6288@c @icon{gnus-summary-mail-reply}
6289@c @icon{gnus-summary-reply}
6290Mail a reply to the author of the current article
6291(@code{gnus-summary-reply}).
6292
6293@item S R
6294@itemx R
6295@kindex R (Summary)
6296@kindex S R (Summary)
6297@findex gnus-summary-reply-with-original
6298@c @icon{gnus-summary-reply-with-original}
6299Mail a reply to the author of the current article and include the
6300original message (@code{gnus-summary-reply-with-original}). This
6301command uses the process/prefix convention.
6302
6303@item S w
6304@kindex S w (Summary)
6305@findex gnus-summary-wide-reply
6306Mail a wide reply to the author of the current article
6307(@code{gnus-summary-wide-reply}). A @dfn{wide reply} is a reply that
6308goes out to all people listed in the @code{To}, @code{From} (or
6309@code{Reply-to}) and @code{Cc} headers. If @code{Mail-Followup-To} is
6310present, that's used instead.
6311
6312@item S W
6313@kindex S W (Summary)
6314@findex gnus-summary-wide-reply-with-original
6315Mail a wide reply to the current article and include the original
6316message (@code{gnus-summary-wide-reply-with-original}). This command uses
b0e4f3fc
KY
6317the process/prefix convention, but only uses the headers from the
6318first article to determine the recipients.
4009494e
GM
6319
6320@item S v
6321@kindex S v (Summary)
6322@findex gnus-summary-very-wide-reply
6323Mail a very wide reply to the author of the current article
6324(@code{gnus-summary-wide-reply}). A @dfn{very wide reply} is a reply
6325that goes out to all people listed in the @code{To}, @code{From} (or
6326@code{Reply-to}) and @code{Cc} headers in all the process/prefixed
6327articles. This command uses the process/prefix convention.
6328
6329@item S V
6330@kindex S V (Summary)
6331@findex gnus-summary-very-wide-reply-with-original
6332Mail a very wide reply to the author of the current article and include the
6333original message (@code{gnus-summary-very-wide-reply-with-original}). This
6334command uses the process/prefix convention.
6335
6336@item S B r
6337@kindex S B r (Summary)
6338@findex gnus-summary-reply-broken-reply-to
6339Mail a reply to the author of the current article but ignore the
6340@code{Reply-To} field (@code{gnus-summary-reply-broken-reply-to}).
6341If you need this because a mailing list incorrectly sets a
6342@code{Reply-To} header pointing to the list, you probably want to set
6343the @code{broken-reply-to} group parameter instead, so things will work
6344correctly. @xref{Group Parameters}.
6345
6346@item S B R
6347@kindex S B R (Summary)
6348@findex gnus-summary-reply-broken-reply-to-with-original
6349Mail a reply to the author of the current article and include the
6350original message but ignore the @code{Reply-To} field
6351(@code{gnus-summary-reply-broken-reply-to-with-original}).
6352
6353@item S o m
6354@itemx C-c C-f
6355@kindex S o m (Summary)
6356@kindex C-c C-f (Summary)
6357@findex gnus-summary-mail-forward
6358@c @icon{gnus-summary-mail-forward}
6359Forward the current article to some other person
6360(@code{gnus-summary-mail-forward}). If no prefix is given, the message
6361is forwarded according to the value of (@code{message-forward-as-mime})
6362and (@code{message-forward-show-mml}); if the prefix is 1, decode the
6363message and forward directly inline; if the prefix is 2, forward message
6364as an rfc822 @acronym{MIME} section; if the prefix is 3, decode message and
6365forward as an rfc822 @acronym{MIME} section; if the prefix is 4, forward message
6366directly inline; otherwise, the message is forwarded as no prefix given
6367but use the flipped value of (@code{message-forward-as-mime}). By
6368default, the message is decoded and forwarded as an rfc822 @acronym{MIME}
6369section.
6370
6371@item S m
6372@itemx m
6373@kindex m (Summary)
6374@kindex S m (Summary)
6375@findex gnus-summary-mail-other-window
6376@c @icon{gnus-summary-mail-originate}
6377Prepare a mail (@code{gnus-summary-mail-other-window}). By default, use
6378the posting style of the current group. If given a prefix, disable that.
6379If the prefix is 1, prompt for a group name to find the posting style.
6380
6381@item S i
4009494e
GM
6382@kindex S i (Summary)
6383@findex gnus-summary-news-other-window
6384Prepare a news (@code{gnus-summary-news-other-window}). By default,
6385post to the current group. If given a prefix, disable that. If the
6386prefix is 1, prompt for a group to post to.
6387
6388This function actually prepares a news even when using mail groups.
6389This is useful for ``posting'' messages to mail groups without actually
6390sending them over the network: they're just saved directly to the group
6391in question. The corresponding back end must have a request-post method
6392for this to work though.
6393
6394@item S D b
6395@kindex S D b (Summary)
6396@findex gnus-summary-resend-bounced-mail
6397@cindex bouncing mail
6398If you have sent a mail, but the mail was bounced back to you for some
6399reason (wrong address, transient failure), you can use this command to
6400resend that bounced mail (@code{gnus-summary-resend-bounced-mail}). You
6401will be popped into a mail buffer where you can edit the headers before
6402sending the mail off again. If you give a prefix to this command, and
6403the bounced mail is a reply to some other mail, Gnus will try to fetch
6404that mail and display it for easy perusal of its headers. This might
6405very well fail, though.
6406
6407@item S D r
6408@kindex S D r (Summary)
6409@findex gnus-summary-resend-message
6410Not to be confused with the previous command,
6411@code{gnus-summary-resend-message} will prompt you for an address to
6412send the current message off to, and then send it to that place. The
6413headers of the message won't be altered---but lots of headers that say
6414@code{Resent-To}, @code{Resent-From} and so on will be added. This
6415means that you actually send a mail to someone that has a @code{To}
6416header that (probably) points to yourself. This will confuse people.
6417So, natcherly you'll only do that if you're really eVIl.
6418
6419This command is mainly used if you have several accounts and want to
6420ship a mail to a different account of yours. (If you're both
6421@code{root} and @code{postmaster} and get a mail for @code{postmaster}
6422to the @code{root} account, you may want to resend it to
6423@code{postmaster}. Ordnung muss sein!
6424
6425This command understands the process/prefix convention
6426(@pxref{Process/Prefix}).
6427
6428@item S D e
6429@kindex S D e (Summary)
6430@findex gnus-summary-resend-message-edit
6431
6432Like the previous command, but will allow you to edit the message as
6433if it were a new message before resending.
6434
6435@item S O m
6436@kindex S O m (Summary)
6437@findex gnus-uu-digest-mail-forward
6438Digest the current series (@pxref{Decoding Articles}) and forward the
6439result using mail (@code{gnus-uu-digest-mail-forward}). This command
6440uses the process/prefix convention (@pxref{Process/Prefix}).
6441
6442@item S M-c
6443@kindex S M-c (Summary)
6444@findex gnus-summary-mail-crosspost-complaint
6445@cindex crossposting
6446@cindex excessive crossposting
6447Send a complaint about excessive crossposting to the author of the
6448current article (@code{gnus-summary-mail-crosspost-complaint}).
6449
6450@findex gnus-crosspost-complaint
6451This command is provided as a way to fight back against the current
6452crossposting pandemic that's sweeping Usenet. It will compose a reply
6453using the @code{gnus-crosspost-complaint} variable as a preamble. This
6454command understands the process/prefix convention
6455(@pxref{Process/Prefix}) and will prompt you before sending each mail.
6456
6457@end table
6458
6459Also @xref{Header Commands, ,Header Commands, message, The Message
6460Manual}, for more information.
6461
6462
6463@node Summary Post Commands
6464@subsection Summary Post Commands
6465@cindex post
6466@cindex composing news
6467
6468Commands for posting a news article:
6469
6470@table @kbd
6471@item S p
6472@itemx a
6473@kindex a (Summary)
6474@kindex S p (Summary)
6475@findex gnus-summary-post-news
6476@c @icon{gnus-summary-post-news}
6477Prepare for posting an article (@code{gnus-summary-post-news}). By
6478default, post to the current group. If given a prefix, disable that.
6479If the prefix is 1, prompt for another group instead.
6480
6481@item S f
6482@itemx f
6483@kindex f (Summary)
6484@kindex S f (Summary)
6485@findex gnus-summary-followup
6486@c @icon{gnus-summary-followup}
6487Post a followup to the current article (@code{gnus-summary-followup}).
6488
6489@item S F
6490@itemx F
6491@kindex S F (Summary)
6492@kindex F (Summary)
6493@c @icon{gnus-summary-followup-with-original}
6494@findex gnus-summary-followup-with-original
6495Post a followup to the current article and include the original message
6496(@code{gnus-summary-followup-with-original}). This command uses the
6497process/prefix convention.
6498
6499@item S n
6500@kindex S n (Summary)
6501@findex gnus-summary-followup-to-mail
6502Post a followup to the current article via news, even if you got the
6503message through mail (@code{gnus-summary-followup-to-mail}).
6504
6505@item S N
6506@kindex S N (Summary)
6507@findex gnus-summary-followup-to-mail-with-original
6508Post a followup to the current article via news, even if you got the
6509message through mail and include the original message
6510(@code{gnus-summary-followup-to-mail-with-original}). This command uses
6511the process/prefix convention.
6512
6513@item S o p
6514@kindex S o p (Summary)
6515@findex gnus-summary-post-forward
6516Forward the current article to a newsgroup
6517(@code{gnus-summary-post-forward}).
6518 If no prefix is given, the message is forwarded according to the value
6519of (@code{message-forward-as-mime}) and
6520(@code{message-forward-show-mml}); if the prefix is 1, decode the
6521message and forward directly inline; if the prefix is 2, forward message
6522as an rfc822 @acronym{MIME} section; if the prefix is 3, decode message and
6523forward as an rfc822 @acronym{MIME} section; if the prefix is 4, forward message
6524directly inline; otherwise, the message is forwarded as no prefix given
6525but use the flipped value of (@code{message-forward-as-mime}). By
6526default, the message is decoded and forwarded as an rfc822 @acronym{MIME} section.
6527
6528@item S O p
6529@kindex S O p (Summary)
6530@findex gnus-uu-digest-post-forward
6531@cindex digests
6532@cindex making digests
6533Digest the current series and forward the result to a newsgroup
6534(@code{gnus-uu-digest-post-forward}). This command uses the
6535process/prefix convention.
6536
6537@item S u
6538@kindex S u (Summary)
6539@findex gnus-uu-post-news
6540@c @icon{gnus-uu-post-news}
6541Uuencode a file, split it into parts, and post it as a series
6542(@code{gnus-uu-post-news}). (@pxref{Uuencoding and Posting}).
6543@end table
6544
6545Also @xref{Header Commands, ,Header Commands, message, The Message
6546Manual}, for more information.
6547
6548
6549@node Summary Message Commands
6550@subsection Summary Message Commands
6551
6552@table @kbd
6553@item S y
6554@kindex S y (Summary)
6555@findex gnus-summary-yank-message
6556Yank the current article into an already existing Message composition
6557buffer (@code{gnus-summary-yank-message}). This command prompts for
6558what message buffer you want to yank into, and understands the
6559process/prefix convention (@pxref{Process/Prefix}).
6560
6561@end table
6562
6563
6564@node Canceling and Superseding
6565@subsection Canceling Articles
6566@cindex canceling articles
6567@cindex superseding articles
6568
6569Have you ever written something, and then decided that you really,
6570really, really wish you hadn't posted that?
6571
6572Well, you can't cancel mail, but you can cancel posts.
6573
6574@findex gnus-summary-cancel-article
6575@kindex C (Summary)
6576@c @icon{gnus-summary-cancel-article}
6577Find the article you wish to cancel (you can only cancel your own
6578articles, so don't try any funny stuff). Then press @kbd{C} or @kbd{S
6579c} (@code{gnus-summary-cancel-article}). Your article will be
6580canceled---machines all over the world will be deleting your article.
6581This command uses the process/prefix convention (@pxref{Process/Prefix}).
6582
6583Be aware, however, that not all sites honor cancels, so your article may
6584live on here and there, while most sites will delete the article in
6585question.
6586
6587Gnus will use the ``current'' select method when canceling. If you
6588want to use the standard posting method, use the @samp{a} symbolic
6589prefix (@pxref{Symbolic Prefixes}).
6590
6591Gnus ensures that only you can cancel your own messages using a
6592@code{Cancel-Lock} header (@pxref{Canceling News, Canceling News, ,
6593message, Message Manual}).
6594
6595If you discover that you have made some mistakes and want to do some
6596corrections, you can post a @dfn{superseding} article that will replace
6597your original article.
6598
6599@findex gnus-summary-supersede-article
6600@kindex S (Summary)
6601Go to the original article and press @kbd{S s}
6602(@code{gnus-summary-supersede-article}). You will be put in a buffer
6603where you can edit the article all you want before sending it off the
6604usual way.
6605
6606The same goes for superseding as for canceling, only more so: Some
6607sites do not honor superseding. On those sites, it will appear that you
6608have posted almost the same article twice.
6609
6610If you have just posted the article, and change your mind right away,
6611there is a trick you can use to cancel/supersede the article without
6612waiting for the article to appear on your site first. You simply return
6613to the post buffer (which is called @code{*sent ...*}). There you will
6614find the article you just posted, with all the headers intact. Change
6615the @code{Message-ID} header to a @code{Cancel} or @code{Supersedes}
6616header by substituting one of those words for the word
6617@code{Message-ID}. Then just press @kbd{C-c C-c} to send the article as
6618you would do normally. The previous article will be
6619canceled/superseded.
6620
6621Just remember, kids: There is no 'c' in 'supersede'.
6622
6623@node Delayed Articles
6624@section Delayed Articles
6625@cindex delayed sending
6626@cindex send delayed
6627
6628Sometimes, you might wish to delay the sending of a message. For
6629example, you might wish to arrange for a message to turn up just in time
6630to remind your about the birthday of your Significant Other. For this,
6631there is the @code{gnus-delay} package. Setup is simple:
6632
6633@lisp
6634(gnus-delay-initialize)
6635@end lisp
6636
6637@findex gnus-delay-article
6638Normally, to send a message you use the @kbd{C-c C-c} command from
6639Message mode. To delay a message, use @kbd{C-c C-j}
6640(@code{gnus-delay-article}) instead. This will ask you for how long the
6641message should be delayed. Possible answers are:
6642
6643@itemize @bullet
6644@item
6645A time span. Consists of an integer and a letter. For example,
6646@code{42d} means to delay for 42 days. Available letters are @code{m}
6647(minutes), @code{h} (hours), @code{d} (days), @code{w} (weeks), @code{M}
6648(months) and @code{Y} (years).
6649
6650@item
6651A specific date. Looks like @code{YYYY-MM-DD}. The message will be
6652delayed until that day, at a specific time (eight o'clock by default).
6653See also @code{gnus-delay-default-hour}.
6654
6655@item
6656A specific time of day. Given in @code{hh:mm} format, 24h, no am/pm
6657stuff. The deadline will be at that time today, except if that time has
6658already passed, then it's at the given time tomorrow. So if it's ten
6659o'clock in the morning and you specify @code{11:15}, then the deadline
6660is one hour and fifteen minutes hence. But if you specify @code{9:20},
6661that means a time tomorrow.
6662@end itemize
6663
6664The action of the @code{gnus-delay-article} command is influenced by a
6665couple of variables:
6666
6667@table @code
6668@item gnus-delay-default-hour
6669@vindex gnus-delay-default-hour
6670When you specify a specific date, the message will be due on that hour
6671on the given date. Possible values are integers 0 through 23.
6672
6673@item gnus-delay-default-delay
6674@vindex gnus-delay-default-delay
6675This is a string and gives the default delay. It can be of any of the
6676formats described above.
6677
6678@item gnus-delay-group
6679@vindex gnus-delay-group
6680Delayed articles will be kept in this group on the drafts server until
6681they are due. You probably don't need to change this. The default
6682value is @code{"delayed"}.
6683
6684@item gnus-delay-header
6685@vindex gnus-delay-header
6686The deadline for each article will be stored in a header. This variable
6687is a string and gives the header name. You probably don't need to
6688change this. The default value is @code{"X-Gnus-Delayed"}.
6689@end table
6690
6691The way delaying works is like this: when you use the
6692@code{gnus-delay-article} command, you give a certain delay. Gnus
6693calculates the deadline of the message and stores it in the
6694@code{X-Gnus-Delayed} header and puts the message in the
6695@code{nndraft:delayed} group.
6696
6697@findex gnus-delay-send-queue
6698And whenever you get new news, Gnus looks through the group for articles
6699which are due and sends them. It uses the @code{gnus-delay-send-queue}
6700function for this. By default, this function is added to the hook
6701@code{gnus-get-new-news-hook}. But of course, you can change this.
6702Maybe you want to use the demon to send drafts? Just tell the demon to
6703execute the @code{gnus-delay-send-queue} function.
6704
6705@table @code
6706@item gnus-delay-initialize
6707@findex gnus-delay-initialize
6708By default, this function installs @code{gnus-delay-send-queue} in
6709@code{gnus-get-new-news-hook}. But it accepts the optional second
6710argument @code{no-check}. If it is non-@code{nil},
6711@code{gnus-get-new-news-hook} is not changed. The optional first
6712argument is ignored.
6713
6714For example, @code{(gnus-delay-initialize nil t)} means to do nothing.
6715Presumably, you want to use the demon for sending due delayed articles.
6716Just don't forget to set that up :-)
6717@end table
6718
e7842e69
KY
6719When delaying an article with @kbd{C-c C-j}, Message mode will
6720automatically add a @code{"Date"} header with the current time. In
6721many cases you probably want the @code{"Date"} header to reflect the
6722time the message is sent instead. To do this, you have to delete
6723@code{Date} from @code{message-draft-headers}.
6724
4009494e
GM
6725
6726@node Marking Articles
6727@section Marking Articles
6728@cindex article marking
6729@cindex article ticking
6730@cindex marks
6731
6732There are several marks you can set on an article.
6733
6734You have marks that decide the @dfn{readedness} (whoo, neato-keano
6735neologism ohoy!) of the article. Alphabetic marks generally mean
6736@dfn{read}, while non-alphabetic characters generally mean @dfn{unread}.
6737
6738In addition, you also have marks that do not affect readedness.
6739
6740@ifinfo
6741There's a plethora of commands for manipulating these marks.
6742@end ifinfo
6743
6744@menu
6745* Unread Articles:: Marks for unread articles.
6746* Read Articles:: Marks for read articles.
6747* Other Marks:: Marks that do not affect readedness.
6748* Setting Marks:: How to set and remove marks.
6749* Generic Marking Commands:: How to customize the marking.
6750* Setting Process Marks:: How to mark articles for later processing.
6751@end menu
6752
6753
6754@node Unread Articles
6755@subsection Unread Articles
6756
6757The following marks mark articles as (kinda) unread, in one form or
6758other.
6759
6760@table @samp
6761@item !
6762@vindex gnus-ticked-mark
6763Marked as ticked (@code{gnus-ticked-mark}).
6764
6765@dfn{Ticked articles} are articles that will remain visible always. If
6766you see an article that you find interesting, or you want to put off
6767reading it, or replying to it, until sometime later, you'd typically
6768tick it. However, articles can be expired (from news servers by the
6769news server software, Gnus itself never expires ticked messages), so if
6770you want to keep an article forever, you'll have to make it persistent
6771(@pxref{Persistent Articles}).
6772
6773@item ?
6774@vindex gnus-dormant-mark
6775Marked as dormant (@code{gnus-dormant-mark}).
6776
6777@dfn{Dormant articles} will only appear in the summary buffer if there
6778are followups to it. If you want to see them even if they don't have
6779followups, you can use the @kbd{/ D} command (@pxref{Limiting}).
6780Otherwise (except for the visibility issue), they are just like ticked
6781messages.
6782
6783@item SPACE
6784@vindex gnus-unread-mark
6785Marked as unread (@code{gnus-unread-mark}).
6786
6787@dfn{Unread articles} are articles that haven't been read at all yet.
6788@end table
6789
6790
6791@node Read Articles
6792@subsection Read Articles
6793@cindex expirable mark
6794
6795All the following marks mark articles as read.
6796
6797@table @samp
6798
6799@item r
6800@vindex gnus-del-mark
6801These are articles that the user has marked as read with the @kbd{d}
6802command manually, more or less (@code{gnus-del-mark}).
6803
6804@item R
6805@vindex gnus-read-mark
6806Articles that have actually been read (@code{gnus-read-mark}).
6807
6808@item O
6809@vindex gnus-ancient-mark
6810Articles that were marked as read in previous sessions and are now
6811@dfn{old} (@code{gnus-ancient-mark}).
6812
6813@item K
6814@vindex gnus-killed-mark
6815Marked as killed (@code{gnus-killed-mark}).
6816
6817@item X
6818@vindex gnus-kill-file-mark
6819Marked as killed by kill files (@code{gnus-kill-file-mark}).
6820
6821@item Y
6822@vindex gnus-low-score-mark
6823Marked as read by having too low a score (@code{gnus-low-score-mark}).
6824
6825@item C
6826@vindex gnus-catchup-mark
6827Marked as read by a catchup (@code{gnus-catchup-mark}).
6828
6829@item G
6830@vindex gnus-canceled-mark
6831Canceled article (@code{gnus-canceled-mark})
6832
4009494e
GM
6833@item Q
6834@vindex gnus-sparse-mark
6835Sparsely reffed article (@code{gnus-sparse-mark}). @xref{Customizing
6836Threading}.
6837
6838@item M
6839@vindex gnus-duplicate-mark
6840Article marked as read by duplicate suppression
6841(@code{gnus-duplicate-mark}). @xref{Duplicate Suppression}.
6842
6843@end table
6844
6845All these marks just mean that the article is marked as read, really.
6846They are interpreted differently when doing adaptive scoring, though.
6847
6848One more special mark, though:
6849
6850@table @samp
6851@item E
6852@vindex gnus-expirable-mark
6853Marked as expirable (@code{gnus-expirable-mark}).
6854
6855Marking articles as @dfn{expirable} (or have them marked as such
6856automatically) doesn't make much sense in normal groups---a user doesn't
6857control expiring of news articles, but in mail groups, for instance,
6858articles marked as @dfn{expirable} can be deleted by Gnus at
6859any time.
6860@end table
6861
6862
6863@node Other Marks
6864@subsection Other Marks
6865@cindex process mark
6866@cindex bookmarks
6867
6868There are some marks that have nothing to do with whether the article is
6869read or not.
6870
6871@itemize @bullet
6872
6873@item
6874You can set a bookmark in the current article. Say you are reading a
6875long thesis on cats' urinary tracts, and have to go home for dinner
6876before you've finished reading the thesis. You can then set a bookmark
6877in the article, and Gnus will jump to this bookmark the next time it
6878encounters the article. @xref{Setting Marks}.
6879
6880@item
6881@vindex gnus-replied-mark
6882All articles that you have replied to or made a followup to (i.e., have
6883answered) will be marked with an @samp{A} in the second column
6884(@code{gnus-replied-mark}).
6885
6886@item
6887@vindex gnus-forwarded-mark
6888All articles that you have forwarded will be marked with an @samp{F} in
6889the second column (@code{gnus-forwarded-mark}).
6890
6891@item
6892@vindex gnus-cached-mark
6893Articles stored in the article cache will be marked with an @samp{*} in
6894the second column (@code{gnus-cached-mark}). @xref{Article Caching}.
6895
6896@item
6897@vindex gnus-saved-mark
6898Articles ``saved'' (in some manner or other; not necessarily
6899religiously) are marked with an @samp{S} in the second column
6900(@code{gnus-saved-mark}).
6901
6902@item
6903@vindex gnus-recent-mark
6904Articles that according to the server haven't been shown to the user
6905before are marked with a @samp{N} in the second column
6906(@code{gnus-recent-mark}). Note that not all servers support this
6907mark, in which case it simply never appears. Compare with
6908@code{gnus-unseen-mark}.
6909
6910@item
6911@vindex gnus-unseen-mark
6912Articles that haven't been seen before in Gnus by the user are marked
6913with a @samp{.} in the second column (@code{gnus-unseen-mark}).
6914Compare with @code{gnus-recent-mark}.
6915
6916@item
6917@vindex gnus-downloaded-mark
6918When using the Gnus agent (@pxref{Agent Basics}), articles may be
6919downloaded for unplugged (offline) viewing. If you are using the
6920@samp{%O} spec, these articles get the @samp{+} mark in that spec.
6921(The variable @code{gnus-downloaded-mark} controls which character to
6922use.)
6923
6924@item
6925@vindex gnus-undownloaded-mark
6926When using the Gnus agent (@pxref{Agent Basics}), some articles might
6927not have been downloaded. Such articles cannot be viewed while you
6928are unplugged (offline). If you are using the @samp{%O} spec, these
6929articles get the @samp{-} mark in that spec. (The variable
6930@code{gnus-undownloaded-mark} controls which character to use.)
6931
6932@item
6933@vindex gnus-downloadable-mark
6934The Gnus agent (@pxref{Agent Basics}) downloads some articles
6935automatically, but it is also possible to explicitly mark articles for
6936download, even if they would not be downloaded automatically. Such
6937explicitly-marked articles get the @samp{%} mark in the first column.
6938(The variable @code{gnus-downloadable-mark} controls which character to
6939use.)
6940
6941@item
6942@vindex gnus-not-empty-thread-mark
6943@vindex gnus-empty-thread-mark
6944If the @samp{%e} spec is used, the presence of threads or not will be
6945marked with @code{gnus-not-empty-thread-mark} and
6946@code{gnus-empty-thread-mark} in the third column, respectively.
6947
6948@item
6949@vindex gnus-process-mark
6950Finally we have the @dfn{process mark} (@code{gnus-process-mark}). A
6951variety of commands react to the presence of the process mark. For
6952instance, @kbd{X u} (@code{gnus-uu-decode-uu}) will uudecode and view
6953all articles that have been marked with the process mark. Articles
6954marked with the process mark have a @samp{#} in the second column.
6955
6956@end itemize
6957
6958You might have noticed that most of these ``non-readedness'' marks
6959appear in the second column by default. So if you have a cached, saved,
6960replied article that you have process-marked, what will that look like?
6961
6962Nothing much. The precedence rules go as follows: process -> cache ->
6963replied -> saved. So if the article is in the cache and is replied,
6964you'll only see the cache mark and not the replied mark.
6965
6966
6967@node Setting Marks
6968@subsection Setting Marks
6969@cindex setting marks
6970
6971All the marking commands understand the numeric prefix.
6972
6973@table @kbd
6974@item M c
6975@itemx M-u
6976@kindex M c (Summary)
6977@kindex M-u (Summary)
6978@findex gnus-summary-clear-mark-forward
6979@cindex mark as unread
6980Clear all readedness-marks from the current article
6981(@code{gnus-summary-clear-mark-forward}). In other words, mark the
6982article as unread.
6983
6984@item M t
6985@itemx !
6986@kindex ! (Summary)
6987@kindex M t (Summary)
6988@findex gnus-summary-tick-article-forward
6989Tick the current article (@code{gnus-summary-tick-article-forward}).
6990@xref{Article Caching}.
6991
6992@item M ?
6993@itemx ?
6994@kindex ? (Summary)
6995@kindex M ? (Summary)
6996@findex gnus-summary-mark-as-dormant
6997Mark the current article as dormant
6998(@code{gnus-summary-mark-as-dormant}). @xref{Article Caching}.
6999
7000@item M d
7001@itemx d
7002@kindex M d (Summary)
7003@kindex d (Summary)
7004@findex gnus-summary-mark-as-read-forward
7005Mark the current article as read
7006(@code{gnus-summary-mark-as-read-forward}).
7007
7008@item D
7009@kindex D (Summary)
7010@findex gnus-summary-mark-as-read-backward
7011Mark the current article as read and move point to the previous line
7012(@code{gnus-summary-mark-as-read-backward}).
7013
7014@item M k
7015@itemx k
7016@kindex k (Summary)
7017@kindex M k (Summary)
7018@findex gnus-summary-kill-same-subject-and-select
7019Mark all articles that have the same subject as the current one as read,
7020and then select the next unread article
7021(@code{gnus-summary-kill-same-subject-and-select}).
7022
7023@item M K
7024@itemx C-k
7025@kindex M K (Summary)
7026@kindex C-k (Summary)
7027@findex gnus-summary-kill-same-subject
7028Mark all articles that have the same subject as the current one as read
7029(@code{gnus-summary-kill-same-subject}).
7030
7031@item M C
7032@kindex M C (Summary)
7033@findex gnus-summary-catchup
7034@c @icon{gnus-summary-catchup}
7035Mark all unread articles as read (@code{gnus-summary-catchup}).
7036
7037@item M C-c
7038@kindex M C-c (Summary)
7039@findex gnus-summary-catchup-all
7040Mark all articles in the group as read---even the ticked and dormant
7041articles (@code{gnus-summary-catchup-all}).
7042
7043@item M H
7044@kindex M H (Summary)
7045@findex gnus-summary-catchup-to-here
7046Catchup the current group to point (before the point)
7047(@code{gnus-summary-catchup-to-here}).
7048
7049@item M h
7050@kindex M h (Summary)
7051@findex gnus-summary-catchup-from-here
7052Catchup the current group from point (after the point)
7053(@code{gnus-summary-catchup-from-here}).
7054
7055@item C-w
7056@kindex C-w (Summary)
7057@findex gnus-summary-mark-region-as-read
7058Mark all articles between point and mark as read
7059(@code{gnus-summary-mark-region-as-read}).
7060
7061@item M V k
7062@kindex M V k (Summary)
7063@findex gnus-summary-kill-below
7064Kill all articles with scores below the default score (or below the
7065numeric prefix) (@code{gnus-summary-kill-below}).
7066
7067@item M e
7068@itemx E
7069@kindex M e (Summary)
7070@kindex E (Summary)
7071@findex gnus-summary-mark-as-expirable
7072Mark the current article as expirable
7073(@code{gnus-summary-mark-as-expirable}).
7074
7075@item M b
7076@kindex M b (Summary)
7077@findex gnus-summary-set-bookmark
7078Set a bookmark in the current article
7079(@code{gnus-summary-set-bookmark}).
7080
7081@item M B
7082@kindex M B (Summary)
7083@findex gnus-summary-remove-bookmark
7084Remove the bookmark from the current article
7085(@code{gnus-summary-remove-bookmark}).
7086
7087@item M V c
7088@kindex M V c (Summary)
7089@findex gnus-summary-clear-above
7090Clear all marks from articles with scores over the default score (or
7091over the numeric prefix) (@code{gnus-summary-clear-above}).
7092
7093@item M V u
7094@kindex M V u (Summary)
7095@findex gnus-summary-tick-above
7096Tick all articles with scores over the default score (or over the
7097numeric prefix) (@code{gnus-summary-tick-above}).
7098
7099@item M V m
7100@kindex M V m (Summary)
7101@findex gnus-summary-mark-above
7102Prompt for a mark, and mark all articles with scores over the default
7103score (or over the numeric prefix) with this mark
7104(@code{gnus-summary-clear-above}).
7105@end table
7106
7107@vindex gnus-summary-goto-unread
7108The @code{gnus-summary-goto-unread} variable controls what action should
7109be taken after setting a mark. If non-@code{nil}, point will move to
7110the next/previous unread article. If @code{nil}, point will just move
7111one line up or down. As a special case, if this variable is
7112@code{never}, all the marking commands as well as other commands (like
7113@kbd{SPACE}) will move to the next article, whether it is unread or not.
7114The default is @code{t}.
7115
7116
7117@node Generic Marking Commands
7118@subsection Generic Marking Commands
7119
7120Some people would like the command that ticks an article (@kbd{!}) go to
7121the next article. Others would like it to go to the next unread
7122article. Yet others would like it to stay on the current article. And
7123even though I haven't heard of anybody wanting it to go to the
7124previous (unread) article, I'm sure there are people that want that as
7125well.
7126
7127Multiply these five behaviors with five different marking commands, and
7128you get a potentially complex set of variable to control what each
7129command should do.
7130
7131To sidestep that mess, Gnus provides commands that do all these
7132different things. They can be found on the @kbd{M M} map in the summary
7133buffer. Type @kbd{M M C-h} to see them all---there are too many of them
7134to list in this manual.
7135
7136While you can use these commands directly, most users would prefer
7137altering the summary mode keymap. For instance, if you would like the
7138@kbd{!} command to go to the next article instead of the next unread
7139article, you could say something like:
7140
7141@lisp
7142@group
7143(add-hook 'gnus-summary-mode-hook 'my-alter-summary-map)
7144(defun my-alter-summary-map ()
7145 (local-set-key "!" 'gnus-summary-put-mark-as-ticked-next))
7146@end group
7147@end lisp
7148
7149@noindent
7150or
7151
7152@lisp
7153(defun my-alter-summary-map ()
7154 (local-set-key "!" "MM!n"))
7155@end lisp
7156
7157
7158@node Setting Process Marks
7159@subsection Setting Process Marks
7160@cindex setting process marks
7161
7162Process marks are displayed as @code{#} in the summary buffer, and are
7163used for marking articles in such a way that other commands will
7164process these articles. For instance, if you process mark four
7165articles and then use the @kbd{*} command, Gnus will enter these four
7166articles into the cache. For more information,
7167@pxref{Process/Prefix}.
7168
7169@table @kbd
7170
7171@item M P p
7172@itemx #
7173@kindex # (Summary)
7174@kindex M P p (Summary)
7175@findex gnus-summary-mark-as-processable
7176Mark the current article with the process mark
7177(@code{gnus-summary-mark-as-processable}).
7178@findex gnus-summary-unmark-as-processable
7179
7180@item M P u
7181@itemx M-#
7182@kindex M P u (Summary)
7183@kindex M-# (Summary)
7184Remove the process mark, if any, from the current article
7185(@code{gnus-summary-unmark-as-processable}).
7186
7187@item M P U
7188@kindex M P U (Summary)
7189@findex gnus-summary-unmark-all-processable
7190Remove the process mark from all articles
7191(@code{gnus-summary-unmark-all-processable}).
7192
7193@item M P i
7194@kindex M P i (Summary)
7195@findex gnus-uu-invert-processable
7196Invert the list of process marked articles
7197(@code{gnus-uu-invert-processable}).
7198
7199@item M P R
7200@kindex M P R (Summary)
7201@findex gnus-uu-mark-by-regexp
7202Mark articles that have a @code{Subject} header that matches a regular
7203expression (@code{gnus-uu-mark-by-regexp}).
7204
7205@item M P G
7206@kindex M P G (Summary)
7207@findex gnus-uu-unmark-by-regexp
7208Unmark articles that have a @code{Subject} header that matches a regular
7209expression (@code{gnus-uu-unmark-by-regexp}).
7210
7211@item M P r
7212@kindex M P r (Summary)
7213@findex gnus-uu-mark-region
7214Mark articles in region (@code{gnus-uu-mark-region}).
7215
7216@item M P g
7217@kindex M P g (Summary)
7218@findex gnus-uu-unmark-region
7219Unmark articles in region (@code{gnus-uu-unmark-region}).
7220
7221@item M P t
7222@kindex M P t (Summary)
7223@findex gnus-uu-mark-thread
7224Mark all articles in the current (sub)thread
7225(@code{gnus-uu-mark-thread}).
7226
7227@item M P T
7228@kindex M P T (Summary)
7229@findex gnus-uu-unmark-thread
7230Unmark all articles in the current (sub)thread
7231(@code{gnus-uu-unmark-thread}).
7232
7233@item M P v
7234@kindex M P v (Summary)
7235@findex gnus-uu-mark-over
7236Mark all articles that have a score above the prefix argument
7237(@code{gnus-uu-mark-over}).
7238
7239@item M P s
7240@kindex M P s (Summary)
7241@findex gnus-uu-mark-series
7242Mark all articles in the current series (@code{gnus-uu-mark-series}).
7243
7244@item M P S
7245@kindex M P S (Summary)
7246@findex gnus-uu-mark-sparse
7247Mark all series that have already had some articles marked
7248(@code{gnus-uu-mark-sparse}).
7249
7250@item M P a
7251@kindex M P a (Summary)
7252@findex gnus-uu-mark-all
7253Mark all articles in series order (@code{gnus-uu-mark-all}).
7254
7255@item M P b
7256@kindex M P b (Summary)
7257@findex gnus-uu-mark-buffer
7258Mark all articles in the buffer in the order they appear
7259(@code{gnus-uu-mark-buffer}).
7260
7261@item M P k
7262@kindex M P k (Summary)
7263@findex gnus-summary-kill-process-mark
7264Push the current process mark set onto the stack and unmark all articles
7265(@code{gnus-summary-kill-process-mark}).
7266
7267@item M P y
7268@kindex M P y (Summary)
7269@findex gnus-summary-yank-process-mark
7270Pop the previous process mark set from the stack and restore it
7271(@code{gnus-summary-yank-process-mark}).
7272
7273@item M P w
7274@kindex M P w (Summary)
7275@findex gnus-summary-save-process-mark
7276Push the current process mark set onto the stack
7277(@code{gnus-summary-save-process-mark}).
7278
7279@end table
7280
7281Also see the @kbd{&} command in @ref{Searching for Articles}, for how to
7282set process marks based on article body contents.
7283
7284
7285@node Limiting
7286@section Limiting
7287@cindex limiting
7288
7289It can be convenient to limit the summary buffer to just show some
7290subset of the articles currently in the group. The effect most limit
7291commands have is to remove a few (or many) articles from the summary
7292buffer.
7293
26b9f88d
MB
7294Limiting commands work on subsets of the articles already fetched from
7295the servers. These commands don't query the server for additional
7296articles.
4009494e
GM
7297
7298@table @kbd
7299
7300@item / /
7301@itemx / s
7302@kindex / / (Summary)
7303@findex gnus-summary-limit-to-subject
7304Limit the summary buffer to articles that match some subject
7305(@code{gnus-summary-limit-to-subject}). If given a prefix, exclude
7306matching articles.
7307
7308@item / a
7309@kindex / a (Summary)
7310@findex gnus-summary-limit-to-author
7311Limit the summary buffer to articles that match some author
7312(@code{gnus-summary-limit-to-author}). If given a prefix, exclude
7313matching articles.
7314
01c52d31
MB
7315@item / R
7316@kindex / R (Summary)
7317@findex gnus-summary-limit-to-recipient
7318Limit the summary buffer to articles that match some recipient
7319(@code{gnus-summary-limit-to-recipient}). If given a prefix, exclude
7320matching articles.
7321
7322@item / A
7323@kindex / A (Summary)
7324@findex gnus-summary-limit-to-address
7325Limit the summary buffer to articles in which contents of From, To or Cc
7326header match a given address (@code{gnus-summary-limit-to-address}). If
7327given a prefix, exclude matching articles.
7328
7329@item / S
7330@kindex / S (Summary)
7331@findex gnus-summary-limit-to-singletons
7332Limit the summary buffer to articles that aren't part of any displayed
7333threads (@code{gnus-summary-limit-to-singletons}). If given a prefix,
7334limit to articles that are part of displayed threads.
7335
4009494e
GM
7336@item / x
7337@kindex / x (Summary)
7338@findex gnus-summary-limit-to-extra
7339Limit the summary buffer to articles that match one of the ``extra''
7340headers (@pxref{To From Newsgroups})
7341(@code{gnus-summary-limit-to-extra}). If given a prefix, exclude
7342matching articles.
7343
7344@item / u
7345@itemx x
7346@kindex / u (Summary)
7347@kindex x (Summary)
7348@findex gnus-summary-limit-to-unread
7349Limit the summary buffer to articles not marked as read
7350(@code{gnus-summary-limit-to-unread}). If given a prefix, limit the
7351buffer to articles strictly unread. This means that ticked and
7352dormant articles will also be excluded.
7353
7354@item / m
7355@kindex / m (Summary)
7356@findex gnus-summary-limit-to-marks
7357Ask for a mark and then limit to all articles that have been marked
7358with that mark (@code{gnus-summary-limit-to-marks}).
7359
7360@item / t
7361@kindex / t (Summary)
7362@findex gnus-summary-limit-to-age
7363Ask for a number and then limit the summary buffer to articles older than (or equal to) that number of days
7364(@code{gnus-summary-limit-to-age}). If given a prefix, limit to
7365articles younger than that number of days.
7366
7367@item / n
7368@kindex / n (Summary)
7369@findex gnus-summary-limit-to-articles
7370With prefix @samp{n}, limit the summary buffer to the next @samp{n}
7371articles. If not given a prefix, use the process marked articles
7372instead. (@code{gnus-summary-limit-to-articles}).
7373
7374@item / w
7375@kindex / w (Summary)
7376@findex gnus-summary-pop-limit
7377Pop the previous limit off the stack and restore it
7378(@code{gnus-summary-pop-limit}). If given a prefix, pop all limits off
7379the stack.
7380
7381@item / .
7382@kindex / . (Summary)
7383@findex gnus-summary-limit-to-unseen
7384Limit the summary buffer to the unseen articles
7385(@code{gnus-summary-limit-to-unseen}).
7386
7387@item / v
7388@kindex / v (Summary)
7389@findex gnus-summary-limit-to-score
7390Limit the summary buffer to articles that have a score at or above some
7391score (@code{gnus-summary-limit-to-score}).
7392
7393@item / p
7394@kindex / p (Summary)
7395@findex gnus-summary-limit-to-display-predicate
7396Limit the summary buffer to articles that satisfy the @code{display}
7397group parameter predicate
7398(@code{gnus-summary-limit-to-display-predicate}). @xref{Group
7399Parameters}, for more on this predicate.
7400
01c52d31
MB
7401@item / r
7402@kindex / r (Summary)
7403@findex gnus-summary-limit-to-replied
7404Limit the summary buffer to replied articles
7405(@code{gnus-summary-limit-to-replied}). If given a prefix, exclude
7406replied articles.
7407
4009494e
GM
7408@item / E
7409@itemx M S
7410@kindex M S (Summary)
7411@kindex / E (Summary)
7412@findex gnus-summary-limit-include-expunged
7413Include all expunged articles in the limit
7414(@code{gnus-summary-limit-include-expunged}).
7415
7416@item / D
7417@kindex / D (Summary)
7418@findex gnus-summary-limit-include-dormant
7419Include all dormant articles in the limit
7420(@code{gnus-summary-limit-include-dormant}).
7421
7422@item / *
7423@kindex / * (Summary)
7424@findex gnus-summary-limit-include-cached
7425Include all cached articles in the limit
7426(@code{gnus-summary-limit-include-cached}).
7427
7428@item / d
7429@kindex / d (Summary)
7430@findex gnus-summary-limit-exclude-dormant
7431Exclude all dormant articles from the limit
7432(@code{gnus-summary-limit-exclude-dormant}).
7433
7434@item / M
7435@kindex / M (Summary)
7436@findex gnus-summary-limit-exclude-marks
7437Exclude all marked articles (@code{gnus-summary-limit-exclude-marks}).
7438
7439@item / T
7440@kindex / T (Summary)
7441@findex gnus-summary-limit-include-thread
7442Include all the articles in the current thread in the limit.
7443
7444@item / c
7445@kindex / c (Summary)
7446@findex gnus-summary-limit-exclude-childless-dormant
7447Exclude all dormant articles that have no children from the limit@*
7448(@code{gnus-summary-limit-exclude-childless-dormant}).
7449
7450@item / C
7451@kindex / C (Summary)
7452@findex gnus-summary-limit-mark-excluded-as-read
7453Mark all excluded unread articles as read
7454(@code{gnus-summary-limit-mark-excluded-as-read}). If given a prefix,
7455also mark excluded ticked and dormant articles as read.
7456
01c52d31
MB
7457@item / b
7458@kindex / b (Summary)
7459@findex gnus-summary-limit-to-bodies
7460Limit the summary buffer to articles that have bodies that match a
7461certain regexp (@code{gnus-summary-limit-to-bodies}). If given a
7462prefix, reverse the limit. This command is quite slow since it
7463requires selecting each article to find the matches.
7464
7465@item / h
7466@kindex / h (Summary)
7467@findex gnus-summary-limit-to-headers
7468Like the previous command, only limit to headers instead
7469(@code{gnus-summary-limit-to-headers}).
7470
4009494e
GM
7471@end table
7472
7473
26b9f88d
MB
7474The following commands aren't limiting commands, but use the @kbd{/}
7475prefix as well.
7476
7477@table @kbd
7478@item / N
7479@kindex / N (Summary)
7480@findex gnus-summary-insert-new-articles
7481Insert all new articles in the summary buffer. It scans for new emails
7482if @var{back-end}@code{-get-new-mail} is non-@code{nil}.
7483
7484@item / o
7485@kindex / o (Summary)
7486@findex gnus-summary-insert-old-articles
7487Insert all old articles in the summary buffer. If given a numbered
7488prefix, fetch this number of articles.
7489
7490@end table
7491
7492
4009494e
GM
7493@node Threading
7494@section Threading
7495@cindex threading
7496@cindex article threading
7497
7498Gnus threads articles by default. @dfn{To thread} is to put responses
7499to articles directly after the articles they respond to---in a
7500hierarchical fashion.
7501
7502Threading is done by looking at the @code{References} headers of the
7503articles. In a perfect world, this would be enough to build pretty
7504trees, but unfortunately, the @code{References} header is often broken
7505or simply missing. Weird news propagation exacerbates the problem,
7506so one has to employ other heuristics to get pleasing results. A
7507plethora of approaches exists, as detailed in horrible detail in
7508@ref{Customizing Threading}.
7509
7510First, a quick overview of the concepts:
7511
7512@table @dfn
7513@item root
7514The top-most article in a thread; the first article in the thread.
7515
7516@item thread
7517A tree-like article structure.
7518
7519@item sub-thread
7520A small(er) section of this tree-like structure.
7521
7522@item loose threads
7523Threads often lose their roots due to article expiry, or due to the root
7524already having been read in a previous session, and not displayed in the
7525summary buffer. We then typically have many sub-threads that really
7526belong to one thread, but are without connecting roots. These are
7527called loose threads.
7528
7529@item thread gathering
7530An attempt to gather loose threads into bigger threads.
7531
7532@item sparse threads
7533A thread where the missing articles have been ``guessed'' at, and are
7534displayed as empty lines in the summary buffer.
7535
7536@end table
7537
7538
7539@menu
7540* Customizing Threading:: Variables you can change to affect the threading.
7541* Thread Commands:: Thread based commands in the summary buffer.
7542@end menu
7543
7544
7545@node Customizing Threading
7546@subsection Customizing Threading
7547@cindex customizing threading
7548
7549@menu
7550* Loose Threads:: How Gnus gathers loose threads into bigger threads.
7551* Filling In Threads:: Making the threads displayed look fuller.
7552* More Threading:: Even more variables for fiddling with threads.
7553* Low-Level Threading:: You thought it was over@dots{} but you were wrong!
7554@end menu
7555
7556
7557@node Loose Threads
7558@subsubsection Loose Threads
7559@cindex <
7560@cindex >
7561@cindex loose threads
7562
7563@table @code
7564@item gnus-summary-make-false-root
7565@vindex gnus-summary-make-false-root
7566If non-@code{nil}, Gnus will gather all loose subtrees into one big tree
7567and create a dummy root at the top. (Wait a minute. Root at the top?
7568Yup.) Loose subtrees occur when the real root has expired, or you've
7569read or killed the root in a previous session.
7570
7571When there is no real root of a thread, Gnus will have to fudge
7572something. This variable says what fudging method Gnus should use.
7573There are four possible values:
7574
7575@iftex
7576@iflatex
7577\gnusfigure{The Summary Buffer}{390}{
7578\put(0,0){\epsfig{figure=ps/summary-adopt,width=7.5cm}}
7579\put(445,0){\makebox(0,0)[br]{\epsfig{figure=ps/summary-empty,width=7.5cm}}}
7580\put(0,400){\makebox(0,0)[tl]{\epsfig{figure=ps/summary-none,width=7.5cm}}}
7581\put(445,400){\makebox(0,0)[tr]{\epsfig{figure=ps/summary-dummy,width=7.5cm}}}
7582}
7583@end iflatex
7584@end iftex
7585
7586@cindex adopting articles
7587
7588@table @code
7589
7590@item adopt
7591Gnus will make the first of the orphaned articles the parent. This
7592parent will adopt all the other articles. The adopted articles will be
7593marked as such by pointy brackets (@samp{<>}) instead of the standard
7594square brackets (@samp{[]}). This is the default method.
7595
7596@item dummy
7597@vindex gnus-summary-dummy-line-format
7598@vindex gnus-summary-make-false-root-always
7599Gnus will create a dummy summary line that will pretend to be the
7600parent. This dummy line does not correspond to any real article, so
7601selecting it will just select the first real article after the dummy
7602article. @code{gnus-summary-dummy-line-format} is used to specify the
7603format of the dummy roots. It accepts only one format spec: @samp{S},
7604which is the subject of the article. @xref{Formatting Variables}.
7605If you want all threads to have a dummy root, even the non-gathered
7606ones, set @code{gnus-summary-make-false-root-always} to @code{t}.
7607
7608@item empty
7609Gnus won't actually make any article the parent, but simply leave the
7610subject field of all orphans except the first empty. (Actually, it will
7611use @code{gnus-summary-same-subject} as the subject (@pxref{Summary
7612Buffer Format}).)
7613
7614@item none
7615Don't make any article parent at all. Just gather the threads and
7616display them after one another.
7617
7618@item nil
7619Don't gather loose threads.
7620@end table
7621
7622@item gnus-summary-gather-subject-limit
7623@vindex gnus-summary-gather-subject-limit
7624Loose threads are gathered by comparing subjects of articles. If this
7625variable is @code{nil}, Gnus requires an exact match between the
7626subjects of the loose threads before gathering them into one big
7627super-thread. This might be too strict a requirement, what with the
7628presence of stupid newsreaders that chop off long subject lines. If
7629you think so, set this variable to, say, 20 to require that only the
7630first 20 characters of the subjects have to match. If you set this
7631variable to a really low number, you'll find that Gnus will gather
7632everything in sight into one thread, which isn't very helpful.
7633
7634@cindex fuzzy article gathering
7635If you set this variable to the special value @code{fuzzy}, Gnus will
7636use a fuzzy string comparison algorithm on the subjects (@pxref{Fuzzy
7637Matching}).
7638
7639@item gnus-simplify-subject-fuzzy-regexp
7640@vindex gnus-simplify-subject-fuzzy-regexp
7641This can either be a regular expression or list of regular expressions
7642that match strings that will be removed from subjects if fuzzy subject
7643simplification is used.
7644
7645@item gnus-simplify-ignored-prefixes
7646@vindex gnus-simplify-ignored-prefixes
7647If you set @code{gnus-summary-gather-subject-limit} to something as low
7648as 10, you might consider setting this variable to something sensible:
7649
7650@c Written by Michael Ernst <mernst@cs.rice.edu>
7651@lisp
7652(setq gnus-simplify-ignored-prefixes
7653 (concat
7654 "\\`\\[?\\("
7655 (mapconcat
7656 'identity
7657 '("looking"
7658 "wanted" "followup" "summary\\( of\\)?"
7659 "help" "query" "problem" "question"
7660 "answer" "reference" "announce"
7661 "How can I" "How to" "Comparison of"
7662 ;; ...
7663 )
7664 "\\|")
7665 "\\)\\s *\\("
7666 (mapconcat 'identity
7667 '("for" "for reference" "with" "about")
7668 "\\|")
7669 "\\)?\\]?:?[ \t]*"))
7670@end lisp
7671
7672All words that match this regexp will be removed before comparing two
7673subjects.
7674
7675@item gnus-simplify-subject-functions
7676@vindex gnus-simplify-subject-functions
7677If non-@code{nil}, this variable overrides
7678@code{gnus-summary-gather-subject-limit}. This variable should be a
7679list of functions to apply to the @code{Subject} string iteratively to
7680arrive at the simplified version of the string.
7681
7682Useful functions to put in this list include:
7683
7684@table @code
7685@item gnus-simplify-subject-re
7686@findex gnus-simplify-subject-re
7687Strip the leading @samp{Re:}.
7688
7689@item gnus-simplify-subject-fuzzy
7690@findex gnus-simplify-subject-fuzzy
7691Simplify fuzzily.
7692
7693@item gnus-simplify-whitespace
7694@findex gnus-simplify-whitespace
7695Remove excessive whitespace.
7696
7697@item gnus-simplify-all-whitespace
7698@findex gnus-simplify-all-whitespace
7699Remove all whitespace.
7700@end table
7701
7702You may also write your own functions, of course.
7703
7704
7705@item gnus-summary-gather-exclude-subject
7706@vindex gnus-summary-gather-exclude-subject
7707Since loose thread gathering is done on subjects only, that might lead
7708to many false hits, especially with certain common subjects like
7709@samp{} and @samp{(none)}. To make the situation slightly better,
7710you can use the regexp @code{gnus-summary-gather-exclude-subject} to say
7711what subjects should be excluded from the gathering process.@*
7712The default is @samp{^ *$\\|^(none)$}.
7713
7714@item gnus-summary-thread-gathering-function
7715@vindex gnus-summary-thread-gathering-function
7716Gnus gathers threads by looking at @code{Subject} headers. This means
7717that totally unrelated articles may end up in the same ``thread'', which
7718is confusing. An alternate approach is to look at all the
7719@code{Message-ID}s in all the @code{References} headers to find matches.
7720This will ensure that no gathered threads ever include unrelated
7721articles, but it also means that people who have posted with broken
7722newsreaders won't be gathered properly. The choice is yours---plague or
7723cholera:
7724
7725@table @code
7726@item gnus-gather-threads-by-subject
7727@findex gnus-gather-threads-by-subject
7728This function is the default gathering function and looks at
7729@code{Subject}s exclusively.
7730
7731@item gnus-gather-threads-by-references
7732@findex gnus-gather-threads-by-references
7733This function looks at @code{References} headers exclusively.
7734@end table
7735
7736If you want to test gathering by @code{References}, you could say
7737something like:
7738
7739@lisp
7740(setq gnus-summary-thread-gathering-function
7741 'gnus-gather-threads-by-references)
7742@end lisp
7743
7744@end table
7745
7746
7747@node Filling In Threads
7748@subsubsection Filling In Threads
7749
7750@table @code
7751@item gnus-fetch-old-headers
7752@vindex gnus-fetch-old-headers
7753If non-@code{nil}, Gnus will attempt to build old threads by fetching
7754more old headers---headers to articles marked as read. If you would
7755like to display as few summary lines as possible, but still connect as
7756many loose threads as possible, you should set this variable to
7757@code{some} or a number. If you set it to a number, no more than that
7758number of extra old headers will be fetched. In either case, fetching
7759old headers only works if the back end you are using carries overview
7760files---this would normally be @code{nntp}, @code{nnspool},
7761@code{nnml}, and @code{nnmaildir}. Also remember that if the root of
7762the thread has been expired by the server, there's not much Gnus can
7763do about that.
7764
7765This variable can also be set to @code{invisible}. This won't have any
7766visible effects, but is useful if you use the @kbd{A T} command a lot
7767(@pxref{Finding the Parent}).
7768
f394fa25
MB
7769The server has to support @acronym{NOV} for any of this to work.
7770
7771@cindex Gmane, gnus-fetch-old-headers
7772This feature can seriously impact performance it ignores all locally
7773cached header entries. Setting it to @code{t} for groups for a server
7774that doesn't expire articles (such as news.gmane.org), leads to very
7775slow summary generation.
7776
4009494e
GM
7777@item gnus-fetch-old-ephemeral-headers
7778@vindex gnus-fetch-old-ephemeral-headers
7779Same as @code{gnus-fetch-old-headers}, but only used for ephemeral
7780newsgroups.
7781
7782@item gnus-build-sparse-threads
7783@vindex gnus-build-sparse-threads
7784Fetching old headers can be slow. A low-rent similar effect can be
7785gotten by setting this variable to @code{some}. Gnus will then look at
7786the complete @code{References} headers of all articles and try to string
7787together articles that belong in the same thread. This will leave
7788@dfn{gaps} in the threading display where Gnus guesses that an article
7789is missing from the thread. (These gaps appear like normal summary
7790lines. If you select a gap, Gnus will try to fetch the article in
7791question.) If this variable is @code{t}, Gnus will display all these
7792``gaps'' without regard for whether they are useful for completing the
7793thread or not. Finally, if this variable is @code{more}, Gnus won't cut
7794off sparse leaf nodes that don't lead anywhere. This variable is
7795@code{nil} by default.
7796
7797@item gnus-read-all-available-headers
7798@vindex gnus-read-all-available-headers
7799This is a rather obscure variable that few will find useful. It's
7800intended for those non-news newsgroups where the back end has to fetch
7801quite a lot to present the summary buffer, and where it's impossible to
7802go back to parents of articles. This is mostly the case in the
c4d82de8 7803web-based groups.
4009494e
GM
7804
7805If you don't use those, then it's safe to leave this as the default
7806@code{nil}. If you want to use this variable, it should be a regexp
7807that matches the group name, or @code{t} for all groups.
7808
7809@end table
7810
7811
7812@node More Threading
7813@subsubsection More Threading
7814
7815@table @code
7816@item gnus-show-threads
7817@vindex gnus-show-threads
7818If this variable is @code{nil}, no threading will be done, and all of
7819the rest of the variables here will have no effect. Turning threading
7820off will speed group selection up a bit, but it is sure to make reading
7821slower and more awkward.
7822
7823@item gnus-thread-hide-subtree
7824@vindex gnus-thread-hide-subtree
7825If non-@code{nil}, all threads will be hidden when the summary buffer is
7826generated.
7827
7828This can also be a predicate specifier (@pxref{Predicate Specifiers}).
7829Available predicates are @code{gnus-article-unread-p} and
7830@code{gnus-article-unseen-p}.
7831
7832Here's an example:
7833
7834@lisp
7835(setq gnus-thread-hide-subtree
7836 '(or gnus-article-unread-p
7837 gnus-article-unseen-p))
7838@end lisp
7839
7840(It's a pretty nonsensical example, since all unseen articles are also
7841unread, but you get my drift.)
7842
7843
7844@item gnus-thread-expunge-below
7845@vindex gnus-thread-expunge-below
7846All threads that have a total score (as defined by
7847@code{gnus-thread-score-function}) less than this number will be
7848expunged. This variable is @code{nil} by default, which means that no
7849threads are expunged.
7850
7851@item gnus-thread-hide-killed
7852@vindex gnus-thread-hide-killed
7853if you kill a thread and this variable is non-@code{nil}, the subtree
7854will be hidden.
7855
7856@item gnus-thread-ignore-subject
7857@vindex gnus-thread-ignore-subject
7858Sometimes somebody changes the subject in the middle of a thread. If
7859this variable is non-@code{nil}, which is the default, the subject
7860change is ignored. If it is @code{nil}, a change in the subject will
7861result in a new thread.
7862
7863@item gnus-thread-indent-level
7864@vindex gnus-thread-indent-level
7865This is a number that says how much each sub-thread should be indented.
7866The default is 4.
7867
7868@item gnus-sort-gathered-threads-function
7869@vindex gnus-sort-gathered-threads-function
7870Sometimes, particularly with mailing lists, the order in which mails
7871arrive locally is not necessarily the same as the order in which they
7872arrived on the mailing list. Consequently, when sorting sub-threads
7873using the default @code{gnus-thread-sort-by-number}, responses can end
7874up appearing before the article to which they are responding to.
7875Setting this variable to an alternate value
7876(e.g. @code{gnus-thread-sort-by-date}), in a group's parameters or in an
7877appropriate hook (e.g. @code{gnus-summary-generate-hook}) can produce a
7878more logical sub-thread ordering in such instances.
7879
7880@end table
7881
7882
7883@node Low-Level Threading
7884@subsubsection Low-Level Threading
7885
7886@table @code
7887
7888@item gnus-parse-headers-hook
7889@vindex gnus-parse-headers-hook
7890Hook run before parsing any headers.
7891
7892@item gnus-alter-header-function
7893@vindex gnus-alter-header-function
7894If non-@code{nil}, this function will be called to allow alteration of
7895article header structures. The function is called with one parameter,
7896the article header vector, which it may alter in any way. For instance,
7897if you have a mail-to-news gateway which alters the @code{Message-ID}s
7898in systematic ways (by adding prefixes and such), you can use this
7899variable to un-scramble the @code{Message-ID}s so that they are more
7900meaningful. Here's one example:
7901
7902@lisp
7903(setq gnus-alter-header-function 'my-alter-message-id)
7904
7905(defun my-alter-message-id (header)
7906 (let ((id (mail-header-id header)))
7907 (when (string-match
7908 "\\(<[^<>@@]*\\)\\.?cygnus\\..*@@\\([^<>@@]*>\\)" id)
7909 (mail-header-set-id
7910 (concat (match-string 1 id) "@@" (match-string 2 id))
7911 header))))
7912@end lisp
7913
7914@end table
7915
7916
7917@node Thread Commands
7918@subsection Thread Commands
7919@cindex thread commands
7920
7921@table @kbd
7922
7923@item T k
7924@itemx C-M-k
7925@kindex T k (Summary)
7926@kindex C-M-k (Summary)
7927@findex gnus-summary-kill-thread
7928Mark all articles in the current (sub-)thread as read
7929(@code{gnus-summary-kill-thread}). If the prefix argument is positive,
7930remove all marks instead. If the prefix argument is negative, tick
7931articles instead.
7932
7933@item T l
7934@itemx C-M-l
7935@kindex T l (Summary)
7936@kindex C-M-l (Summary)
7937@findex gnus-summary-lower-thread
7938Lower the score of the current (sub-)thread
7939(@code{gnus-summary-lower-thread}).
7940
7941@item T i
7942@kindex T i (Summary)
7943@findex gnus-summary-raise-thread
7944Increase the score of the current (sub-)thread
7945(@code{gnus-summary-raise-thread}).
7946
7947@item T #
7948@kindex T # (Summary)
7949@findex gnus-uu-mark-thread
7950Set the process mark on the current (sub-)thread
7951(@code{gnus-uu-mark-thread}).
7952
7953@item T M-#
7954@kindex T M-# (Summary)
7955@findex gnus-uu-unmark-thread
7956Remove the process mark from the current (sub-)thread
7957(@code{gnus-uu-unmark-thread}).
7958
7959@item T T
7960@kindex T T (Summary)
7961@findex gnus-summary-toggle-threads
7962Toggle threading (@code{gnus-summary-toggle-threads}).
7963
7964@item T s
7965@kindex T s (Summary)
7966@findex gnus-summary-show-thread
7967Expose the (sub-)thread hidden under the current article, if any@*
7968(@code{gnus-summary-show-thread}).
7969
7970@item T h
7971@kindex T h (Summary)
7972@findex gnus-summary-hide-thread
7973Hide the current (sub-)thread (@code{gnus-summary-hide-thread}).
7974
7975@item T S
7976@kindex T S (Summary)
7977@findex gnus-summary-show-all-threads
7978Expose all hidden threads (@code{gnus-summary-show-all-threads}).
7979
7980@item T H
7981@kindex T H (Summary)
7982@findex gnus-summary-hide-all-threads
7983Hide all threads (@code{gnus-summary-hide-all-threads}).
7984
7985@item T t
7986@kindex T t (Summary)
7987@findex gnus-summary-rethread-current
7988Re-thread the current article's thread
7989(@code{gnus-summary-rethread-current}). This works even when the
7990summary buffer is otherwise unthreaded.
7991
7992@item T ^
7993@kindex T ^ (Summary)
7994@findex gnus-summary-reparent-thread
7995Make the current article the child of the marked (or previous) article
7996(@code{gnus-summary-reparent-thread}).
7997
01c52d31
MB
7998@item T M-^
7999@kindex T M-^ (Summary)
8000@findex gnus-summary-reparent-children
8001Make the current article the parent of the marked articles
8002(@code{gnus-summary-reparent-children}).
8003
4009494e
GM
8004@end table
8005
8006The following commands are thread movement commands. They all
8007understand the numeric prefix.
8008
8009@table @kbd
8010
8011@item T n
8012@kindex T n (Summary)
8013@itemx C-M-f
8014@kindex C-M-n (Summary)
8015@itemx M-down
8016@kindex M-down (Summary)
8017@findex gnus-summary-next-thread
8018Go to the next thread (@code{gnus-summary-next-thread}).
8019
8020@item T p
8021@kindex T p (Summary)
8022@itemx C-M-b
8023@kindex C-M-p (Summary)
8024@itemx M-up
8025@kindex M-up (Summary)
8026@findex gnus-summary-prev-thread
8027Go to the previous thread (@code{gnus-summary-prev-thread}).
8028
8029@item T d
8030@kindex T d (Summary)
8031@findex gnus-summary-down-thread
8032Descend the thread (@code{gnus-summary-down-thread}).
8033
8034@item T u
8035@kindex T u (Summary)
8036@findex gnus-summary-up-thread
8037Ascend the thread (@code{gnus-summary-up-thread}).
8038
8039@item T o
8040@kindex T o (Summary)
8041@findex gnus-summary-top-thread
8042Go to the top of the thread (@code{gnus-summary-top-thread}).
8043@end table
8044
8045@vindex gnus-thread-operation-ignore-subject
8046If you ignore subject while threading, you'll naturally end up with
8047threads that have several different subjects in them. If you then issue
8048a command like @kbd{T k} (@code{gnus-summary-kill-thread}) you might not
8049wish to kill the entire thread, but just those parts of the thread that
8050have the same subject as the current article. If you like this idea,
8051you can fiddle with @code{gnus-thread-operation-ignore-subject}. If it
8052is non-@code{nil} (which it is by default), subjects will be ignored
8053when doing thread commands. If this variable is @code{nil}, articles in
8054the same thread with different subjects will not be included in the
8055operation in question. If this variable is @code{fuzzy}, only articles
8056that have subjects fuzzily equal will be included (@pxref{Fuzzy
8057Matching}).
8058
8059
8060@node Sorting the Summary Buffer
8061@section Sorting the Summary Buffer
8062
8063@findex gnus-thread-sort-by-total-score
8064@findex gnus-thread-sort-by-date
8065@findex gnus-thread-sort-by-score
8066@findex gnus-thread-sort-by-subject
8067@findex gnus-thread-sort-by-author
01c52d31 8068@findex gnus-thread-sort-by-recipient
4009494e
GM
8069@findex gnus-thread-sort-by-number
8070@findex gnus-thread-sort-by-random
8071@vindex gnus-thread-sort-functions
8072@findex gnus-thread-sort-by-most-recent-number
8073@findex gnus-thread-sort-by-most-recent-date
8074If you are using a threaded summary display, you can sort the threads by
8075setting @code{gnus-thread-sort-functions}, which can be either a single
8076function, a list of functions, or a list containing functions and
8077@code{(not some-function)} elements.
8078
8079By default, sorting is done on article numbers. Ready-made sorting
8080predicate functions include @code{gnus-thread-sort-by-number},
01c52d31
MB
8081@code{gnus-thread-sort-by-author}, @code{gnus-thread-sort-by-recipient},
8082@code{gnus-thread-sort-by-subject},
8083@code{gnus-thread-sort-by-date},
8084@code{gnus-thread-sort-by-score},
4009494e
GM
8085@code{gnus-thread-sort-by-most-recent-number},
8086@code{gnus-thread-sort-by-most-recent-date},
8087@code{gnus-thread-sort-by-random} and
8088@code{gnus-thread-sort-by-total-score}.
8089
8090Each function takes two threads and returns non-@code{nil} if the first
8091thread should be sorted before the other. Note that sorting really is
8092normally done by looking only at the roots of each thread.
8093
8094If you use more than one function, the primary sort key should be the
8095last function in the list. You should probably always include
8096@code{gnus-thread-sort-by-number} in the list of sorting
8097functions---preferably first. This will ensure that threads that are
8098equal with respect to the other sort criteria will be displayed in
8099ascending article order.
8100
8101If you would like to sort by reverse score, then by subject, and finally
8102by number, you could do something like:
8103
8104@lisp
8105(setq gnus-thread-sort-functions
8106 '(gnus-thread-sort-by-number
8107 gnus-thread-sort-by-subject
8108 (not gnus-thread-sort-by-total-score)))
8109@end lisp
8110
8111The threads that have highest score will be displayed first in the
8112summary buffer. When threads have the same score, they will be sorted
8113alphabetically. The threads that have the same score and the same
8114subject will be sorted by number, which is (normally) the sequence in
8115which the articles arrived.
8116
8117If you want to sort by score and then reverse arrival order, you could
8118say something like:
8119
8120@lisp
8121(setq gnus-thread-sort-functions
01c52d31 8122 '((not gnus-thread-sort-by-number)
4009494e
GM
8123 gnus-thread-sort-by-score))
8124@end lisp
8125
8126@vindex gnus-thread-score-function
8127The function in the @code{gnus-thread-score-function} variable (default
8128@code{+}) is used for calculating the total score of a thread. Useful
8129functions might be @code{max}, @code{min}, or squared means, or whatever
8130tickles your fancy.
8131
8132@findex gnus-article-sort-functions
8133@findex gnus-article-sort-by-date
6ecfe5c2 8134@findex gnus-article-sort-by-most-recent-date
4009494e
GM
8135@findex gnus-article-sort-by-score
8136@findex gnus-article-sort-by-subject
8137@findex gnus-article-sort-by-author
8138@findex gnus-article-sort-by-random
8139@findex gnus-article-sort-by-number
6ecfe5c2 8140@findex gnus-article-sort-by-most-recent-number
4009494e
GM
8141If you are using an unthreaded display for some strange reason or
8142other, you have to fiddle with the @code{gnus-article-sort-functions}
8143variable. It is very similar to the
8144@code{gnus-thread-sort-functions}, except that it uses slightly
8145different functions for article comparison. Available sorting
8146predicate functions are @code{gnus-article-sort-by-number},
8147@code{gnus-article-sort-by-author},
8148@code{gnus-article-sort-by-subject}, @code{gnus-article-sort-by-date},
8149@code{gnus-article-sort-by-random}, and
8150@code{gnus-article-sort-by-score}.
8151
8152If you want to sort an unthreaded summary display by subject, you could
8153say something like:
8154
8155@lisp
8156(setq gnus-article-sort-functions
8157 '(gnus-article-sort-by-number
8158 gnus-article-sort-by-subject))
8159@end lisp
8160
01c52d31
MB
8161You can define group specific sorting via @code{gnus-parameters},
8162@xref{Group Parameters}.
4009494e
GM
8163
8164
8165@node Asynchronous Fetching
8166@section Asynchronous Article Fetching
8167@cindex asynchronous article fetching
8168@cindex article pre-fetch
8169@cindex pre-fetch
8170
8171If you read your news from an @acronym{NNTP} server that's far away, the
8172network latencies may make reading articles a chore. You have to wait
8173for a while after pressing @kbd{n} to go to the next article before the
8174article appears. Why can't Gnus just go ahead and fetch the article
8175while you are reading the previous one? Why not, indeed.
8176
8177First, some caveats. There are some pitfalls to using asynchronous
8178article fetching, especially the way Gnus does it.
8179
8180Let's say you are reading article 1, which is short, and article 2 is
8181quite long, and you are not interested in reading that. Gnus does not
8182know this, so it goes ahead and fetches article 2. You decide to read
8183article 3, but since Gnus is in the process of fetching article 2, the
8184connection is blocked.
8185
8186To avoid these situations, Gnus will open two (count 'em two)
8187connections to the server. Some people may think this isn't a very nice
8188thing to do, but I don't see any real alternatives. Setting up that
8189extra connection takes some time, so Gnus startup will be slower.
8190
8191Gnus will fetch more articles than you will read. This will mean that
8192the link between your machine and the @acronym{NNTP} server will become more
8193loaded than if you didn't use article pre-fetch. The server itself will
8194also become more loaded---both with the extra article requests, and the
8195extra connection.
8196
8197Ok, so now you know that you shouldn't really use this thing@dots{} unless
8198you really want to.
8199
8200@vindex gnus-asynchronous
8201Here's how: Set @code{gnus-asynchronous} to @code{t}. The rest should
8202happen automatically.
8203
8204@vindex gnus-use-article-prefetch
8205You can control how many articles are to be pre-fetched by setting
8206@code{gnus-use-article-prefetch}. This is 30 by default, which means
8207that when you read an article in the group, the back end will pre-fetch
8208the next 30 articles. If this variable is @code{t}, the back end will
8209pre-fetch all the articles it can without bound. If it is
8210@code{nil}, no pre-fetching will be done.
8211
8212@vindex gnus-async-prefetch-article-p
8213@findex gnus-async-unread-p
8214There are probably some articles that you don't want to pre-fetch---read
8215articles, for instance. The @code{gnus-async-prefetch-article-p}
8216variable controls whether an article is to be pre-fetched. This
8217function should return non-@code{nil} when the article in question is
8218to be pre-fetched. The default is @code{gnus-async-unread-p}, which
8219returns @code{nil} on read articles. The function is called with an
8220article data structure as the only parameter.
8221
8222If, for instance, you wish to pre-fetch only unread articles shorter
8223than 100 lines, you could say something like:
8224
8225@lisp
8226(defun my-async-short-unread-p (data)
8227 "Return non-nil for short, unread articles."
8228 (and (gnus-data-unread-p data)
8229 (< (mail-header-lines (gnus-data-header data))
8230 100)))
8231
8232(setq gnus-async-prefetch-article-p 'my-async-short-unread-p)
8233@end lisp
8234
8235These functions will be called many, many times, so they should
8236preferably be short and sweet to avoid slowing down Gnus too much.
8237It's probably a good idea to byte-compile things like this.
8238
85115796
KY
8239@vindex gnus-async-post-fetch-function
8240@findex gnus-html-prefetch-images
8241After an article has been prefetched, this
8242@code{gnus-async-post-fetch-function} will be called. The buffer will
8243be narrowed to the region of the article that was fetched. A useful
8244value would be @code{gnus-html-prefetch-images}, which will prefetch
8245and store images referenced in the article, so that you don't have to
8246wait for them to be fetched when you read the article. This is useful
8247for @acronym{HTML} messages that have external images.
8248
4009494e
GM
8249@vindex gnus-prefetched-article-deletion-strategy
8250Articles have to be removed from the asynch buffer sooner or later. The
8251@code{gnus-prefetched-article-deletion-strategy} says when to remove
8252articles. This is a list that may contain the following elements:
8253
8254@table @code
8255@item read
8256Remove articles when they are read.
8257
8258@item exit
8259Remove articles when exiting the group.
8260@end table
8261
8262The default value is @code{(read exit)}.
8263
8264@c @vindex gnus-use-header-prefetch
8265@c If @code{gnus-use-header-prefetch} is non-@code{nil}, prefetch articles
8266@c from the next group.
8267
8268
8269@node Article Caching
8270@section Article Caching
8271@cindex article caching
8272@cindex caching
8273
8274If you have an @emph{extremely} slow @acronym{NNTP} connection, you may
8275consider turning article caching on. Each article will then be stored
8276locally under your home directory. As you may surmise, this could
8277potentially use @emph{huge} amounts of disk space, as well as eat up all
8278your inodes so fast it will make your head swim. In vodka.
8279
8280Used carefully, though, it could be just an easier way to save articles.
8281
8282@vindex gnus-use-long-file-name
8283@vindex gnus-cache-directory
8284@vindex gnus-use-cache
8285To turn caching on, set @code{gnus-use-cache} to @code{t}. By default,
8286all articles ticked or marked as dormant will then be copied
8287over to your local cache (@code{gnus-cache-directory}). Whether this
8288cache is flat or hierarchical is controlled by the
8289@code{gnus-use-long-file-name} variable, as usual.
8290
8291When re-selecting a ticked or dormant article, it will be fetched from the
8292cache instead of from the server. As articles in your cache will never
8293expire, this might serve as a method of saving articles while still
8294keeping them where they belong. Just mark all articles you want to save
8295as dormant, and don't worry.
8296
8297When an article is marked as read, is it removed from the cache.
8298
8299@vindex gnus-cache-remove-articles
8300@vindex gnus-cache-enter-articles
8301The entering/removal of articles from the cache is controlled by the
8302@code{gnus-cache-enter-articles} and @code{gnus-cache-remove-articles}
8303variables. Both are lists of symbols. The first is @code{(ticked
8304dormant)} by default, meaning that ticked and dormant articles will be
8305put in the cache. The latter is @code{(read)} by default, meaning that
8306articles marked as read are removed from the cache. Possibly
8307symbols in these two lists are @code{ticked}, @code{dormant},
8308@code{unread} and @code{read}.
8309
8310@findex gnus-jog-cache
8311So where does the massive article-fetching and storing come into the
8312picture? The @code{gnus-jog-cache} command will go through all
8313subscribed newsgroups, request all unread articles, score them, and
8314store them in the cache. You should only ever, ever ever ever, use this
8315command if 1) your connection to the @acronym{NNTP} server is really, really,
8316really slow and 2) you have a really, really, really huge disk.
8317Seriously. One way to cut down on the number of articles downloaded is
8318to score unwanted articles down and have them marked as read. They will
8319not then be downloaded by this command.
8320
8321@vindex gnus-uncacheable-groups
8322@vindex gnus-cacheable-groups
8323It is likely that you do not want caching on all groups. For instance,
8324if your @code{nnml} mail is located under your home directory, it makes no
8325sense to cache it somewhere else under your home directory. Unless you
8326feel that it's neat to use twice as much space.
8327
8328To limit the caching, you could set @code{gnus-cacheable-groups} to a
8329regexp of groups to cache, @samp{^nntp} for instance, or set the
8330@code{gnus-uncacheable-groups} regexp to @samp{^nnml}, for instance.
8331Both variables are @code{nil} by default. If a group matches both
8332variables, the group is not cached.
8333
8334@findex gnus-cache-generate-nov-databases
8335@findex gnus-cache-generate-active
8336@vindex gnus-cache-active-file
8337The cache stores information on what articles it contains in its active
8338file (@code{gnus-cache-active-file}). If this file (or any other parts
8339of the cache) becomes all messed up for some reason or other, Gnus
8340offers two functions that will try to set things right. @kbd{M-x
8341gnus-cache-generate-nov-databases} will (re)build all the @acronym{NOV}
8342files, and @kbd{gnus-cache-generate-active} will (re)generate the active
8343file.
8344
8345@findex gnus-cache-move-cache
8346@code{gnus-cache-move-cache} will move your whole
8347@code{gnus-cache-directory} to some other location. You get asked to
8348where, isn't that cool?
8349
8350@node Persistent Articles
8351@section Persistent Articles
8352@cindex persistent articles
8353
8354Closely related to article caching, we have @dfn{persistent articles}.
8355In fact, it's just a different way of looking at caching, and much more
8356useful in my opinion.
8357
8358Say you're reading a newsgroup, and you happen on to some valuable gem
8359that you want to keep and treasure forever. You'd normally just save it
8360(using one of the many saving commands) in some file. The problem with
8361that is that it's just, well, yucky. Ideally you'd prefer just having
8362the article remain in the group where you found it forever; untouched by
8363the expiry going on at the news server.
8364
8365This is what a @dfn{persistent article} is---an article that just won't
8366be deleted. It's implemented using the normal cache functions, but
8367you use two explicit commands for managing persistent articles:
8368
8369@table @kbd
8370
8371@item *
8372@kindex * (Summary)
8373@findex gnus-cache-enter-article
8374Make the current article persistent (@code{gnus-cache-enter-article}).
8375
8376@item M-*
8377@kindex M-* (Summary)
8378@findex gnus-cache-remove-article
8379Remove the current article from the persistent articles
8380(@code{gnus-cache-remove-article}). This will normally delete the
8381article.
8382@end table
8383
8384Both these commands understand the process/prefix convention.
8385
8386To avoid having all ticked articles (and stuff) entered into the cache,
8387you should set @code{gnus-use-cache} to @code{passive} if you're just
8388interested in persistent articles:
8389
8390@lisp
8391(setq gnus-use-cache 'passive)
8392@end lisp
8393
01c52d31
MB
8394@node Sticky Articles
8395@section Sticky Articles
8396@cindex sticky articles
8397
8398When you select an article the current article buffer will be reused
8399according to the value of the variable
8400@code{gnus-single-article-buffer}. If its value is non-@code{nil} (the
8401default) all articles reuse the same article buffer. Else each group
8402has its own article buffer.
8403
8404This implies that it's not possible to have more than one article buffer
8405in a group at a time. But sometimes you might want to display all the
8406latest emails from your mother, your father, your aunt, your uncle and
8407your 17 cousins to coordinate the next christmas party.
8408
8409That's where sticky articles come in handy. A sticky article buffer
8410basically is a normal article buffer, but it won't be reused when you
8411select another article. You can make an article sticky with:
8412
8413@table @kbd
8414@item A S
8415@kindex A S (Summary)
8416@findex gnus-sticky-article
8417Make the current article sticky. If a prefix arg is given, ask for a
8418name for this sticky article buffer.
8419@end table
8420
8421To close a sticky article buffer you can use these commands:
8422
8423@table @kbd
8424@item q
8425@kindex q (Article)
8426@findex bury-buffer
8427Puts this sticky article buffer at the end of the list of all buffers.
8428
8429@item k
8430@kindex k (Article)
8431@findex gnus-kill-sticky-article-buffer
8432Kills this sticky article buffer.
8433@end table
8434
8435To kill all sticky article buffers you can use:
8436
8437@defun gnus-kill-sticky-article-buffers ARG
8438Kill all sticky article buffers.
8439If a prefix ARG is given, ask for confirmation.
8440@end defun
4009494e
GM
8441
8442@node Article Backlog
8443@section Article Backlog
8444@cindex backlog
8445@cindex article backlog
8446
8447If you have a slow connection, but the idea of using caching seems
8448unappealing to you (and it is, really), you can help the situation some
8449by switching on the @dfn{backlog}. This is where Gnus will buffer
8450already read articles so that it doesn't have to re-fetch articles
8451you've already read. This only helps if you are in the habit of
8452re-selecting articles you've recently read, of course. If you never do
8453that, turning the backlog on will slow Gnus down a little bit, and
8454increase memory usage some.
8455
8456@vindex gnus-keep-backlog
8457If you set @code{gnus-keep-backlog} to a number @var{n}, Gnus will store
8458at most @var{n} old articles in a buffer for later re-fetching. If this
8459variable is non-@code{nil} and is not a number, Gnus will store
8460@emph{all} read articles, which means that your Emacs will grow without
8461bound before exploding and taking your machine down with you. I put
8462that in there just to keep y'all on your toes.
8463
8464The default value is 20.
8465
8466
8467@node Saving Articles
8468@section Saving Articles
8469@cindex saving articles
8470
8471Gnus can save articles in a number of ways. Below is the documentation
8472for saving articles in a fairly straight-forward fashion (i.e., little
8473processing of the article is done before it is saved). For a different
8474approach (uudecoding, unsharing) you should use @code{gnus-uu}
8475(@pxref{Decoding Articles}).
8476
8477For the commands listed here, the target is a file. If you want to
8478save to a group, see the @kbd{B c} (@code{gnus-summary-copy-article})
8479command (@pxref{Mail Group Commands}).
8480
8481@vindex gnus-save-all-headers
8482If @code{gnus-save-all-headers} is non-@code{nil}, Gnus will not delete
8483unwanted headers before saving the article.
8484
8485@vindex gnus-saved-headers
8486If the preceding variable is @code{nil}, all headers that match the
8487@code{gnus-saved-headers} regexp will be kept, while the rest will be
8488deleted before saving.
8489
8490@table @kbd
8491
8492@item O o
8493@itemx o
8494@kindex O o (Summary)
8495@kindex o (Summary)
8496@findex gnus-summary-save-article
8497@c @icon{gnus-summary-save-article}
8498Save the current article using the default article saver
8499(@code{gnus-summary-save-article}).
8500
8501@item O m
8502@kindex O m (Summary)
8503@findex gnus-summary-save-article-mail
8504Save the current article in a Unix mail box (mbox) file
8505(@code{gnus-summary-save-article-mail}).
8506
8507@item O r
8508@kindex O r (Summary)
8509@findex gnus-summary-save-article-rmail
8510Save the current article in Rmail format
bc79f9ab
GM
8511(@code{gnus-summary-save-article-rmail}). This is mbox since Emacs 23,
8512Babyl in older versions.
4009494e
GM
8513
8514@item O f
8515@kindex O f (Summary)
8516@findex gnus-summary-save-article-file
8517@c @icon{gnus-summary-save-article-file}
8518Save the current article in plain file format
8519(@code{gnus-summary-save-article-file}).
8520
8521@item O F
8522@kindex O F (Summary)
8523@findex gnus-summary-write-article-file
8524Write the current article in plain file format, overwriting any previous
8525file contents (@code{gnus-summary-write-article-file}).
8526
8527@item O b
8528@kindex O b (Summary)
8529@findex gnus-summary-save-article-body-file
8530Save the current article body in plain file format
8531(@code{gnus-summary-save-article-body-file}).
8532
8533@item O h
8534@kindex O h (Summary)
8535@findex gnus-summary-save-article-folder
8536Save the current article in mh folder format
8537(@code{gnus-summary-save-article-folder}).
8538
8539@item O v
8540@kindex O v (Summary)
8541@findex gnus-summary-save-article-vm
8542Save the current article in a VM folder
8543(@code{gnus-summary-save-article-vm}).
8544
8545@item O p
8546@itemx |
8547@kindex O p (Summary)
8548@kindex | (Summary)
8549@findex gnus-summary-pipe-output
89167438 8550@vindex gnus-summary-pipe-output-default-command
4009494e
GM
8551Save the current article in a pipe. Uhm, like, what I mean is---Pipe
8552the current article to a process (@code{gnus-summary-pipe-output}).
8553If given a symbolic prefix (@pxref{Symbolic Prefixes}), include the
6ecfe5c2
MB
8554complete headers in the piped output. The symbolic prefix @code{r} is
8555special; it lets this command pipe a raw article including all headers.
8556The @code{gnus-summary-pipe-output-default-command} variable can be set
8557to a string containing the default command and options (default
8558@code{nil}).
4009494e
GM
8559
8560@item O P
8561@kindex O P (Summary)
8562@findex gnus-summary-muttprint
8563@vindex gnus-summary-muttprint-program
8564Save the current article into muttprint. That is, print it using the
8565external program @uref{http://muttprint.sourceforge.net/,
8566Muttprint}. The program name and options to use is controlled by the
8567variable @code{gnus-summary-muttprint-program}.
8568(@code{gnus-summary-muttprint}).
8569
8570@end table
8571
8572@vindex gnus-prompt-before-saving
8573All these commands use the process/prefix convention
8574(@pxref{Process/Prefix}). If you save bunches of articles using these
8575functions, you might get tired of being prompted for files to save each
8576and every article in. The prompting action is controlled by
8577the @code{gnus-prompt-before-saving} variable, which is @code{always} by
8578default, giving you that excessive prompting action you know and
8579loathe. If you set this variable to @code{t} instead, you'll be prompted
8580just once for each series of articles you save. If you like to really
8581have Gnus do all your thinking for you, you can even set this variable
8582to @code{nil}, which means that you will never be prompted for files to
8583save articles in. Gnus will simply save all the articles in the default
8584files.
8585
8586
8587@vindex gnus-default-article-saver
8588You can customize the @code{gnus-default-article-saver} variable to make
8589Gnus do what you want it to. You can use any of the eight ready-made
8590functions below, or you can create your own.
8591
8592@table @code
8593
8594@item gnus-summary-save-in-rmail
8595@findex gnus-summary-save-in-rmail
8596@vindex gnus-rmail-save-name
8597@findex gnus-plain-save-name
bc79f9ab
GM
8598This is the default format, that used by the Rmail package. Since Emacs
859923, Rmail uses standard mbox format. Before this, it used the
8600@dfn{Babyl} format. Accordingly, this command writes mbox format since
8601Emacs 23, unless appending to an existing Babyl file. In older versions
8602of Emacs, it always uses Babyl format. Uses the function in the
4009494e
GM
8603@code{gnus-rmail-save-name} variable to get a file name to save the
8604article in. The default is @code{gnus-plain-save-name}.
8605
8606@item gnus-summary-save-in-mail
8607@findex gnus-summary-save-in-mail
8608@vindex gnus-mail-save-name
8609Save in a Unix mail (mbox) file. Uses the function in the
8610@code{gnus-mail-save-name} variable to get a file name to save the
8611article in. The default is @code{gnus-plain-save-name}.
8612
8613@item gnus-summary-save-in-file
8614@findex gnus-summary-save-in-file
8615@vindex gnus-file-save-name
8616@findex gnus-numeric-save-name
8617Append the article straight to an ordinary file. Uses the function in
8618the @code{gnus-file-save-name} variable to get a file name to save the
8619article in. The default is @code{gnus-numeric-save-name}.
8620
8621@item gnus-summary-write-to-file
8622@findex gnus-summary-write-to-file
8623Write the article straight to an ordinary file. The file is
8624overwritten if it exists. Uses the function in the
8625@code{gnus-file-save-name} variable to get a file name to save the
8626article in. The default is @code{gnus-numeric-save-name}.
8627
8628@item gnus-summary-save-body-in-file
8629@findex gnus-summary-save-body-in-file
8630Append the article body to an ordinary file. Uses the function in the
8631@code{gnus-file-save-name} variable to get a file name to save the
8632article in. The default is @code{gnus-numeric-save-name}.
8633
8634@item gnus-summary-write-body-to-file
8635@findex gnus-summary-write-body-to-file
8636Write the article body straight to an ordinary file. The file is
8637overwritten if it exists. Uses the function in the
8638@code{gnus-file-save-name} variable to get a file name to save the
8639article in. The default is @code{gnus-numeric-save-name}.
8640
8641@item gnus-summary-save-in-folder
8642@findex gnus-summary-save-in-folder
8643@findex gnus-folder-save-name
8644@findex gnus-Folder-save-name
8645@vindex gnus-folder-save-name
8646@cindex rcvstore
8647@cindex MH folders
8648Save the article to an MH folder using @code{rcvstore} from the MH
8649library. Uses the function in the @code{gnus-folder-save-name} variable
8650to get a file name to save the article in. The default is
8651@code{gnus-folder-save-name}, but you can also use
8652@code{gnus-Folder-save-name}, which creates capitalized names.
8653
8654@item gnus-summary-save-in-vm
8655@findex gnus-summary-save-in-vm
8656Save the article in a VM folder. You have to have the VM mail
8657reader to use this setting.
89167438
MB
8658
8659@item gnus-summary-save-in-pipe
8660@findex gnus-summary-save-in-pipe
d62672f3
MB
8661Pipe the article to a shell command. This function takes optional two
8662arguments COMMAND and RAW. Valid values for COMMAND include:
8663
8664@itemize @bullet
8665@item a string@*
8666The executable command name and possibly arguments.
8667@item @code{nil}@*
8668You will be prompted for the command in the minibuffer.
8669@item the symbol @code{default}@*
8670It will be replaced with the command which the variable
8671@code{gnus-summary-pipe-output-default-command} holds or the command
8672last used for saving.
8673@end itemize
8674
8675Non-@code{nil} value for RAW overrides @code{:decode} and
8676@code{:headers} properties (see below) and the raw article including all
8677headers will be piped.
4009494e
GM
8678@end table
8679
8680The symbol of each function may have the following properties:
8681
8682@table @code
8683@item :decode
8684The value non-@code{nil} means save decoded articles. This is
8685meaningful only with @code{gnus-summary-save-in-file},
8686@code{gnus-summary-save-body-in-file},
89167438
MB
8687@code{gnus-summary-write-to-file},
8688@code{gnus-summary-write-body-to-file}, and
8689@code{gnus-summary-save-in-pipe}.
4009494e
GM
8690
8691@item :function
8692The value specifies an alternative function which appends, not
8693overwrites, articles to a file. This implies that when saving many
8694articles at a time, @code{gnus-prompt-before-saving} is bound to
8695@code{t} and all articles are saved in a single file. This is
8696meaningful only with @code{gnus-summary-write-to-file} and
8697@code{gnus-summary-write-body-to-file}.
8698
8699@item :headers
8700The value specifies the symbol of a variable of which the value
8701specifies headers to be saved. If it is omitted,
8702@code{gnus-save-all-headers} and @code{gnus-saved-headers} control what
8703headers should be saved.
8704@end table
8705
8706@vindex gnus-article-save-directory
8707All of these functions, except for the last one, will save the article
8708in the @code{gnus-article-save-directory}, which is initialized from the
8709@env{SAVEDIR} environment variable. This is @file{~/News/} by
8710default.
8711
8712As you can see above, the functions use different functions to find a
8713suitable name of a file to save the article in. Below is a list of
8714available functions that generate names:
8715
8716@table @code
8717
8718@item gnus-Numeric-save-name
8719@findex gnus-Numeric-save-name
8720File names like @file{~/News/Alt.andrea-dworkin/45}.
8721
8722@item gnus-numeric-save-name
8723@findex gnus-numeric-save-name
8724File names like @file{~/News/alt.andrea-dworkin/45}.
8725
8726@item gnus-Plain-save-name
8727@findex gnus-Plain-save-name
8728File names like @file{~/News/Alt.andrea-dworkin}.
8729
8730@item gnus-plain-save-name
8731@findex gnus-plain-save-name
8732File names like @file{~/News/alt.andrea-dworkin}.
8733
8734@item gnus-sender-save-name
8735@findex gnus-sender-save-name
8736File names like @file{~/News/larsi}.
8737@end table
8738
8739@vindex gnus-split-methods
8740You can have Gnus suggest where to save articles by plonking a regexp into
8741the @code{gnus-split-methods} alist. For instance, if you would like to
8742save articles related to Gnus in the file @file{gnus-stuff}, and articles
8743related to VM in @file{vm-stuff}, you could set this variable to something
8744like:
8745
8746@lisp
8747(("^Subject:.*gnus\\|^Newsgroups:.*gnus" "gnus-stuff")
8748 ("^Subject:.*vm\\|^Xref:.*vm" "vm-stuff")
8749 (my-choosing-function "../other-dir/my-stuff")
8750 ((equal gnus-newsgroup-name "mail.misc") "mail-stuff"))
8751@end lisp
8752
8753We see that this is a list where each element is a list that has two
8754elements---the @dfn{match} and the @dfn{file}. The match can either be
8755a string (in which case it is used as a regexp to match on the article
8756head); it can be a symbol (which will be called as a function with the
8757group name as a parameter); or it can be a list (which will be
8758@code{eval}ed). If any of these actions have a non-@code{nil} result,
8759the @dfn{file} will be used as a default prompt. In addition, the
8760result of the operation itself will be used if the function or form
8761called returns a string or a list of strings.
8762
8763You basically end up with a list of file names that might be used when
8764saving the current article. (All ``matches'' will be used.) You will
8765then be prompted for what you really want to use as a name, with file
8766name completion over the results from applying this variable.
8767
8768This variable is @code{((gnus-article-archive-name))} by default, which
8769means that Gnus will look at the articles it saves for an
8770@code{Archive-name} line and use that as a suggestion for the file
8771name.
8772
8773Here's an example function to clean up file names somewhat. If you have
8774lots of mail groups called things like
8775@samp{nnml:mail.whatever}, you may want to chop off the beginning of
8776these group names before creating the file name to save to. The
8777following will do just that:
8778
8779@lisp
8780(defun my-save-name (group)
8781 (when (string-match "^nnml:mail." group)
8782 (substring group (match-end 0))))
8783
8784(setq gnus-split-methods
8785 '((gnus-article-archive-name)
8786 (my-save-name)))
8787@end lisp
8788
8789
8790@vindex gnus-use-long-file-name
8791Finally, you have the @code{gnus-use-long-file-name} variable. If it is
8792@code{nil}, all the preceding functions will replace all periods
8793(@samp{.}) in the group names with slashes (@samp{/})---which means that
8794the functions will generate hierarchies of directories instead of having
8795all the files in the top level directory
8796(@file{~/News/alt/andrea-dworkin} instead of
8797@file{~/News/alt.andrea-dworkin}.) This variable is @code{t} by default
8798on most systems. However, for historical reasons, this is @code{nil} on
8799Xenix and usg-unix-v machines by default.
8800
8801This function also affects kill and score file names. If this variable
8802is a list, and the list contains the element @code{not-score}, long file
8803names will not be used for score files, if it contains the element
8804@code{not-save}, long file names will not be used for saving, and if it
8805contains the element @code{not-kill}, long file names will not be used
8806for kill files.
8807
8808If you'd like to save articles in a hierarchy that looks something like
8809a spool, you could
8810
8811@lisp
8812(setq gnus-use-long-file-name '(not-save)) ; @r{to get a hierarchy}
8813(setq gnus-default-article-saver
8814 'gnus-summary-save-in-file) ; @r{no encoding}
8815@end lisp
8816
8817Then just save with @kbd{o}. You'd then read this hierarchy with
8818ephemeral @code{nneething} groups---@kbd{G D} in the group buffer, and
8819the top level directory as the argument (@file{~/News/}). Then just walk
8820around to the groups/directories with @code{nneething}.
8821
8822
8823@node Decoding Articles
8824@section Decoding Articles
8825@cindex decoding articles
8826
8827Sometime users post articles (or series of articles) that have been
8828encoded in some way or other. Gnus can decode them for you.
8829
8830@menu
8831* Uuencoded Articles:: Uudecode articles.
8832* Shell Archives:: Unshar articles.
8833* PostScript Files:: Split PostScript.
8834* Other Files:: Plain save and binhex.
8835* Decoding Variables:: Variables for a happy decoding.
8836* Viewing Files:: You want to look at the result of the decoding?
8837@end menu
8838
8839@cindex series
8840@cindex article series
8841All these functions use the process/prefix convention
8842(@pxref{Process/Prefix}) for finding out what articles to work on, with
8843the extension that a ``single article'' means ``a single series''. Gnus
8844can find out by itself what articles belong to a series, decode all the
8845articles and unpack/view/save the resulting file(s).
8846
8847Gnus guesses what articles are in the series according to the following
8848simplish rule: The subjects must be (nearly) identical, except for the
8849last two numbers of the line. (Spaces are largely ignored, however.)
8850
8851For example: If you choose a subject called @samp{cat.gif (2/3)}, Gnus
8852will find all the articles that match the regexp @samp{^cat.gif
8853([0-9]+/[0-9]+).*$}.
8854
8855Subjects that are non-standard, like @samp{cat.gif (2/3) Part 6 of a
8856series}, will not be properly recognized by any of the automatic viewing
8857commands, and you have to mark the articles manually with @kbd{#}.
8858
8859
8860@node Uuencoded Articles
8861@subsection Uuencoded Articles
8862@cindex uudecode
8863@cindex uuencoded articles
8864
8865@table @kbd
8866
8867@item X u
8868@kindex X u (Summary)
8869@findex gnus-uu-decode-uu
8870@c @icon{gnus-uu-decode-uu}
8871Uudecodes the current series (@code{gnus-uu-decode-uu}).
8872
8873@item X U
8874@kindex X U (Summary)
8875@findex gnus-uu-decode-uu-and-save
8876Uudecodes and saves the current series
8877(@code{gnus-uu-decode-uu-and-save}).
8878
8879@item X v u
8880@kindex X v u (Summary)
8881@findex gnus-uu-decode-uu-view
8882Uudecodes and views the current series (@code{gnus-uu-decode-uu-view}).
8883
8884@item X v U
8885@kindex X v U (Summary)
8886@findex gnus-uu-decode-uu-and-save-view
8887Uudecodes, views and saves the current series
8888(@code{gnus-uu-decode-uu-and-save-view}).
8889
8890@end table
8891
8892Remember that these all react to the presence of articles marked with
8893the process mark. If, for instance, you'd like to decode and save an
8894entire newsgroup, you'd typically do @kbd{M P a}
8895(@code{gnus-uu-mark-all}) and then @kbd{X U}
8896(@code{gnus-uu-decode-uu-and-save}).
8897
8898All this is very much different from how @code{gnus-uu} worked with
8899@sc{gnus 4.1}, where you had explicit keystrokes for everything under
8900the sun. This version of @code{gnus-uu} generally assumes that you mark
8901articles in some way (@pxref{Setting Process Marks}) and then press
8902@kbd{X u}.
8903
8904@vindex gnus-uu-notify-files
8905Note: When trying to decode articles that have names matching
8906@code{gnus-uu-notify-files}, which is hard-coded to
8907@samp{[Cc][Ii][Nn][Dd][Yy][0-9]+.\\(gif\\|jpg\\)}, @code{gnus-uu} will
8908automatically post an article on @samp{comp.unix.wizards} saying that
8909you have just viewed the file in question. This feature can't be turned
8910off.
8911
8912
8913@node Shell Archives
8914@subsection Shell Archives
8915@cindex unshar
8916@cindex shell archives
8917@cindex shared articles
8918
8919Shell archives (``shar files'') used to be a popular way to distribute
8920sources, but it isn't used all that much today. In any case, we have
8921some commands to deal with these:
8922
8923@table @kbd
8924
8925@item X s
8926@kindex X s (Summary)
8927@findex gnus-uu-decode-unshar
8928Unshars the current series (@code{gnus-uu-decode-unshar}).
8929
8930@item X S
8931@kindex X S (Summary)
8932@findex gnus-uu-decode-unshar-and-save
8933Unshars and saves the current series (@code{gnus-uu-decode-unshar-and-save}).
8934
8935@item X v s
8936@kindex X v s (Summary)
8937@findex gnus-uu-decode-unshar-view
8938Unshars and views the current series (@code{gnus-uu-decode-unshar-view}).
8939
8940@item X v S
8941@kindex X v S (Summary)
8942@findex gnus-uu-decode-unshar-and-save-view
8943Unshars, views and saves the current series
8944(@code{gnus-uu-decode-unshar-and-save-view}).
8945@end table
8946
8947
8948@node PostScript Files
8949@subsection PostScript Files
8950@cindex PostScript
8951
8952@table @kbd
8953
8954@item X p
8955@kindex X p (Summary)
8956@findex gnus-uu-decode-postscript
8957Unpack the current PostScript series (@code{gnus-uu-decode-postscript}).
8958
8959@item X P
8960@kindex X P (Summary)
8961@findex gnus-uu-decode-postscript-and-save
8962Unpack and save the current PostScript series
8963(@code{gnus-uu-decode-postscript-and-save}).
8964
8965@item X v p
8966@kindex X v p (Summary)
8967@findex gnus-uu-decode-postscript-view
8968View the current PostScript series
8969(@code{gnus-uu-decode-postscript-view}).
8970
8971@item X v P
8972@kindex X v P (Summary)
8973@findex gnus-uu-decode-postscript-and-save-view
8974View and save the current PostScript series
8975(@code{gnus-uu-decode-postscript-and-save-view}).
8976@end table
8977
8978
8979@node Other Files
8980@subsection Other Files
8981
8982@table @kbd
8983@item X o
8984@kindex X o (Summary)
8985@findex gnus-uu-decode-save
8986Save the current series
8987(@code{gnus-uu-decode-save}).
8988
8989@item X b
8990@kindex X b (Summary)
8991@findex gnus-uu-decode-binhex
8992Unbinhex the current series (@code{gnus-uu-decode-binhex}). This
8993doesn't really work yet.
b890d447
MB
8994
8995@item X Y
8996@kindex X Y (Summary)
8997@findex gnus-uu-decode-yenc
8998yEnc-decode the current series and save it (@code{gnus-uu-decode-yenc}).
4009494e
GM
8999@end table
9000
9001
9002@node Decoding Variables
9003@subsection Decoding Variables
9004
9005Adjective, not verb.
9006
9007@menu
9008* Rule Variables:: Variables that say how a file is to be viewed.
9009* Other Decode Variables:: Other decode variables.
9010* Uuencoding and Posting:: Variables for customizing uuencoding.
9011@end menu
9012
9013
9014@node Rule Variables
9015@subsubsection Rule Variables
9016@cindex rule variables
9017
9018Gnus uses @dfn{rule variables} to decide how to view a file. All these
9019variables are of the form
9020
9021@lisp
9022 (list '(regexp1 command2)
9023 '(regexp2 command2)
9024 ...)
9025@end lisp
9026
9027@table @code
9028
9029@item gnus-uu-user-view-rules
9030@vindex gnus-uu-user-view-rules
9031@cindex sox
9032This variable is consulted first when viewing files. If you wish to use,
9033for instance, @code{sox} to convert an @file{.au} sound file, you could
9034say something like:
9035@lisp
9036(setq gnus-uu-user-view-rules
9037 (list '("\\\\.au$" "sox %s -t .aiff > /dev/audio")))
9038@end lisp
9039
9040@item gnus-uu-user-view-rules-end
9041@vindex gnus-uu-user-view-rules-end
9042This variable is consulted if Gnus couldn't make any matches from the
9043user and default view rules.
9044
9045@item gnus-uu-user-archive-rules
9046@vindex gnus-uu-user-archive-rules
9047This variable can be used to say what commands should be used to unpack
9048archives.
9049@end table
9050
9051
9052@node Other Decode Variables
9053@subsubsection Other Decode Variables
9054
9055@table @code
9056@vindex gnus-uu-grabbed-file-functions
9057
9058@item gnus-uu-grabbed-file-functions
9059All functions in this list will be called right after each file has been
9060successfully decoded---so that you can move or view files right away,
9061and don't have to wait for all files to be decoded before you can do
9062anything. Ready-made functions you can put in this list are:
9063
9064@table @code
9065
9066@item gnus-uu-grab-view
9067@findex gnus-uu-grab-view
9068View the file.
9069
9070@item gnus-uu-grab-move
9071@findex gnus-uu-grab-move
9072Move the file (if you're using a saving function.)
9073@end table
9074
9075@item gnus-uu-be-dangerous
9076@vindex gnus-uu-be-dangerous
9077Specifies what to do if unusual situations arise during decoding. If
9078@code{nil}, be as conservative as possible. If @code{t}, ignore things
9079that didn't work, and overwrite existing files. Otherwise, ask each
9080time.
9081
9082@item gnus-uu-ignore-files-by-name
9083@vindex gnus-uu-ignore-files-by-name
9084Files with name matching this regular expression won't be viewed.
9085
9086@item gnus-uu-ignore-files-by-type
9087@vindex gnus-uu-ignore-files-by-type
9088Files with a @acronym{MIME} type matching this variable won't be viewed.
9089Note that Gnus tries to guess what type the file is based on the name.
9090@code{gnus-uu} is not a @acronym{MIME} package (yet), so this is slightly
9091kludgey.
9092
9093@item gnus-uu-tmp-dir
9094@vindex gnus-uu-tmp-dir
9095Where @code{gnus-uu} does its work.
9096
9097@item gnus-uu-do-not-unpack-archives
9098@vindex gnus-uu-do-not-unpack-archives
9099Non-@code{nil} means that @code{gnus-uu} won't peek inside archives
9100looking for files to display.
9101
9102@item gnus-uu-view-and-save
9103@vindex gnus-uu-view-and-save
9104Non-@code{nil} means that the user will always be asked to save a file
9105after viewing it.
9106
9107@item gnus-uu-ignore-default-view-rules
9108@vindex gnus-uu-ignore-default-view-rules
9109Non-@code{nil} means that @code{gnus-uu} will ignore the default viewing
9110rules.
9111
9112@item gnus-uu-ignore-default-archive-rules
9113@vindex gnus-uu-ignore-default-archive-rules
9114Non-@code{nil} means that @code{gnus-uu} will ignore the default archive
9115unpacking commands.
9116
9117@item gnus-uu-kill-carriage-return
9118@vindex gnus-uu-kill-carriage-return
9119Non-@code{nil} means that @code{gnus-uu} will strip all carriage returns
9120from articles.
9121
9122@item gnus-uu-unmark-articles-not-decoded
9123@vindex gnus-uu-unmark-articles-not-decoded
9124Non-@code{nil} means that @code{gnus-uu} will mark unsuccessfully
9125decoded articles as unread.
9126
9127@item gnus-uu-correct-stripped-uucode
9128@vindex gnus-uu-correct-stripped-uucode
9129Non-@code{nil} means that @code{gnus-uu} will @emph{try} to fix
9130uuencoded files that have had trailing spaces deleted.
9131
9132@item gnus-uu-pre-uudecode-hook
9133@vindex gnus-uu-pre-uudecode-hook
9134Hook run before sending a message to @code{uudecode}.
9135
9136@item gnus-uu-view-with-metamail
9137@vindex gnus-uu-view-with-metamail
9138@cindex metamail
9139Non-@code{nil} means that @code{gnus-uu} will ignore the viewing
9140commands defined by the rule variables and just fudge a @acronym{MIME}
9141content type based on the file name. The result will be fed to
9142@code{metamail} for viewing.
9143
9144@item gnus-uu-save-in-digest
9145@vindex gnus-uu-save-in-digest
9146Non-@code{nil} means that @code{gnus-uu}, when asked to save without
9147decoding, will save in digests. If this variable is @code{nil},
9148@code{gnus-uu} will just save everything in a file without any
9149embellishments. The digesting almost conforms to RFC 1153---no easy way
9150to specify any meaningful volume and issue numbers were found, so I
9151simply dropped them.
9152
9153@end table
9154
9155
9156@node Uuencoding and Posting
9157@subsubsection Uuencoding and Posting
9158
9159@table @code
9160
9161@item gnus-uu-post-include-before-composing
9162@vindex gnus-uu-post-include-before-composing
9163Non-@code{nil} means that @code{gnus-uu} will ask for a file to encode
9164before you compose the article. If this variable is @code{t}, you can
9165either include an encoded file with @kbd{C-c C-i} or have one included
9166for you when you post the article.
9167
9168@item gnus-uu-post-length
9169@vindex gnus-uu-post-length
9170Maximum length of an article. The encoded file will be split into how
9171many articles it takes to post the entire file.
9172
9173@item gnus-uu-post-threaded
9174@vindex gnus-uu-post-threaded
9175Non-@code{nil} means that @code{gnus-uu} will post the encoded file in a
9176thread. This may not be smart, as no other decoder I have seen is able
9177to follow threads when collecting uuencoded articles. (Well, I have
9178seen one package that does that---@code{gnus-uu}, but somehow, I don't
9179think that counts@dots{}) Default is @code{nil}.
9180
9181@item gnus-uu-post-separate-description
9182@vindex gnus-uu-post-separate-description
9183Non-@code{nil} means that the description will be posted in a separate
9184article. The first article will typically be numbered (0/x). If this
9185variable is @code{nil}, the description the user enters will be included
9186at the beginning of the first article, which will be numbered (1/x).
9187Default is @code{t}.
9188
9189@end table
9190
9191
9192@node Viewing Files
9193@subsection Viewing Files
9194@cindex viewing files
9195@cindex pseudo-articles
9196
9197After decoding, if the file is some sort of archive, Gnus will attempt
9198to unpack the archive and see if any of the files in the archive can be
9199viewed. For instance, if you have a gzipped tar file @file{pics.tar.gz}
9200containing the files @file{pic1.jpg} and @file{pic2.gif}, Gnus will
9201uncompress and de-tar the main file, and then view the two pictures.
9202This unpacking process is recursive, so if the archive contains archives
9203of archives, it'll all be unpacked.
9204
9205Finally, Gnus will normally insert a @dfn{pseudo-article} for each
9206extracted file into the summary buffer. If you go to these
9207``articles'', you will be prompted for a command to run (usually Gnus
9208will make a suggestion), and then the command will be run.
9209
9210@vindex gnus-view-pseudo-asynchronously
9211If @code{gnus-view-pseudo-asynchronously} is @code{nil}, Emacs will wait
9212until the viewing is done before proceeding.
9213
9214@vindex gnus-view-pseudos
9215If @code{gnus-view-pseudos} is @code{automatic}, Gnus will not insert
9216the pseudo-articles into the summary buffer, but view them
9217immediately. If this variable is @code{not-confirm}, the user won't even
9218be asked for a confirmation before viewing is done.
9219
9220@vindex gnus-view-pseudos-separately
9221If @code{gnus-view-pseudos-separately} is non-@code{nil}, one
9222pseudo-article will be created for each file to be viewed. If
9223@code{nil}, all files that use the same viewing command will be given as
9224a list of parameters to that command.
9225
9226@vindex gnus-insert-pseudo-articles
9227If @code{gnus-insert-pseudo-articles} is non-@code{nil}, insert
9228pseudo-articles when decoding. It is @code{t} by default.
9229
9230So; there you are, reading your @emph{pseudo-articles} in your
9231@emph{virtual newsgroup} from the @emph{virtual server}; and you think:
9232Why isn't anything real anymore? How did we get here?
9233
9234
9235@node Article Treatment
9236@section Article Treatment
9237
9238Reading through this huge manual, you may have quite forgotten that the
9239object of newsreaders is to actually, like, read what people have
9240written. Reading articles. Unfortunately, people are quite bad at
9241writing, so there are tons of functions and variables to make reading
9242these articles easier.
9243
9244@menu
9245* Article Highlighting:: You want to make the article look like fruit salad.
9246* Article Fontisizing:: Making emphasized text look nice.
9247* Article Hiding:: You also want to make certain info go away.
9248* Article Washing:: Lots of way-neat functions to make life better.
9249* Article Header:: Doing various header transformations.
9250* Article Buttons:: Click on URLs, Message-IDs, addresses and the like.
9251* Article Button Levels:: Controlling appearance of buttons.
9252* Article Date:: Grumble, UT!
9253* Article Display:: Display various stuff---X-Face, Picons, Smileys
9254* Article Signature:: What is a signature?
9255* Article Miscellanea:: Various other stuff.
9256@end menu
9257
9258
9259@node Article Highlighting
9260@subsection Article Highlighting
9261@cindex highlighting
9262
9263Not only do you want your article buffer to look like fruit salad, but
9264you want it to look like technicolor fruit salad.
9265
9266@table @kbd
9267
9268@item W H a
9269@kindex W H a (Summary)
9270@findex gnus-article-highlight
9271@findex gnus-article-maybe-highlight
9272Do much highlighting of the current article
9273(@code{gnus-article-highlight}). This function highlights header, cited
9274text, the signature, and adds buttons to the body and the head.
9275
9276@item W H h
9277@kindex W H h (Summary)
9278@findex gnus-article-highlight-headers
9279@vindex gnus-header-face-alist
9280Highlight the headers (@code{gnus-article-highlight-headers}). The
9281highlighting will be done according to the @code{gnus-header-face-alist}
9282variable, which is a list where each element has the form
9283@code{(@var{regexp} @var{name} @var{content})}.
9284@var{regexp} is a regular expression for matching the
9285header, @var{name} is the face used for highlighting the header name
9286(@pxref{Faces and Fonts}) and @var{content} is the face for highlighting
9287the header value. The first match made will be used. Note that
9288@var{regexp} shouldn't have @samp{^} prepended---Gnus will add one.
9289
9290@item W H c
9291@kindex W H c (Summary)
9292@findex gnus-article-highlight-citation
9293Highlight cited text (@code{gnus-article-highlight-citation}).
9294
9295Some variables to customize the citation highlights:
9296
9297@table @code
9298@vindex gnus-cite-parse-max-size
9299
9300@item gnus-cite-parse-max-size
9301If the article size in bytes is bigger than this variable (which is
930225000 by default), no citation highlighting will be performed.
9303
9304@item gnus-cite-max-prefix
9305@vindex gnus-cite-max-prefix
9306Maximum possible length for a citation prefix (default 20).
9307
9308@item gnus-cite-face-list
9309@vindex gnus-cite-face-list
9310List of faces used for highlighting citations (@pxref{Faces and Fonts}).
9311When there are citations from multiple articles in the same message,
9312Gnus will try to give each citation from each article its own face.
9313This should make it easier to see who wrote what.
9314
9315@item gnus-supercite-regexp
9316@vindex gnus-supercite-regexp
9317Regexp matching normal Supercite attribution lines.
9318
9319@item gnus-supercite-secondary-regexp
9320@vindex gnus-supercite-secondary-regexp
9321Regexp matching mangled Supercite attribution lines.
9322
9323@item gnus-cite-minimum-match-count
9324@vindex gnus-cite-minimum-match-count
9325Minimum number of identical prefixes we have to see before we believe
9326that it's a citation.
9327
9328@item gnus-cite-attribution-prefix
9329@vindex gnus-cite-attribution-prefix
9330Regexp matching the beginning of an attribution line.
9331
9332@item gnus-cite-attribution-suffix
9333@vindex gnus-cite-attribution-suffix
9334Regexp matching the end of an attribution line.
9335
9336@item gnus-cite-attribution-face
9337@vindex gnus-cite-attribution-face
9338Face used for attribution lines. It is merged with the face for the
9339cited text belonging to the attribution.
9340
9341@item gnus-cite-ignore-quoted-from
9342@vindex gnus-cite-ignore-quoted-from
9343If non-@code{nil}, no citation highlighting will be performed on lines
9344beginning with @samp{>From }. Those lines may have been quoted by MTAs
9345in order not to mix up with the envelope From line. The default value
9346is @code{t}.
9347
9348@end table
9349
9350
9351@item W H s
9352@kindex W H s (Summary)
9353@vindex gnus-signature-separator
9354@vindex gnus-signature-face
9355@findex gnus-article-highlight-signature
9356Highlight the signature (@code{gnus-article-highlight-signature}).
9357Everything after @code{gnus-signature-separator} (@pxref{Article
9358Signature}) in an article will be considered a signature and will be
9359highlighted with @code{gnus-signature-face}, which is @code{italic} by
9360default.
9361
9362@end table
9363
9364@xref{Customizing Articles}, for how to highlight articles automatically.
9365
9366
9367@node Article Fontisizing
9368@subsection Article Fontisizing
9369@cindex emphasis
9370@cindex article emphasis
9371
9372@findex gnus-article-emphasize
9373@kindex W e (Summary)
9374People commonly add emphasis to words in news articles by writing things
9375like @samp{_this_} or @samp{*this*} or @samp{/this/}. Gnus can make
9376this look nicer by running the article through the @kbd{W e}
9377(@code{gnus-article-emphasize}) command.
9378
9379@vindex gnus-emphasis-alist
9380How the emphasis is computed is controlled by the
9381@code{gnus-emphasis-alist} variable. This is an alist where the first
9382element is a regular expression to be matched. The second is a number
9383that says what regular expression grouping is used to find the entire
9384emphasized word. The third is a number that says what regexp grouping
9385should be displayed and highlighted. (The text between these two
9386groupings will be hidden.) The fourth is the face used for
9387highlighting.
9388
9389@lisp
9390(setq gnus-emphasis-alist
9391 '(("_\\(\\w+\\)_" 0 1 gnus-emphasis-underline)
9392 ("\\*\\(\\w+\\)\\*" 0 1 gnus-emphasis-bold)))
9393@end lisp
9394
9395@cindex slash
9396@cindex asterisk
9397@cindex underline
9398@cindex /
9399@cindex *
9400
9401@vindex gnus-emphasis-underline
9402@vindex gnus-emphasis-bold
9403@vindex gnus-emphasis-italic
9404@vindex gnus-emphasis-underline-bold
9405@vindex gnus-emphasis-underline-italic
9406@vindex gnus-emphasis-bold-italic
9407@vindex gnus-emphasis-underline-bold-italic
9408By default, there are seven rules, and they use the following faces:
9409@code{gnus-emphasis-bold}, @code{gnus-emphasis-italic},
9410@code{gnus-emphasis-underline}, @code{gnus-emphasis-bold-italic},
9411@code{gnus-emphasis-underline-italic},
9412@code{gnus-emphasis-underline-bold}, and
9413@code{gnus-emphasis-underline-bold-italic}.
9414
9415If you want to change these faces, you can either use @kbd{M-x
9416customize}, or you can use @code{copy-face}. For instance, if you want
9417to make @code{gnus-emphasis-italic} use a red face instead, you could
9418say something like:
9419
9420@lisp
9421(copy-face 'red 'gnus-emphasis-italic)
9422@end lisp
9423
9424@vindex gnus-group-highlight-words-alist
9425
9426If you want to highlight arbitrary words, you can use the
9427@code{gnus-group-highlight-words-alist} variable, which uses the same
9428syntax as @code{gnus-emphasis-alist}. The @code{highlight-words} group
9429parameter (@pxref{Group Parameters}) can also be used.
9430
9431@xref{Customizing Articles}, for how to fontize articles automatically.
9432
9433
9434@node Article Hiding
9435@subsection Article Hiding
9436@cindex article hiding
9437
9438Or rather, hiding certain things in each article. There usually is much
9439too much cruft in most articles.
9440
9441@table @kbd
9442
9443@item W W a
9444@kindex W W a (Summary)
9445@findex gnus-article-hide
9446Do quite a lot of hiding on the article buffer
9447(@kbd{gnus-article-hide}). In particular, this function will hide
9448headers, @acronym{PGP}, cited text and the signature.
9449
9450@item W W h
9451@kindex W W h (Summary)
9452@findex gnus-article-hide-headers
9453Hide headers (@code{gnus-article-hide-headers}). @xref{Hiding
9454Headers}.
9455
9456@item W W b
9457@kindex W W b (Summary)
9458@findex gnus-article-hide-boring-headers
9459Hide headers that aren't particularly interesting
9460(@code{gnus-article-hide-boring-headers}). @xref{Hiding Headers}.
9461
9462@item W W s
9463@kindex W W s (Summary)
9464@findex gnus-article-hide-signature
9465Hide signature (@code{gnus-article-hide-signature}). @xref{Article
9466Signature}.
9467
9468@item W W l
9469@kindex W W l (Summary)
9470@findex gnus-article-hide-list-identifiers
9471@vindex gnus-list-identifiers
9472Strip list identifiers specified in @code{gnus-list-identifiers}. These
9473are strings some mailing list servers add to the beginning of all
9474@code{Subject} headers---for example, @samp{[zebra 4711]}. Any leading
9475@samp{Re: } is skipped before stripping. @code{gnus-list-identifiers}
9476may not contain @code{\\(..\\)}.
9477
9478@table @code
9479
9480@item gnus-list-identifiers
9481@vindex gnus-list-identifiers
9482A regular expression that matches list identifiers to be removed from
9483subject. This can also be a list of regular expressions.
9484
9485@end table
9486
9487@item W W P
9488@kindex W W P (Summary)
9489@findex gnus-article-hide-pem
9490Hide @acronym{PEM} (privacy enhanced messages) cruft
9491(@code{gnus-article-hide-pem}).
9492
9493@item W W B
9494@kindex W W B (Summary)
9495@findex gnus-article-strip-banner
9496@vindex gnus-article-banner-alist
9497@vindex gnus-article-address-banner-alist
9498@cindex banner
9499@cindex OneList
9500@cindex stripping advertisements
9501@cindex advertisements
9502Strip the banner specified by the @code{banner} group parameter
9503(@code{gnus-article-strip-banner}). This is mainly used to hide those
9504annoying banners and/or signatures that some mailing lists and moderated
9505groups adds to all the messages. The way to use this function is to add
9506the @code{banner} group parameter (@pxref{Group Parameters}) to the
9507group you want banners stripped from. The parameter either be a string,
9508which will be interpreted as a regular expression matching text to be
9509removed, or the symbol @code{signature}, meaning that the (last)
9510signature should be removed, or other symbol, meaning that the
9511corresponding regular expression in @code{gnus-article-banner-alist} is
9512used.
9513
9514Regardless of a group, you can hide things like advertisements only when
9515the sender of an article has a certain mail address specified in
9516@code{gnus-article-address-banner-alist}.
9517
9518@table @code
9519
9520@item gnus-article-address-banner-alist
9521@vindex gnus-article-address-banner-alist
9522Alist of mail addresses and banners. Each element has the form
9523@code{(@var{address} . @var{banner})}, where @var{address} is a regexp
9524matching a mail address in the From header, @var{banner} is one of a
9525symbol @code{signature}, an item in @code{gnus-article-banner-alist},
9526a regexp and @code{nil}. If @var{address} matches author's mail
9527address, it will remove things like advertisements. For example, if a
9528sender has the mail address @samp{hail@@yoo-hoo.co.jp} and there is a
9529banner something like @samp{Do You Yoo-hoo!?} in all articles he
9530sends, you can use the following element to remove them:
9531
9532@lisp
9533("@@yoo-hoo\\.co\\.jp\\'" .
9534 "\n_+\nDo You Yoo-hoo!\\?\n.*\n.*\n")
9535@end lisp
9536
9537@end table
9538
9539@item W W c
9540@kindex W W c (Summary)
9541@findex gnus-article-hide-citation
9542Hide citation (@code{gnus-article-hide-citation}). Some variables for
9543customizing the hiding:
9544
9545@table @code
9546
9547@item gnus-cited-opened-text-button-line-format
9548@itemx gnus-cited-closed-text-button-line-format
9549@vindex gnus-cited-closed-text-button-line-format
9550@vindex gnus-cited-opened-text-button-line-format
9551Gnus adds buttons to show where the cited text has been hidden, and to
9552allow toggle hiding the text. The format of the variable is specified
9553by these format-like variable (@pxref{Formatting Variables}). These
9554specs are valid:
9555
9556@table @samp
9557@item b
9558Starting point of the hidden text.
9559@item e
9560Ending point of the hidden text.
9561@item l
9562Number of characters in the hidden region.
9563@item n
9564Number of lines of hidden text.
9565@end table
9566
9567@item gnus-cited-lines-visible
9568@vindex gnus-cited-lines-visible
9569The number of lines at the beginning of the cited text to leave
9570shown. This can also be a cons cell with the number of lines at the top
9571and bottom of the text, respectively, to remain visible.
9572
9573@end table
9574
9575@item W W C-c
9576@kindex W W C-c (Summary)
9577@findex gnus-article-hide-citation-maybe
9578
9579Hide citation (@code{gnus-article-hide-citation-maybe}) depending on the
9580following two variables:
9581
9582@table @code
9583@item gnus-cite-hide-percentage
9584@vindex gnus-cite-hide-percentage
9585If the cited text is of a bigger percentage than this variable (default
958650), hide the cited text.
9587
9588@item gnus-cite-hide-absolute
9589@vindex gnus-cite-hide-absolute
9590The cited text must have at least this length (default 10) before it
9591is hidden.
9592@end table
9593
9594@item W W C
9595@kindex W W C (Summary)
9596@findex gnus-article-hide-citation-in-followups
9597Hide cited text in articles that aren't roots
9598(@code{gnus-article-hide-citation-in-followups}). This isn't very
9599useful as an interactive command, but might be a handy function to stick
9600have happen automatically (@pxref{Customizing Articles}).
9601
9602@end table
9603
9604All these ``hiding'' commands are toggles, but if you give a negative
9605prefix to these commands, they will show what they have previously
9606hidden. If you give a positive prefix, they will always hide.
9607
9608Also @pxref{Article Highlighting} for further variables for
9609citation customization.
9610
9611@xref{Customizing Articles}, for how to hide article elements
9612automatically.
9613
9614
9615@node Article Washing
9616@subsection Article Washing
9617@cindex washing
9618@cindex article washing
9619
9620We call this ``article washing'' for a really good reason. Namely, the
9621@kbd{A} key was taken, so we had to use the @kbd{W} key instead.
9622
9623@dfn{Washing} is defined by us as ``changing something from something to
9624something else'', but normally results in something looking better.
9625Cleaner, perhaps.
9626
9627@xref{Customizing Articles}, if you want to change how Gnus displays
9628articles by default.
9629
9630@table @kbd
9631
9632@item C-u g
9633This is not really washing, it's sort of the opposite of washing. If
9634you type this, you see the article exactly as it exists on disk or on
9635the server.
9636
9637@item g
9638Force redisplaying of the current article
9639(@code{gnus-summary-show-article}). This is also not really washing.
9640If you type this, you see the article without any previously applied
9641interactive Washing functions but with all default treatments
9642(@pxref{Customizing Articles}).
9643
9644@item W l
9645@kindex W l (Summary)
9646@findex gnus-summary-stop-page-breaking
9647Remove page breaks from the current article
9648(@code{gnus-summary-stop-page-breaking}). @xref{Misc Article}, for page
9649delimiters.
9650
9651@item W r
9652@kindex W r (Summary)
9653@findex gnus-summary-caesar-message
9654@c @icon{gnus-summary-caesar-message}
9655Do a Caesar rotate (rot13) on the article buffer
9656(@code{gnus-summary-caesar-message}).
9657Unreadable articles that tell you to read them with Caesar rotate or rot13.
9658(Typically offensive jokes and such.)
9659
9660It's commonly called ``rot13'' because each letter is rotated 13
9661positions in the alphabet, e. g. @samp{B} (letter #2) -> @samp{O} (letter
9662#15). It is sometimes referred to as ``Caesar rotate'' because Caesar
9663is rumored to have employed this form of, uh, somewhat weak encryption.
9664
9665@item W m
9666@kindex W m (Summary)
9667@findex gnus-summary-morse-message
9668Morse decode the article buffer (@code{gnus-summary-morse-message}).
9669
01c52d31
MB
9670@item W i
9671@kindex W i (Summary)
9672@findex gnus-summary-idna-message
9673Decode IDNA encoded domain names in the current articles. IDNA
9674encoded domain names looks like @samp{xn--bar}. If a string remain
9675unencoded after running invoking this, it is likely an invalid IDNA
9676string (@samp{xn--bar} is invalid). You must have GNU Libidn
9677(@url{http://www.gnu.org/software/libidn/}) installed for this command
9678to work.
9679
4009494e
GM
9680@item W t
9681@item t
9682@kindex W t (Summary)
9683@kindex t (Summary)
9684@findex gnus-summary-toggle-header
9685Toggle whether to display all headers in the article buffer
9686(@code{gnus-summary-toggle-header}).
9687
9688@item W v
9689@kindex W v (Summary)
9690@findex gnus-summary-verbose-headers
9691Toggle whether to display all headers in the article buffer permanently
9692(@code{gnus-summary-verbose-headers}).
9693
9694@item W o
9695@kindex W o (Summary)
9696@findex gnus-article-treat-overstrike
9697Treat overstrike (@code{gnus-article-treat-overstrike}).
9698
9699@item W d
9700@kindex W d (Summary)
9701@findex gnus-article-treat-dumbquotes
9702@vindex gnus-article-dumbquotes-map
9703@cindex Smartquotes
9704@cindex M****s*** sm*rtq**t*s
9705@cindex Latin 1
9706Treat M****s*** sm*rtq**t*s according to
9707@code{gnus-article-dumbquotes-map}
9708(@code{gnus-article-treat-dumbquotes}). Note that this function guesses
9709whether a character is a sm*rtq**t* or not, so it should only be used
9710interactively.
9711
9712Sm*rtq**t*s are M****s***'s unilateral extension to the character map in
9713an attempt to provide more quoting characters. If you see something
9714like @code{\222} or @code{\264} where you're expecting some kind of
9715apostrophe or quotation mark, then try this wash.
9716
9717@item W Y f
9718@kindex W Y f (Summary)
9719@findex gnus-article-outlook-deuglify-article
9720@cindex Outlook Express
9721Full deuglify of broken Outlook (Express) articles: Treat dumbquotes,
9722unwrap lines, repair attribution and rearrange citation.
9723(@code{gnus-article-outlook-deuglify-article}).
9724
9725@item W Y u
9726@kindex W Y u (Summary)
9727@findex gnus-article-outlook-unwrap-lines
9728@vindex gnus-outlook-deuglify-unwrap-min
9729@vindex gnus-outlook-deuglify-unwrap-max
9730Unwrap lines that appear to be wrapped citation lines. You can control
9731what lines will be unwrapped by frobbing
9732@code{gnus-outlook-deuglify-unwrap-min} and
9733@code{gnus-outlook-deuglify-unwrap-max}, indicating the minimum and
9734maximum length of an unwrapped citation line.
9735(@code{gnus-article-outlook-unwrap-lines}).
9736
9737@item W Y a
9738@kindex W Y a (Summary)
9739@findex gnus-article-outlook-repair-attribution
9740Repair a broken attribution line.@*
9741(@code{gnus-article-outlook-repair-attribution}).
9742
9743@item W Y c
9744@kindex W Y c (Summary)
9745@findex gnus-article-outlook-rearrange-citation
9746Repair broken citations by rearranging the text.
9747(@code{gnus-article-outlook-rearrange-citation}).
9748
9749@item W w
9750@kindex W w (Summary)
9751@findex gnus-article-fill-cited-article
9752Do word wrap (@code{gnus-article-fill-cited-article}).
9753
9754You can give the command a numerical prefix to specify the width to use
9755when filling.
9756
9757@item W Q
9758@kindex W Q (Summary)
9759@findex gnus-article-fill-long-lines
9760Fill long lines (@code{gnus-article-fill-long-lines}).
9761
9762@item W C
9763@kindex W C (Summary)
9764@findex gnus-article-capitalize-sentences
9765Capitalize the first word in each sentence
9766(@code{gnus-article-capitalize-sentences}).
9767
9768@item W c
9769@kindex W c (Summary)
9770@findex gnus-article-remove-cr
9771Translate CRLF pairs (i. e., @samp{^M}s on the end of the lines) into LF
9772(this takes care of DOS line endings), and then translate any remaining
9773CRs into LF (this takes care of Mac line endings)
9774(@code{gnus-article-remove-cr}).
9775
9776@item W q
9777@kindex W q (Summary)
9778@findex gnus-article-de-quoted-unreadable
9779Treat quoted-printable (@code{gnus-article-de-quoted-unreadable}).
9780Quoted-Printable is one common @acronym{MIME} encoding employed when
9781sending non-@acronym{ASCII} (i.e., 8-bit) articles. It typically
01c52d31
MB
9782makes strings like @samp{d@'ej@`a vu} look like @samp{d=E9j=E0 vu},
9783which doesn't look very readable to me. Note that this is usually
9784done automatically by Gnus if the message in question has a
4009494e
GM
9785@code{Content-Transfer-Encoding} header that says that this encoding
9786has been done. If a prefix is given, a charset will be asked for.
9787
9788@item W 6
9789@kindex W 6 (Summary)
9790@findex gnus-article-de-base64-unreadable
9791Treat base64 (@code{gnus-article-de-base64-unreadable}). Base64 is
9792one common @acronym{MIME} encoding employed when sending
9793non-@acronym{ASCII} (i.e., 8-bit) articles. Note that this is
9794usually done automatically by Gnus if the message in question has a
9795@code{Content-Transfer-Encoding} header that says that this encoding
9796has been done. If a prefix is given, a charset will be asked for.
9797
9798@item W Z
9799@kindex W Z (Summary)
9800@findex gnus-article-decode-HZ
9801Treat HZ or HZP (@code{gnus-article-decode-HZ}). HZ (or HZP) is one
9802common encoding employed when sending Chinese articles. It typically
9803makes strings look like @samp{~@{<:Ky2;S@{#,NpJ)l6HK!#~@}}.
9804
01c52d31
MB
9805@item W A
9806@kindex W A (Summary)
9807@findex gnus-article-treat-ansi-sequences
9808@cindex @acronym{ANSI} control sequences
9809Translate @acronym{ANSI} SGR control sequences into overlays or
9810extents (@code{gnus-article-treat-ansi-sequences}). @acronym{ANSI}
9811sequences are used in some Chinese hierarchies for highlighting.
9812
4009494e
GM
9813@item W u
9814@kindex W u (Summary)
9815@findex gnus-article-unsplit-urls
9816Remove newlines from within URLs. Some mailers insert newlines into
9817outgoing email messages to keep lines short. This reformatting can
9818split long URLs onto multiple lines. Repair those URLs by removing
9819the newlines (@code{gnus-article-unsplit-urls}).
9820
9821@item W h
9822@kindex W h (Summary)
9823@findex gnus-article-wash-html
9824Treat @acronym{HTML} (@code{gnus-article-wash-html}). Note that this is
9825usually done automatically by Gnus if the message in question has a
9826@code{Content-Type} header that says that the message is @acronym{HTML}.
9827
9828If a prefix is given, a charset will be asked for. If it is a number,
9829the charset defined in @code{gnus-summary-show-article-charset-alist}
9830(@pxref{Paging the Article}) will be used.
9831
9832@vindex gnus-article-wash-function
9833The default is to use the function specified by
9834@code{mm-text-html-renderer} (@pxref{Display Customization, ,Display
9835Customization, emacs-mime, The Emacs MIME Manual}) to convert the
9836@acronym{HTML}, but this is controlled by the
9837@code{gnus-article-wash-function} variable. Pre-defined functions you
9838can use include:
9839
9840@table @code
9841@item w3
9842Use Emacs/W3.
9843
9844@item w3m
9845Use @uref{http://emacs-w3m.namazu.org/, emacs-w3m}.
9846
9847@item w3m-standalone
9848Use @uref{http://w3m.sourceforge.net/, w3m}.
9849
9850@item links
9851Use @uref{http://links.sf.net/, Links}.
9852
9853@item lynx
9854Use @uref{http://lynx.isc.org/, Lynx}.
9855
9856@item html2text
9857Use html2text---a simple @acronym{HTML} converter included with Gnus.
9858
9859@end table
9860
9861@item W b
9862@kindex W b (Summary)
9863@findex gnus-article-add-buttons
9864Add clickable buttons to the article (@code{gnus-article-add-buttons}).
9865@xref{Article Buttons}.
9866
9867@item W B
9868@kindex W B (Summary)
9869@findex gnus-article-add-buttons-to-head
9870Add clickable buttons to the article headers
9871(@code{gnus-article-add-buttons-to-head}).
9872
9873@item W p
9874@kindex W p (Summary)
9875@findex gnus-article-verify-x-pgp-sig
9876Verify a signed control message
9877(@code{gnus-article-verify-x-pgp-sig}). Control messages such as
9878@code{newgroup} and @code{checkgroups} are usually signed by the
9879hierarchy maintainer. You need to add the @acronym{PGP} public key of
9880the maintainer to your keyring to verify the
9881message.@footnote{@acronym{PGP} keys for many hierarchies are
9882available at @uref{ftp://ftp.isc.org/pub/pgpcontrol/README.html}}
9883
9884@item W s
9885@kindex W s (Summary)
9886@findex gnus-summary-force-verify-and-decrypt
9887Verify a signed (@acronym{PGP}, @acronym{PGP/MIME} or
9888@acronym{S/MIME}) message
9889(@code{gnus-summary-force-verify-and-decrypt}). @xref{Security}.
9890
9891@item W a
9892@kindex W a (Summary)
9893@findex gnus-article-strip-headers-in-body
9894Strip headers like the @code{X-No-Archive} header from the beginning of
9895article bodies (@code{gnus-article-strip-headers-in-body}).
9896
9897@item W E l
9898@kindex W E l (Summary)
9899@findex gnus-article-strip-leading-blank-lines
9900Remove all blank lines from the beginning of the article
9901(@code{gnus-article-strip-leading-blank-lines}).
9902
9903@item W E m
9904@kindex W E m (Summary)
9905@findex gnus-article-strip-multiple-blank-lines
9906Replace all blank lines with empty lines and then all multiple empty
9907lines with a single empty line.
9908(@code{gnus-article-strip-multiple-blank-lines}).
9909
9910@item W E t
9911@kindex W E t (Summary)
9912@findex gnus-article-remove-trailing-blank-lines
9913Remove all blank lines at the end of the article
9914(@code{gnus-article-remove-trailing-blank-lines}).
9915
9916@item W E a
9917@kindex W E a (Summary)
9918@findex gnus-article-strip-blank-lines
9919Do all the three commands above
9920(@code{gnus-article-strip-blank-lines}).
9921
9922@item W E A
9923@kindex W E A (Summary)
9924@findex gnus-article-strip-all-blank-lines
9925Remove all blank lines
9926(@code{gnus-article-strip-all-blank-lines}).
9927
9928@item W E s
9929@kindex W E s (Summary)
9930@findex gnus-article-strip-leading-space
9931Remove all white space from the beginning of all lines of the article
9932body (@code{gnus-article-strip-leading-space}).
9933
9934@item W E e
9935@kindex W E e (Summary)
9936@findex gnus-article-strip-trailing-space
9937Remove all white space from the end of all lines of the article
9938body (@code{gnus-article-strip-trailing-space}).
9939
9940@end table
9941
9942@xref{Customizing Articles}, for how to wash articles automatically.
9943
9944
9945@node Article Header
9946@subsection Article Header
9947
9948These commands perform various transformations of article header.
9949
9950@table @kbd
9951
9952@item W G u
9953@kindex W G u (Summary)
9954@findex gnus-article-treat-unfold-headers
9955Unfold folded header lines (@code{gnus-article-treat-unfold-headers}).
9956
9957@item W G n
9958@kindex W G n (Summary)
9959@findex gnus-article-treat-fold-newsgroups
9960Fold the @code{Newsgroups} and @code{Followup-To} headers
9961(@code{gnus-article-treat-fold-newsgroups}).
9962
9963@item W G f
9964@kindex W G f (Summary)
9965@findex gnus-article-treat-fold-headers
9966Fold all the message headers
9967(@code{gnus-article-treat-fold-headers}).
9968
9969@item W E w
9970@kindex W E w (Summary)
9971@findex gnus-article-remove-leading-whitespace
9972Remove excessive whitespace from all headers
9973(@code{gnus-article-remove-leading-whitespace}).
9974
9975@end table
9976
9977
9978@node Article Buttons
9979@subsection Article Buttons
9980@cindex buttons
9981
9982People often include references to other stuff in articles, and it would
9983be nice if Gnus could just fetch whatever it is that people talk about
9984with the minimum of fuzz when you hit @kbd{RET} or use the middle mouse
9985button on these references.
9986
9987@vindex gnus-button-man-handler
9988Gnus adds @dfn{buttons} to certain standard references by default:
9989Well-formed URLs, mail addresses, Message-IDs, Info links, man pages and
9990Emacs or Gnus related references. This is controlled by two variables,
9991one that handles article bodies and one that handles article heads:
9992
9993@table @code
9994
9995@item gnus-button-alist
9996@vindex gnus-button-alist
9997This is an alist where each entry has this form:
9998
9999@lisp
10000(@var{regexp} @var{button-par} @var{use-p} @var{function} @var{data-par})
10001@end lisp
10002
10003@table @var
10004
10005@item regexp
10006All text that match this regular expression (case insensitive) will be
10007considered an external reference. Here's a typical regexp that matches
10008embedded URLs: @samp{<URL:\\([^\n\r>]*\\)>}. This can also be a
10009variable containing a regexp, useful variables to use include
10010@code{gnus-button-url-regexp} and @code{gnus-button-mid-or-mail-regexp}.
10011
10012@item button-par
10013Gnus has to know which parts of the matches is to be highlighted. This
10014is a number that says what sub-expression of the regexp is to be
10015highlighted. If you want it all highlighted, you use 0 here.
10016
10017@item use-p
10018This form will be @code{eval}ed, and if the result is non-@code{nil},
10019this is considered a match. This is useful if you want extra sifting to
10020avoid false matches. Often variables named
10021@code{gnus-button-@var{*}-level} are used here, @xref{Article Button
10022Levels}, but any other form may be used too.
10023
10024@c @code{use-p} is @code{eval}ed only if @code{regexp} matches.
10025
10026@item function
10027This function will be called when you click on this button.
10028
10029@item data-par
10030As with @var{button-par}, this is a sub-expression number, but this one
10031says which part of the match is to be sent as data to @var{function}.
10032
10033@end table
10034
10035So the full entry for buttonizing URLs is then
10036
10037@lisp
10038("<URL:\\([^\n\r>]*\\)>" 0 t gnus-button-url 1)
10039@end lisp
10040
10041@item gnus-header-button-alist
10042@vindex gnus-header-button-alist
10043This is just like the other alist, except that it is applied to the
10044article head only, and that each entry has an additional element that is
10045used to say what headers to apply the buttonize coding to:
10046
10047@lisp
10048(@var{header} @var{regexp} @var{button-par} @var{use-p} @var{function} @var{data-par})
10049@end lisp
10050
10051@var{header} is a regular expression.
10052@end table
10053
10054@subsubsection Related variables and functions
10055
10056@table @code
10057@item gnus-button-@var{*}-level
10058@xref{Article Button Levels}.
10059
10060@c Stuff related to gnus-button-browse-level
10061
10062@item gnus-button-url-regexp
10063@vindex gnus-button-url-regexp
10064A regular expression that matches embedded URLs. It is used in the
10065default values of the variables above.
10066
10067@c Stuff related to gnus-button-man-level
10068
10069@item gnus-button-man-handler
10070@vindex gnus-button-man-handler
10071The function to use for displaying man pages. It must take at least one
10072argument with a string naming the man page.
10073
10074@c Stuff related to gnus-button-message-level
10075
10076@item gnus-button-mid-or-mail-regexp
10077@vindex gnus-button-mid-or-mail-regexp
10078Regular expression that matches a message ID or a mail address.
10079
10080@item gnus-button-prefer-mid-or-mail
10081@vindex gnus-button-prefer-mid-or-mail
10082This variable determines what to do when the button on a string as
10083@samp{foo123@@bar.invalid} is pushed. Strings like this can be either a
10084message ID or a mail address. If it is one of the symbols @code{mid} or
10085@code{mail}, Gnus will always assume that the string is a message ID or
10086a mail address, respectively. If this variable is set to the symbol
10087@code{ask}, always query the user what to do. If it is a function, this
10088function will be called with the string as its only argument. The
10089function must return @code{mid}, @code{mail}, @code{invalid} or
10090@code{ask}. The default value is the function
10091@code{gnus-button-mid-or-mail-heuristic}.
10092
10093@item gnus-button-mid-or-mail-heuristic
10094@findex gnus-button-mid-or-mail-heuristic
10095Function that guesses whether its argument is a message ID or a mail
10096address. Returns @code{mid} if it's a message IDs, @code{mail} if
10097it's a mail address, @code{ask} if unsure and @code{invalid} if the
10098string is invalid.
10099
10100@item gnus-button-mid-or-mail-heuristic-alist
10101@vindex gnus-button-mid-or-mail-heuristic-alist
10102An alist of @code{(RATE . REGEXP)} pairs used by the function
10103@code{gnus-button-mid-or-mail-heuristic}.
10104
10105@c Stuff related to gnus-button-tex-level
10106
10107@item gnus-button-ctan-handler
10108@findex gnus-button-ctan-handler
10109The function to use for displaying CTAN links. It must take one
10110argument, the string naming the URL.
10111
10112@item gnus-ctan-url
10113@vindex gnus-ctan-url
10114Top directory of a CTAN (Comprehensive TeX Archive Network) archive used
10115by @code{gnus-button-ctan-handler}.
10116
10117@c Misc stuff
10118
10119@item gnus-article-button-face
10120@vindex gnus-article-button-face
10121Face used on buttons.
10122
10123@item gnus-article-mouse-face
10124@vindex gnus-article-mouse-face
10125Face used when the mouse cursor is over a button.
10126
10127@end table
10128
10129@xref{Customizing Articles}, for how to buttonize articles automatically.
10130
10131
10132@node Article Button Levels
10133@subsection Article button levels
10134@cindex button levels
10135The higher the value of the variables @code{gnus-button-@var{*}-level},
10136the more buttons will appear. If the level is zero, no corresponding
10137buttons are displayed. With the default value (which is 5) you should
10138already see quite a lot of buttons. With higher levels, you will see
10139more buttons, but you may also get more false positives. To avoid them,
10140you can set the variables @code{gnus-button-@var{*}-level} local to
10141specific groups (@pxref{Group Parameters}). Here's an example for the
10142variable @code{gnus-parameters}:
10143
10144@lisp
10145;; @r{increase @code{gnus-button-*-level} in some groups:}
10146(setq gnus-parameters
10147 '(("\\<\\(emacs\\|gnus\\)\\>" (gnus-button-emacs-level 10))
10148 ("\\<unix\\>" (gnus-button-man-level 10))
10149 ("\\<tex\\>" (gnus-button-tex-level 10))))
10150@end lisp
10151
10152@table @code
10153
10154@item gnus-button-browse-level
10155@vindex gnus-button-browse-level
10156Controls the display of references to message IDs, mail addresses and
10157news URLs. Related variables and functions include
10158@code{gnus-button-url-regexp}, @code{browse-url}, and
10159@code{browse-url-browser-function}.
10160
10161@item gnus-button-emacs-level
10162@vindex gnus-button-emacs-level
10163Controls the display of Emacs or Gnus references. Related functions are
10164@code{gnus-button-handle-custom},
10165@code{gnus-button-handle-describe-function},
10166@code{gnus-button-handle-describe-variable},
10167@code{gnus-button-handle-symbol},
10168@code{gnus-button-handle-describe-key},
10169@code{gnus-button-handle-apropos},
10170@code{gnus-button-handle-apropos-command},
10171@code{gnus-button-handle-apropos-variable},
10172@code{gnus-button-handle-apropos-documentation}, and
10173@code{gnus-button-handle-library}.
10174
10175@item gnus-button-man-level
10176@vindex gnus-button-man-level
10177Controls the display of references to (Unix) man pages.
10178See @code{gnus-button-man-handler}.
10179
10180@item gnus-button-message-level
10181@vindex gnus-button-message-level
10182Controls the display of message IDs, mail addresses and news URLs.
10183Related variables and functions include
10184@code{gnus-button-mid-or-mail-regexp},
10185@code{gnus-button-prefer-mid-or-mail},
10186@code{gnus-button-mid-or-mail-heuristic}, and
10187@code{gnus-button-mid-or-mail-heuristic-alist}.
10188
10189@item gnus-button-tex-level
10190@vindex gnus-button-tex-level
10191Controls the display of references to @TeX{} or LaTeX stuff, e.g. for CTAN
10192URLs. See the variables @code{gnus-ctan-url},
10193@code{gnus-button-ctan-handler},
10194@code{gnus-button-ctan-directory-regexp}, and
10195@code{gnus-button-handle-ctan-bogus-regexp}.
10196
10197@end table
10198
10199
10200@node Article Date
10201@subsection Article Date
10202
10203The date is most likely generated in some obscure timezone you've never
10204heard of, so it's quite nice to be able to find out what the time was
10205when the article was sent.
10206
10207@table @kbd
10208
10209@item W T u
10210@kindex W T u (Summary)
10211@findex gnus-article-date-ut
10212Display the date in UT (aka. GMT, aka ZULU)
10213(@code{gnus-article-date-ut}).
10214
10215@item W T i
10216@kindex W T i (Summary)
10217@findex gnus-article-date-iso8601
10218@cindex ISO 8601
10219Display the date in international format, aka. ISO 8601
10220(@code{gnus-article-date-iso8601}).
10221
10222@item W T l
10223@kindex W T l (Summary)
10224@findex gnus-article-date-local
10225Display the date in the local timezone (@code{gnus-article-date-local}).
10226
10227@item W T p
10228@kindex W T p (Summary)
10229@findex gnus-article-date-english
10230Display the date in a format that's easily pronounceable in English
10231(@code{gnus-article-date-english}).
10232
10233@item W T s
10234@kindex W T s (Summary)
10235@vindex gnus-article-time-format
10236@findex gnus-article-date-user
10237@findex format-time-string
10238Display the date using a user-defined format
10239(@code{gnus-article-date-user}). The format is specified by the
10240@code{gnus-article-time-format} variable, and is a string that's passed
10241to @code{format-time-string}. See the documentation of that variable
10242for a list of possible format specs.
10243
10244@item W T e
10245@kindex W T e (Summary)
10246@findex gnus-article-date-lapsed
10247@findex gnus-start-date-timer
10248@findex gnus-stop-date-timer
10249Say how much time has elapsed between the article was posted and now
10250(@code{gnus-article-date-lapsed}). It looks something like:
10251
10252@example
10253X-Sent: 6 weeks, 4 days, 1 hour, 3 minutes, 8 seconds ago
10254@end example
10255
10256@vindex gnus-article-date-lapsed-new-header
10257The value of @code{gnus-article-date-lapsed-new-header} determines
10258whether this header will just be added below the old Date one, or will
10259replace it.
10260
10261An advantage of using Gnus to read mail is that it converts simple bugs
10262into wonderful absurdities.
10263
10264If you want to have this line updated continually, you can put
10265
10266@lisp
10267(gnus-start-date-timer)
10268@end lisp
10269
10270in your @file{~/.gnus.el} file, or you can run it off of some hook. If
10271you want to stop the timer, you can use the @code{gnus-stop-date-timer}
10272command.
10273
10274@item W T o
10275@kindex W T o (Summary)
10276@findex gnus-article-date-original
10277Display the original date (@code{gnus-article-date-original}). This can
10278be useful if you normally use some other conversion function and are
10279worried that it might be doing something totally wrong. Say, claiming
10280that the article was posted in 1854. Although something like that is
10281@emph{totally} impossible. Don't you trust me? *titter*
10282
10283@end table
10284
10285@xref{Customizing Articles}, for how to display the date in your
10286preferred format automatically.
10287
10288
10289@node Article Display
10290@subsection Article Display
10291@cindex picons
10292@cindex x-face
10293@cindex smileys
10294
10295These commands add various frivolous display gimmicks to the article
10296buffer in Emacs versions that support them.
10297
10298@code{X-Face} headers are small black-and-white images supplied by the
10299message headers (@pxref{X-Face}).
10300
10301@code{Face} headers are small colored images supplied by the message
10302headers (@pxref{Face}).
10303
10304Smileys are those little @samp{:-)} symbols that people like to litter
10305their messages with (@pxref{Smileys}).
10306
10307Picons, on the other hand, reside on your own system, and Gnus will
10308try to match the headers to what you have (@pxref{Picons}).
10309
10310All these functions are toggles---if the elements already exist,
10311they'll be removed.
10312
10313@table @kbd
10314@item W D x
10315@kindex W D x (Summary)
10316@findex gnus-article-display-x-face
10317Display an @code{X-Face} in the @code{From} header.
10318(@code{gnus-article-display-x-face}).
10319
10320@item W D d
10321@kindex W D d (Summary)
10322@findex gnus-article-display-face
10323Display a @code{Face} in the @code{From} header.
10324(@code{gnus-article-display-face}).
10325
10326@item W D s
10327@kindex W D s (Summary)
10328@findex gnus-treat-smiley
10329Display smileys (@code{gnus-treat-smiley}).
10330
10331@item W D f
10332@kindex W D f (Summary)
10333@findex gnus-treat-from-picon
10334Piconify the @code{From} header (@code{gnus-treat-from-picon}).
10335
10336@item W D m
10337@kindex W D m (Summary)
10338@findex gnus-treat-mail-picon
10339Piconify all mail headers (i. e., @code{Cc}, @code{To})
10340(@code{gnus-treat-mail-picon}).
10341
10342@item W D n
10343@kindex W D n (Summary)
10344@findex gnus-treat-newsgroups-picon
10345Piconify all news headers (i. e., @code{Newsgroups} and
10346@code{Followup-To}) (@code{gnus-treat-newsgroups-picon}).
10347
10348@item W D D
10349@kindex W D D (Summary)
10350@findex gnus-article-remove-images
10351Remove all images from the article buffer
10352(@code{gnus-article-remove-images}).
10353
25f28806
LMI
10354@item W D W
10355@kindex W D W (Summary)
10356@findex gnus-html-show-images
10357If you're reading an @acronym{HTML} article rendered with
10358@code{gnus-article-html}, then you can insert any blocked images in
10359the buffer with this command.
10360(@code{gnus-html-show-images}).
10361
4009494e
GM
10362@end table
10363
10364
10365
10366@node Article Signature
10367@subsection Article Signature
10368@cindex signatures
10369@cindex article signature
10370
10371@vindex gnus-signature-separator
10372Each article is divided into two parts---the head and the body. The
10373body can be divided into a signature part and a text part. The variable
10374that says what is to be considered a signature is
10375@code{gnus-signature-separator}. This is normally the standard
10376@samp{^-- $} as mandated by son-of-RFC 1036. However, many people use
10377non-standard signature separators, so this variable can also be a list
10378of regular expressions to be tested, one by one. (Searches are done
10379from the end of the body towards the beginning.) One likely value is:
10380
10381@lisp
10382(setq gnus-signature-separator
10383 '("^-- $" ; @r{The standard}
10384 "^-- *$" ; @r{A common mangling}
10385 "^-------*$" ; @r{Many people just use a looong}
10386 ; @r{line of dashes. Shame!}
10387 "^ *--------*$" ; @r{Double-shame!}
10388 "^________*$" ; @r{Underscores are also popular}
10389 "^========*$")) ; @r{Pervert!}
10390@end lisp
10391
10392The more permissive you are, the more likely it is that you'll get false
10393positives.
10394
10395@vindex gnus-signature-limit
10396@code{gnus-signature-limit} provides a limit to what is considered a
10397signature when displaying articles.
10398
10399@enumerate
10400@item
10401If it is an integer, no signature may be longer (in characters) than
10402that integer.
10403@item
10404If it is a floating point number, no signature may be longer (in lines)
10405than that number.
10406@item
10407If it is a function, the function will be called without any parameters,
10408and if it returns @code{nil}, there is no signature in the buffer.
10409@item
10410If it is a string, it will be used as a regexp. If it matches, the text
10411in question is not a signature.
10412@end enumerate
10413
10414This variable can also be a list where the elements may be of the types
10415listed above. Here's an example:
10416
10417@lisp
10418(setq gnus-signature-limit
10419 '(200.0 "^---*Forwarded article"))
10420@end lisp
10421
10422This means that if there are more than 200 lines after the signature
10423separator, or the text after the signature separator is matched by
10424the regular expression @samp{^---*Forwarded article}, then it isn't a
10425signature after all.
10426
10427
10428@node Article Miscellanea
10429@subsection Article Miscellanea
10430
10431@table @kbd
10432@item A t
10433@kindex A t (Summary)
10434@findex gnus-article-babel
10435Translate the article from one language to another
10436(@code{gnus-article-babel}).
10437
10438@end table
10439
10440
10441@node MIME Commands
10442@section MIME Commands
10443@cindex MIME decoding
10444@cindex attachments
10445@cindex viewing attachments
10446
10447The following commands all understand the numerical prefix. For
01c52d31 10448instance, @kbd{3 K v} means ``view the third @acronym{MIME} part''.
4009494e
GM
10449
10450@table @kbd
10451@item b
10452@itemx K v
10453@kindex b (Summary)
10454@kindex K v (Summary)
10455View the @acronym{MIME} part.
10456
10457@item K o
10458@kindex K o (Summary)
10459Save the @acronym{MIME} part.
10460
01c52d31
MB
10461@item K O
10462@kindex K O (Summary)
10463Prompt for a file name, then save the @acronym{MIME} part and strip it
10464from the article. The stripped @acronym{MIME} object will be referred
10465via the message/external-body @acronym{MIME} type.
10466
10467@item K r
10468@kindex K r (Summary)
10469Replace the @acronym{MIME} part with an external body.
10470
10471@item K d
10472@kindex K d (Summary)
10473Delete the @acronym{MIME} part and add some information about the
10474removed part.
10475
4009494e
GM
10476@item K c
10477@kindex K c (Summary)
10478Copy the @acronym{MIME} part.
10479
10480@item K e
10481@kindex K e (Summary)
10482View the @acronym{MIME} part externally.
10483
10484@item K i
10485@kindex K i (Summary)
10486View the @acronym{MIME} part internally.
10487
10488@item K |
10489@kindex K | (Summary)
10490Pipe the @acronym{MIME} part to an external command.
10491@end table
10492
10493The rest of these @acronym{MIME} commands do not use the numerical prefix in
10494the same manner:
10495
10496@table @kbd
9b3ebcb6
MB
10497@item K H
10498@kindex K H (Summary)
10499@findex gnus-article-browse-html-article
10500View @samp{text/html} parts of the current article with a WWW browser.
1d4d7664
KY
10501Inline images embedded in a message using the @code{cid} scheme, as they
10502are generally considered to be safe, will be processed properly. The
10503message header is added to the beginning of every @acronym{HTML} part
10504unless the prefix argument is given.
9b3ebcb6 10505
1d4d7664
KY
10506Warning: Spammers use links to images (using the @code{http} scheme) in
10507@acronym{HTML} articles to verify whether you have read the message. As
10508this command passes the @acronym{HTML} content to the browser without
10509eliminating these ``web bugs'' you should only use it for mails from
10510trusted senders.
9b3ebcb6
MB
10511
10512If you always want to display @acronym{HTML} parts in the browser, set
10513@code{mm-text-html-renderer} to @code{nil}.
10514
1d4d7664
KY
10515This command creates temporary files to pass @acronym{HTML} contents
10516including images if any to the browser, and deletes them when exiting
10517the group (if you want).
10518
4009494e
GM
10519@item K b
10520@kindex K b (Summary)
10521Make all the @acronym{MIME} parts have buttons in front of them. This is
10522mostly useful if you wish to save (or perform other actions) on inlined
10523parts.
10524
10525@item K m
10526@kindex K m (Summary)
10527@findex gnus-summary-repair-multipart
10528Some multipart messages are transmitted with missing or faulty headers.
10529This command will attempt to ``repair'' these messages so that they can
10530be viewed in a more pleasant manner
10531(@code{gnus-summary-repair-multipart}).
10532
10533@item X m
10534@kindex X m (Summary)
10535@findex gnus-summary-save-parts
10536Save all parts matching a @acronym{MIME} type to a directory
10537(@code{gnus-summary-save-parts}). Understands the process/prefix
10538convention (@pxref{Process/Prefix}).
10539
10540@item M-t
10541@kindex M-t (Summary)
10542@findex gnus-summary-toggle-display-buttonized
10543Toggle the buttonized display of the article buffer
10544(@code{gnus-summary-toggle-display-buttonized}).
10545
10546@item W M w
10547@kindex W M w (Summary)
10548@findex gnus-article-decode-mime-words
10549Decode RFC 2047-encoded words in the article headers
10550(@code{gnus-article-decode-mime-words}).
10551
10552@item W M c
10553@kindex W M c (Summary)
10554@findex gnus-article-decode-charset
10555Decode encoded article bodies as well as charsets
10556(@code{gnus-article-decode-charset}).
10557
10558This command looks in the @code{Content-Type} header to determine the
10559charset. If there is no such header in the article, you can give it a
10560prefix, which will prompt for the charset to decode as. In regional
10561groups where people post using some common encoding (but do not
10562include @acronym{MIME} headers), you can set the @code{charset} group/topic
10563parameter to the required charset (@pxref{Group Parameters}).
10564
10565@item W M v
10566@kindex W M v (Summary)
10567@findex gnus-mime-view-all-parts
10568View all the @acronym{MIME} parts in the current article
10569(@code{gnus-mime-view-all-parts}).
10570
10571@end table
10572
10573Relevant variables:
10574
10575@table @code
10576@item gnus-ignored-mime-types
10577@vindex gnus-ignored-mime-types
10578This is a list of regexps. @acronym{MIME} types that match a regexp from
10579this list will be completely ignored by Gnus. The default value is
10580@code{nil}.
10581
10582To have all Vcards be ignored, you'd say something like this:
10583
10584@lisp
10585(setq gnus-ignored-mime-types
10586 '("text/x-vcard"))
10587@end lisp
10588
10589@item gnus-article-loose-mime
10590@vindex gnus-article-loose-mime
10591If non-@code{nil}, Gnus won't require the @samp{MIME-Version} header
10592before interpreting the message as a @acronym{MIME} message. This helps
10593when reading messages from certain broken mail user agents. The
b890d447 10594default is @code{t}.
4009494e
GM
10595
10596@item gnus-article-emulate-mime
10597@vindex gnus-article-emulate-mime
10598@cindex uuencode
10599@cindex yEnc
10600There are other, non-@acronym{MIME} encoding methods used. The most common
10601is @samp{uuencode}, but yEncode is also getting to be popular. If
10602this variable is non-@code{nil}, Gnus will look in message bodies to
10603see if it finds these encodings, and if so, it'll run them through the
10604Gnus @acronym{MIME} machinery. The default is @code{t}. Only
10605single-part yEnc encoded attachments can be decoded. There's no support
10606for encoding in Gnus.
10607
10608@item gnus-unbuttonized-mime-types
10609@vindex gnus-unbuttonized-mime-types
10610This is a list of regexps. @acronym{MIME} types that match a regexp from
10611this list won't have @acronym{MIME} buttons inserted unless they aren't
10612displayed or this variable is overridden by
10613@code{gnus-buttonized-mime-types}. The default value is
10614@code{(".*/.*")}. This variable is only used when
10615@code{gnus-inhibit-mime-unbuttonizing} is @code{nil}.
10616
10617@item gnus-buttonized-mime-types
10618@vindex gnus-buttonized-mime-types
10619This is a list of regexps. @acronym{MIME} types that match a regexp from
10620this list will have @acronym{MIME} buttons inserted unless they aren't
10621displayed. This variable overrides
10622@code{gnus-unbuttonized-mime-types}. The default value is @code{nil}.
10623This variable is only used when @code{gnus-inhibit-mime-unbuttonizing}
10624is @code{nil}.
10625
10626To see e.g. security buttons but no other buttons, you could set this
10627variable to @code{("multipart/signed")} and leave
10628@code{gnus-unbuttonized-mime-types} at the default value.
10629
10630You could also add @code{"multipart/alternative"} to this list to
10631display radio buttons that allow you to choose one of two media types
10632those mails include. See also @code{mm-discouraged-alternatives}
10633(@pxref{Display Customization, ,Display Customization, emacs-mime, The
10634Emacs MIME Manual}).
10635
10636@item gnus-inhibit-mime-unbuttonizing
10637@vindex gnus-inhibit-mime-unbuttonizing
10638If this is non-@code{nil}, then all @acronym{MIME} parts get buttons. The
10639default value is @code{nil}.
10640
10641@item gnus-article-mime-part-function
10642@vindex gnus-article-mime-part-function
10643For each @acronym{MIME} part, this function will be called with the @acronym{MIME}
10644handle as the parameter. The function is meant to be used to allow
10645users to gather information from the article (e. g., add Vcard info to
10646the bbdb database) or to do actions based on parts (e. g., automatically
10647save all jpegs into some directory).
10648
10649Here's an example function the does the latter:
10650
10651@lisp
10652(defun my-save-all-jpeg-parts (handle)
10653 (when (equal (car (mm-handle-type handle)) "image/jpeg")
10654 (with-temp-buffer
10655 (insert (mm-get-part handle))
10656 (write-region (point-min) (point-max)
10657 (read-file-name "Save jpeg to: ")))))
10658(setq gnus-article-mime-part-function
10659 'my-save-all-jpeg-parts)
10660@end lisp
10661
10662@vindex gnus-mime-multipart-functions
10663@item gnus-mime-multipart-functions
10664Alist of @acronym{MIME} multipart types and functions to handle them.
10665
10666@vindex gnus-mime-display-multipart-alternative-as-mixed
10667@item gnus-mime-display-multipart-alternative-as-mixed
10668Display "multipart/alternative" parts as "multipart/mixed".
10669
10670@vindex gnus-mime-display-multipart-related-as-mixed
10671@item gnus-mime-display-multipart-related-as-mixed
10672Display "multipart/related" parts as "multipart/mixed".
10673
9b3ebcb6 10674If displaying @samp{text/html} is discouraged, see
4009494e
GM
10675@code{mm-discouraged-alternatives}, images or other material inside a
10676"multipart/related" part might be overlooked when this variable is
10677@code{nil}. @ref{Display Customization, Display Customization, ,
10678emacs-mime, Emacs-Mime Manual}.
10679
10680@vindex gnus-mime-display-multipart-as-mixed
10681@item gnus-mime-display-multipart-as-mixed
10682Display "multipart" parts as "multipart/mixed". If @code{t}, it
10683overrides @code{nil} values of
10684@code{gnus-mime-display-multipart-alternative-as-mixed} and
10685@code{gnus-mime-display-multipart-related-as-mixed}.
10686
10687@vindex mm-file-name-rewrite-functions
10688@item mm-file-name-rewrite-functions
10689List of functions used for rewriting file names of @acronym{MIME} parts.
10690Each function takes a file name as input and returns a file name.
10691
10692Ready-made functions include@*
10693@code{mm-file-name-delete-whitespace},
10694@code{mm-file-name-trim-whitespace},
10695@code{mm-file-name-collapse-whitespace}, and
10696@code{mm-file-name-replace-whitespace}. The later uses the value of
10697the variable @code{mm-file-name-replace-whitespace} to replace each
10698whitespace character in a file name with that string; default value
10699is @code{"_"} (a single underscore).
10700@findex mm-file-name-delete-whitespace
10701@findex mm-file-name-trim-whitespace
10702@findex mm-file-name-collapse-whitespace
10703@findex mm-file-name-replace-whitespace
10704@vindex mm-file-name-replace-whitespace
10705
10706The standard functions @code{capitalize}, @code{downcase},
10707@code{upcase}, and @code{upcase-initials} may be useful, too.
10708
10709Everybody knows that whitespace characters in file names are evil,
10710except those who don't know. If you receive lots of attachments from
10711such unenlightened users, you can make live easier by adding
10712
10713@lisp
10714(setq mm-file-name-rewrite-functions
10715 '(mm-file-name-trim-whitespace
10716 mm-file-name-collapse-whitespace
10717 mm-file-name-replace-whitespace))
10718@end lisp
10719
10720@noindent
10721to your @file{~/.gnus.el} file.
10722
10723@end table
10724
10725
10726@node Charsets
10727@section Charsets
10728@cindex charsets
10729
10730People use different charsets, and we have @acronym{MIME} to let us know what
10731charsets they use. Or rather, we wish we had. Many people use
10732newsreaders and mailers that do not understand or use @acronym{MIME}, and
10733just send out messages without saying what character sets they use. To
10734help a bit with this, some local news hierarchies have policies that say
10735what character set is the default. For instance, the @samp{fj}
10736hierarchy uses @code{iso-2022-jp}.
10737
10738@vindex gnus-group-charset-alist
10739This knowledge is encoded in the @code{gnus-group-charset-alist}
10740variable, which is an alist of regexps (use the first item to match full
10741group names) and default charsets to be used when reading these groups.
10742
10743@vindex gnus-newsgroup-ignored-charsets
10744In addition, some people do use soi-disant @acronym{MIME}-aware agents that
10745aren't. These blithely mark messages as being in @code{iso-8859-1}
10746even if they really are in @code{koi-8}. To help here, the
10747@code{gnus-newsgroup-ignored-charsets} variable can be used. The
10748charsets that are listed here will be ignored. The variable can be
10749set on a group-by-group basis using the group parameters (@pxref{Group
10750Parameters}). The default value is @code{(unknown-8bit x-unknown)},
10751which includes values some agents insist on having in there.
10752
10753@vindex gnus-group-posting-charset-alist
10754When posting, @code{gnus-group-posting-charset-alist} is used to
10755determine which charsets should not be encoded using the @acronym{MIME}
10756encodings. For instance, some hierarchies discourage using
10757quoted-printable header encoding.
10758
10759This variable is an alist of regexps and permitted unencoded charsets
10760for posting. Each element of the alist has the form @code{(}@var{test
10761header body-list}@code{)}, where:
10762
10763@table @var
10764@item test
10765is either a regular expression matching the newsgroup header or a
10766variable to query,
10767@item header
10768is the charset which may be left unencoded in the header (@code{nil}
10769means encode all charsets),
10770@item body-list
10771is a list of charsets which may be encoded using 8bit content-transfer
10772encoding in the body, or one of the special values @code{nil} (always
10773encode using quoted-printable) or @code{t} (always use 8bit).
10774@end table
10775
10776@cindex Russian
10777@cindex koi8-r
10778@cindex koi8-u
10779@cindex iso-8859-5
10780@cindex coding system aliases
10781@cindex preferred charset
10782
10783@xref{Encoding Customization, , Encoding Customization, emacs-mime,
10784The Emacs MIME Manual}, for additional variables that control which
10785MIME charsets are used when sending messages.
10786
10787Other charset tricks that may be useful, although not Gnus-specific:
10788
10789If there are several @acronym{MIME} charsets that encode the same Emacs
10790charset, you can choose what charset to use by saying the following:
10791
10792@lisp
10793(put-charset-property 'cyrillic-iso8859-5
10794 'preferred-coding-system 'koi8-r)
10795@end lisp
10796
10797This means that Russian will be encoded using @code{koi8-r} instead of
10798the default @code{iso-8859-5} @acronym{MIME} charset.
10799
10800If you want to read messages in @code{koi8-u}, you can cheat and say
10801
10802@lisp
10803(define-coding-system-alias 'koi8-u 'koi8-r)
10804@end lisp
10805
10806This will almost do the right thing.
10807
10808And finally, to read charsets like @code{windows-1251}, you can say
10809something like
10810
10811@lisp
10812(codepage-setup 1251)
10813(define-coding-system-alias 'windows-1251 'cp1251)
10814@end lisp
10815
10816
10817@node Article Commands
10818@section Article Commands
10819
10820@table @kbd
10821
10822@item A P
10823@cindex PostScript
10824@cindex printing
10825@kindex A P (Summary)
10826@vindex gnus-ps-print-hook
10827@findex gnus-summary-print-article
10828Generate and print a PostScript image of the article buffer
10829(@code{gnus-summary-print-article}). @code{gnus-ps-print-hook} will
10830be run just before printing the buffer. An alternative way to print
10831article is to use Muttprint (@pxref{Saving Articles}).
10832
10833@end table
10834
10835
10836@node Summary Sorting
10837@section Summary Sorting
10838@cindex summary sorting
10839
10840You can have the summary buffer sorted in various ways, even though I
10841can't really see why you'd want that.
10842
10843@table @kbd
10844
10845@item C-c C-s C-n
10846@kindex C-c C-s C-n (Summary)
10847@findex gnus-summary-sort-by-number
10848Sort by article number (@code{gnus-summary-sort-by-number}).
10849
6ecfe5c2
MB
10850@item C-c C-s C-m C-n
10851@kindex C-c C-s C-n (Summary)
10852@findex gnus-summary-sort-by-most-recent-number
10853Sort by most recent article number
10854(@code{gnus-summary-sort-by-most-recent-number}).
10855
4009494e
GM
10856@item C-c C-s C-a
10857@kindex C-c C-s C-a (Summary)
10858@findex gnus-summary-sort-by-author
10859Sort by author (@code{gnus-summary-sort-by-author}).
10860
01c52d31
MB
10861@item C-c C-s C-t
10862@kindex C-c C-s C-t (Summary)
10863@findex gnus-summary-sort-by-recipient
10864Sort by recipient (@code{gnus-summary-sort-by-recipient}).
10865
4009494e
GM
10866@item C-c C-s C-s
10867@kindex C-c C-s C-s (Summary)
10868@findex gnus-summary-sort-by-subject
10869Sort by subject (@code{gnus-summary-sort-by-subject}).
10870
10871@item C-c C-s C-d
10872@kindex C-c C-s C-d (Summary)
10873@findex gnus-summary-sort-by-date
10874Sort by date (@code{gnus-summary-sort-by-date}).
10875
6ecfe5c2
MB
10876@item C-c C-s C-m C-d
10877@kindex C-c C-s C-m C-d (Summary)
10878@findex gnus-summary-sort-by-most-recent-date
10879Sort by most recent date (@code{gnus-summary-sort-by-most-recent-date}).
10880
4009494e
GM
10881@item C-c C-s C-l
10882@kindex C-c C-s C-l (Summary)
10883@findex gnus-summary-sort-by-lines
10884Sort by lines (@code{gnus-summary-sort-by-lines}).
10885
10886@item C-c C-s C-c
10887@kindex C-c C-s C-c (Summary)
10888@findex gnus-summary-sort-by-chars
10889Sort by article length (@code{gnus-summary-sort-by-chars}).
10890
10891@item C-c C-s C-i
10892@kindex C-c C-s C-i (Summary)
10893@findex gnus-summary-sort-by-score
10894Sort by score (@code{gnus-summary-sort-by-score}).
10895
10896@item C-c C-s C-r
10897@kindex C-c C-s C-r (Summary)
10898@findex gnus-summary-sort-by-random
10899Randomize (@code{gnus-summary-sort-by-random}).
10900
10901@item C-c C-s C-o
10902@kindex C-c C-s C-o (Summary)
10903@findex gnus-summary-sort-by-original
10904Sort using the default sorting method
10905(@code{gnus-summary-sort-by-original}).
10906@end table
10907
10908These functions will work both when you use threading and when you don't
10909use threading. In the latter case, all summary lines will be sorted,
10910line by line. In the former case, sorting will be done on a
10911root-by-root basis, which might not be what you were looking for. To
10912toggle whether to use threading, type @kbd{T T} (@pxref{Thread
10913Commands}).
10914
6ecfe5c2
MB
10915If a prefix argument if given, the sort order is reversed.
10916
4009494e
GM
10917
10918@node Finding the Parent
10919@section Finding the Parent
10920@cindex parent articles
10921@cindex referring articles
10922
10923@table @kbd
10924@item ^
10925@kindex ^ (Summary)
10926@findex gnus-summary-refer-parent-article
10927If you'd like to read the parent of the current article, and it is not
10928displayed in the summary buffer, you might still be able to. That is,
10929if the current group is fetched by @acronym{NNTP}, the parent hasn't expired
10930and the @code{References} in the current article are not mangled, you
10931can just press @kbd{^} or @kbd{A r}
10932(@code{gnus-summary-refer-parent-article}). If everything goes well,
10933you'll get the parent. If the parent is already displayed in the
10934summary buffer, point will just move to this article.
10935
10936If given a positive numerical prefix, fetch that many articles back into
10937the ancestry. If given a negative numerical prefix, fetch just that
10938ancestor. So if you say @kbd{3 ^}, Gnus will fetch the parent, the
10939grandparent and the grandgrandparent of the current article. If you say
10940@kbd{-3 ^}, Gnus will only fetch the grandgrandparent of the current
10941article.
10942
10943@item A R (Summary)
10944@findex gnus-summary-refer-references
10945@kindex A R (Summary)
10946Fetch all articles mentioned in the @code{References} header of the
10947article (@code{gnus-summary-refer-references}).
10948
10949@item A T (Summary)
10950@findex gnus-summary-refer-thread
10951@kindex A T (Summary)
10952Display the full thread where the current article appears
10953(@code{gnus-summary-refer-thread}). This command has to fetch all the
10954headers in the current group to work, so it usually takes a while. If
10955you do it often, you may consider setting @code{gnus-fetch-old-headers}
10956to @code{invisible} (@pxref{Filling In Threads}). This won't have any
10957visible effects normally, but it'll make this command work a whole lot
10958faster. Of course, it'll make group entry somewhat slow.
10959
10960@vindex gnus-refer-thread-limit
10961The @code{gnus-refer-thread-limit} variable says how many old (i. e.,
10962articles before the first displayed in the current group) headers to
10963fetch when doing this command. The default is 200. If @code{t}, all
10964the available headers will be fetched. This variable can be overridden
10965by giving the @kbd{A T} command a numerical prefix.
10966
10967@item M-^ (Summary)
10968@findex gnus-summary-refer-article
10969@kindex M-^ (Summary)
10970@cindex Message-ID
10971@cindex fetching by Message-ID
10972You can also ask Gnus for an arbitrary article, no matter what group it
10973belongs to. @kbd{M-^} (@code{gnus-summary-refer-article}) will ask you
10974for a @code{Message-ID}, which is one of those long, hard-to-read
10975thingies that look something like @samp{<38o6up$6f2@@hymir.ifi.uio.no>}.
10976You have to get it all exactly right. No fuzzy searches, I'm afraid.
10977
10978Gnus looks for the @code{Message-ID} in the headers that have already
10979been fetched, but also tries all the select methods specified by
10980@code{gnus-refer-article-method} if it is not found.
10981@end table
10982
10983@vindex gnus-refer-article-method
10984If the group you are reading is located on a back end that does not
10985support fetching by @code{Message-ID} very well (like @code{nnspool}),
10986you can set @code{gnus-refer-article-method} to an @acronym{NNTP} method. It
10987would, perhaps, be best if the @acronym{NNTP} server you consult is the one
10988updating the spool you are reading from, but that's not really
10989necessary.
10990
10991It can also be a list of select methods, as well as the special symbol
10992@code{current}, which means to use the current select method. If it
10993is a list, Gnus will try all the methods in the list until it finds a
10994match.
10995
10996Here's an example setting that will first try the current method, and
10997then ask Google if that fails:
10998
10999@lisp
11000(setq gnus-refer-article-method
11001 '(current
11002 (nnweb "google" (nnweb-type google))))
11003@end lisp
11004
11005Most of the mail back ends support fetching by @code{Message-ID}, but
11006do not do a particularly excellent job at it. That is, @code{nnmbox},
11007@code{nnbabyl}, @code{nnmaildir}, @code{nnml}, are able to locate
11008articles from any groups, while @code{nnfolder}, and @code{nnimap} are
11009only able to locate articles that have been posted to the current
11010group. (Anything else would be too time consuming.) @code{nnmh} does
11011not support this at all.
11012
11013
11014@node Alternative Approaches
11015@section Alternative Approaches
11016
11017Different people like to read news using different methods. This being
11018Gnus, we offer a small selection of minor modes for the summary buffers.
11019
11020@menu
11021* Pick and Read:: First mark articles and then read them.
11022* Binary Groups:: Auto-decode all articles.
11023@end menu
11024
11025
11026@node Pick and Read
11027@subsection Pick and Read
11028@cindex pick and read
11029
11030Some newsreaders (like @code{nn} and, uhm, @code{Netnews} on VM/CMS) use
11031a two-phased reading interface. The user first marks in a summary
11032buffer the articles she wants to read. Then she starts reading the
11033articles with just an article buffer displayed.
11034
11035@findex gnus-pick-mode
11036@kindex M-x gnus-pick-mode
11037Gnus provides a summary buffer minor mode that allows
11038this---@code{gnus-pick-mode}. This basically means that a few process
11039mark commands become one-keystroke commands to allow easy marking, and
11040it provides one additional command for switching to the summary buffer.
11041
11042Here are the available keystrokes when using pick mode:
11043
11044@table @kbd
11045@item .
11046@kindex . (Pick)
11047@findex gnus-pick-article-or-thread
11048Pick the article or thread on the current line
11049(@code{gnus-pick-article-or-thread}). If the variable
11050@code{gnus-thread-hide-subtree} is true, then this key selects the
11051entire thread when used at the first article of the thread. Otherwise,
11052it selects just the article. If given a numerical prefix, go to that
11053thread or article and pick it. (The line number is normally displayed
11054at the beginning of the summary pick lines.)
11055
11056@item SPACE
11057@kindex SPACE (Pick)
11058@findex gnus-pick-next-page
11059Scroll the summary buffer up one page (@code{gnus-pick-next-page}). If
11060at the end of the buffer, start reading the picked articles.
11061
11062@item u
11063@kindex u (Pick)
11064@findex gnus-pick-unmark-article-or-thread.
11065Unpick the thread or article
11066(@code{gnus-pick-unmark-article-or-thread}). If the variable
11067@code{gnus-thread-hide-subtree} is true, then this key unpicks the
11068thread if used at the first article of the thread. Otherwise it unpicks
11069just the article. You can give this key a numerical prefix to unpick
11070the thread or article at that line.
11071
11072@item RET
11073@kindex RET (Pick)
11074@findex gnus-pick-start-reading
11075@vindex gnus-pick-display-summary
11076Start reading the picked articles (@code{gnus-pick-start-reading}). If
11077given a prefix, mark all unpicked articles as read first. If
11078@code{gnus-pick-display-summary} is non-@code{nil}, the summary buffer
11079will still be visible when you are reading.
11080
11081@end table
11082
11083All the normal summary mode commands are still available in the
11084pick-mode, with the exception of @kbd{u}. However @kbd{!} is available
11085which is mapped to the same function
11086@code{gnus-summary-tick-article-forward}.
11087
11088If this sounds like a good idea to you, you could say:
11089
11090@lisp
11091(add-hook 'gnus-summary-mode-hook 'gnus-pick-mode)
11092@end lisp
11093
11094@vindex gnus-pick-mode-hook
11095@code{gnus-pick-mode-hook} is run in pick minor mode buffers.
11096
11097@vindex gnus-mark-unpicked-articles-as-read
11098If @code{gnus-mark-unpicked-articles-as-read} is non-@code{nil}, mark
11099all unpicked articles as read. The default is @code{nil}.
11100
11101@vindex gnus-summary-pick-line-format
11102The summary line format in pick mode is slightly different from the
11103standard format. At the beginning of each line the line number is
11104displayed. The pick mode line format is controlled by the
11105@code{gnus-summary-pick-line-format} variable (@pxref{Formatting
11106Variables}). It accepts the same format specs that
11107@code{gnus-summary-line-format} does (@pxref{Summary Buffer Lines}).
11108
11109
11110@node Binary Groups
11111@subsection Binary Groups
11112@cindex binary groups
11113
11114@findex gnus-binary-mode
11115@kindex M-x gnus-binary-mode
11116If you spend much time in binary groups, you may grow tired of hitting
11117@kbd{X u}, @kbd{n}, @kbd{RET} all the time. @kbd{M-x gnus-binary-mode}
11118is a minor mode for summary buffers that makes all ordinary Gnus article
11119selection functions uudecode series of articles and display the result
11120instead of just displaying the articles the normal way.
11121
11122@kindex g (Binary)
11123@findex gnus-binary-show-article
11124The only way, in fact, to see the actual articles is the @kbd{g}
11125command, when you have turned on this mode
11126(@code{gnus-binary-show-article}).
11127
11128@vindex gnus-binary-mode-hook
11129@code{gnus-binary-mode-hook} is called in binary minor mode buffers.
11130
11131
11132@node Tree Display
11133@section Tree Display
11134@cindex trees
11135
11136@vindex gnus-use-trees
11137If you don't like the normal Gnus summary display, you might try setting
11138@code{gnus-use-trees} to @code{t}. This will create (by default) an
11139additional @dfn{tree buffer}. You can execute all summary mode commands
11140in the tree buffer.
11141
11142There are a few variables to customize the tree display, of course:
11143
11144@table @code
11145@item gnus-tree-mode-hook
11146@vindex gnus-tree-mode-hook
11147A hook called in all tree mode buffers.
11148
11149@item gnus-tree-mode-line-format
11150@vindex gnus-tree-mode-line-format
11151A format string for the mode bar in the tree mode buffers (@pxref{Mode
11152Line Formatting}). The default is @samp{Gnus: %%b %S %Z}. For a list
11153of valid specs, @pxref{Summary Buffer Mode Line}.
11154
11155@item gnus-selected-tree-face
11156@vindex gnus-selected-tree-face
11157Face used for highlighting the selected article in the tree buffer. The
11158default is @code{modeline}.
11159
11160@item gnus-tree-line-format
11161@vindex gnus-tree-line-format
11162A format string for the tree nodes. The name is a bit of a misnomer,
11163though---it doesn't define a line, but just the node. The default value
11164is @samp{%(%[%3,3n%]%)}, which displays the first three characters of
11165the name of the poster. It is vital that all nodes are of the same
11166length, so you @emph{must} use @samp{%4,4n}-like specifiers.
11167
11168Valid specs are:
11169
11170@table @samp
11171@item n
11172The name of the poster.
11173@item f
11174The @code{From} header.
11175@item N
11176The number of the article.
11177@item [
11178The opening bracket.
11179@item ]
11180The closing bracket.
11181@item s
11182The subject.
11183@end table
11184
11185@xref{Formatting Variables}.
11186
11187Variables related to the display are:
11188
11189@table @code
11190@item gnus-tree-brackets
11191@vindex gnus-tree-brackets
11192This is used for differentiating between ``real'' articles and
11193``sparse'' articles. The format is
11194@example
11195((@var{real-open} . @var{real-close})
11196 (@var{sparse-open} . @var{sparse-close})
11197 (@var{dummy-open} . @var{dummy-close}))
11198@end example
11199and the default is @code{((?[ . ?]) (?( . ?)) (?@{ . ?@}) (?< . ?>))}.
11200
11201@item gnus-tree-parent-child-edges
11202@vindex gnus-tree-parent-child-edges
11203This is a list that contains the characters used for connecting parent
11204nodes to their children. The default is @code{(?- ?\\ ?|)}.
11205
11206@end table
11207
11208@item gnus-tree-minimize-window
11209@vindex gnus-tree-minimize-window
11210If this variable is non-@code{nil}, Gnus will try to keep the tree
11211buffer as small as possible to allow more room for the other Gnus
11212windows. If this variable is a number, the tree buffer will never be
11213higher than that number. The default is @code{t}. Note that if you
11214have several windows displayed side-by-side in a frame and the tree
11215buffer is one of these, minimizing the tree window will also resize all
11216other windows displayed next to it.
11217
11218You may also wish to add the following hook to keep the window minimized
11219at all times:
11220
11221@lisp
11222(add-hook 'gnus-configure-windows-hook
11223 'gnus-tree-perhaps-minimize)
11224@end lisp
11225
11226@item gnus-generate-tree-function
11227@vindex gnus-generate-tree-function
11228@findex gnus-generate-horizontal-tree
11229@findex gnus-generate-vertical-tree
11230The function that actually generates the thread tree. Two predefined
11231functions are available: @code{gnus-generate-horizontal-tree} and
11232@code{gnus-generate-vertical-tree} (which is the default).
11233
11234@end table
11235
11236Here's an example from a horizontal tree buffer:
11237
11238@example
11239@{***@}-(***)-[odd]-[Gun]
11240 | \[Jan]
11241 | \[odd]-[Eri]
11242 | \(***)-[Eri]
11243 | \[odd]-[Paa]
11244 \[Bjo]
11245 \[Gun]
11246 \[Gun]-[Jor]
11247@end example
11248
11249Here's the same thread displayed in a vertical tree buffer:
11250
11251@example
11252@group
11253@{***@}
11254 |--------------------------\-----\-----\
11255(***) [Bjo] [Gun] [Gun]
11256 |--\-----\-----\ |
11257[odd] [Jan] [odd] (***) [Jor]
11258 | | |--\
11259[Gun] [Eri] [Eri] [odd]
11260 |
11261 [Paa]
11262@end group
11263@end example
11264
11265If you're using horizontal trees, it might be nice to display the trees
11266side-by-side with the summary buffer. You could add something like the
11267following to your @file{~/.gnus.el} file:
11268
11269@lisp
11270(setq gnus-use-trees t
11271 gnus-generate-tree-function 'gnus-generate-horizontal-tree
11272 gnus-tree-minimize-window nil)
11273(gnus-add-configuration
11274 '(article
11275 (vertical 1.0
11276 (horizontal 0.25
11277 (summary 0.75 point)
11278 (tree 1.0))
11279 (article 1.0))))
11280@end lisp
11281
11282@xref{Window Layout}.
11283
11284
11285@node Mail Group Commands
11286@section Mail Group Commands
11287@cindex mail group commands
11288
11289Some commands only make sense in mail groups. If these commands are
11290invalid in the current group, they will raise a hell and let you know.
11291
11292All these commands (except the expiry and edit commands) use the
11293process/prefix convention (@pxref{Process/Prefix}).
11294
11295@table @kbd
11296
11297@item B e
11298@kindex B e (Summary)
11299@findex gnus-summary-expire-articles
11300@cindex expiring mail
11301Run all expirable articles in the current group through the expiry
11302process (@code{gnus-summary-expire-articles}). That is, delete all
11303expirable articles in the group that have been around for a while.
11304(@pxref{Expiring Mail}).
11305
11306@item B C-M-e
11307@kindex B C-M-e (Summary)
11308@findex gnus-summary-expire-articles-now
11309@cindex expiring mail
11310Delete all the expirable articles in the group
11311(@code{gnus-summary-expire-articles-now}). This means that @strong{all}
11312articles eligible for expiry in the current group will
11313disappear forever into that big @file{/dev/null} in the sky.
11314
11315@item B DEL
11316@kindex B DEL (Summary)
b1519d85 11317@cindex deleting mail
4009494e
GM
11318@findex gnus-summary-delete-article
11319@c @icon{gnus-summary-mail-delete}
11320Delete the mail article. This is ``delete'' as in ``delete it from your
11321disk forever and ever, never to return again.'' Use with caution.
11322(@code{gnus-summary-delete-article}).
11323
11324@item B m
11325@kindex B m (Summary)
11326@cindex move mail
11327@findex gnus-summary-move-article
11328@vindex gnus-preserve-marks
11329Move the article from one mail group to another
11330(@code{gnus-summary-move-article}). Marks will be preserved if
11331@code{gnus-preserve-marks} is non-@code{nil} (which is the default).
11332
11333@item B c
11334@kindex B c (Summary)
11335@cindex copy mail
11336@findex gnus-summary-copy-article
11337@c @icon{gnus-summary-mail-copy}
11338Copy the article from one group (mail group or not) to a mail group
11339(@code{gnus-summary-copy-article}). Marks will be preserved if
11340@code{gnus-preserve-marks} is non-@code{nil} (which is the default).
11341
11342@item B B
11343@kindex B B (Summary)
11344@cindex crosspost mail
11345@findex gnus-summary-crosspost-article
11346Crosspost the current article to some other group
11347(@code{gnus-summary-crosspost-article}). This will create a new copy of
11348the article in the other group, and the Xref headers of the article will
11349be properly updated.
11350
11351@item B i
11352@kindex B i (Summary)
11353@findex gnus-summary-import-article
11354Import an arbitrary file into the current mail newsgroup
11355(@code{gnus-summary-import-article}). You will be prompted for a file
11356name, a @code{From} header and a @code{Subject} header.
11357
11358@item B I
11359@kindex B I (Summary)
11360@findex gnus-summary-create-article
11361Create an empty article in the current mail newsgroups
11362(@code{gnus-summary-create-article}). You will be prompted for a
11363@code{From} header and a @code{Subject} header.
11364
11365@item B r
11366@kindex B r (Summary)
11367@findex gnus-summary-respool-article
11368@vindex gnus-summary-respool-default-method
11369Respool the mail article (@code{gnus-summary-respool-article}).
11370@code{gnus-summary-respool-default-method} will be used as the default
11371select method when respooling. This variable is @code{nil} by default,
11372which means that the current group select method will be used instead.
11373Marks will be preserved if @code{gnus-preserve-marks} is non-@code{nil}
11374(which is the default).
11375
11376@item B w
11377@itemx e
11378@kindex B w (Summary)
11379@kindex e (Summary)
11380@findex gnus-summary-edit-article
11381@kindex C-c C-c (Article)
11382@findex gnus-summary-edit-article-done
11383Edit the current article (@code{gnus-summary-edit-article}). To finish
11384editing and make the changes permanent, type @kbd{C-c C-c}
11385(@code{gnus-summary-edit-article-done}). If you give a prefix to the
11386@kbd{C-c C-c} command, Gnus won't re-highlight the article.
11387
11388@item B q
11389@kindex B q (Summary)
11390@findex gnus-summary-respool-query
11391If you want to re-spool an article, you might be curious as to what group
11392the article will end up in before you do the re-spooling. This command
11393will tell you (@code{gnus-summary-respool-query}).
11394
11395@item B t
11396@kindex B t (Summary)
11397@findex gnus-summary-respool-trace
11398Similarly, this command will display all fancy splitting patterns used
11399when respooling, if any (@code{gnus-summary-respool-trace}).
11400
11401@item B p
11402@kindex B p (Summary)
11403@findex gnus-summary-article-posted-p
11404Some people have a tendency to send you ``courtesy'' copies when they
11405follow up to articles you have posted. These usually have a
11406@code{Newsgroups} header in them, but not always. This command
11407(@code{gnus-summary-article-posted-p}) will try to fetch the current
11408article from your news server (or rather, from
11409@code{gnus-refer-article-method} or @code{gnus-select-method}) and will
11410report back whether it found the article or not. Even if it says that
11411it didn't find the article, it may have been posted anyway---mail
11412propagation is much faster than news propagation, and the news copy may
11413just not have arrived yet.
11414
11415@item K E
11416@kindex K E (Summary)
11417@findex gnus-article-encrypt-body
11418@vindex gnus-article-encrypt-protocol
11419Encrypt the body of an article (@code{gnus-article-encrypt-body}).
11420The body is encrypted with the encryption protocol specified by the
11421variable @code{gnus-article-encrypt-protocol}.
11422
11423@end table
11424
11425@vindex gnus-move-split-methods
11426@cindex moving articles
11427If you move (or copy) articles regularly, you might wish to have Gnus
11428suggest where to put the articles. @code{gnus-move-split-methods} is a
11429variable that uses the same syntax as @code{gnus-split-methods}
11430(@pxref{Saving Articles}). You may customize that variable to create
11431suggestions you find reasonable. (Note that
11432@code{gnus-move-split-methods} uses group names where
11433@code{gnus-split-methods} uses file names.)
11434
11435@lisp
11436(setq gnus-move-split-methods
11437 '(("^From:.*Lars Magne" "nnml:junk")
11438 ("^Subject:.*gnus" "nnfolder:important")
11439 (".*" "nnml:misc")))
11440@end lisp
11441
11442
11443@node Various Summary Stuff
11444@section Various Summary Stuff
11445
11446@menu
11447* Summary Group Information:: Information oriented commands.
11448* Searching for Articles:: Multiple article commands.
11449* Summary Generation Commands::
11450* Really Various Summary Commands:: Those pesky non-conformant commands.
11451@end menu
11452
11453@table @code
11454@vindex gnus-summary-display-while-building
11455@item gnus-summary-display-while-building
11456If non-@code{nil}, show and update the summary buffer as it's being
11457built. If @code{t}, update the buffer after every line is inserted.
11458If the value is an integer, @var{n}, update the display every @var{n}
11459lines. The default is @code{nil}.
11460
11461@vindex gnus-summary-display-arrow
11462@item gnus-summary-display-arrow
11463If non-@code{nil}, display an arrow in the fringe to indicate the
11464current article.
11465
11466@vindex gnus-summary-mode-hook
11467@item gnus-summary-mode-hook
11468This hook is called when creating a summary mode buffer.
11469
11470@vindex gnus-summary-generate-hook
11471@item gnus-summary-generate-hook
11472This is called as the last thing before doing the threading and the
11473generation of the summary buffer. It's quite convenient for customizing
11474the threading variables based on what data the newsgroup has. This hook
11475is called from the summary buffer after most summary buffer variables
11476have been set.
11477
11478@vindex gnus-summary-prepare-hook
11479@item gnus-summary-prepare-hook
11480It is called after the summary buffer has been generated. You might use
11481it to, for instance, highlight lines or modify the look of the buffer in
11482some other ungodly manner. I don't care.
11483
11484@vindex gnus-summary-prepared-hook
11485@item gnus-summary-prepared-hook
11486A hook called as the very last thing after the summary buffer has been
11487generated.
11488
11489@vindex gnus-summary-ignore-duplicates
11490@item gnus-summary-ignore-duplicates
11491When Gnus discovers two articles that have the same @code{Message-ID},
11492it has to do something drastic. No articles are allowed to have the
11493same @code{Message-ID}, but this may happen when reading mail from some
11494sources. Gnus allows you to customize what happens with this variable.
11495If it is @code{nil} (which is the default), Gnus will rename the
11496@code{Message-ID} (for display purposes only) and display the article as
11497any other article. If this variable is @code{t}, it won't display the
11498article---it'll be as if it never existed.
11499
11500@vindex gnus-alter-articles-to-read-function
11501@item gnus-alter-articles-to-read-function
11502This function, which takes two parameters (the group name and the list
11503of articles to be selected), is called to allow the user to alter the
11504list of articles to be selected.
11505
11506For instance, the following function adds the list of cached articles to
11507the list in one particular group:
11508
11509@lisp
11510(defun my-add-cached-articles (group articles)
11511 (if (string= group "some.group")
11512 (append gnus-newsgroup-cached articles)
11513 articles))
11514@end lisp
11515
11516@vindex gnus-newsgroup-variables
11517@item gnus-newsgroup-variables
11518A list of newsgroup (summary buffer) local variables, or cons of
11519variables and their default expressions to be evalled (when the default
11520values are not @code{nil}), that should be made global while the summary
11521buffer is active.
11522
11523Note: The default expressions will be evaluated (using function
11524@code{eval}) before assignment to the local variable rather than just
11525assigned to it. If the default expression is the symbol @code{global},
11526that symbol will not be evaluated but the global value of the local
11527variable will be used instead.
11528
11529These variables can be used to set variables in the group parameters
11530while still allowing them to affect operations done in other
11531buffers. For example:
11532
11533@lisp
11534(setq gnus-newsgroup-variables
11535 '(message-use-followup-to
11536 (gnus-visible-headers .
11537 "^From:\\|^Newsgroups:\\|^Subject:\\|^Date:\\|^To:")))
11538@end lisp
11539
11540Also @pxref{Group Parameters}.
3a23a519
MB
11541
11542@vindex gnus-propagate-marks
11543@item gnus-propagate-marks
11544If non-@code{nil}, propagate marks to the backends for possible
11545storing. @xref{NNTP marks}, and friends, for a more fine-grained
11546sieve.
11547
4009494e
GM
11548@end table
11549
11550
11551@node Summary Group Information
11552@subsection Summary Group Information
11553
11554@table @kbd
11555
11556@item H f
11557@kindex H f (Summary)
11558@findex gnus-summary-fetch-faq
11559@vindex gnus-group-faq-directory
11560Try to fetch the @acronym{FAQ} (list of frequently asked questions)
11561for the current group (@code{gnus-summary-fetch-faq}). Gnus will try
11562to get the @acronym{FAQ} from @code{gnus-group-faq-directory}, which
11563is usually a directory on a remote machine. This variable can also be
11564a list of directories. In that case, giving a prefix to this command
11565will allow you to choose between the various sites. @code{ange-ftp}
11566or @code{efs} will probably be used for fetching the file.
11567
11568@item H d
11569@kindex H d (Summary)
11570@findex gnus-summary-describe-group
11571Give a brief description of the current group
11572(@code{gnus-summary-describe-group}). If given a prefix, force
11573rereading the description from the server.
11574
11575@item H h
11576@kindex H h (Summary)
11577@findex gnus-summary-describe-briefly
11578Give an extremely brief description of the most important summary
11579keystrokes (@code{gnus-summary-describe-briefly}).
11580
11581@item H i
11582@kindex H i (Summary)
11583@findex gnus-info-find-node
11584Go to the Gnus info node (@code{gnus-info-find-node}).
11585@end table
11586
11587
11588@node Searching for Articles
11589@subsection Searching for Articles
11590
11591@table @kbd
11592
11593@item M-s
11594@kindex M-s (Summary)
11595@findex gnus-summary-search-article-forward
11596Search through all subsequent (raw) articles for a regexp
11597(@code{gnus-summary-search-article-forward}).
11598
11599@item M-r
11600@kindex M-r (Summary)
11601@findex gnus-summary-search-article-backward
11602Search through all previous (raw) articles for a regexp
11603(@code{gnus-summary-search-article-backward}).
11604
01c52d31
MB
11605@item M-S
11606@kindex M-S (Summary)
11607@findex gnus-summary-repeat-search-article-forward
11608Repeat the previous search forwards
11609(@code{gnus-summary-repeat-search-article-forward}).
11610
11611@item M-R
11612@kindex M-R (Summary)
11613@findex gnus-summary-repeat-search-article-backward
11614Repeat the previous search backwards
11615(@code{gnus-summary-repeat-search-article-backward}).
11616
4009494e
GM
11617@item &
11618@kindex & (Summary)
11619@findex gnus-summary-execute-command
11620This command will prompt you for a header, a regular expression to match
11621on this field, and a command to be executed if the match is made
11622(@code{gnus-summary-execute-command}). If the header is an empty
11623string, the match is done on the entire article. If given a prefix,
11624search backward instead.
11625
11626For instance, @kbd{& RET some.*string RET #} will put the process mark on
11627all articles that have heads or bodies that match @samp{some.*string}.
11628
11629@item M-&
11630@kindex M-& (Summary)
11631@findex gnus-summary-universal-argument
11632Perform any operation on all articles that have been marked with
11633the process mark (@code{gnus-summary-universal-argument}).
11634@end table
11635
11636@node Summary Generation Commands
11637@subsection Summary Generation Commands
11638
11639@table @kbd
11640
11641@item Y g
11642@kindex Y g (Summary)
11643@findex gnus-summary-prepare
11644Regenerate the current summary buffer (@code{gnus-summary-prepare}).
11645
11646@item Y c
11647@kindex Y c (Summary)
11648@findex gnus-summary-insert-cached-articles
11649Pull all cached articles (for the current group) into the summary buffer
11650(@code{gnus-summary-insert-cached-articles}).
11651
11652@item Y d
11653@kindex Y d (Summary)
11654@findex gnus-summary-insert-dormant-articles
11655Pull all dormant articles (for the current group) into the summary buffer
11656(@code{gnus-summary-insert-dormant-articles}).
11657
01c52d31
MB
11658@item Y t
11659@kindex Y t (Summary)
11660@findex gnus-summary-insert-ticked-articles
11661Pull all ticked articles (for the current group) into the summary buffer
11662(@code{gnus-summary-insert-ticked-articles}).
11663
4009494e
GM
11664@end table
11665
11666
11667@node Really Various Summary Commands
11668@subsection Really Various Summary Commands
11669
11670@table @kbd
11671
11672@item A D
11673@itemx C-d
11674@kindex C-d (Summary)
11675@kindex A D (Summary)
11676@findex gnus-summary-enter-digest-group
11677If the current article is a collection of other articles (for instance,
11678a digest), you might use this command to enter a group based on the that
11679article (@code{gnus-summary-enter-digest-group}). Gnus will try to
11680guess what article type is currently displayed unless you give a prefix
11681to this command, which forces a ``digest'' interpretation. Basically,
11682whenever you see a message that is a collection of other messages of
11683some format, you @kbd{C-d} and read these messages in a more convenient
11684fashion.
11685
01c52d31
MB
11686@vindex gnus-auto-select-on-ephemeral-exit
11687The variable @code{gnus-auto-select-on-ephemeral-exit} controls what
11688article should be selected after exiting a digest group. Valid values
11689include:
11690
11691@table @code
11692@item next
11693Select the next article.
11694
11695@item next-unread
11696Select the next unread article.
11697
11698@item next-noselect
11699Move the cursor to the next article. This is the default.
11700
11701@item next-unread-noselect
11702Move the cursor to the next unread article.
11703@end table
11704
11705If it has any other value or there is no next (unread) article, the
11706article selected before entering to the digest group will appear.
11707
4009494e
GM
11708@item C-M-d
11709@kindex C-M-d (Summary)
11710@findex gnus-summary-read-document
11711This command is very similar to the one above, but lets you gather
11712several documents into one biiig group
11713(@code{gnus-summary-read-document}). It does this by opening several
11714@code{nndoc} groups for each document, and then opening an
11715@code{nnvirtual} group on top of these @code{nndoc} groups. This
11716command understands the process/prefix convention
11717(@pxref{Process/Prefix}).
11718
11719@item C-t
11720@kindex C-t (Summary)
11721@findex gnus-summary-toggle-truncation
11722Toggle truncation of summary lines
11723(@code{gnus-summary-toggle-truncation}). This will probably confuse the
11724line centering function in the summary buffer, so it's not a good idea
11725to have truncation switched off while reading articles.
11726
11727@item =
11728@kindex = (Summary)
11729@findex gnus-summary-expand-window
11730Expand the summary buffer window (@code{gnus-summary-expand-window}).
11731If given a prefix, force an @code{article} window configuration.
11732
11733@item C-M-e
11734@kindex C-M-e (Summary)
11735@findex gnus-summary-edit-parameters
11736Edit the group parameters (@pxref{Group Parameters}) of the current
11737group (@code{gnus-summary-edit-parameters}).
11738
11739@item C-M-a
11740@kindex C-M-a (Summary)
11741@findex gnus-summary-customize-parameters
11742Customize the group parameters (@pxref{Group Parameters}) of the current
11743group (@code{gnus-summary-customize-parameters}).
11744
11745@end table
11746
11747
11748@node Exiting the Summary Buffer
11749@section Exiting the Summary Buffer
11750@cindex summary exit
11751@cindex exiting groups
11752
11753Exiting from the summary buffer will normally update all info on the
11754group and return you to the group buffer.
11755
11756@table @kbd
11757
11758@item Z Z
11759@itemx Z Q
11760@itemx q
11761@kindex Z Z (Summary)
11762@kindex Z Q (Summary)
11763@kindex q (Summary)
11764@findex gnus-summary-exit
11765@vindex gnus-summary-exit-hook
11766@vindex gnus-summary-prepare-exit-hook
11767@vindex gnus-group-no-more-groups-hook
11768@c @icon{gnus-summary-exit}
11769Exit the current group and update all information on the group
11770(@code{gnus-summary-exit}). @code{gnus-summary-prepare-exit-hook} is
11771called before doing much of the exiting, which calls
11772@code{gnus-summary-expire-articles} by default.
11773@code{gnus-summary-exit-hook} is called after finishing the exit
11774process. @code{gnus-group-no-more-groups-hook} is run when returning to
11775group mode having no more (unread) groups.
11776
11777@item Z E
11778@itemx Q
11779@kindex Z E (Summary)
11780@kindex Q (Summary)
11781@findex gnus-summary-exit-no-update
11782Exit the current group without updating any information on the group
11783(@code{gnus-summary-exit-no-update}).
11784
11785@item Z c
11786@itemx c
11787@kindex Z c (Summary)
11788@kindex c (Summary)
11789@findex gnus-summary-catchup-and-exit
11790@c @icon{gnus-summary-catchup-and-exit}
11791Mark all unticked articles in the group as read and then exit
11792(@code{gnus-summary-catchup-and-exit}).
11793
11794@item Z C
11795@kindex Z C (Summary)
11796@findex gnus-summary-catchup-all-and-exit
11797Mark all articles, even the ticked ones, as read and then exit
11798(@code{gnus-summary-catchup-all-and-exit}).
11799
11800@item Z n
11801@kindex Z n (Summary)
11802@findex gnus-summary-catchup-and-goto-next-group
11803Mark all articles as read and go to the next group
11804(@code{gnus-summary-catchup-and-goto-next-group}).
11805
01c52d31
MB
11806@item Z p
11807@kindex Z p (Summary)
11808@findex gnus-summary-catchup-and-goto-prev-group
11809Mark all articles as read and go to the previous group
11810(@code{gnus-summary-catchup-and-goto-prev-group}).
11811
4009494e
GM
11812@item Z R
11813@itemx C-x C-s
11814@kindex Z R (Summary)
11815@kindex C-x C-s (Summary)
11816@findex gnus-summary-reselect-current-group
11817Exit this group, and then enter it again
11818(@code{gnus-summary-reselect-current-group}). If given a prefix, select
11819all articles, both read and unread.
11820
11821@item Z G
11822@itemx M-g
11823@kindex Z G (Summary)
11824@kindex M-g (Summary)
11825@findex gnus-summary-rescan-group
11826@c @icon{gnus-summary-mail-get}
11827Exit the group, check for new articles in the group, and select the
11828group (@code{gnus-summary-rescan-group}). If given a prefix, select all
11829articles, both read and unread.
11830
11831@item Z N
11832@kindex Z N (Summary)
11833@findex gnus-summary-next-group
11834Exit the group and go to the next group
11835(@code{gnus-summary-next-group}).
11836
11837@item Z P
11838@kindex Z P (Summary)
11839@findex gnus-summary-prev-group
11840Exit the group and go to the previous group
11841(@code{gnus-summary-prev-group}).
11842
11843@item Z s
11844@kindex Z s (Summary)
11845@findex gnus-summary-save-newsrc
11846Save the current number of read/marked articles in the dribble buffer
11847and then save the dribble buffer (@code{gnus-summary-save-newsrc}). If
11848given a prefix, also save the @file{.newsrc} file(s). Using this
11849command will make exit without updating (the @kbd{Q} command) worthless.
11850@end table
11851
11852@vindex gnus-exit-group-hook
11853@code{gnus-exit-group-hook} is called when you exit the current group
11854with an ``updating'' exit. For instance @kbd{Q}
11855(@code{gnus-summary-exit-no-update}) does not call this hook.
11856
11857@findex gnus-summary-wake-up-the-dead
11858@findex gnus-dead-summary-mode
11859@vindex gnus-kill-summary-on-exit
11860If you're in the habit of exiting groups, and then changing your mind
11861about it, you might set @code{gnus-kill-summary-on-exit} to @code{nil}.
11862If you do that, Gnus won't kill the summary buffer when you exit it.
11863(Quelle surprise!) Instead it will change the name of the buffer to
11864something like @samp{*Dead Summary ... *} and install a minor mode
11865called @code{gnus-dead-summary-mode}. Now, if you switch back to this
11866buffer, you'll find that all keys are mapped to a function called
11867@code{gnus-summary-wake-up-the-dead}. So tapping any keys in a dead
11868summary buffer will result in a live, normal summary buffer.
11869
11870There will never be more than one dead summary buffer at any one time.
11871
11872@vindex gnus-use-cross-reference
11873The data on the current group will be updated (which articles you have
11874read, which articles you have replied to, etc.) when you exit the
11875summary buffer. If the @code{gnus-use-cross-reference} variable is
11876@code{t} (which is the default), articles that are cross-referenced to
11877this group and are marked as read, will also be marked as read in the
11878other subscribed groups they were cross-posted to. If this variable is
11879neither @code{nil} nor @code{t}, the article will be marked as read in
11880both subscribed and unsubscribed groups (@pxref{Crosspost Handling}).
11881
11882
11883@node Crosspost Handling
11884@section Crosspost Handling
11885
11886@cindex velveeta
11887@cindex spamming
11888Marking cross-posted articles as read ensures that you'll never have to
11889read the same article more than once. Unless, of course, somebody has
11890posted it to several groups separately. Posting the same article to
11891several groups (not cross-posting) is called @dfn{spamming}, and you are
11892by law required to send nasty-grams to anyone who perpetrates such a
11893heinous crime. You may want to try NoCeM handling to filter out spam
11894(@pxref{NoCeM}).
11895
11896Remember: Cross-posting is kinda ok, but posting the same article
11897separately to several groups is not. Massive cross-posting (aka.
11898@dfn{velveeta}) is to be avoided at all costs, and you can even use the
11899@code{gnus-summary-mail-crosspost-complaint} command to complain about
11900excessive crossposting (@pxref{Summary Mail Commands}).
11901
11902@cindex cross-posting
11903@cindex Xref
11904@cindex @acronym{NOV}
11905One thing that may cause Gnus to not do the cross-posting thing
11906correctly is if you use an @acronym{NNTP} server that supports @sc{xover}
11907(which is very nice, because it speeds things up considerably) which
11908does not include the @code{Xref} header in its @acronym{NOV} lines. This is
11909Evil, but all too common, alas, alack. Gnus tries to Do The Right Thing
11910even with @sc{xover} by registering the @code{Xref} lines of all
11911articles you actually read, but if you kill the articles, or just mark
11912them as read without reading them, Gnus will not get a chance to snoop
11913the @code{Xref} lines out of these articles, and will be unable to use
11914the cross reference mechanism.
11915
11916@cindex LIST overview.fmt
11917@cindex overview.fmt
11918To check whether your @acronym{NNTP} server includes the @code{Xref} header
11919in its overview files, try @samp{telnet your.nntp.server nntp},
11920@samp{MODE READER} on @code{inn} servers, and then say @samp{LIST
11921overview.fmt}. This may not work, but if it does, and the last line you
11922get does not read @samp{Xref:full}, then you should shout and whine at
11923your news admin until she includes the @code{Xref} header in the
11924overview files.
11925
4009494e 11926If you want Gnus to get the @code{Xref}s right all the time, you have to
4b70e299
MB
11927set @code{nntp-nov-is-evil} to @code{t}, which slows things down
11928considerably. Also @pxref{Slow/Expensive Connection}.
4009494e
GM
11929
11930C'est la vie.
11931
11932For an alternative approach, @pxref{Duplicate Suppression}.
11933
11934
11935@node Duplicate Suppression
11936@section Duplicate Suppression
11937
11938By default, Gnus tries to make sure that you don't have to read the same
11939article more than once by utilizing the crossposting mechanism
11940(@pxref{Crosspost Handling}). However, that simple and efficient
11941approach may not work satisfactory for some users for various
11942reasons.
11943
11944@enumerate
11945@item
11946The @acronym{NNTP} server may fail to generate the @code{Xref} header. This
11947is evil and not very common.
11948
11949@item
11950The @acronym{NNTP} server may fail to include the @code{Xref} header in the
11951@file{.overview} data bases. This is evil and all too common, alas.
11952
11953@item
11954You may be reading the same group (or several related groups) from
11955different @acronym{NNTP} servers.
11956
11957@item
11958You may be getting mail that duplicates articles posted to groups.
11959@end enumerate
11960
11961I'm sure there are other situations where @code{Xref} handling fails as
11962well, but these four are the most common situations.
11963
11964If, and only if, @code{Xref} handling fails for you, then you may
11965consider switching on @dfn{duplicate suppression}. If you do so, Gnus
11966will remember the @code{Message-ID}s of all articles you have read or
11967otherwise marked as read, and then, as if by magic, mark them as read
11968all subsequent times you see them---in @emph{all} groups. Using this
11969mechanism is quite likely to be somewhat inefficient, but not overly
11970so. It's certainly preferable to reading the same articles more than
11971once.
11972
11973Duplicate suppression is not a very subtle instrument. It's more like a
11974sledge hammer than anything else. It works in a very simple
11975fashion---if you have marked an article as read, it adds this Message-ID
11976to a cache. The next time it sees this Message-ID, it will mark the
11977article as read with the @samp{M} mark. It doesn't care what group it
11978saw the article in.
11979
11980@table @code
11981@item gnus-suppress-duplicates
11982@vindex gnus-suppress-duplicates
11983If non-@code{nil}, suppress duplicates.
11984
11985@item gnus-save-duplicate-list
11986@vindex gnus-save-duplicate-list
11987If non-@code{nil}, save the list of duplicates to a file. This will
11988make startup and shutdown take longer, so the default is @code{nil}.
11989However, this means that only duplicate articles read in a single Gnus
11990session are suppressed.
11991
11992@item gnus-duplicate-list-length
11993@vindex gnus-duplicate-list-length
11994This variable says how many @code{Message-ID}s to keep in the duplicate
11995suppression list. The default is 10000.
11996
11997@item gnus-duplicate-file
11998@vindex gnus-duplicate-file
11999The name of the file to store the duplicate suppression list in. The
12000default is @file{~/News/suppression}.
12001@end table
12002
12003If you have a tendency to stop and start Gnus often, setting
12004@code{gnus-save-duplicate-list} to @code{t} is probably a good idea. If
12005you leave Gnus running for weeks on end, you may have it @code{nil}. On
12006the other hand, saving the list makes startup and shutdown much slower,
12007so that means that if you stop and start Gnus often, you should set
12008@code{gnus-save-duplicate-list} to @code{nil}. Uhm. I'll leave this up
12009to you to figure out, I think.
12010
12011@node Security
12012@section Security
12013
12014Gnus is able to verify signed messages or decrypt encrypted messages.
12015The formats that are supported are @acronym{PGP}, @acronym{PGP/MIME}
12016and @acronym{S/MIME}, however you need some external programs to get
12017things to work:
12018
12019@enumerate
12020@item
12021To handle @acronym{PGP} and @acronym{PGP/MIME} messages, you have to
12022install an OpenPGP implementation such as GnuPG. The Lisp interface
8c9bb6f5
DU
12023to GnuPG included with Emacs is called EasyPG (@pxref{Top, ,EasyPG,
12024epa, EasyPG Assistant user's manual}), but PGG (@pxref{Top, ,PGG, pgg,
12025PGG Manual}), Mailcrypt, and gpg.el are also supported.
4009494e
GM
12026
12027@item
12028To handle @acronym{S/MIME} message, you need to install OpenSSL. OpenSSL 0.9.6
12029or newer is recommended.
12030
12031@end enumerate
12032
4146636e
KY
12033The variables that control security functionality on reading/composing
12034messages include:
4009494e
GM
12035
12036@table @code
12037@item mm-verify-option
12038@vindex mm-verify-option
12039Option of verifying signed parts. @code{never}, not verify;
12040@code{always}, always verify; @code{known}, only verify known
12041protocols. Otherwise, ask user.
12042
12043@item mm-decrypt-option
12044@vindex mm-decrypt-option
12045Option of decrypting encrypted parts. @code{never}, no decryption;
12046@code{always}, always decrypt; @code{known}, only decrypt known
12047protocols. Otherwise, ask user.
12048
4146636e
KY
12049@item mm-sign-option
12050@vindex mm-sign-option
12051Option of creating signed parts. @code{nil}, use default signing
12052keys; @code{guided}, ask user to select signing keys from the menu.
12053
12054@item mm-encrypt-option
12055@vindex mm-encrypt-option
12056Option of creating encrypted parts. @code{nil}, use the first
12057public-key matching the @samp{From:} header as the recipient;
12058@code{guided}, ask user to select recipient keys from the menu.
12059
4009494e
GM
12060@item mml1991-use
12061@vindex mml1991-use
12062Symbol indicating elisp interface to OpenPGP implementation for
7f3bc720
DU
12063@acronym{PGP} messages. The default is @code{epg}, but @code{pgg},
12064@code{mailcrypt}, and @code{gpg} are also supported although
8c9bb6f5 12065deprecated. By default, Gnus uses the first available interface in
71fbd643 12066this order.
4009494e
GM
12067
12068@item mml2015-use
12069@vindex mml2015-use
12070Symbol indicating elisp interface to OpenPGP implementation for
7f3bc720
DU
12071@acronym{PGP/MIME} messages. The default is @code{epg}, but
12072@code{pgg}, @code{mailcrypt}, and @code{gpg} are also supported
71fbd643 12073although deprecated. By default, Gnus uses the first available
8c9bb6f5 12074interface in this order.
4009494e
GM
12075
12076@end table
12077
12078By default the buttons that display security information are not
12079shown, because they clutter reading the actual e-mail. You can type
12080@kbd{K b} manually to display the information. Use the
12081@code{gnus-buttonized-mime-types} and
12082@code{gnus-unbuttonized-mime-types} variables to control this
12083permanently. @ref{MIME Commands} for further details, and hints on
12084how to customize these variables to always display security
12085information.
12086
12087@cindex snarfing keys
12088@cindex importing PGP keys
12089@cindex PGP key ring import
12090Snarfing OpenPGP keys (i.e., importing keys from articles into your
12091key ring) is not supported explicitly through a menu item or command,
12092rather Gnus do detect and label keys as @samp{application/pgp-keys},
12093allowing you to specify whatever action you think is appropriate
12094through the usual @acronym{MIME} infrastructure. You can use a
12095@file{~/.mailcap} entry (@pxref{mailcap, , mailcap, emacs-mime, The
12096Emacs MIME Manual}) such as the following to import keys using GNU
12097Privacy Guard when you click on the @acronym{MIME} button
12098(@pxref{Using MIME}).
12099
12100@example
12101application/pgp-keys; gpg --import --interactive --verbose; needsterminal
12102@end example
12103@noindent
12104This happens to also be the default action defined in
12105@code{mailcap-mime-data}.
12106
12107More information on how to set things for sending outgoing signed and
12108encrypted messages up can be found in the message manual
12109(@pxref{Security, ,Security, message, Message Manual}).
12110
12111@node Mailing List
12112@section Mailing List
12113@cindex mailing list
12114@cindex RFC 2396
12115
12116@kindex A M (summary)
12117@findex gnus-mailing-list-insinuate
12118Gnus understands some mailing list fields of RFC 2369. To enable it,
12119add a @code{to-list} group parameter (@pxref{Group Parameters}),
12120possibly using @kbd{A M} (@code{gnus-mailing-list-insinuate}) in the
12121summary buffer.
12122
12123That enables the following commands to the summary buffer:
12124
12125@table @kbd
12126
12127@item C-c C-n h
12128@kindex C-c C-n h (Summary)
12129@findex gnus-mailing-list-help
12130Send a message to fetch mailing list help, if List-Help field exists.
12131
12132@item C-c C-n s
12133@kindex C-c C-n s (Summary)
12134@findex gnus-mailing-list-subscribe
12135Send a message to subscribe the mailing list, if List-Subscribe field exists.
12136
12137@item C-c C-n u
12138@kindex C-c C-n u (Summary)
12139@findex gnus-mailing-list-unsubscribe
12140Send a message to unsubscribe the mailing list, if List-Unsubscribe
12141field exists.
12142
12143@item C-c C-n p
12144@kindex C-c C-n p (Summary)
12145@findex gnus-mailing-list-post
12146Post to the mailing list, if List-Post field exists.
12147
12148@item C-c C-n o
12149@kindex C-c C-n o (Summary)
12150@findex gnus-mailing-list-owner
12151Send a message to the mailing list owner, if List-Owner field exists.
12152
12153@item C-c C-n a
12154@kindex C-c C-n a (Summary)
01c52d31 12155@findex gnus-mailing-list-archive
4009494e
GM
12156Browse the mailing list archive, if List-Archive field exists.
12157
12158@end table
12159
12160
12161@node Article Buffer
12162@chapter Article Buffer
12163@cindex article buffer
12164
12165The articles are displayed in the article buffer, of which there is only
12166one. All the summary buffers share the same article buffer unless you
12167tell Gnus otherwise.
12168
12169@menu
12170* Hiding Headers:: Deciding what headers should be displayed.
12171* Using MIME:: Pushing articles through @acronym{MIME} before reading them.
85115796 12172* HTML:: Reading @acronym{HTML} messages.
4009494e
GM
12173* Customizing Articles:: Tailoring the look of the articles.
12174* Article Keymap:: Keystrokes available in the article buffer.
12175* Misc Article:: Other stuff.
12176@end menu
12177
12178
12179@node Hiding Headers
12180@section Hiding Headers
12181@cindex hiding headers
12182@cindex deleting headers
12183
12184The top section of each article is the @dfn{head}. (The rest is the
12185@dfn{body}, but you may have guessed that already.)
12186
12187@vindex gnus-show-all-headers
12188There is a lot of useful information in the head: the name of the person
12189who wrote the article, the date it was written and the subject of the
12190article. That's well and nice, but there's also lots of information
12191most people do not want to see---what systems the article has passed
12192through before reaching you, the @code{Message-ID}, the
12193@code{References}, etc. ad nauseam---and you'll probably want to get rid
12194of some of those lines. If you want to keep all those lines in the
12195article buffer, you can set @code{gnus-show-all-headers} to @code{t}.
12196
12197Gnus provides you with two variables for sifting headers:
12198
12199@table @code
12200
12201@item gnus-visible-headers
12202@vindex gnus-visible-headers
12203If this variable is non-@code{nil}, it should be a regular expression
12204that says what headers you wish to keep in the article buffer. All
12205headers that do not match this variable will be hidden.
12206
12207For instance, if you only want to see the name of the person who wrote
12208the article and the subject, you'd say:
12209
12210@lisp
12211(setq gnus-visible-headers "^From:\\|^Subject:")
12212@end lisp
12213
12214This variable can also be a list of regexps to match headers to
12215remain visible.
12216
12217@item gnus-ignored-headers
12218@vindex gnus-ignored-headers
12219This variable is the reverse of @code{gnus-visible-headers}. If this
12220variable is set (and @code{gnus-visible-headers} is @code{nil}), it
12221should be a regular expression that matches all lines that you want to
12222hide. All lines that do not match this variable will remain visible.
12223
12224For instance, if you just want to get rid of the @code{References} line
12225and the @code{Xref} line, you might say:
12226
12227@lisp
12228(setq gnus-ignored-headers "^References:\\|^Xref:")
12229@end lisp
12230
12231This variable can also be a list of regexps to match headers to
12232be removed.
12233
12234Note that if @code{gnus-visible-headers} is non-@code{nil}, this
12235variable will have no effect.
12236
12237@end table
12238
12239@vindex gnus-sorted-header-list
12240Gnus can also sort the headers for you. (It does this by default.) You
12241can control the sorting by setting the @code{gnus-sorted-header-list}
12242variable. It is a list of regular expressions that says in what order
12243the headers are to be displayed.
12244
12245For instance, if you want the name of the author of the article first,
12246and then the subject, you might say something like:
12247
12248@lisp
12249(setq gnus-sorted-header-list '("^From:" "^Subject:"))
12250@end lisp
12251
12252Any headers that are to remain visible, but are not listed in this
12253variable, will be displayed in random order after all the headers listed in this variable.
12254
12255@findex gnus-article-hide-boring-headers
12256@vindex gnus-boring-article-headers
12257You can hide further boring headers by setting
12258@code{gnus-treat-hide-boring-headers} to @code{head}. What this function
12259does depends on the @code{gnus-boring-article-headers} variable. It's a
12260list, but this list doesn't actually contain header names. Instead it
12261lists various @dfn{boring conditions} that Gnus can check and remove
12262from sight.
12263
12264These conditions are:
12265@table @code
12266@item empty
12267Remove all empty headers.
12268@item followup-to
12269Remove the @code{Followup-To} header if it is identical to the
12270@code{Newsgroups} header.
12271@item reply-to
12272Remove the @code{Reply-To} header if it lists the same addresses as
12273the @code{From} header, or if the @code{broken-reply-to} group
12274parameter is set.
12275@item newsgroups
12276Remove the @code{Newsgroups} header if it only contains the current group
12277name.
12278@item to-address
12279Remove the @code{To} header if it only contains the address identical to
12280the current group's @code{to-address} parameter.
12281@item to-list
12282Remove the @code{To} header if it only contains the address identical to
12283the current group's @code{to-list} parameter.
12284@item cc-list
12285Remove the @code{Cc} header if it only contains the address identical to
12286the current group's @code{to-list} parameter.
12287@item date
12288Remove the @code{Date} header if the article is less than three days
12289old.
12290@item long-to
12291Remove the @code{To} and/or @code{Cc} header if it is very long.
12292@item many-to
12293Remove all @code{To} and/or @code{Cc} headers if there are more than one.
12294@end table
12295
12296To include these three elements, you could say something like:
12297
12298@lisp
12299(setq gnus-boring-article-headers
12300 '(empty followup-to reply-to))
12301@end lisp
12302
12303This is also the default value for this variable.
12304
12305
12306@node Using MIME
12307@section Using MIME
12308@cindex @acronym{MIME}
12309
12310Mime is a standard for waving your hands through the air, aimlessly,
12311while people stand around yawning.
12312
12313@acronym{MIME}, however, is a standard for encoding your articles, aimlessly,
12314while all newsreaders die of fear.
12315
12316@acronym{MIME} may specify what character set the article uses, the encoding
12317of the characters, and it also makes it possible to embed pictures and
12318other naughty stuff in innocent-looking articles.
12319
12320@vindex gnus-display-mime-function
12321@findex gnus-display-mime
12322Gnus pushes @acronym{MIME} articles through @code{gnus-display-mime-function}
12323to display the @acronym{MIME} parts. This is @code{gnus-display-mime} by
12324default, which creates a bundle of clickable buttons that can be used to
12325display, save and manipulate the @acronym{MIME} objects.
12326
12327The following commands are available when you have placed point over a
12328@acronym{MIME} button:
12329
12330@table @kbd
12331@findex gnus-article-press-button
12332@item RET (Article)
12333@kindex RET (Article)
12334@itemx BUTTON-2 (Article)
12335Toggle displaying of the @acronym{MIME} object
12336(@code{gnus-article-press-button}). If built-in viewers can not display
12337the object, Gnus resorts to external viewers in the @file{mailcap}
12338files. If a viewer has the @samp{copiousoutput} specification, the
12339object is displayed inline.
12340
12341@findex gnus-mime-view-part
12342@item M-RET (Article)
12343@kindex M-RET (Article)
12344@itemx v (Article)
12345Prompt for a method, and then view the @acronym{MIME} object using this
12346method (@code{gnus-mime-view-part}).
12347
12348@findex gnus-mime-view-part-as-type
12349@item t (Article)
12350@kindex t (Article)
12351View the @acronym{MIME} object as if it were a different @acronym{MIME} media type
12352(@code{gnus-mime-view-part-as-type}).
12353
12354@findex gnus-mime-view-part-as-charset
12355@item C (Article)
12356@kindex C (Article)
12357Prompt for a charset, and then view the @acronym{MIME} object using this
12358charset (@code{gnus-mime-view-part-as-charset}).
12359
12360@findex gnus-mime-save-part
12361@item o (Article)
12362@kindex o (Article)
12363Prompt for a file name, and then save the @acronym{MIME} object
12364(@code{gnus-mime-save-part}).
12365
12366@findex gnus-mime-save-part-and-strip
12367@item C-o (Article)
12368@kindex C-o (Article)
12369Prompt for a file name, then save the @acronym{MIME} object and strip it from
12370the article. Then proceed to article editing, where a reasonable
12371suggestion is being made on how the altered article should look
12372like. The stripped @acronym{MIME} object will be referred via the
12373message/external-body @acronym{MIME} type.
12374(@code{gnus-mime-save-part-and-strip}).
12375
01c52d31
MB
12376@findex gnus-mime-replace-part
12377@item r (Article)
12378@kindex r (Article)
12379Prompt for a file name, replace the @acronym{MIME} object with an
12380external body refering to the file via the message/external-body
12381@acronym{MIME} type. (@code{gnus-mime-replace-part}).
12382
4009494e
GM
12383@findex gnus-mime-delete-part
12384@item d (Article)
12385@kindex d (Article)
12386Delete the @acronym{MIME} object from the article and replace it with some
12387information about the removed @acronym{MIME} object
12388(@code{gnus-mime-delete-part}).
12389
01c52d31
MB
12390@c FIXME: gnus-auto-select-part should be documented here
12391
4009494e
GM
12392@findex gnus-mime-copy-part
12393@item c (Article)
12394@kindex c (Article)
12395Copy the @acronym{MIME} object to a fresh buffer and display this buffer
01c52d31
MB
12396(@code{gnus-mime-copy-part}). If given a prefix, copy the raw contents
12397without decoding. If given a numerical prefix, you can do semi-manual
12398charset stuff (see @code{gnus-summary-show-article-charset-alist} in
12399@ref{Paging the Article}). Compressed files like @file{.gz} and
4009494e
GM
12400@file{.bz2} are automatically decompressed if
12401@code{auto-compression-mode} is enabled (@pxref{Compressed Files,,
12402Accessing Compressed Files, emacs, The Emacs Editor}).
12403
12404@findex gnus-mime-print-part
12405@item p (Article)
12406@kindex p (Article)
12407Print the @acronym{MIME} object (@code{gnus-mime-print-part}). This
12408command respects the @samp{print=} specifications in the
12409@file{.mailcap} file.
12410
12411@findex gnus-mime-inline-part
12412@item i (Article)
12413@kindex i (Article)
12414Insert the contents of the @acronym{MIME} object into the buffer
9b3ebcb6 12415(@code{gnus-mime-inline-part}) as @samp{text/plain}. If given a prefix, insert
4009494e
GM
12416the raw contents without decoding. If given a numerical prefix, you can
12417do semi-manual charset stuff (see
12418@code{gnus-summary-show-article-charset-alist} in @ref{Paging the
01c52d31
MB
12419Article}). Compressed files like @file{.gz} and @file{.bz2} are
12420automatically decompressed depending on @code{jka-compr} regardless of
12421@code{auto-compression-mode} (@pxref{Compressed Files,, Accessing
12422Compressed Files, emacs, The Emacs Editor}).
4009494e
GM
12423
12424@findex gnus-mime-view-part-internally
12425@item E (Article)
12426@kindex E (Article)
12427View the @acronym{MIME} object with an internal viewer. If no internal
12428viewer is available, use an external viewer
12429(@code{gnus-mime-view-part-internally}).
12430
12431@findex gnus-mime-view-part-externally
12432@item e (Article)
12433@kindex e (Article)
12434View the @acronym{MIME} object with an external viewer.
12435(@code{gnus-mime-view-part-externally}).
12436
12437@findex gnus-mime-pipe-part
12438@item | (Article)
12439@kindex | (Article)
12440Output the @acronym{MIME} object to a process (@code{gnus-mime-pipe-part}).
12441
12442@findex gnus-mime-action-on-part
12443@item . (Article)
12444@kindex . (Article)
12445Interactively run an action on the @acronym{MIME} object
12446(@code{gnus-mime-action-on-part}).
12447
12448@end table
12449
12450Gnus will display some @acronym{MIME} objects automatically. The way Gnus
12451determines which parts to do this with is described in the Emacs
12452@acronym{MIME} manual.
12453
12454It might be best to just use the toggling functions from the article
12455buffer to avoid getting nasty surprises. (For instance, you enter the
12456group @samp{alt.sing-a-long} and, before you know it, @acronym{MIME} has
12457decoded the sound file in the article and some horrible sing-a-long song
12458comes screaming out your speakers, and you can't find the volume button,
12459because there isn't one, and people are starting to look at you, and you
12460try to stop the program, but you can't, and you can't find the program
12461to control the volume, and everybody else in the room suddenly decides
12462to look at you disdainfully, and you'll feel rather stupid.)
12463
12464Any similarity to real events and people is purely coincidental. Ahem.
12465
12466Also @pxref{MIME Commands}.
12467
12468
85115796
KY
12469@node HTML
12470@section @acronym{HTML}
12471@cindex @acronym{HTML}
12472
12473If you have @code{w3m} installed on your system, Gnus can display
12474@acronym{HTML} articles in the article buffer. There are many Gnus
12475add-ons for doing this, using various approaches, but there's one
12476(sort of) built-in method that's used by default.
12477
12478For a complete overview, consult @xref{Display Customization,
12479,Display Customization, emacs-mime, The Emacs MIME Manual}. This
12480section only describes the default method.
12481
12482@table @code
12483@item mm-text-html-renderer
12484@vindex mm-text-html-renderer
12485If set to @code{gnus-article-html}, Gnus will use the built-in method,
12486that's based on @code{curl} and @code{w3m}.
12487
51dee5ef
KY
12488@item gnus-blocked-images
12489@vindex gnus-blocked-images
12490Images that have @acronym{URL}s that match this regexp won't be
12491fetched and displayed. For instance, do block all @acronym{URL}s that
12492have the string ``ads'' in them, do the following:
12493
12494@lisp
12495(setq gnus-blocked-images "ads")
12496@end lisp
12497
12498The default is to block all external images.
12499
85115796
KY
12500@item gnus-html-cache-directory
12501@vindex gnus-html-cache-directory
12502Gnus will download and cache images according to how
51dee5ef 12503@code{gnus-blocked-images} is set. These images will be stored in
85115796
KY
12504this directory.
12505
12506@item gnus-html-cache-size
12507@vindex gnus-html-cache-size
12508When @code{gnus-html-cache-size} bytes have been used in that
12509directory, the oldest files will be deleted. The default is 500MB.
12510
12511@item gnus-html-frame-width
12512@vindex gnus-html-frame-width
12513The width to use when rendering HTML. The default is 70.
12514
59d09f15
LMI
12515@item gnus-max-image-proportion
12516@vindex gnus-max-image-proportion
12517How big pictures displayed are in relation to the window they're in.
12518A value of 0.7 (the default) means that they are allowed to take up
1251970% of the width and height of the window. If they are larger than
12520this, and Emacs supports it, then the images will be rescaled down to
12521fit these criteria.
12522
85115796
KY
12523@end table
12524
12525To use this, make sure that you have @code{w3m} and @code{curl}
12526installed. If you have, then Gnus should display @acronym{HTML}
12527automatically.
12528
12529
12530
4009494e
GM
12531@node Customizing Articles
12532@section Customizing Articles
12533@cindex article customization
12534
12535A slew of functions for customizing how the articles are to look like
12536exist. You can call these functions interactively
12537(@pxref{Article Washing}), or you can have them
12538called automatically when you select the articles.
12539
12540To have them called automatically, you should set the corresponding
12541``treatment'' variable. For instance, to have headers hidden, you'd set
12542@code{gnus-treat-hide-headers}. Below is a list of variables that can
12543be set, but first we discuss the values these variables can have.
12544
12545Note: Some values, while valid, make little sense. Check the list below
12546for sensible values.
12547
12548@enumerate
12549@item
12550@code{nil}: Don't do this treatment.
12551
12552@item
12553@code{t}: Do this treatment on all body parts.
12554
12555@item
12556@code{head}: Do the treatment on the headers.
12557
12558@item
01c52d31
MB
12559@code{first}: Do this treatment on the first body part.
12560
12561@item
12562@code{last}: Do this treatment on the last body part.
4009494e
GM
12563
12564@item
12565An integer: Do this treatment on all body parts that have a length less
12566than this number.
12567
12568@item
12569A list of strings: Do this treatment on all body parts that are in
12570articles that are read in groups that have names that match one of the
12571regexps in the list.
12572
12573@item
12574A list where the first element is not a string:
12575
12576The list is evaluated recursively. The first element of the list is a
12577predicate. The following predicates are recognized: @code{or},
12578@code{and}, @code{not} and @code{typep}. Here's an example:
12579
12580@lisp
12581(or last
12582 (typep "text/x-vcard"))
12583@end lisp
12584
12585@end enumerate
12586
12587You may have noticed that the word @dfn{part} is used here. This refers
12588to the fact that some messages are @acronym{MIME} multipart articles that may
12589be divided into several parts. Articles that are not multiparts are
12590considered to contain just a single part.
12591
12592@vindex gnus-article-treat-types
12593Are the treatments applied to all sorts of multipart parts? Yes, if you
12594want to, but by default, only @samp{text/plain} parts are given the
12595treatment. This is controlled by the @code{gnus-article-treat-types}
12596variable, which is a list of regular expressions that are matched to the
12597type of the part. This variable is ignored if the value of the
12598controlling variable is a predicate list, as described above.
12599
12600@ifinfo
12601@c Avoid sort of redundant entries in the same section for the printed
12602@c manual, but add them in info to allow `i gnus-treat-foo-bar RET' or
12603@c `i foo-bar'.
12604@vindex gnus-treat-buttonize
12605@vindex gnus-treat-buttonize-head
12606@vindex gnus-treat-capitalize-sentences
12607@vindex gnus-treat-overstrike
12608@vindex gnus-treat-strip-cr
12609@vindex gnus-treat-strip-headers-in-body
12610@vindex gnus-treat-strip-leading-blank-lines
12611@vindex gnus-treat-strip-multiple-blank-lines
12612@vindex gnus-treat-strip-pem
12613@vindex gnus-treat-strip-trailing-blank-lines
12614@vindex gnus-treat-unsplit-urls
12615@vindex gnus-treat-wash-html
12616@vindex gnus-treat-date-english
12617@vindex gnus-treat-date-iso8601
12618@vindex gnus-treat-date-lapsed
12619@vindex gnus-treat-date-local
12620@vindex gnus-treat-date-original
12621@vindex gnus-treat-date-user-defined
12622@vindex gnus-treat-date-ut
12623@vindex gnus-treat-from-picon
12624@vindex gnus-treat-mail-picon
12625@vindex gnus-treat-newsgroups-picon
12626@vindex gnus-treat-display-smileys
12627@vindex gnus-treat-body-boundary
12628@vindex gnus-treat-display-x-face
12629@vindex gnus-treat-display-face
12630@vindex gnus-treat-emphasize
12631@vindex gnus-treat-fill-article
12632@vindex gnus-treat-fill-long-lines
12633@vindex gnus-treat-hide-boring-headers
12634@vindex gnus-treat-hide-citation
12635@vindex gnus-treat-hide-citation-maybe
12636@vindex gnus-treat-hide-headers
12637@vindex gnus-treat-hide-signature
12638@vindex gnus-treat-strip-banner
12639@vindex gnus-treat-strip-list-identifiers
12640@vindex gnus-treat-highlight-citation
12641@vindex gnus-treat-highlight-headers
12642@vindex gnus-treat-highlight-signature
12643@vindex gnus-treat-play-sounds
12644@vindex gnus-treat-translate
12645@vindex gnus-treat-x-pgp-sig
12646@vindex gnus-treat-unfold-headers
12647@vindex gnus-treat-fold-headers
12648@vindex gnus-treat-fold-newsgroups
12649@vindex gnus-treat-leading-whitespace
12650@end ifinfo
12651
12652The following treatment options are available. The easiest way to
12653customize this is to examine the @code{gnus-article-treat} customization
12654group. Values in parenthesis are suggested sensible values. Others are
12655possible but those listed are probably sufficient for most people.
12656
12657@table @code
12658@item gnus-treat-buttonize (t, integer)
12659@item gnus-treat-buttonize-head (head)
12660
12661@xref{Article Buttons}.
12662
12663@item gnus-treat-capitalize-sentences (t, integer)
12664@item gnus-treat-overstrike (t, integer)
12665@item gnus-treat-strip-cr (t, integer)
12666@item gnus-treat-strip-headers-in-body (t, integer)
01c52d31 12667@item gnus-treat-strip-leading-blank-lines (t, first, integer)
4009494e
GM
12668@item gnus-treat-strip-multiple-blank-lines (t, integer)
12669@item gnus-treat-strip-pem (t, last, integer)
12670@item gnus-treat-strip-trailing-blank-lines (t, last, integer)
12671@item gnus-treat-unsplit-urls (t, integer)
12672@item gnus-treat-wash-html (t, integer)
12673
12674@xref{Article Washing}.
12675
12676@item gnus-treat-date-english (head)
12677@item gnus-treat-date-iso8601 (head)
12678@item gnus-treat-date-lapsed (head)
12679@item gnus-treat-date-local (head)
12680@item gnus-treat-date-original (head)
12681@item gnus-treat-date-user-defined (head)
12682@item gnus-treat-date-ut (head)
12683
12684@xref{Article Date}.
12685
12686@item gnus-treat-from-picon (head)
12687@item gnus-treat-mail-picon (head)
12688@item gnus-treat-newsgroups-picon (head)
12689
12690@xref{Picons}.
12691
12692@item gnus-treat-display-smileys (t, integer)
12693
12694@item gnus-treat-body-boundary (head)
12695
12696@vindex gnus-body-boundary-delimiter
12697Adds a delimiter between header and body, the string used as delimiter
12698is controlled by @code{gnus-body-boundary-delimiter}.
12699
12700@xref{Smileys}.
12701
12702@vindex gnus-treat-display-x-face
12703@item gnus-treat-display-x-face (head)
12704
12705@xref{X-Face}.
12706
12707@vindex gnus-treat-display-face
12708@item gnus-treat-display-face (head)
12709
12710@xref{Face}.
12711
12712@vindex gnus-treat-emphasize
12713@item gnus-treat-emphasize (t, head, integer)
12714@vindex gnus-treat-fill-article
12715@item gnus-treat-fill-article (t, integer)
12716@vindex gnus-treat-fill-long-lines
12717@item gnus-treat-fill-long-lines (t, integer)
12718@vindex gnus-treat-hide-boring-headers
12719@item gnus-treat-hide-boring-headers (head)
12720@vindex gnus-treat-hide-citation
12721@item gnus-treat-hide-citation (t, integer)
12722@vindex gnus-treat-hide-citation-maybe
12723@item gnus-treat-hide-citation-maybe (t, integer)
12724@vindex gnus-treat-hide-headers
12725@item gnus-treat-hide-headers (head)
12726@vindex gnus-treat-hide-signature
12727@item gnus-treat-hide-signature (t, last)
12728@vindex gnus-treat-strip-banner
12729@item gnus-treat-strip-banner (t, last)
12730@vindex gnus-treat-strip-list-identifiers
12731@item gnus-treat-strip-list-identifiers (head)
12732
12733@xref{Article Hiding}.
12734
12735@vindex gnus-treat-highlight-citation
12736@item gnus-treat-highlight-citation (t, integer)
12737@vindex gnus-treat-highlight-headers
12738@item gnus-treat-highlight-headers (head)
12739@vindex gnus-treat-highlight-signature
12740@item gnus-treat-highlight-signature (t, last, integer)
12741
12742@xref{Article Highlighting}.
12743
12744@vindex gnus-treat-play-sounds
12745@item gnus-treat-play-sounds
12746@vindex gnus-treat-translate
12747@item gnus-treat-translate
01c52d31 12748@item gnus-treat-ansi-sequences (t)
4009494e
GM
12749@vindex gnus-treat-x-pgp-sig
12750@item gnus-treat-x-pgp-sig (head)
12751
12752@vindex gnus-treat-unfold-headers
12753@item gnus-treat-unfold-headers (head)
12754@vindex gnus-treat-fold-headers
12755@item gnus-treat-fold-headers (head)
12756@vindex gnus-treat-fold-newsgroups
12757@item gnus-treat-fold-newsgroups (head)
12758@vindex gnus-treat-leading-whitespace
12759@item gnus-treat-leading-whitespace (head)
12760
12761@xref{Article Header}.
12762
12763
12764@end table
12765
12766@vindex gnus-part-display-hook
12767You can, of course, write your own functions to be called from
12768@code{gnus-part-display-hook}. The functions are called narrowed to the
12769part, and you can do anything you like, pretty much. There is no
12770information that you have to keep in the buffer---you can change
12771everything.
12772
12773
12774@node Article Keymap
12775@section Article Keymap
12776
12777Most of the keystrokes in the summary buffer can also be used in the
12778article buffer. They should behave as if you typed them in the summary
12779buffer, which means that you don't actually have to have a summary
12780buffer displayed while reading. You can do it all from the article
12781buffer.
12782
12783@kindex v (Article)
12784@cindex keys, reserved for users (Article)
12785The key @kbd{v} is reserved for users. You can bind it to some
12786command or better use it as a prefix key.
12787
12788A few additional keystrokes are available:
12789
12790@table @kbd
12791
12792@item SPACE
12793@kindex SPACE (Article)
12794@findex gnus-article-next-page
12795Scroll forwards one page (@code{gnus-article-next-page}).
12796This is exactly the same as @kbd{h SPACE h}.
12797
12798@item DEL
12799@kindex DEL (Article)
12800@findex gnus-article-prev-page
12801Scroll backwards one page (@code{gnus-article-prev-page}).
12802This is exactly the same as @kbd{h DEL h}.
12803
12804@item C-c ^
12805@kindex C-c ^ (Article)
12806@findex gnus-article-refer-article
12807If point is in the neighborhood of a @code{Message-ID} and you press
12808@kbd{C-c ^}, Gnus will try to get that article from the server
12809(@code{gnus-article-refer-article}).
12810
12811@item C-c C-m
12812@kindex C-c C-m (Article)
12813@findex gnus-article-mail
12814Send a reply to the address near point (@code{gnus-article-mail}). If
12815given a prefix, include the mail.
12816
12817@item s
12818@kindex s (Article)
12819@findex gnus-article-show-summary
12820Reconfigure the buffers so that the summary buffer becomes visible
12821(@code{gnus-article-show-summary}).
12822
12823@item ?
12824@kindex ? (Article)
12825@findex gnus-article-describe-briefly
12826Give a very brief description of the available keystrokes
12827(@code{gnus-article-describe-briefly}).
12828
12829@item TAB
12830@kindex TAB (Article)
12831@findex gnus-article-next-button
12832Go to the next button, if any (@code{gnus-article-next-button}). This
12833only makes sense if you have buttonizing turned on.
12834
12835@item M-TAB
12836@kindex M-TAB (Article)
12837@findex gnus-article-prev-button
12838Go to the previous button, if any (@code{gnus-article-prev-button}).
12839
12840@item R
12841@kindex R (Article)
12842@findex gnus-article-reply-with-original
12843Send a reply to the current article and yank the current article
95838435
MB
12844(@code{gnus-article-reply-with-original}). If the region is active,
12845only yank the text in the region.
12846
12847@item S W
12848@kindex S W (Article)
12849@findex gnus-article-wide-reply-with-original
12850Send a wide reply to the current article and yank the current article
12851(@code{gnus-article-wide-reply-with-original}). If the region is
12852active, only yank the text in the region.
4009494e
GM
12853
12854@item F
12855@kindex F (Article)
12856@findex gnus-article-followup-with-original
12857Send a followup to the current article and yank the current article
95838435
MB
12858(@code{gnus-article-followup-with-original}). If the region is active,
12859only yank the text in the region.
4009494e
GM
12860
12861
12862@end table
12863
12864
12865@node Misc Article
12866@section Misc Article
12867
12868@table @code
12869
12870@item gnus-single-article-buffer
12871@vindex gnus-single-article-buffer
12872@cindex article buffers, several
12873If non-@code{nil}, use the same article buffer for all the groups.
12874(This is the default.) If @code{nil}, each group will have its own
12875article buffer.
12876
12877@vindex gnus-article-decode-hook
12878@item gnus-article-decode-hook
12879@cindex @acronym{MIME}
12880Hook used to decode @acronym{MIME} articles. The default value is
12881@code{(article-decode-charset article-decode-encoded-words)}
12882
12883@vindex gnus-article-prepare-hook
12884@item gnus-article-prepare-hook
12885This hook is called right after the article has been inserted into the
12886article buffer. It is mainly intended for functions that do something
12887depending on the contents; it should probably not be used for changing
12888the contents of the article buffer.
12889
12890@item gnus-article-mode-hook
12891@vindex gnus-article-mode-hook
12892Hook called in article mode buffers.
12893
12894@item gnus-article-mode-syntax-table
12895@vindex gnus-article-mode-syntax-table
12896Syntax table used in article buffers. It is initialized from
12897@code{text-mode-syntax-table}.
12898
12899@vindex gnus-article-over-scroll
12900@item gnus-article-over-scroll
12901If non-@code{nil}, allow scrolling the article buffer even when there
12902no more new text to scroll in. The default is @code{nil}.
12903
12904@vindex gnus-article-mode-line-format
12905@item gnus-article-mode-line-format
12906This variable is a format string along the same lines as
12907@code{gnus-summary-mode-line-format} (@pxref{Summary Buffer Mode
12908Line}). It accepts the same format specifications as that variable,
12909with two extensions:
12910
12911@table @samp
12912
12913@item w
12914The @dfn{wash status} of the article. This is a short string with one
12915character for each possible article wash operation that may have been
12916performed. The characters and their meaning:
12917
12918@table @samp
12919
12920@item c
12921Displayed when cited text may be hidden in the article buffer.
12922
12923@item h
12924Displayed when headers are hidden in the article buffer.
12925
12926@item p
12927Displayed when article is digitally signed or encrypted, and Gnus has
12928hidden the security headers. (N.B. does not tell anything about
12929security status, i.e. good or bad signature.)
12930
12931@item s
12932Displayed when the signature has been hidden in the Article buffer.
12933
12934@item o
12935Displayed when Gnus has treated overstrike characters in the article buffer.
12936
12937@item e
6772c8e1 12938Displayed when Gnus has treated emphasized strings in the article buffer.
4009494e
GM
12939
12940@end table
12941
12942@item m
12943The number of @acronym{MIME} parts in the article.
12944
12945@end table
12946
12947@vindex gnus-break-pages
12948
12949@item gnus-break-pages
12950Controls whether @dfn{page breaking} is to take place. If this variable
12951is non-@code{nil}, the articles will be divided into pages whenever a
12952page delimiter appears in the article. If this variable is @code{nil},
12953paging will not be done.
12954
12955@item gnus-page-delimiter
12956@vindex gnus-page-delimiter
12957This is the delimiter mentioned above. By default, it is @samp{^L}
12958(formfeed).
12959
12960@cindex IDNA
12961@cindex internationalized domain names
12962@vindex gnus-use-idna
12963@item gnus-use-idna
12964This variable controls whether Gnus performs IDNA decoding of
12965internationalized domain names inside @samp{From}, @samp{To} and
01c52d31
MB
12966@samp{Cc} headers. @xref{IDNA, ,IDNA,message, The Message Manual},
12967for how to compose such messages. This requires
4009494e
GM
12968@uref{http://www.gnu.org/software/libidn/, GNU Libidn}, and this
12969variable is only enabled if you have installed it.
12970
12971@end table
12972
12973
12974@node Composing Messages
12975@chapter Composing Messages
12976@cindex composing messages
12977@cindex messages
12978@cindex mail
12979@cindex sending mail
12980@cindex reply
12981@cindex followup
12982@cindex post
12983@cindex using gpg
12984@cindex using s/mime
12985@cindex using smime
12986
12987@kindex C-c C-c (Post)
12988All commands for posting and mailing will put you in a message buffer
12989where you can edit the article all you like, before you send the
12990article by pressing @kbd{C-c C-c}. @xref{Top, , Overview, message,
12991Message Manual}. Where the message will be posted/mailed to depends
12992on your setup (@pxref{Posting Server}).
12993
12994@menu
12995* Mail:: Mailing and replying.
12996* Posting Server:: What server should you post and mail via?
12997* POP before SMTP:: You cannot send a mail unless you read a mail.
12998* Mail and Post:: Mailing and posting at the same time.
12999* Archived Messages:: Where Gnus stores the messages you've sent.
13000* Posting Styles:: An easier way to specify who you are.
13001* Drafts:: Postponing messages and rejected messages.
13002* Rejected Articles:: What happens if the server doesn't like your article?
13003* Signing and encrypting:: How to compose secure messages.
13004@end menu
13005
13006Also @pxref{Canceling and Superseding} for information on how to
13007remove articles you shouldn't have posted.
13008
13009
13010@node Mail
13011@section Mail
13012
13013Variables for customizing outgoing mail:
13014
13015@table @code
13016@item gnus-uu-digest-headers
13017@vindex gnus-uu-digest-headers
13018List of regexps to match headers included in digested messages. The
13019headers will be included in the sequence they are matched. If
13020@code{nil} include all headers.
13021
13022@item gnus-add-to-list
13023@vindex gnus-add-to-list
13024If non-@code{nil}, add a @code{to-list} group parameter to mail groups
13025that have none when you do a @kbd{a}.
13026
13027@item gnus-confirm-mail-reply-to-news
13028@vindex gnus-confirm-mail-reply-to-news
13029If non-@code{nil}, Gnus will ask you for a confirmation when you are
13030about to reply to news articles by mail. If it is @code{nil}, nothing
13031interferes in what you want to do. This can also be a function
13032receiving the group name as the only parameter which should return
13033non-@code{nil} if a confirmation is needed, or a regular expression
13034matching group names, where confirmation should be asked for.
13035
13036If you find yourself never wanting to reply to mail, but occasionally
13037press @kbd{R} anyway, this variable might be for you.
13038
13039@item gnus-confirm-treat-mail-like-news
13040@vindex gnus-confirm-treat-mail-like-news
13041If non-@code{nil}, Gnus also requests confirmation according to
13042@code{gnus-confirm-mail-reply-to-news} when replying to mail. This is
13043useful for treating mailing lists like newsgroups.
13044
13045@end table
13046
13047
13048@node Posting Server
13049@section Posting Server
13050
13051When you press those magical @kbd{C-c C-c} keys to ship off your latest
13052(extremely intelligent, of course) article, where does it go?
13053
13054Thank you for asking. I hate you.
13055
13056It can be quite complicated.
13057
13058@vindex gnus-post-method
13059When posting news, Message usually invokes @code{message-send-news}
13060(@pxref{News Variables, , News Variables, message, Message Manual}).
13061Normally, Gnus will post using the same select method as you're
13062reading from (which might be convenient if you're reading lots of
13063groups from different private servers). However. If the server
13064you're reading from doesn't allow posting, just reading, you probably
13065want to use some other server to post your (extremely intelligent and
13066fabulously interesting) articles. You can then set the
13067@code{gnus-post-method} to some other method:
13068
13069@lisp
13070(setq gnus-post-method '(nnspool ""))
13071@end lisp
13072
13073Now, if you've done this, and then this server rejects your article, or
13074this server is down, what do you do then? To override this variable you
13075can use a non-zero prefix to the @kbd{C-c C-c} command to force using
13076the ``current'' server, to get back the default behavior, for posting.
13077
13078If you give a zero prefix (i.e., @kbd{C-u 0 C-c C-c}) to that command,
13079Gnus will prompt you for what method to use for posting.
13080
13081You can also set @code{gnus-post-method} to a list of select methods.
13082If that's the case, Gnus will always prompt you for what method to use
13083for posting.
13084
13085Finally, if you want to always post using the native select method,
13086you can set this variable to @code{native}.
13087
d82cf70b
MB
13088@vindex message-send-mail-function
13089When sending mail, Message invokes the function specified by the
13090variable @code{message-send-mail-function}. Gnus tries to set it to a
13091value suitable for your system.
13092@xref{Mail Variables, ,Mail Variables,message,Message manual}, for more
13093information.
4009494e
GM
13094
13095@node POP before SMTP
13096@section POP before SMTP
13097@cindex pop before smtp
13098@findex message-smtpmail-send-it
13099@findex mail-source-touch-pop
13100
13101Does your @acronym{ISP} require the @acronym{POP}-before-@acronym{SMTP}
13102authentication? It is whether you need to connect to the @acronym{POP}
13103mail server within a certain time before sending mails. If so, there is
13104a convenient way. To do that, put the following lines in your
13105@file{~/.gnus.el} file:
13106
13107@lisp
13108(setq message-send-mail-function 'message-smtpmail-send-it)
13109(add-hook 'message-send-mail-hook 'mail-source-touch-pop)
13110@end lisp
13111
13112@noindent
13113It means to let Gnus connect to the @acronym{POP} mail server in advance
13114whenever you send a mail. The @code{mail-source-touch-pop} function
13115does only a @acronym{POP} authentication according to the value of
13116@code{mail-sources} without fetching mails, just before sending a mail.
13117Note that you have to use @code{message-smtpmail-send-it} which runs
13118@code{message-send-mail-hook} rather than @code{smtpmail-send-it} and
13119set the value of @code{mail-sources} for a @acronym{POP} connection
13120correctly. @xref{Mail Sources}.
13121
13122If you have two or more @acronym{POP} mail servers set in
13123@code{mail-sources}, you may want to specify one of them to
13124@code{mail-source-primary-source} as the @acronym{POP} mail server to be
13125used for the @acronym{POP}-before-@acronym{SMTP} authentication. If it
13126is your primary @acronym{POP} mail server (i.e., you are fetching mails
13127mainly from that server), you can set it permanently as follows:
13128
13129@lisp
13130(setq mail-source-primary-source
13131 '(pop :server "pop3.mail.server"
13132 :password "secret"))
13133@end lisp
13134
13135@noindent
13136Otherwise, bind it dynamically only when performing the
13137@acronym{POP}-before-@acronym{SMTP} authentication as follows:
13138
13139@lisp
13140(add-hook 'message-send-mail-hook
13141 (lambda ()
13142 (let ((mail-source-primary-source
13143 '(pop :server "pop3.mail.server"
13144 :password "secret")))
13145 (mail-source-touch-pop))))
13146@end lisp
13147
13148@node Mail and Post
13149@section Mail and Post
13150
13151Here's a list of variables relevant to both mailing and
13152posting:
13153
13154@table @code
13155@item gnus-mailing-list-groups
13156@findex gnus-mailing-list-groups
13157@cindex mailing lists
13158
13159If your news server offers groups that are really mailing lists
13160gatewayed to the @acronym{NNTP} server, you can read those groups without
13161problems, but you can't post/followup to them without some difficulty.
13162One solution is to add a @code{to-address} to the group parameters
13163(@pxref{Group Parameters}). An easier thing to do is set the
13164@code{gnus-mailing-list-groups} to a regexp that matches the groups that
13165really are mailing lists. Then, at least, followups to the mailing
13166lists will work most of the time. Posting to these groups (@kbd{a}) is
13167still a pain, though.
13168
13169@item gnus-user-agent
13170@vindex gnus-user-agent
13171@cindex User-Agent
13172
13173This variable controls which information should be exposed in the
13174User-Agent header. It can be a list of symbols or a string. Valid
13175symbols are @code{gnus} (show Gnus version) and @code{emacs} (show Emacs
13176version). In addition to the Emacs version, you can add @code{codename}
13177(show (S)XEmacs codename) or either @code{config} (show system
13178configuration) or @code{type} (show system type). If you set it to a
13179string, be sure to use a valid format, see RFC 2616.
13180
13181@end table
13182
13183You may want to do spell-checking on messages that you send out. Or, if
13184you don't want to spell-check by hand, you could add automatic
13185spell-checking via the @code{ispell} package:
13186
13187@cindex ispell
13188@findex ispell-message
13189@lisp
13190(add-hook 'message-send-hook 'ispell-message)
13191@end lisp
13192
13193If you want to change the @code{ispell} dictionary based on what group
13194you're in, you could say something like the following:
13195
13196@lisp
13197(add-hook 'gnus-select-group-hook
13198 (lambda ()
13199 (cond
13200 ((string-match
13201 "^de\\." (gnus-group-real-name gnus-newsgroup-name))
13202 (ispell-change-dictionary "deutsch"))
13203 (t
13204 (ispell-change-dictionary "english")))))
13205@end lisp
13206
13207Modify to suit your needs.
13208
01c52d31
MB
13209@vindex gnus-message-highlight-citation
13210If @code{gnus-message-highlight-citation} is t, different levels of
13211citations are highlighted like in Gnus article buffers also in message
13212mode buffers.
4009494e
GM
13213
13214@node Archived Messages
13215@section Archived Messages
13216@cindex archived messages
13217@cindex sent messages
13218
13219Gnus provides a few different methods for storing the mail and news you
13220send. The default method is to use the @dfn{archive virtual server} to
13221store the messages. If you want to disable this completely, the
13222@code{gnus-message-archive-group} variable should be @code{nil}, which
13223is the default.
13224
13225For archiving interesting messages in a group you read, see the
13226@kbd{B c} (@code{gnus-summary-copy-article}) command (@pxref{Mail
13227Group Commands}).
13228
13229@vindex gnus-message-archive-method
13230@code{gnus-message-archive-method} says what virtual server Gnus is to
01c52d31
MB
13231use to store sent messages. The default is @code{"archive"}, and when
13232actually being used it is expanded into:
4009494e
GM
13233
13234@lisp
13235(nnfolder "archive"
13236 (nnfolder-directory "~/Mail/archive")
13237 (nnfolder-active-file "~/Mail/archive/active")
13238 (nnfolder-get-new-mail nil)
13239 (nnfolder-inhibit-expiry t))
13240@end lisp
13241
01c52d31
MB
13242@quotation
13243@vindex gnus-update-message-archive-method
13244Note: a server like this is saved in the @file{~/.newsrc.eld} file first
13245so that it may be used as a real method of the server which is named
13246@code{"archive"} (that is, for the case where
13247@code{gnus-message-archive-method} is set to @code{"archive"}) ever
13248since. If it once has been saved, it will never be updated by default
13249even if you change the value of @code{gnus-message-archive-method}
13250afterward. Therefore, the server @code{"archive"} doesn't necessarily
13251mean the @code{nnfolder} server like this at all times. If you want the
13252saved method to reflect always the value of
13253@code{gnus-message-archive-method}, set the
13254@code{gnus-update-message-archive-method} variable to a non-@code{nil}
13255value. The default value of this variable is @code{nil}.
13256@end quotation
13257
4009494e
GM
13258You can, however, use any mail select method (@code{nnml},
13259@code{nnmbox}, etc.). @code{nnfolder} is a quite likable select method
13260for doing this sort of thing, though. If you don't like the default
13261directory chosen, you could say something like:
13262
13263@lisp
13264(setq gnus-message-archive-method
13265 '(nnfolder "archive"
13266 (nnfolder-inhibit-expiry t)
13267 (nnfolder-active-file "~/News/sent-mail/active")
13268 (nnfolder-directory "~/News/sent-mail/")))
13269@end lisp
13270
13271@vindex gnus-message-archive-group
13272@cindex Gcc
13273Gnus will insert @code{Gcc} headers in all outgoing messages that point
13274to one or more group(s) on that server. Which group to use is
13275determined by the @code{gnus-message-archive-group} variable.
13276
13277This variable can be used to do the following:
13278
13279@table @asis
13280@item a string
13281Messages will be saved in that group.
13282
13283Note that you can include a select method in the group name, then the
13284message will not be stored in the select method given by
13285@code{gnus-message-archive-method}, but in the select method specified
13286by the group name, instead. Suppose @code{gnus-message-archive-method}
13287has the default value shown above. Then setting
13288@code{gnus-message-archive-group} to @code{"foo"} means that outgoing
13289messages are stored in @samp{nnfolder+archive:foo}, but if you use the
13290value @code{"nnml:foo"}, then outgoing messages will be stored in
13291@samp{nnml:foo}.
13292
13293@item a list of strings
13294Messages will be saved in all those groups.
13295
13296@item an alist of regexps, functions and forms
13297When a key ``matches'', the result is used.
13298
13299@item @code{nil}
13300No message archiving will take place. This is the default.
13301@end table
13302
13303Let's illustrate:
13304
13305Just saving to a single group called @samp{MisK}:
13306@lisp
13307(setq gnus-message-archive-group "MisK")
13308@end lisp
13309
13310Saving to two groups, @samp{MisK} and @samp{safe}:
13311@lisp
13312(setq gnus-message-archive-group '("MisK" "safe"))
13313@end lisp
13314
13315Save to different groups based on what group you are in:
13316@lisp
13317(setq gnus-message-archive-group
13318 '(("^alt" "sent-to-alt")
13319 ("mail" "sent-to-mail")
13320 (".*" "sent-to-misc")))
13321@end lisp
13322
13323More complex stuff:
13324@lisp
13325(setq gnus-message-archive-group
13326 '((if (message-news-p)
13327 "misc-news"
13328 "misc-mail")))
13329@end lisp
13330
13331How about storing all news messages in one file, but storing all mail
13332messages in one file per month:
13333
13334@lisp
13335(setq gnus-message-archive-group
13336 '((if (message-news-p)
13337 "misc-news"
13338 (concat "mail." (format-time-string "%Y-%m")))))
13339@end lisp
13340
13341@c (XEmacs 19.13 doesn't have @code{format-time-string}, so you'll have to
13342@c use a different value for @code{gnus-message-archive-group} there.)
13343
13344Now, when you send a message off, it will be stored in the appropriate
13345group. (If you want to disable storing for just one particular message,
13346you can just remove the @code{Gcc} header that has been inserted.) The
13347archive group will appear in the group buffer the next time you start
13348Gnus, or the next time you press @kbd{F} in the group buffer. You can
13349enter it and read the articles in it just like you'd read any other
13350group. If the group gets really big and annoying, you can simply rename
13351if (using @kbd{G r} in the group buffer) to something
13352nice---@samp{misc-mail-september-1995}, or whatever. New messages will
13353continue to be stored in the old (now empty) group.
13354
13355That's the default method of archiving sent messages. Gnus offers a
13356different way for the people who don't like the default method. In that
13357case you should set @code{gnus-message-archive-group} to @code{nil};
13358this will disable archiving.
13359
13360@table @code
13361@item gnus-outgoing-message-group
13362@vindex gnus-outgoing-message-group
13363All outgoing messages will be put in this group. If you want to store
13364all your outgoing mail and articles in the group @samp{nnml:archive},
13365you set this variable to that value. This variable can also be a list of
13366group names.
13367
13368If you want to have greater control over what group to put each
13369message in, you can set this variable to a function that checks the
13370current newsgroup name and then returns a suitable group name (or list
13371of names).
13372
13373This variable can be used instead of @code{gnus-message-archive-group},
13374but the latter is the preferred method.
13375
13376@item gnus-gcc-mark-as-read
13377@vindex gnus-gcc-mark-as-read
13378If non-@code{nil}, automatically mark @code{Gcc} articles as read.
13379
13380@item gnus-gcc-externalize-attachments
13381@vindex gnus-gcc-externalize-attachments
13382If @code{nil}, attach files as normal parts in Gcc copies; if a regexp
13383and matches the Gcc group name, attach files as external parts; if it is
13384@code{all}, attach local files as external parts; if it is other
13385non-@code{nil}, the behavior is the same as @code{all}, but it may be
13386changed in the future.
13387
13388@end table
13389
13390
13391@node Posting Styles
13392@section Posting Styles
13393@cindex posting styles
13394@cindex styles
13395
13396All them variables, they make my head swim.
13397
13398So what if you want a different @code{Organization} and signature based
13399on what groups you post to? And you post both from your home machine
13400and your work machine, and you want different @code{From} lines, and so
13401on?
13402
13403@vindex gnus-posting-styles
13404One way to do stuff like that is to write clever hooks that change the
13405variables you need to have changed. That's a bit boring, so somebody
13406came up with the bright idea of letting the user specify these things in
13407a handy alist. Here's an example of a @code{gnus-posting-styles}
13408variable:
13409
13410@lisp
13411((".*"
13412 (signature "Peace and happiness")
13413 (organization "What me?"))
13414 ("^comp"
13415 (signature "Death to everybody"))
13416 ("comp.emacs.i-love-it"
13417 (organization "Emacs is it")))
13418@end lisp
13419
13420As you might surmise from this example, this alist consists of several
13421@dfn{styles}. Each style will be applicable if the first element
13422``matches'', in some form or other. The entire alist will be iterated
13423over, from the beginning towards the end, and each match will be
13424applied, which means that attributes in later styles that match override
13425the same attributes in earlier matching styles. So
13426@samp{comp.programming.literate} will have the @samp{Death to everybody}
13427signature and the @samp{What me?} @code{Organization} header.
13428
13429The first element in each style is called the @code{match}. If it's a
13430string, then Gnus will try to regexp match it against the group name.
13431If it is the form @code{(header @var{match} @var{regexp})}, then Gnus
13432will look in the original article for a header whose name is
13433@var{match} and compare that @var{regexp}. @var{match} and
13434@var{regexp} are strings. (The original article is the one you are
13435replying or following up to. If you are not composing a reply or a
13436followup, then there is nothing to match against.) If the
13437@code{match} is a function symbol, that function will be called with
13438no arguments. If it's a variable symbol, then the variable will be
13439referenced. If it's a list, then that list will be @code{eval}ed. In
13440any case, if this returns a non-@code{nil} value, then the style is
13441said to @dfn{match}.
13442
13443Each style may contain an arbitrary amount of @dfn{attributes}. Each
13444attribute consists of a @code{(@var{name} @var{value})} pair. In
13445addition, you can also use the @code{(@var{name} :file @var{value})}
13446form or the @code{(@var{name} :value @var{value})} form. Where
13447@code{:file} signifies @var{value} represents a file name and its
13448contents should be used as the attribute value, @code{:value} signifies
13449@var{value} does not represent a file name explicitly. The attribute
13450name can be one of:
13451
13452@itemize @bullet
13453@item @code{signature}
13454@item @code{signature-file}
13455@item @code{x-face-file}
13456@item @code{address}, overriding @code{user-mail-address}
13457@item @code{name}, overriding @code{(user-full-name)}
13458@item @code{body}
13459@end itemize
13460
01c52d31
MB
13461Note that the @code{signature-file} attribute honors the variable
13462@code{message-signature-directory}.
13463
4009494e
GM
13464The attribute name can also be a string or a symbol. In that case,
13465this will be used as a header name, and the value will be inserted in
13466the headers of the article; if the value is @code{nil}, the header
13467name will be removed. If the attribute name is @code{eval}, the form
13468is evaluated, and the result is thrown away.
13469
13470The attribute value can be a string (used verbatim), a function with
13471zero arguments (the return value will be used), a variable (its value
13472will be used) or a list (it will be @code{eval}ed and the return value
13473will be used). The functions and sexps are called/@code{eval}ed in the
13474message buffer that is being set up. The headers of the current article
13475are available through the @code{message-reply-headers} variable, which
13476is a vector of the following headers: number subject from date id
13477references chars lines xref extra.
13478
13479@vindex message-reply-headers
13480
13481If you wish to check whether the message you are about to compose is
13482meant to be a news article or a mail message, you can check the values
13483of the @code{message-news-p} and @code{message-mail-p} functions.
13484
13485@findex message-mail-p
13486@findex message-news-p
13487
13488So here's a new example:
13489
13490@lisp
13491(setq gnus-posting-styles
13492 '((".*"
13493 (signature-file "~/.signature")
13494 (name "User Name")
13495 (x-face-file "~/.xface")
13496 (x-url (getenv "WWW_HOME"))
13497 (organization "People's Front Against MWM"))
13498 ("^rec.humor"
13499 (signature my-funny-signature-randomizer))
13500 ((equal (system-name) "gnarly") ;; @r{A form}
13501 (signature my-quote-randomizer))
13502 (message-news-p ;; @r{A function symbol}
13503 (signature my-news-signature))
13504 (window-system ;; @r{A value symbol}
13505 ("X-Window-System" (format "%s" window-system)))
13506 ;; @r{If I'm replying to Larsi, set the Organization header.}
13507 ((header "from" "larsi.*org")
13508 (Organization "Somewhere, Inc."))
13509 ((posting-from-work-p) ;; @r{A user defined function}
13510 (signature-file "~/.work-signature")
13511 (address "user@@bar.foo")
13512 (body "You are fired.\n\nSincerely, your boss.")
13513 (organization "Important Work, Inc"))
13514 ("nnml:.*"
c57008f6 13515 (From (with-current-buffer gnus-article-buffer
4009494e
GM
13516 (message-fetch-field "to"))))
13517 ("^nn.+:"
13518 (signature-file "~/.mail-signature"))))
13519@end lisp
13520
13521The @samp{nnml:.*} rule means that you use the @code{To} address as the
13522@code{From} address in all your outgoing replies, which might be handy
13523if you fill many roles.
13524You may also use @code{message-alternative-emails} instead.
13525@xref{Message Headers, ,Message Headers, message, Message Manual}.
13526
13527@node Drafts
13528@section Drafts
13529@cindex drafts
13530
13531If you are writing a message (mail or news) and suddenly remember that
13532you have a steak in the oven (or some pesto in the food processor, you
13533craaazy vegetarians), you'll probably wish there was a method to save
13534the message you are writing so that you can continue editing it some
13535other day, and send it when you feel its finished.
13536
13537Well, don't worry about it. Whenever you start composing a message of
13538some sort using the Gnus mail and post commands, the buffer you get will
13539automatically associate to an article in a special @dfn{draft} group.
13540If you save the buffer the normal way (@kbd{C-x C-s}, for instance), the
13541article will be saved there. (Auto-save files also go to the draft
13542group.)
13543
13544@cindex nndraft
13545@vindex nndraft-directory
13546The draft group is a special group (which is implemented as an
13547@code{nndraft} group, if you absolutely have to know) called
13548@samp{nndraft:drafts}. The variable @code{nndraft-directory} says where
13549@code{nndraft} is to store its files. What makes this group special is
13550that you can't tick any articles in it or mark any articles as
13551read---all articles in the group are permanently unread.
13552
13553If the group doesn't exist, it will be created and you'll be subscribed
13554to it. The only way to make it disappear from the Group buffer is to
13555unsubscribe it. The special properties of the draft group comes from
13556a group property (@pxref{Group Parameters}), and if lost the group
13557behaves like any other group. This means the commands below will not
13558be available. To restore the special properties of the group, the
13559simplest way is to kill the group, using @kbd{C-k}, and restart
13560Gnus. The group is automatically created again with the
13561correct parameters. The content of the group is not lost.
13562
13563@c @findex gnus-dissociate-buffer-from-draft
13564@c @kindex C-c M-d (Mail)
13565@c @kindex C-c M-d (Post)
13566@c @findex gnus-associate-buffer-with-draft
13567@c @kindex C-c C-d (Mail)
13568@c @kindex C-c C-d (Post)
13569@c If you're writing some super-secret message that you later want to
13570@c encode with PGP before sending, you may wish to turn the auto-saving
13571@c (and association with the draft group) off. You never know who might be
13572@c interested in reading all your extremely valuable and terribly horrible
13573@c and interesting secrets. The @kbd{C-c M-d}
13574@c (@code{gnus-dissociate-buffer-from-draft}) command does that for you.
13575@c If you change your mind and want to turn the auto-saving back on again,
13576@c @kbd{C-c C-d} (@code{gnus-associate-buffer-with-draft} does that.
13577@c
13578@c @vindex gnus-use-draft
13579@c To leave association with the draft group off by default, set
13580@c @code{gnus-use-draft} to @code{nil}. It is @code{t} by default.
13581
13582@findex gnus-draft-edit-message
13583@kindex D e (Draft)
13584When you want to continue editing the article, you simply enter the
13585draft group and push @kbd{D e} (@code{gnus-draft-edit-message}) to do
13586that. You will be placed in a buffer where you left off.
13587
13588Rejected articles will also be put in this draft group (@pxref{Rejected
13589Articles}).
13590
13591@findex gnus-draft-send-all-messages
13592@kindex D s (Draft)
13593@findex gnus-draft-send-message
13594@kindex D S (Draft)
13595If you have lots of rejected messages you want to post (or mail) without
13596doing further editing, you can use the @kbd{D s} command
13597(@code{gnus-draft-send-message}). This command understands the
13598process/prefix convention (@pxref{Process/Prefix}). The @kbd{D S}
13599command (@code{gnus-draft-send-all-messages}) will ship off all messages
13600in the buffer.
13601
13602@findex gnus-draft-toggle-sending
13603@kindex D t (Draft)
13604If you have some messages that you wish not to send, you can use the
13605@kbd{D t} (@code{gnus-draft-toggle-sending}) command to mark the message
13606as unsendable. This is a toggling command.
13607
598451ed
KY
13608Finally, if you want to delete a draft, use the normal @kbd{B DEL}
13609command (@pxref{Mail Group Commands}).
13610
4009494e
GM
13611
13612@node Rejected Articles
13613@section Rejected Articles
13614@cindex rejected articles
13615
13616Sometimes a news server will reject an article. Perhaps the server
13617doesn't like your face. Perhaps it just feels miserable. Perhaps
13618@emph{there be demons}. Perhaps you have included too much cited text.
13619Perhaps the disk is full. Perhaps the server is down.
13620
13621These situations are, of course, totally beyond the control of Gnus.
13622(Gnus, of course, loves the way you look, always feels great, has angels
13623fluttering around inside of it, doesn't care about how much cited text
13624you include, never runs full and never goes down.) So Gnus saves these
13625articles until some later time when the server feels better.
13626
13627The rejected articles will automatically be put in a special draft group
13628(@pxref{Drafts}). When the server comes back up again, you'd then
13629typically enter that group and send all the articles off.
13630
13631@node Signing and encrypting
13632@section Signing and encrypting
13633@cindex using gpg
13634@cindex using s/mime
13635@cindex using smime
13636
13637Gnus can digitally sign and encrypt your messages, using vanilla
13638@acronym{PGP} format or @acronym{PGP/MIME} or @acronym{S/MIME}. For
13639decoding such messages, see the @code{mm-verify-option} and
13640@code{mm-decrypt-option} options (@pxref{Security}).
13641
13642@vindex gnus-message-replysign
13643@vindex gnus-message-replyencrypt
13644@vindex gnus-message-replysignencrypted
13645Often, you would like to sign replies to people who send you signed
13646messages. Even more often, you might want to encrypt messages which
13647are in reply to encrypted messages. Gnus offers
13648@code{gnus-message-replysign} to enable the former, and
13649@code{gnus-message-replyencrypt} for the latter. In addition, setting
13650@code{gnus-message-replysignencrypted} (on by default) will sign
13651automatically encrypted messages.
13652
13653Instructing @acronym{MML} to perform security operations on a
13654@acronym{MIME} part is done using the @kbd{C-c C-m s} key map for
13655signing and the @kbd{C-c C-m c} key map for encryption, as follows.
13656
13657@table @kbd
13658
13659@item C-c C-m s s
13660@kindex C-c C-m s s (Message)
13661@findex mml-secure-message-sign-smime
13662
13663Digitally sign current message using @acronym{S/MIME}.
13664
13665@item C-c C-m s o
13666@kindex C-c C-m s o (Message)
13667@findex mml-secure-message-sign-pgp
13668
13669Digitally sign current message using @acronym{PGP}.
13670
13671@item C-c C-m s p
13672@kindex C-c C-m s p (Message)
13673@findex mml-secure-message-sign-pgp
13674
13675Digitally sign current message using @acronym{PGP/MIME}.
13676
13677@item C-c C-m c s
13678@kindex C-c C-m c s (Message)
13679@findex mml-secure-message-encrypt-smime
13680
13681Digitally encrypt current message using @acronym{S/MIME}.
13682
13683@item C-c C-m c o
13684@kindex C-c C-m c o (Message)
13685@findex mml-secure-message-encrypt-pgp
13686
13687Digitally encrypt current message using @acronym{PGP}.
13688
13689@item C-c C-m c p
13690@kindex C-c C-m c p (Message)
13691@findex mml-secure-message-encrypt-pgpmime
13692
13693Digitally encrypt current message using @acronym{PGP/MIME}.
13694
13695@item C-c C-m C-n
13696@kindex C-c C-m C-n (Message)
13697@findex mml-unsecure-message
13698Remove security related @acronym{MML} tags from message.
13699
13700@end table
13701
13702@xref{Security, ,Security, message, Message Manual}, for more information.
13703
13704@node Select Methods
13705@chapter Select Methods
13706@cindex foreign groups
13707@cindex select methods
13708
13709A @dfn{foreign group} is a group not read by the usual (or
13710default) means. It could be, for instance, a group from a different
13711@acronym{NNTP} server, it could be a virtual group, or it could be your own
13712personal mail group.
13713
13714A foreign group (or any group, really) is specified by a @dfn{name} and
13715a @dfn{select method}. To take the latter first, a select method is a
13716list where the first element says what back end to use (e.g. @code{nntp},
13717@code{nnspool}, @code{nnml}) and the second element is the @dfn{server
13718name}. There may be additional elements in the select method, where the
13719value may have special meaning for the back end in question.
13720
13721One could say that a select method defines a @dfn{virtual server}---so
13722we do just that (@pxref{Server Buffer}).
13723
13724The @dfn{name} of the group is the name the back end will recognize the
13725group as.
13726
13727For instance, the group @samp{soc.motss} on the @acronym{NNTP} server
13728@samp{some.where.edu} will have the name @samp{soc.motss} and select
13729method @code{(nntp "some.where.edu")}. Gnus will call this group
13730@samp{nntp+some.where.edu:soc.motss}, even though the @code{nntp}
13731back end just knows this group as @samp{soc.motss}.
13732
13733The different methods all have their peculiarities, of course.
13734
13735@menu
13736* Server Buffer:: Making and editing virtual servers.
13737* Getting News:: Reading USENET news with Gnus.
13738* Getting Mail:: Reading your personal mail with Gnus.
13739* Browsing the Web:: Getting messages from a plethora of Web sources.
13740* IMAP:: Using Gnus as a @acronym{IMAP} client.
c4d82de8 13741* Other Sources:: Reading directories, files.
4009494e
GM
13742* Combined Groups:: Combining groups into one group.
13743* Email Based Diary:: Using mails to manage diary events in Gnus.
13744* Gnus Unplugged:: Reading news and mail offline.
13745@end menu
13746
13747
13748@node Server Buffer
13749@section Server Buffer
13750
13751Traditionally, a @dfn{server} is a machine or a piece of software that
13752one connects to, and then requests information from. Gnus does not
13753connect directly to any real servers, but does all transactions through
13754one back end or other. But that's just putting one layer more between
13755the actual media and Gnus, so we might just as well say that each
13756back end represents a virtual server.
13757
13758For instance, the @code{nntp} back end may be used to connect to several
13759different actual @acronym{NNTP} servers, or, perhaps, to many different ports
13760on the same actual @acronym{NNTP} server. You tell Gnus which back end to
13761use, and what parameters to set by specifying a @dfn{select method}.
13762
13763These select method specifications can sometimes become quite
13764complicated---say, for instance, that you want to read from the
13765@acronym{NNTP} server @samp{news.funet.fi} on port number 13, which
13766hangs if queried for @acronym{NOV} headers and has a buggy select. Ahem.
13767Anyway, if you had to specify that for each group that used this
13768server, that would be too much work, so Gnus offers a way of naming
13769select methods, which is what you do in the server buffer.
13770
13771To enter the server buffer, use the @kbd{^}
13772(@code{gnus-group-enter-server-mode}) command in the group buffer.
13773
13774@menu
13775* Server Buffer Format:: You can customize the look of this buffer.
13776* Server Commands:: Commands to manipulate servers.
13777* Example Methods:: Examples server specifications.
13778* Creating a Virtual Server:: An example session.
13779* Server Variables:: Which variables to set.
13780* Servers and Methods:: You can use server names as select methods.
13781* Unavailable Servers:: Some servers you try to contact may be down.
13782@end menu
13783
13784@vindex gnus-server-mode-hook
13785@code{gnus-server-mode-hook} is run when creating the server buffer.
13786
13787
13788@node Server Buffer Format
13789@subsection Server Buffer Format
13790@cindex server buffer format
13791
13792@vindex gnus-server-line-format
13793You can change the look of the server buffer lines by changing the
13794@code{gnus-server-line-format} variable. This is a @code{format}-like
13795variable, with some simple extensions:
13796
13797@table @samp
13798
13799@item h
13800How the news is fetched---the back end name.
13801
13802@item n
13803The name of this server.
13804
13805@item w
13806Where the news is to be fetched from---the address.
13807
13808@item s
13809The opened/closed/denied status of the server.
13810
13811@item a
13812Whether this server is agentized.
13813@end table
13814
13815@vindex gnus-server-mode-line-format
13816The mode line can also be customized by using the
13817@code{gnus-server-mode-line-format} variable (@pxref{Mode Line
13818Formatting}). The following specs are understood:
13819
13820@table @samp
13821@item S
13822Server name.
13823
13824@item M
13825Server method.
13826@end table
13827
13828Also @pxref{Formatting Variables}.
13829
13830
13831@node Server Commands
13832@subsection Server Commands
13833@cindex server commands
13834
13835@table @kbd
13836
13837@item v
13838@kindex v (Server)
13839@cindex keys, reserved for users (Server)
13840The key @kbd{v} is reserved for users. You can bind it to some
13841command or better use it as a prefix key.
13842
13843@item a
13844@kindex a (Server)
13845@findex gnus-server-add-server
13846Add a new server (@code{gnus-server-add-server}).
13847
13848@item e
13849@kindex e (Server)
13850@findex gnus-server-edit-server
13851Edit a server (@code{gnus-server-edit-server}).
13852
13853@item SPACE
13854@kindex SPACE (Server)
13855@findex gnus-server-read-server
13856Browse the current server (@code{gnus-server-read-server}).
13857
13858@item q
13859@kindex q (Server)
13860@findex gnus-server-exit
13861Return to the group buffer (@code{gnus-server-exit}).
13862
13863@item k
13864@kindex k (Server)
13865@findex gnus-server-kill-server
13866Kill the current server (@code{gnus-server-kill-server}).
13867
13868@item y
13869@kindex y (Server)
13870@findex gnus-server-yank-server
13871Yank the previously killed server (@code{gnus-server-yank-server}).
13872
13873@item c
13874@kindex c (Server)
13875@findex gnus-server-copy-server
13876Copy the current server (@code{gnus-server-copy-server}).
13877
13878@item l
13879@kindex l (Server)
13880@findex gnus-server-list-servers
13881List all servers (@code{gnus-server-list-servers}).
13882
13883@item s
13884@kindex s (Server)
13885@findex gnus-server-scan-server
13886Request that the server scan its sources for new articles
13887(@code{gnus-server-scan-server}). This is mainly sensible with mail
13888servers.
13889
13890@item g
13891@kindex g (Server)
13892@findex gnus-server-regenerate-server
13893Request that the server regenerate all its data structures
13894(@code{gnus-server-regenerate-server}). This can be useful if you have
13895a mail back end that has gotten out of sync.
13896
01c52d31
MB
13897@item z
13898@kindex z (Server)
13899@findex gnus-server-compact-server
13900
13901Compact all groups in the server under point
13902(@code{gnus-server-compact-server}). Currently implemented only in
13903nnml (@pxref{Mail Spool}). This removes gaps between article numbers,
13904hence getting a correct total article count.
13905
4009494e
GM
13906@end table
13907
13908
13909@node Example Methods
13910@subsection Example Methods
13911
13912Most select methods are pretty simple and self-explanatory:
13913
13914@lisp
13915(nntp "news.funet.fi")
13916@end lisp
13917
13918Reading directly from the spool is even simpler:
13919
13920@lisp
13921(nnspool "")
13922@end lisp
13923
13924As you can see, the first element in a select method is the name of the
13925back end, and the second is the @dfn{address}, or @dfn{name}, if you
13926will.
13927
13928After these two elements, there may be an arbitrary number of
13929@code{(@var{variable} @var{form})} pairs.
13930
13931To go back to the first example---imagine that you want to read from
13932port 15 on that machine. This is what the select method should
13933look like then:
13934
13935@lisp
13936(nntp "news.funet.fi" (nntp-port-number 15))
13937@end lisp
13938
13939You should read the documentation to each back end to find out what
13940variables are relevant, but here's an @code{nnmh} example:
13941
13942@code{nnmh} is a mail back end that reads a spool-like structure. Say
13943you have two structures that you wish to access: One is your private
13944mail spool, and the other is a public one. Here's the possible spec for
13945your private mail:
13946
13947@lisp
13948(nnmh "private" (nnmh-directory "~/private/mail/"))
13949@end lisp
13950
13951(This server is then called @samp{private}, but you may have guessed
13952that.)
13953
13954Here's the method for a public spool:
13955
13956@lisp
13957(nnmh "public"
13958 (nnmh-directory "/usr/information/spool/")
13959 (nnmh-get-new-mail nil))
13960@end lisp
13961
13962@cindex proxy
13963@cindex firewall
13964
13965If you are behind a firewall and only have access to the @acronym{NNTP}
13966server from the firewall machine, you can instruct Gnus to @code{rlogin}
31fe2b00
SM
13967on the firewall machine and connect with
13968@uref{http://netcat.sourceforge.net/, netcat} from there to the
13969@acronym{NNTP} server.
4009494e
GM
13970Doing this can be rather fiddly, but your virtual server definition
13971should probably look something like this:
13972
13973@lisp
13974(nntp "firewall"
31fe2b00 13975 (nntp-open-connection-function nntp-open-via-rlogin-and-netcat)
4009494e 13976 (nntp-via-address "the.firewall.machine")
31fe2b00 13977 (nntp-address "the.real.nntp.host"))
4009494e
GM
13978@end lisp
13979
13980If you want to use the wonderful @code{ssh} program to provide a
13981compressed connection over the modem line, you could add the following
13982configuration to the example above:
13983
13984@lisp
13985 (nntp-via-rlogin-command "ssh")
13986@end lisp
13987
01c52d31
MB
13988See also @code{nntp-via-rlogin-command-switches}. Here's an example for
13989an indirect connection:
fbcbb58c 13990
01c52d31
MB
13991@lisp
13992(setq gnus-select-method
13993 '(nntp "indirect"
13994 (nntp-address "news.server.example")
13995 (nntp-via-user-name "intermediate_user_name")
13996 (nntp-via-address "intermediate.host.example")
13997 (nntp-via-rlogin-command "ssh")
31fe2b00
SM
13998 (nntp-via-rlogin-command-switches ("-C"))
13999 (nntp-open-connection-function nntp-open-via-rlogin-and-netcat)))
01c52d31 14000@end lisp
4009494e 14001
fbcbb58c
KY
14002This means that you have to have set up @code{ssh-agent} correctly to
14003provide automatic authorization, of course.
14004
4009494e
GM
14005If you're behind a firewall, but have direct access to the outside world
14006through a wrapper command like "runsocks", you could open a socksified
31fe2b00 14007netcat connection to the news server as follows:
4009494e
GM
14008
14009@lisp
14010(nntp "outside"
14011 (nntp-pre-command "runsocks")
990e2c2f 14012 (nntp-open-connection-function nntp-open-netcat-stream)
31fe2b00 14013 (nntp-address "the.news.server"))
4009494e
GM
14014@end lisp
14015
4009494e
GM
14016
14017@node Creating a Virtual Server
14018@subsection Creating a Virtual Server
14019
14020If you're saving lots of articles in the cache by using persistent
14021articles, you may want to create a virtual server to read the cache.
14022
14023First you need to add a new server. The @kbd{a} command does that. It
14024would probably be best to use @code{nnml} to read the cache. You
14025could also use @code{nnspool} or @code{nnmh}, though.
14026
14027Type @kbd{a nnml RET cache RET}.
14028
14029You should now have a brand new @code{nnml} virtual server called
14030@samp{cache}. You now need to edit it to have the right definitions.
14031Type @kbd{e} to edit the server. You'll be entered into a buffer that
14032will contain the following:
14033
14034@lisp
14035(nnml "cache")
14036@end lisp
14037
14038Change that to:
14039
14040@lisp
14041(nnml "cache"
14042 (nnml-directory "~/News/cache/")
14043 (nnml-active-file "~/News/cache/active"))
14044@end lisp
14045
14046Type @kbd{C-c C-c} to return to the server buffer. If you now press
14047@kbd{RET} over this virtual server, you should be entered into a browse
14048buffer, and you should be able to enter any of the groups displayed.
14049
14050
14051@node Server Variables
14052@subsection Server Variables
14053@cindex server variables
14054@cindex server parameters
14055
14056One sticky point when defining variables (both on back ends and in Emacs
14057in general) is that some variables are typically initialized from other
14058variables when the definition of the variables is being loaded. If you
14059change the ``base'' variable after the variables have been loaded, you
14060won't change the ``derived'' variables.
14061
14062This typically affects directory and file variables. For instance,
14063@code{nnml-directory} is @file{~/Mail/} by default, and all @code{nnml}
14064directory variables are initialized from that variable, so
14065@code{nnml-active-file} will be @file{~/Mail/active}. If you define a
14066new virtual @code{nnml} server, it will @emph{not} suffice to set just
14067@code{nnml-directory}---you have to explicitly set all the file
14068variables to be what you want them to be. For a complete list of
14069variables for each back end, see each back end's section later in this
14070manual, but here's an example @code{nnml} definition:
14071
14072@lisp
14073(nnml "public"
14074 (nnml-directory "~/my-mail/")
14075 (nnml-active-file "~/my-mail/active")
14076 (nnml-newsgroups-file "~/my-mail/newsgroups"))
14077@end lisp
14078
14079Server variables are often called @dfn{server parameters}.
14080
14081@node Servers and Methods
14082@subsection Servers and Methods
14083
14084Wherever you would normally use a select method
14085(e.g. @code{gnus-secondary-select-method}, in the group select method,
14086when browsing a foreign server) you can use a virtual server name
14087instead. This could potentially save lots of typing. And it's nice all
14088over.
14089
14090
14091@node Unavailable Servers
14092@subsection Unavailable Servers
14093
14094If a server seems to be unreachable, Gnus will mark that server as
14095@code{denied}. That means that any subsequent attempt to make contact
14096with that server will just be ignored. ``It can't be opened,'' Gnus
14097will tell you, without making the least effort to see whether that is
14098actually the case or not.
14099
14100That might seem quite naughty, but it does make sense most of the time.
14101Let's say you have 10 groups subscribed to on server
14102@samp{nephelococcygia.com}. This server is located somewhere quite far
14103away from you and the machine is quite slow, so it takes 1 minute just
14104to find out that it refuses connection to you today. If Gnus were to
14105attempt to do that 10 times, you'd be quite annoyed, so Gnus won't
14106attempt to do that. Once it has gotten a single ``connection refused'',
14107it will regard that server as ``down''.
14108
14109So, what happens if the machine was only feeling unwell temporarily?
14110How do you test to see whether the machine has come up again?
14111
14112You jump to the server buffer (@pxref{Server Buffer}) and poke it
14113with the following commands:
14114
14115@table @kbd
14116
14117@item O
14118@kindex O (Server)
14119@findex gnus-server-open-server
14120Try to establish connection to the server on the current line
14121(@code{gnus-server-open-server}).
14122
14123@item C
14124@kindex C (Server)
14125@findex gnus-server-close-server
14126Close the connection (if any) to the server
14127(@code{gnus-server-close-server}).
14128
14129@item D
14130@kindex D (Server)
14131@findex gnus-server-deny-server
14132Mark the current server as unreachable
14133(@code{gnus-server-deny-server}).
14134
14135@item M-o
14136@kindex M-o (Server)
14137@findex gnus-server-open-all-servers
14138Open the connections to all servers in the buffer
14139(@code{gnus-server-open-all-servers}).
14140
14141@item M-c
14142@kindex M-c (Server)
14143@findex gnus-server-close-all-servers
14144Close the connections to all servers in the buffer
14145(@code{gnus-server-close-all-servers}).
14146
14147@item R
14148@kindex R (Server)
14149@findex gnus-server-remove-denials
14150Remove all marks to whether Gnus was denied connection from any servers
14151(@code{gnus-server-remove-denials}).
14152
14153@item L
14154@kindex L (Server)
14155@findex gnus-server-offline-server
14156Set server status to offline (@code{gnus-server-offline-server}).
14157
14158@end table
14159
14160
14161@node Getting News
14162@section Getting News
14163@cindex reading news
14164@cindex news back ends
14165
14166A newsreader is normally used for reading news. Gnus currently provides
14167only two methods of getting news---it can read from an @acronym{NNTP} server,
14168or it can read from a local spool.
14169
14170@menu
14171* NNTP:: Reading news from an @acronym{NNTP} server.
14172* News Spool:: Reading news from the local spool.
14173@end menu
14174
14175
14176@node NNTP
14177@subsection NNTP
14178@cindex nntp
14179
14180Subscribing to a foreign group from an @acronym{NNTP} server is rather easy.
14181You just specify @code{nntp} as method and the address of the @acronym{NNTP}
14182server as the, uhm, address.
14183
14184If the @acronym{NNTP} server is located at a non-standard port, setting the
14185third element of the select method to this port number should allow you
14186to connect to the right port. You'll have to edit the group info for
14187that (@pxref{Foreign Groups}).
14188
14189The name of the foreign group can be the same as a native group. In
14190fact, you can subscribe to the same group from as many different servers
14191you feel like. There will be no name collisions.
14192
14193The following variables can be used to create a virtual @code{nntp}
14194server:
14195
14196@table @code
14197
14198@item nntp-server-opened-hook
14199@vindex nntp-server-opened-hook
14200@cindex @sc{mode reader}
14201@cindex authinfo
14202@cindex authentication
14203@cindex nntp authentication
14204@findex nntp-send-authinfo
14205@findex nntp-send-mode-reader
14206is run after a connection has been made. It can be used to send
14207commands to the @acronym{NNTP} server after it has been contacted. By
14208default it sends the command @code{MODE READER} to the server with the
14209@code{nntp-send-mode-reader} function. This function should always be
14210present in this hook.
14211
14212@item nntp-authinfo-function
14213@vindex nntp-authinfo-function
14214@findex nntp-send-authinfo
14215@vindex nntp-authinfo-file
14216This function will be used to send @samp{AUTHINFO} to the @acronym{NNTP}
14217server. The default function is @code{nntp-send-authinfo}, which looks
14218through your @file{~/.authinfo} (or whatever you've set the
14219@code{nntp-authinfo-file} variable to) for applicable entries. If none
14220are found, it will prompt you for a login name and a password. The
14221format of the @file{~/.authinfo} file is (almost) the same as the
14222@code{ftp} @file{~/.netrc} file, which is defined in the @code{ftp}
14223manual page, but here are the salient facts:
14224
14225@enumerate
14226@item
14227The file contains one or more line, each of which define one server.
14228
14229@item
14230Each line may contain an arbitrary number of token/value pairs.
14231
14232The valid tokens include @samp{machine}, @samp{login}, @samp{password},
14233@samp{default}. In addition Gnus introduces two new tokens, not present
14234in the original @file{.netrc}/@code{ftp} syntax, namely @samp{port} and
14235@samp{force}. (This is the only way the @file{.authinfo} file format
14236deviates from the @file{.netrc} file format.) @samp{port} is used to
14237indicate what port on the server the credentials apply to and
14238@samp{force} is explained below.
14239
14240@end enumerate
14241
14242Here's an example file:
14243
14244@example
14245machine news.uio.no login larsi password geheimnis
14246machine nntp.ifi.uio.no login larsi force yes
14247@end example
14248
14249The token/value pairs may appear in any order; @samp{machine} doesn't
14250have to be first, for instance.
14251
14252In this example, both login name and password have been supplied for the
14253former server, while the latter has only the login name listed, and the
14254user will be prompted for the password. The latter also has the
14255@samp{force} tag, which means that the authinfo will be sent to the
14256@var{nntp} server upon connection; the default (i.e., when there is not
14257@samp{force} tag) is to not send authinfo to the @var{nntp} server
14258until the @var{nntp} server asks for it.
14259
14260You can also add @samp{default} lines that will apply to all servers
14261that don't have matching @samp{machine} lines.
14262
14263@example
14264default force yes
14265@end example
14266
14267This will force sending @samp{AUTHINFO} commands to all servers not
14268previously mentioned.
14269
14270Remember to not leave the @file{~/.authinfo} file world-readable.
14271
14272@item nntp-server-action-alist
14273@vindex nntp-server-action-alist
14274This is a list of regexps to match on server types and actions to be
14275taken when matches are made. For instance, if you want Gnus to beep
14276every time you connect to innd, you could say something like:
14277
14278@lisp
14279(setq nntp-server-action-alist
14280 '(("innd" (ding))))
14281@end lisp
14282
14283You probably don't want to do that, though.
14284
14285The default value is
14286
14287@lisp
14288'(("nntpd 1\\.5\\.11t"
14289 (remove-hook 'nntp-server-opened-hook
14290 'nntp-send-mode-reader)))
14291@end lisp
14292
14293This ensures that Gnus doesn't send the @code{MODE READER} command to
14294nntpd 1.5.11t, since that command chokes that server, I've been told.
14295
14296@item nntp-maximum-request
14297@vindex nntp-maximum-request
14298If the @acronym{NNTP} server doesn't support @acronym{NOV} headers, this back end
14299will collect headers by sending a series of @code{head} commands. To
14300speed things up, the back end sends lots of these commands without
14301waiting for reply, and then reads all the replies. This is controlled
14302by the @code{nntp-maximum-request} variable, and is 400 by default. If
14303your network is buggy, you should set this to 1.
14304
14305@item nntp-connection-timeout
14306@vindex nntp-connection-timeout
14307If you have lots of foreign @code{nntp} groups that you connect to
14308regularly, you're sure to have problems with @acronym{NNTP} servers not
14309responding properly, or being too loaded to reply within reasonable
14310time. This is can lead to awkward problems, which can be helped
14311somewhat by setting @code{nntp-connection-timeout}. This is an integer
14312that says how many seconds the @code{nntp} back end should wait for a
14313connection before giving up. If it is @code{nil}, which is the default,
14314no timeouts are done.
14315
14316@item nntp-nov-is-evil
14317@vindex nntp-nov-is-evil
14318If the @acronym{NNTP} server does not support @acronym{NOV}, you could set this
14319variable to @code{t}, but @code{nntp} usually checks automatically whether @acronym{NOV}
14320can be used.
14321
14322@item nntp-xover-commands
14323@vindex nntp-xover-commands
14324@cindex @acronym{NOV}
14325@cindex XOVER
14326List of strings used as commands to fetch @acronym{NOV} lines from a
14327server. The default value of this variable is @code{("XOVER"
14328"XOVERVIEW")}.
14329
14330@item nntp-nov-gap
14331@vindex nntp-nov-gap
14332@code{nntp} normally sends just one big request for @acronym{NOV} lines to
14333the server. The server responds with one huge list of lines. However,
14334if you have read articles 2-5000 in the group, and only want to read
14335article 1 and 5001, that means that @code{nntp} will fetch 4999 @acronym{NOV}
14336lines that you will not need. This variable says how
14337big a gap between two consecutive articles is allowed to be before the
14338@code{XOVER} request is split into several request. Note that if your
14339network is fast, setting this variable to a really small number means
14340that fetching will probably be slower. If this variable is @code{nil},
14341@code{nntp} will never split requests. The default is 5.
14342
14343@item nntp-xref-number-is-evil
14344@vindex nntp-xref-number-is-evil
14345When Gnus refers to an article having the @code{Message-ID} that a user
14346specifies or having the @code{Message-ID} of the parent article of the
14347current one (@pxref{Finding the Parent}), Gnus sends a @code{HEAD}
14348command to the @acronym{NNTP} server to know where it is, and the server
14349returns the data containing the pairs of a group and an article number
14350in the @code{Xref} header. Gnus normally uses the article number to
14351refer to the article if the data shows that that article is in the
14352current group, while it uses the @code{Message-ID} otherwise. However,
14353some news servers, e.g., ones running Diablo, run multiple engines
14354having the same articles but article numbers are not kept synchronized
14355between them. In that case, the article number that appears in the
14356@code{Xref} header varies by which engine is chosen, so you cannot refer
14357to the parent article that is in the current group, for instance. If
14358you connect to such a server, set this variable to a non-@code{nil}
14359value, and Gnus never uses article numbers. For example:
14360
14361@lisp
14362(setq gnus-select-method
14363 '(nntp "newszilla"
14364 (nntp-address "newszilla.example.com")
14365 (nntp-xref-number-is-evil t)
14366 @dots{}))
14367@end lisp
14368
14369The default value of this server variable is @code{nil}.
14370
14371@item nntp-prepare-server-hook
14372@vindex nntp-prepare-server-hook
14373A hook run before attempting to connect to an @acronym{NNTP} server.
14374
14375@item nntp-record-commands
14376@vindex nntp-record-commands
14377If non-@code{nil}, @code{nntp} will log all commands it sends to the
14378@acronym{NNTP} server (along with a timestamp) in the @samp{*nntp-log*}
14379buffer. This is useful if you are debugging a Gnus/@acronym{NNTP} connection
14380that doesn't seem to work.
14381
14382@item nntp-open-connection-function
14383@vindex nntp-open-connection-function
14384It is possible to customize how the connection to the nntp server will
14385be opened. If you specify an @code{nntp-open-connection-function}
14386parameter, Gnus will use that function to establish the connection.
01c52d31
MB
14387Seven pre-made functions are supplied. These functions can be grouped
14388in two categories: direct connection functions (four pre-made), and
14389indirect ones (three pre-made).
4009494e
GM
14390
14391@item nntp-never-echoes-commands
14392@vindex nntp-never-echoes-commands
14393Non-@code{nil} means the nntp server never echoes commands. It is
14394reported that some nntps server doesn't echo commands. So, you may want
14395to set this to non-@code{nil} in the method for such a server setting
14396@code{nntp-open-connection-function} to @code{nntp-open-ssl-stream} for
14397example. The default value is @code{nil}. Note that the
14398@code{nntp-open-connection-functions-never-echo-commands} variable
14399overrides the @code{nil} value of this variable.
14400
14401@item nntp-open-connection-functions-never-echo-commands
14402@vindex nntp-open-connection-functions-never-echo-commands
14403List of functions that never echo commands. Add or set a function which
14404you set to @code{nntp-open-connection-function} to this list if it does
14405not echo commands. Note that a non-@code{nil} value of the
14406@code{nntp-never-echoes-commands} variable overrides this variable. The
14407default value is @code{(nntp-open-network-stream)}.
14408
14409@item nntp-prepare-post-hook
14410@vindex nntp-prepare-post-hook
14411A hook run just before posting an article. If there is no
14412@code{Message-ID} header in the article and the news server provides the
14413recommended ID, it will be added to the article before running this
14414hook. It is useful to make @code{Cancel-Lock} headers even if you
14415inhibit Gnus to add a @code{Message-ID} header, you could say:
14416
14417@lisp
14418(add-hook 'nntp-prepare-post-hook 'canlock-insert-header)
14419@end lisp
14420
14421Note that not all servers support the recommended ID. This works for
14422INN versions 2.3.0 and later, for instance.
14423
14424@end table
14425
14426@menu
14427* Direct Functions:: Connecting directly to the server.
14428* Indirect Functions:: Connecting indirectly to the server.
14429* Common Variables:: Understood by several connection functions.
01c52d31 14430* NNTP marks:: Storing marks for @acronym{NNTP} servers.
4009494e
GM
14431@end menu
14432
14433
14434@node Direct Functions
14435@subsubsection Direct Functions
14436@cindex direct connection functions
14437
14438These functions are called direct because they open a direct connection
14439between your machine and the @acronym{NNTP} server. The behavior of these
14440functions is also affected by commonly understood variables
14441(@pxref{Common Variables}).
14442
14443@table @code
14444@findex nntp-open-network-stream
14445@item nntp-open-network-stream
14446This is the default, and simply connects to some port or other on the
14447remote system.
14448
14449@findex nntp-open-tls-stream
14450@item nntp-open-tls-stream
14451Opens a connection to a server over a @dfn{secure} channel. To use
14452this you must have @uref{http://www.gnu.org/software/gnutls/, GNUTLS}
14453installed. You then define a server as follows:
14454
14455@lisp
14456;; @r{"nntps" is port 563 and is predefined in our @file{/etc/services}}
14457;; @r{however, @samp{gnutls-cli -p} doesn't like named ports.}
14458;;
14459(nntp "snews.bar.com"
14460 (nntp-open-connection-function nntp-open-tls-stream)
83828b06 14461 (nntp-port-number 563)
4009494e
GM
14462 (nntp-address "snews.bar.com"))
14463@end lisp
14464
14465@findex nntp-open-ssl-stream
14466@item nntp-open-ssl-stream
14467Opens a connection to a server over a @dfn{secure} channel. To use
14468this you must have @uref{http://www.openssl.org, OpenSSL} or
14469@uref{ftp://ftp.psy.uq.oz.au/pub/Crypto/SSL, SSLeay} installed. You
14470then define a server as follows:
14471
14472@lisp
14473;; @r{"snews" is port 563 and is predefined in our @file{/etc/services}}
14474;; @r{however, @samp{openssl s_client -port} doesn't like named ports.}
14475;;
14476(nntp "snews.bar.com"
14477 (nntp-open-connection-function nntp-open-ssl-stream)
14478 (nntp-port-number 563)
14479 (nntp-address "snews.bar.com"))
14480@end lisp
14481
990e2c2f
SM
14482@findex nntp-open-netcat-stream
14483@item nntp-open-netcat-stream
31fe2b00
SM
14484Opens a connection to an @acronym{NNTP} server using the @code{netcat}
14485program. You might wonder why this function exists, since we have
14486the default @code{nntp-open-network-stream} which would do the job. (One
4009494e
GM
14487of) the reason(s) is that if you are behind a firewall but have direct
14488connections to the outside world thanks to a command wrapper like
14489@code{runsocks}, you can use it like this:
14490
14491@lisp
14492(nntp "socksified"
14493 (nntp-pre-command "runsocks")
990e2c2f 14494 (nntp-open-connection-function nntp-open-netcat-stream)
4009494e
GM
14495 (nntp-address "the.news.server"))
14496@end lisp
14497
14498With the default method, you would need to wrap your whole Emacs
14499session, which is not a good idea.
31fe2b00
SM
14500
14501@findex nntp-open-telnet-stream
14502@item nntp-open-telnet-stream
990e2c2f 14503Like @code{nntp-open-netcat-stream}, but uses @code{telnet} rather than
31fe2b00
SM
14504@code{netcat}. @code{telnet} is a bit less robust because of things
14505like line-end-conversion, but sometimes netcat is simply
14506not available. The previous example would turn into:
14507
14508@lisp
14509(nntp "socksified"
14510 (nntp-pre-command "runsocks")
14511 (nntp-open-connection-function nntp-open-telnet-stream)
14512 (nntp-address "the.news.server")
14513 (nntp-end-of-line "\n"))
14514@end lisp
4009494e
GM
14515@end table
14516
14517
14518@node Indirect Functions
14519@subsubsection Indirect Functions
14520@cindex indirect connection functions
14521
14522These functions are called indirect because they connect to an
14523intermediate host before actually connecting to the @acronym{NNTP} server.
14524All of these functions and related variables are also said to belong to
14525the ``via'' family of connection: they're all prefixed with ``via'' to make
14526things cleaner. The behavior of these functions is also affected by
14527commonly understood variables (@pxref{Common Variables}).
14528
14529@table @code
31fe2b00
SM
14530@item nntp-open-via-rlogin-and-netcat
14531@findex nntp-open-via-rlogin-and-netcat
14532Does an @samp{rlogin} on a remote system, and then uses @code{netcat} to connect
4009494e
GM
14533to the real @acronym{NNTP} server from there. This is useful for instance if
14534you need to connect to a firewall machine first.
14535
31fe2b00 14536@code{nntp-open-via-rlogin-and-netcat}-specific variables:
4009494e
GM
14537
14538@table @code
14539@item nntp-via-rlogin-command
14540@vindex nntp-via-rlogin-command
14541Command used to log in on the intermediate host. The default is
14542@samp{rsh}, but @samp{ssh} is a popular alternative.
14543
14544@item nntp-via-rlogin-command-switches
14545@vindex nntp-via-rlogin-command-switches
14546List of strings to be used as the switches to
14547@code{nntp-via-rlogin-command}. The default is @code{nil}. If you use
14548@samp{ssh} for @code{nntp-via-rlogin-command}, you may set this to
31fe2b00 14549@samp{("-C")} in order to compress all data connections.
4009494e
GM
14550@end table
14551
31fe2b00
SM
14552@item nntp-open-via-rlogin-and-telnet
14553@findex nntp-open-via-rlogin-and-telnet
14554Does essentially the same, but uses @code{telnet} instead of @samp{netcat}
01c52d31 14555to connect to the real @acronym{NNTP} server from the intermediate host.
31fe2b00 14556@code{telnet} is a bit less robust because of things like
867d4bb3 14557line-end-conversion, but sometimes @code{netcat} is simply not available.
01c52d31 14558
31fe2b00 14559@code{nntp-open-via-rlogin-and-telnet}-specific variables:
01c52d31
MB
14560
14561@table @code
31fe2b00
SM
14562@item nntp-telnet-command
14563@vindex nntp-telnet-command
01c52d31 14564Command used to connect to the real @acronym{NNTP} server from the
fbcbb58c 14565intermediate host. The default is @samp{telnet}.
01c52d31 14566
31fe2b00
SM
14567@item nntp-telnet-switches
14568@vindex nntp-telnet-switches
01c52d31 14569List of strings to be used as the switches to the
31fe2b00 14570@code{nntp-telnet-command} command. The default is @code{("-8")}.
01c52d31
MB
14571
14572@item nntp-via-rlogin-command
14573@vindex nntp-via-rlogin-command
14574Command used to log in on the intermediate host. The default is
14575@samp{rsh}, but @samp{ssh} is a popular alternative.
14576
14577@item nntp-via-rlogin-command-switches
14578@vindex nntp-via-rlogin-command-switches
14579List of strings to be used as the switches to
31fe2b00
SM
14580@code{nntp-via-rlogin-command}. If you use @samp{ssh}, you may need to set
14581this to @samp{("-t" "-e" "none")} or @samp{("-C" "-t" "-e" "none")} if
14582the telnet command requires a pseudo-tty allocation on an intermediate
14583host. The default is @code{nil}.
01c52d31
MB
14584@end table
14585
31fe2b00
SM
14586Note that you may want to change the value for @code{nntp-end-of-line}
14587to @samp{\n} (@pxref{Common Variables}).
14588
4009494e
GM
14589@item nntp-open-via-telnet-and-telnet
14590@findex nntp-open-via-telnet-and-telnet
14591Does essentially the same, but uses @samp{telnet} instead of
14592@samp{rlogin} to connect to the intermediate host.
14593
14594@code{nntp-open-via-telnet-and-telnet}-specific variables:
14595
14596@table @code
14597@item nntp-via-telnet-command
14598@vindex nntp-via-telnet-command
14599Command used to @code{telnet} the intermediate host. The default is
14600@samp{telnet}.
14601
14602@item nntp-via-telnet-switches
14603@vindex nntp-via-telnet-switches
14604List of strings to be used as the switches to the
14605@code{nntp-via-telnet-command} command. The default is @samp{("-8")}.
14606
14607@item nntp-via-user-password
14608@vindex nntp-via-user-password
14609Password to use when logging in on the intermediate host.
14610
14611@item nntp-via-envuser
14612@vindex nntp-via-envuser
14613If non-@code{nil}, the intermediate @code{telnet} session (client and
14614server both) will support the @code{ENVIRON} option and not prompt for
14615login name. This works for Solaris @code{telnet}, for instance.
14616
14617@item nntp-via-shell-prompt
14618@vindex nntp-via-shell-prompt
14619Regexp matching the shell prompt on the intermediate host. The default
14620is @samp{bash\\|\$ *\r?$\\|> *\r?}.
14621
14622@end table
14623
01c52d31
MB
14624Note that you may want to change the value for @code{nntp-end-of-line}
14625to @samp{\n} (@pxref{Common Variables}).
4009494e
GM
14626@end table
14627
14628
14629Here are some additional variables that are understood by all the above
14630functions:
14631
14632@table @code
14633
14634@item nntp-via-user-name
14635@vindex nntp-via-user-name
14636User name to use when connecting to the intermediate host.
14637
14638@item nntp-via-address
14639@vindex nntp-via-address
14640Address of the intermediate host to connect to.
14641
14642@end table
14643
14644
14645@node Common Variables
14646@subsubsection Common Variables
14647
14648The following variables affect the behavior of all, or several of the
14649pre-made connection functions. When not specified, all functions are
14650affected (the values of the following variables will be used as the
14651default if each virtual @code{nntp} server doesn't specify those server
14652variables individually).
14653
14654@table @code
14655
14656@item nntp-pre-command
14657@vindex nntp-pre-command
14658A command wrapper to use when connecting through a non native
14659connection function (all except @code{nntp-open-network-stream},
14660@code{nntp-open-tls-stream}, and @code{nntp-open-ssl-stream}). This is
14661where you would put a @samp{SOCKS} wrapper for instance.
14662
14663@item nntp-address
14664@vindex nntp-address
14665The address of the @acronym{NNTP} server.
14666
14667@item nntp-port-number
14668@vindex nntp-port-number
14669Port number to connect to the @acronym{NNTP} server. The default is
14670@samp{nntp}. If you use @acronym{NNTP} over
14671@acronym{TLS}/@acronym{SSL}, you may want to use integer ports rather
14672than named ports (i.e, use @samp{563} instead of @samp{snews} or
14673@samp{nntps}), because external @acronym{TLS}/@acronym{SSL} tools may
14674not work with named ports.
14675
14676@item nntp-end-of-line
14677@vindex nntp-end-of-line
14678String to use as end-of-line marker when talking to the @acronym{NNTP}
14679server. This is @samp{\r\n} by default, but should be @samp{\n} when
01c52d31 14680using a non native telnet connection function.
4009494e 14681
990e2c2f
SM
14682@item nntp-netcat-command
14683@vindex nntp-netcat-command
4009494e 14684Command to use when connecting to the @acronym{NNTP} server through
31fe2b00 14685@samp{netcat}. This is @emph{not} for an intermediate host. This is
4009494e 14686just for the real @acronym{NNTP} server. The default is
31fe2b00 14687@samp{nc}.
4009494e 14688
990e2c2f
SM
14689@item nntp-netcat-switches
14690@vindex nntp-netcat-switches
14691A list of switches to pass to @code{nntp-netcat-command}. The default
31fe2b00 14692is @samp{()}.
4009494e
GM
14693
14694@end table
14695
01c52d31
MB
14696@node NNTP marks
14697@subsubsection NNTP marks
14698@cindex storing NNTP marks
14699
14700Gnus stores marks (@pxref{Marking Articles}) for @acronym{NNTP}
14701servers in marks files. A marks file records what marks you have set
14702in a group and each file is specific to the corresponding server.
14703Marks files are stored in @file{~/News/marks}
14704(@code{nntp-marks-directory}) under a classic hierarchy resembling
14705that of a news server, for example marks for the group
14706@samp{gmane.discuss} on the news.gmane.org server will be stored in
14707the file @file{~/News/marks/news.gmane.org/gmane/discuss/.marks}.
14708
14709Marks files are useful because you can copy the @file{~/News/marks}
14710directory (using rsync, scp or whatever) to another Gnus installation,
14711and it will realize what articles you have read and marked. The data
14712in @file{~/News/marks} has priority over the same data in
14713@file{~/.newsrc.eld}.
14714
14715Note that marks files are very much server-specific: Gnus remembers
14716the article numbers so if you don't use the same servers on both
14717installations things are most likely to break (most @acronym{NNTP}
14718servers do not use the same article numbers as any other server).
14719However, if you use servers A, B, C on one installation and servers A,
14720D, E on the other, you can sync the marks files for A and then you'll
14721get synchronization for that server between the two installations.
14722
14723Using @acronym{NNTP} marks can possibly incur a performance penalty so
14724if Gnus feels sluggish, try setting the @code{nntp-marks-is-evil}
14725variable to @code{t}. Marks will then be stored in @file{~/.newsrc.eld}.
14726
14727Related variables:
14728
14729@table @code
14730
14731@item nntp-marks-is-evil
14732@vindex nntp-marks-is-evil
14733If non-@code{nil}, this back end will ignore any marks files. The
14734default is @code{nil}.
14735
14736@item nntp-marks-directory
14737@vindex nntp-marks-directory
14738The directory where marks for nntp groups will be stored.
14739
14740@end table
14741
4009494e
GM
14742
14743@node News Spool
14744@subsection News Spool
14745@cindex nnspool
14746@cindex news spool
14747
14748Subscribing to a foreign group from the local spool is extremely easy,
14749and might be useful, for instance, to speed up reading groups that
14750contain very big articles---@samp{alt.binaries.pictures.furniture}, for
14751instance.
14752
14753Anyway, you just specify @code{nnspool} as the method and @code{""} (or
14754anything else) as the address.
14755
14756If you have access to a local spool, you should probably use that as the
14757native select method (@pxref{Finding the News}). It is normally faster
14758than using an @code{nntp} select method, but might not be. It depends.
14759You just have to try to find out what's best at your site.
14760
14761@table @code
14762
14763@item nnspool-inews-program
14764@vindex nnspool-inews-program
14765Program used to post an article.
14766
14767@item nnspool-inews-switches
14768@vindex nnspool-inews-switches
14769Parameters given to the inews program when posting an article.
14770
14771@item nnspool-spool-directory
14772@vindex nnspool-spool-directory
14773Where @code{nnspool} looks for the articles. This is normally
14774@file{/usr/spool/news/}.
14775
14776@item nnspool-nov-directory
14777@vindex nnspool-nov-directory
14778Where @code{nnspool} will look for @acronym{NOV} files. This is normally@*
14779@file{/usr/spool/news/over.view/}.
14780
14781@item nnspool-lib-dir
14782@vindex nnspool-lib-dir
14783Where the news lib dir is (@file{/usr/lib/news/} by default).
14784
14785@item nnspool-active-file
14786@vindex nnspool-active-file
14787The name of the active file.
14788
14789@item nnspool-newsgroups-file
14790@vindex nnspool-newsgroups-file
14791The name of the group descriptions file.
14792
14793@item nnspool-history-file
14794@vindex nnspool-history-file
14795The name of the news history file.
14796
14797@item nnspool-active-times-file
14798@vindex nnspool-active-times-file
14799The name of the active date file.
14800
14801@item nnspool-nov-is-evil
14802@vindex nnspool-nov-is-evil
14803If non-@code{nil}, @code{nnspool} won't try to use any @acronym{NOV} files
14804that it finds.
14805
14806@item nnspool-sift-nov-with-sed
14807@vindex nnspool-sift-nov-with-sed
14808@cindex sed
14809If non-@code{nil}, which is the default, use @code{sed} to get the
14810relevant portion from the overview file. If @code{nil},
14811@code{nnspool} will load the entire file into a buffer and process it
14812there.
14813
14814@end table
14815
14816
14817@node Getting Mail
14818@section Getting Mail
14819@cindex reading mail
14820@cindex mail
14821
14822Reading mail with a newsreader---isn't that just plain WeIrD? But of
14823course.
14824
14825@menu
14826* Mail in a Newsreader:: Important introductory notes.
14827* Getting Started Reading Mail:: A simple cookbook example.
14828* Splitting Mail:: How to create mail groups.
14829* Mail Sources:: How to tell Gnus where to get mail from.
14830* Mail Back End Variables:: Variables for customizing mail handling.
14831* Fancy Mail Splitting:: Gnus can do hairy splitting of incoming mail.
14832* Group Mail Splitting:: Use group customize to drive mail splitting.
14833* Incorporating Old Mail:: What about the old mail you have?
14834* Expiring Mail:: Getting rid of unwanted mail.
14835* Washing Mail:: Removing cruft from the mail you get.
14836* Duplicates:: Dealing with duplicated mail.
14837* Not Reading Mail:: Using mail back ends for reading other files.
14838* Choosing a Mail Back End:: Gnus can read a variety of mail formats.
14839@end menu
14840
14841
14842@node Mail in a Newsreader
14843@subsection Mail in a Newsreader
14844
14845If you are used to traditional mail readers, but have decided to switch
14846to reading mail with Gnus, you may find yourself experiencing something
14847of a culture shock.
14848
14849Gnus does not behave like traditional mail readers. If you want to make
14850it behave that way, you can, but it's an uphill battle.
14851
14852Gnus, by default, handles all its groups using the same approach. This
14853approach is very newsreaderly---you enter a group, see the new/unread
14854messages, and when you read the messages, they get marked as read, and
14855you don't see them any more. (Unless you explicitly ask for them.)
14856
14857In particular, you do not do anything explicitly to delete messages.
14858
14859Does this mean that all the messages that have been marked as read are
14860deleted? How awful!
14861
14862But, no, it means that old messages are @dfn{expired} according to some
14863scheme or other. For news messages, the expire process is controlled by
14864the news administrator; for mail, the expire process is controlled by
14865you. The expire process for mail is covered in depth in @ref{Expiring
14866Mail}.
14867
14868What many Gnus users find, after using it a while for both news and
14869mail, is that the transport mechanism has very little to do with how
14870they want to treat a message.
14871
14872Many people subscribe to several mailing lists. These are transported
14873via @acronym{SMTP}, and are therefore mail. But we might go for weeks without
14874answering, or even reading these messages very carefully. We may not
14875need to save them because if we should need to read one again, they are
14876archived somewhere else.
14877
14878Some people have local news groups which have only a handful of readers.
14879These are transported via @acronym{NNTP}, and are therefore news. But we may need
14880to read and answer a large fraction of the messages very carefully in
14881order to do our work. And there may not be an archive, so we may need
14882to save the interesting messages the same way we would personal mail.
14883
14884The important distinction turns out to be not the transport mechanism,
14885but other factors such as how interested we are in the subject matter,
14886or how easy it is to retrieve the message if we need to read it again.
14887
14888Gnus provides many options for sorting mail into ``groups'' which behave
14889like newsgroups, and for treating each group (whether mail or news)
14890differently.
14891
14892Some users never get comfortable using the Gnus (ahem) paradigm and wish
14893that Gnus should grow up and be a male, er, mail reader. It is possible
14894to whip Gnus into a more mailreaderly being, but, as said before, it's
14895not easy. People who prefer proper mail readers should try @sc{vm}
14896instead, which is an excellent, and proper, mail reader.
14897
14898I don't mean to scare anybody off, but I want to make it clear that you
14899may be required to learn a new way of thinking about messages. After
14900you've been subjected to The Gnus Way, you will come to love it. I can
14901guarantee it. (At least the guy who sold me the Emacs Subliminal
14902Brain-Washing Functions that I've put into Gnus did guarantee it. You
14903Will Be Assimilated. You Love Gnus. You Love The Gnus Mail Way.
14904You Do.)
14905
14906
14907@node Getting Started Reading Mail
14908@subsection Getting Started Reading Mail
14909
14910It's quite easy to use Gnus to read your new mail. You just plonk the
14911mail back end of your choice into @code{gnus-secondary-select-methods},
14912and things will happen automatically.
14913
14914For instance, if you want to use @code{nnml} (which is a ``one file per
14915mail'' back end), you could put the following in your @file{~/.gnus.el} file:
14916
14917@lisp
14918(setq gnus-secondary-select-methods '((nnml "")))
14919@end lisp
14920
14921Now, the next time you start Gnus, this back end will be queried for new
14922articles, and it will move all the messages in your spool file to its
14923directory, which is @file{~/Mail/} by default. The new group that will
14924be created (@samp{mail.misc}) will be subscribed, and you can read it
14925like any other group.
14926
14927You will probably want to split the mail into several groups, though:
14928
14929@lisp
14930(setq nnmail-split-methods
14931 '(("junk" "^From:.*Lars Ingebrigtsen")
14932 ("crazy" "^Subject:.*die\\|^Organization:.*flabby")
14933 ("other" "")))
14934@end lisp
14935
14936This will result in three new @code{nnml} mail groups being created:
14937@samp{nnml:junk}, @samp{nnml:crazy}, and @samp{nnml:other}. All the
14938mail that doesn't fit into the first two groups will be placed in the
14939last group.
14940
14941This should be sufficient for reading mail with Gnus. You might want to
14942give the other sections in this part of the manual a perusal, though.
14943Especially @pxref{Choosing a Mail Back End} and @pxref{Expiring Mail}.
14944
14945
14946@node Splitting Mail
14947@subsection Splitting Mail
14948@cindex splitting mail
14949@cindex mail splitting
14950@cindex mail filtering (splitting)
14951
14952@vindex nnmail-split-methods
14953The @code{nnmail-split-methods} variable says how the incoming mail is
14954to be split into groups.
14955
14956@lisp
14957(setq nnmail-split-methods
14958 '(("mail.junk" "^From:.*Lars Ingebrigtsen")
14959 ("mail.crazy" "^Subject:.*die\\|^Organization:.*flabby")
14960 ("mail.other" "")))
14961@end lisp
14962
14963This variable is a list of lists, where the first element of each of
14964these lists is the name of the mail group (they do not have to be called
14965something beginning with @samp{mail}, by the way), and the second
14966element is a regular expression used on the header of each mail to
14967determine if it belongs in this mail group. The first string may
14968contain @samp{\\1} forms, like the ones used by @code{replace-match} to
14969insert sub-expressions from the matched text. For instance:
14970
14971@lisp
14972("list.\\1" "From:.* \\(.*\\)-list@@majordomo.com")
14973@end lisp
14974
14975@noindent
14976In that case, @code{nnmail-split-lowercase-expanded} controls whether
14977the inserted text should be made lowercase. @xref{Fancy Mail Splitting}.
14978
14979The second element can also be a function. In that case, it will be
14980called narrowed to the headers with the first element of the rule as the
14981argument. It should return a non-@code{nil} value if it thinks that the
14982mail belongs in that group.
14983
14984@cindex @samp{bogus} group
14985The last of these groups should always be a general one, and the regular
14986expression should @emph{always} be @samp{""} so that it matches any mails
14987that haven't been matched by any of the other regexps. (These rules are
14988processed from the beginning of the alist toward the end. The first rule
14989to make a match will ``win'', unless you have crossposting enabled. In
14990that case, all matching rules will ``win''.) If no rule matched, the mail
14991will end up in the @samp{bogus} group. When new groups are created by
14992splitting mail, you may want to run @code{gnus-group-find-new-groups} to
14993see the new groups. This also applies to the @samp{bogus} group.
14994
14995If you like to tinker with this yourself, you can set this variable to a
14996function of your choice. This function will be called without any
14997arguments in a buffer narrowed to the headers of an incoming mail
14998message. The function should return a list of group names that it
14999thinks should carry this mail message.
15000
15001Note that the mail back ends are free to maul the poor, innocent,
15002incoming headers all they want to. They all add @code{Lines} headers;
15003some add @code{X-Gnus-Group} headers; most rename the Unix mbox
15004@code{From<SPACE>} line to something else.
15005
15006@vindex nnmail-crosspost
15007The mail back ends all support cross-posting. If several regexps match,
15008the mail will be ``cross-posted'' to all those groups.
15009@code{nnmail-crosspost} says whether to use this mechanism or not. Note
15010that no articles are crossposted to the general (@samp{""}) group.
15011
15012@vindex nnmail-crosspost-link-function
15013@cindex crosspost
15014@cindex links
15015@code{nnmh} and @code{nnml} makes crossposts by creating hard links to
15016the crossposted articles. However, not all file systems support hard
15017links. If that's the case for you, set
15018@code{nnmail-crosspost-link-function} to @code{copy-file}. (This
15019variable is @code{add-name-to-file} by default.)
15020
15021@kindex M-x nnmail-split-history
15022@findex nnmail-split-history
15023If you wish to see where the previous mail split put the messages, you
15024can use the @kbd{M-x nnmail-split-history} command. If you wish to see
15025where re-spooling messages would put the messages, you can use
15026@code{gnus-summary-respool-trace} and related commands (@pxref{Mail
15027Group Commands}).
15028
15029@vindex nnmail-split-header-length-limit
15030Header lines longer than the value of
15031@code{nnmail-split-header-length-limit} are excluded from the split
15032function.
15033
15034@vindex nnmail-mail-splitting-decodes
15035@vindex nnmail-mail-splitting-charset
15036By default, splitting does not decode headers, so you can not match on
15037non-@acronym{ASCII} strings. But it is useful if you want to match
15038articles based on the raw header data. To enable it, set the
15039@code{nnmail-mail-splitting-decodes} variable to a non-@code{nil} value.
15040In addition, the value of the @code{nnmail-mail-splitting-charset}
15041variable is used for decoding non-@acronym{MIME} encoded string when
15042@code{nnmail-mail-splitting-decodes} is non-@code{nil}. The default
15043value is @code{nil} which means not to decode non-@acronym{MIME} encoded
15044string. A suitable value for you will be @code{undecided} or be the
15045charset used normally in mails you are interested in.
15046
15047@vindex nnmail-resplit-incoming
15048By default, splitting is performed on all incoming messages. If you
15049specify a @code{directory} entry for the variable @code{mail-sources}
15050(@pxref{Mail Source Specifiers}), however, then splitting does
15051@emph{not} happen by default. You can set the variable
15052@code{nnmail-resplit-incoming} to a non-@code{nil} value to make
15053splitting happen even in this case. (This variable has no effect on
15054other kinds of entries.)
15055
15056Gnus gives you all the opportunity you could possibly want for shooting
15057yourself in the foot. Let's say you create a group that will contain
15058all the mail you get from your boss. And then you accidentally
15059unsubscribe from the group. Gnus will still put all the mail from your
15060boss in the unsubscribed group, and so, when your boss mails you ``Have
15061that report ready by Monday or you're fired!'', you'll never see it and,
15062come Tuesday, you'll still believe that you're gainfully employed while
15063you really should be out collecting empty bottles to save up for next
15064month's rent money.
15065
15066
15067@node Mail Sources
15068@subsection Mail Sources
15069
15070Mail can be gotten from many different sources---the mail spool, from
15071a @acronym{POP} mail server, from a procmail directory, or from a
15072maildir, for instance.
15073
15074@menu
15075* Mail Source Specifiers:: How to specify what a mail source is.
15076* Mail Source Customization:: Some variables that influence things.
15077* Fetching Mail:: Using the mail source specifiers.
15078@end menu
15079
15080
15081@node Mail Source Specifiers
15082@subsubsection Mail Source Specifiers
15083@cindex POP
15084@cindex mail server
15085@cindex procmail
15086@cindex mail spool
15087@cindex mail source
15088
15089You tell Gnus how to fetch mail by setting @code{mail-sources}
15090(@pxref{Fetching Mail}) to a @dfn{mail source specifier}.
15091
15092Here's an example:
15093
15094@lisp
15095(pop :server "pop3.mailserver.com" :user "myname")
15096@end lisp
15097
15098As can be observed, a mail source specifier is a list where the first
15099element is a @dfn{mail source type}, followed by an arbitrary number of
15100@dfn{keywords}. Keywords that are not explicitly specified are given
15101default values.
15102
a1da1e37
MB
15103The @code{mail-sources} is global for all mail groups. You can specify
15104an additional mail source for a particular group by including the
15105@code{group} mail specifier in @code{mail-sources}, and setting a
15106@code{mail-source} group parameter (@pxref{Group Parameters}) specifying
15107a single mail source. When this is used, @code{mail-sources} is
15108typically just @code{(group)}; the @code{mail-source} parameter for a
15109group might look like this:
15110
15111@lisp
15112(mail-source . (file :path "home/user/spools/foo.spool"))
15113@end lisp
15114
15115This means that the group's (and only this group's) messages will be
15116fetched from the spool file @samp{/user/spools/foo.spool}.
15117
4009494e
GM
15118The following mail source types are available:
15119
15120@table @code
15121@item file
15122Get mail from a single file; typically from the mail spool.
15123
15124Keywords:
15125
15126@table @code
15127@item :path
15128The file name. Defaults to the value of the @env{MAIL}
15129environment variable or the value of @code{rmail-spool-directory}
15130(usually something like @file{/usr/mail/spool/user-name}).
15131
15132@item :prescript
15133@itemx :postscript
15134Script run before/after fetching mail.
15135@end table
15136
15137An example file mail source:
15138
15139@lisp
15140(file :path "/usr/spool/mail/user-name")
15141@end lisp
15142
15143Or using the default file name:
15144
15145@lisp
15146(file)
15147@end lisp
15148
15149If the mail spool file is not located on the local machine, it's best
15150to use @acronym{POP} or @acronym{IMAP} or the like to fetch the mail.
15151You can not use ange-ftp file names here---it has no way to lock the
15152mail spool while moving the mail.
15153
15154If it's impossible to set up a proper server, you can use ssh instead.
15155
15156@lisp
15157(setq mail-sources
15158 '((file :prescript "ssh host bin/getmail >%t")))
15159@end lisp
15160
15161The @samp{getmail} script would look something like the following:
15162
15163@example
15164#!/bin/sh
15165# getmail - move mail from spool to stdout
15166# flu@@iki.fi
15167
15168MOVEMAIL=/usr/lib/emacs/20.3/i386-redhat-linux/movemail
15169TMP=$HOME/Mail/tmp
15170rm -f $TMP; $MOVEMAIL $MAIL $TMP >/dev/null && cat $TMP
15171@end example
15172
15173Alter this script to fit the @samp{movemail} and temporary
15174file you want to use.
15175
15176
15177@item directory
15178@vindex nnmail-scan-directory-mail-source-once
15179Get mail from several files in a directory. This is typically used
15180when you have procmail split the incoming mail into several files.
15181That is, there is a one-to-one correspondence between files in that
15182directory and groups, so that mail from the file @file{foo.bar.spool}
15183will be put in the group @code{foo.bar}. (You can change the suffix
15184to be used instead of @code{.spool}.) Setting
15185@code{nnmail-scan-directory-mail-source-once} to non-@code{nil} forces
15186Gnus to scan the mail source only once. This is particularly useful
15187if you want to scan mail groups at a specified level.
15188
15189@vindex nnmail-resplit-incoming
15190There is also the variable @code{nnmail-resplit-incoming}, if you set
15191that to a non-@code{nil} value, then the normal splitting process is
15192applied to all the files from the directory, @ref{Splitting Mail}.
15193
15194Keywords:
15195
15196@table @code
15197@item :path
15198The name of the directory where the files are. There is no default
15199value.
15200
15201@item :suffix
15202Only files ending with this suffix are used. The default is
15203@samp{.spool}.
15204
15205@item :predicate
15206Only files that have this predicate return non-@code{nil} are returned.
15207The default is @code{identity}. This is used as an additional
15208filter---only files that have the right suffix @emph{and} satisfy this
15209predicate are considered.
15210
15211@item :prescript
15212@itemx :postscript
15213Script run before/after fetching mail.
15214
15215@end table
15216
15217An example directory mail source:
15218
15219@lisp
15220(directory :path "/home/user-name/procmail-dir/"
15221 :suffix ".prcml")
15222@end lisp
15223
15224@item pop
15225Get mail from a @acronym{POP} server.
15226
15227Keywords:
15228
15229@table @code
15230@item :server
15231The name of the @acronym{POP} server. The default is taken from the
15232@env{MAILHOST} environment variable.
15233
15234@item :port
15235The port number of the @acronym{POP} server. This can be a number (eg,
15236@samp{:port 1234}) or a string (eg, @samp{:port "pop3"}). If it is a
15237string, it should be a service name as listed in @file{/etc/services} on
15238Unix systems. The default is @samp{"pop3"}. On some systems you might
15239need to specify it as @samp{"pop-3"} instead.
15240
15241@item :user
15242The user name to give to the @acronym{POP} server. The default is the login
15243name.
15244
15245@item :password
15246The password to give to the @acronym{POP} server. If not specified,
15247the user is prompted.
15248
15249@item :program
15250The program to use to fetch mail from the @acronym{POP} server. This
15251should be a @code{format}-like string. Here's an example:
15252
15253@example
15254fetchmail %u@@%s -P %p %t
15255@end example
15256
15257The valid format specifier characters are:
15258
15259@table @samp
15260@item t
15261The name of the file the mail is to be moved to. This must always be
15262included in this string.
15263
15264@item s
15265The name of the server.
15266
15267@item P
15268The port number of the server.
15269
15270@item u
15271The user name to use.
15272
15273@item p
15274The password to use.
15275@end table
15276
15277The values used for these specs are taken from the values you give the
15278corresponding keywords.
15279
15280@item :prescript
15281A script to be run before fetching the mail. The syntax is the same as
15282the @code{:program} keyword. This can also be a function to be run.
15283
15284@item :postscript
15285A script to be run after fetching the mail. The syntax is the same as
15286the @code{:program} keyword. This can also be a function to be run.
15287
15288@item :function
15289The function to use to fetch mail from the @acronym{POP} server. The
15290function is called with one parameter---the name of the file where the
15291mail should be moved to.
15292
15293@item :authentication
15294This can be either the symbol @code{password} or the symbol @code{apop}
15295and says what authentication scheme to use. The default is
15296@code{password}.
15297
15298@end table
15299
15300@vindex pop3-movemail
15301@vindex pop3-leave-mail-on-server
15302If the @code{:program} and @code{:function} keywords aren't specified,
15303@code{pop3-movemail} will be used. If @code{pop3-leave-mail-on-server}
15304is non-@code{nil} the mail is to be left on the @acronym{POP} server
15305after fetching when using @code{pop3-movemail}. Note that POP servers
15306maintain no state information between sessions, so what the client
15307believes is there and what is actually there may not match up. If they
15308do not, then you may get duplicate mails or the whole thing can fall
15309apart and leave you with a corrupt mailbox.
15310
15311Here are some examples for getting mail from a @acronym{POP} server.
15312Fetch from the default @acronym{POP} server, using the default user
15313name, and default fetcher:
15314
15315@lisp
15316(pop)
15317@end lisp
15318
15319Fetch from a named server with a named user and password:
15320
15321@lisp
15322(pop :server "my.pop.server"
15323 :user "user-name" :password "secret")
15324@end lisp
15325
15326Use @samp{movemail} to move the mail:
15327
15328@lisp
15329(pop :program "movemail po:%u %t %p")
15330@end lisp
15331
15332@item maildir
15333Get mail from a maildir. This is a type of mailbox that is supported by
15334at least qmail and postfix, where each file in a special directory
15335contains exactly one mail.
15336
15337Keywords:
15338
15339@table @code
15340@item :path
15341The name of the directory where the mails are stored. The default is
15342taken from the @env{MAILDIR} environment variable or
15343@file{~/Maildir/}.
15344@item :subdirs
15345The subdirectories of the Maildir. The default is
15346@samp{("new" "cur")}.
15347
15348@c If you sometimes look at your mail through a pop3 daemon before fetching
15349@c them with Gnus, you may also have to fetch your mails from the
15350@c @code{cur} directory inside the maildir, like in the first example
15351@c below.
15352
15353You can also get mails from remote hosts (because maildirs don't suffer
15354from locking problems).
15355
15356@end table
15357
15358Two example maildir mail sources:
15359
15360@lisp
15361(maildir :path "/home/user-name/Maildir/"
15362 :subdirs ("cur" "new"))
15363@end lisp
15364
15365@lisp
15366(maildir :path "/user@@remotehost.org:~/Maildir/"
15367 :subdirs ("new"))
15368@end lisp
15369
15370@item imap
15371Get mail from a @acronym{IMAP} server. If you don't want to use
15372@acronym{IMAP} as intended, as a network mail reading protocol (ie
15373with nnimap), for some reason or other, Gnus let you treat it similar
15374to a @acronym{POP} server and fetches articles from a given
15375@acronym{IMAP} mailbox. @xref{IMAP}, for more information.
15376
15377Note that for the Kerberos, GSSAPI, @acronym{TLS}/@acronym{SSL} and STARTTLS support you
15378may need external programs and libraries, @xref{IMAP}.
15379
15380Keywords:
15381
15382@table @code
15383@item :server
15384The name of the @acronym{IMAP} server. The default is taken from the
15385@env{MAILHOST} environment variable.
15386
15387@item :port
15388The port number of the @acronym{IMAP} server. The default is @samp{143}, or
15389@samp{993} for @acronym{TLS}/@acronym{SSL} connections.
15390
15391@item :user
15392The user name to give to the @acronym{IMAP} server. The default is the login
15393name.
15394
15395@item :password
15396The password to give to the @acronym{IMAP} server. If not specified, the user is
15397prompted.
15398
15399@item :stream
15400What stream to use for connecting to the server, this is one of the
15401symbols in @code{imap-stream-alist}. Right now, this means
15402@samp{gssapi}, @samp{kerberos4}, @samp{starttls}, @samp{tls},
15403@samp{ssl}, @samp{shell} or the default @samp{network}.
15404
15405@item :authentication
15406Which authenticator to use for authenticating to the server, this is
15407one of the symbols in @code{imap-authenticator-alist}. Right now,
15408this means @samp{gssapi}, @samp{kerberos4}, @samp{digest-md5},
15409@samp{cram-md5}, @samp{anonymous} or the default @samp{login}.
15410
15411@item :program
15412When using the `shell' :stream, the contents of this variable is
15413mapped into the @code{imap-shell-program} variable. This should be a
15414@code{format}-like string (or list of strings). Here's an example:
15415
15416@example
15417ssh %s imapd
15418@end example
15419
01c52d31
MB
15420Make sure nothing is interfering with the output of the program, e.g.,
15421don't forget to redirect the error output to the void. The valid format
15422specifier characters are:
4009494e
GM
15423
15424@table @samp
15425@item s
15426The name of the server.
15427
15428@item l
15429User name from @code{imap-default-user}.
15430
15431@item p
15432The port number of the server.
15433@end table
15434
15435The values used for these specs are taken from the values you give the
15436corresponding keywords.
15437
15438@item :mailbox
15439The name of the mailbox to get mail from. The default is @samp{INBOX}
d55fe5bb 15440which normally is the mailbox which receives incoming mail.
4009494e
GM
15441
15442@item :predicate
15443The predicate used to find articles to fetch. The default, @samp{UNSEEN
15444UNDELETED}, is probably the best choice for most people, but if you
15445sometimes peek in your mailbox with a @acronym{IMAP} client and mark some
15446articles as read (or; SEEN) you might want to set this to @samp{1:*}.
15447Then all articles in the mailbox is fetched, no matter what. For a
15448complete list of predicates, see RFC 2060 section 6.4.4.
15449
15450@item :fetchflag
15451How to flag fetched articles on the server, the default @samp{\Deleted}
15452will mark them as deleted, an alternative would be @samp{\Seen} which
15453would simply mark them as read. These are the two most likely choices,
15454but more flags are defined in RFC 2060 section 2.3.2.
15455
15456@item :dontexpunge
15457If non-@code{nil}, don't remove all articles marked as deleted in the
15458mailbox after finishing the fetch.
15459
15460@end table
15461
15462An example @acronym{IMAP} mail source:
15463
15464@lisp
15465(imap :server "mail.mycorp.com"
15466 :stream kerberos4
15467 :fetchflag "\\Seen")
15468@end lisp
15469
15470@item webmail
15471Get mail from a webmail server, such as @uref{http://www.hotmail.com/},
15472@uref{http://webmail.netscape.com/}, @uref{http://www.netaddress.com/},
15473@uref{http://mail.yahoo.com/}.
15474
15475NOTE: Webmail largely depends on cookies. A "one-line-cookie" patch is
15476required for url "4.0pre.46".
15477
15478WARNING: Mails may be lost. NO WARRANTY.
15479
15480Keywords:
15481
15482@table @code
15483@item :subtype
15484The type of the webmail server. The default is @code{hotmail}. The
15485alternatives are @code{netscape}, @code{netaddress}, @code{my-deja}.
15486
15487@item :user
15488The user name to give to the webmail server. The default is the login
15489name.
15490
15491@item :password
15492The password to give to the webmail server. If not specified, the user is
15493prompted.
15494
15495@item :dontexpunge
15496If non-@code{nil}, only fetch unread articles and don't move them to
15497trash folder after finishing the fetch.
15498
15499@end table
15500
15501An example webmail source:
15502
15503@lisp
15504(webmail :subtype 'hotmail
15505 :user "user-name"
15506 :password "secret")
15507@end lisp
a1da1e37
MB
15508
15509@item group
15510Get the actual mail source from the @code{mail-source} group parameter,
15511@xref{Group Parameters}.
15512
4009494e
GM
15513@end table
15514
15515@table @dfn
15516@item Common Keywords
15517Common keywords can be used in any type of mail source.
15518
15519Keywords:
15520
15521@table @code
15522@item :plugged
15523If non-@code{nil}, fetch the mail even when Gnus is unplugged. If you
15524use directory source to get mail, you can specify it as in this
15525example:
15526
15527@lisp
15528(setq mail-sources
15529 '((directory :path "/home/pavel/.Spool/"
15530 :suffix ""
15531 :plugged t)))
15532@end lisp
15533
15534Gnus will then fetch your mail even when you are unplugged. This is
15535useful when you use local mail and news.
15536
15537@end table
15538@end table
15539
15540@subsubsection Function Interface
15541
15542Some of the above keywords specify a Lisp function to be executed.
15543For each keyword @code{:foo}, the Lisp variable @code{foo} is bound to
15544the value of the keyword while the function is executing. For example,
15545consider the following mail-source setting:
15546
15547@lisp
15548(setq mail-sources '((pop :user "jrl"
15549 :server "pophost" :function fetchfunc)))
15550@end lisp
15551
15552While the function @code{fetchfunc} is executing, the symbol @code{user}
15553is bound to @code{"jrl"}, and the symbol @code{server} is bound to
15554@code{"pophost"}. The symbols @code{port}, @code{password},
15555@code{program}, @code{prescript}, @code{postscript}, @code{function},
15556and @code{authentication} are also bound (to their default values).
15557
15558See above for a list of keywords for each type of mail source.
15559
15560
15561@node Mail Source Customization
15562@subsubsection Mail Source Customization
15563
15564The following is a list of variables that influence how the mail is
15565fetched. You would normally not need to set or change any of these
15566variables.
15567
15568@table @code
15569@item mail-source-crash-box
15570@vindex mail-source-crash-box
15571File where mail will be stored while processing it. The default is@*
15572@file{~/.emacs-mail-crash-box}.
15573
37a68866 15574@cindex Incoming*
4009494e
GM
15575@item mail-source-delete-incoming
15576@vindex mail-source-delete-incoming
15577If non-@code{nil}, delete incoming files after handling them. If
15578@code{t}, delete the files immediately, if @code{nil}, never delete any
15579files. If a positive number, delete files older than number of days
37a68866
MB
15580(the deletion will only happen when receiving new mail). You may also
15581set @code{mail-source-delete-incoming} to @code{nil} and call
4009494e 15582@code{mail-source-delete-old-incoming} from a hook or interactively.
2b968687
MB
15583@code{mail-source-delete-incoming} defaults to @code{10} in alpha Gnusae
15584and @code{2} in released Gnusae. @xref{Gnus Development}.
4009494e
GM
15585
15586@item mail-source-delete-old-incoming-confirm
15587@vindex mail-source-delete-old-incoming-confirm
15588If non-@code{nil}, ask for confirmation before deleting old incoming
15589files. This variable only applies when
15590@code{mail-source-delete-incoming} is a positive number.
15591
15592@item mail-source-ignore-errors
15593@vindex mail-source-ignore-errors
15594If non-@code{nil}, ignore errors when reading mail from a mail source.
15595
15596@item mail-source-directory
15597@vindex mail-source-directory
15598Directory where incoming mail source files (if any) will be stored. The
15599default is @file{~/Mail/}. At present, the only thing this is used for
15600is to say where the incoming files will be stored if the variable
15601@code{mail-source-delete-incoming} is @code{nil} or a number.
15602
15603@item mail-source-incoming-file-prefix
15604@vindex mail-source-incoming-file-prefix
15605Prefix for file name for storing incoming mail. The default is
15606@file{Incoming}, in which case files will end up with names like
15607@file{Incoming30630D_} or @file{Incoming298602ZD}. This is really only
15608relevant if @code{mail-source-delete-incoming} is @code{nil} or a
15609number.
15610
15611@item mail-source-default-file-modes
15612@vindex mail-source-default-file-modes
15613All new mail files will get this file mode. The default is 384.
15614
15615@item mail-source-movemail-program
15616@vindex mail-source-movemail-program
15617If non-@code{nil}, name of program for fetching new mail. If
15618@code{nil}, @code{movemail} in @var{exec-directory}.
15619
15620@end table
15621
15622
15623@node Fetching Mail
15624@subsubsection Fetching Mail
15625
15626@vindex mail-sources
4009494e
GM
15627The way to actually tell Gnus where to get new mail from is to set
15628@code{mail-sources} to a list of mail source specifiers
15629(@pxref{Mail Source Specifiers}).
15630
b890d447
MB
15631If this variable is @code{nil}, the mail back ends will never attempt to
15632fetch mail by themselves.
4009494e
GM
15633
15634If you want to fetch mail both from your local spool as well as a
15635@acronym{POP} mail server, you'd say something like:
15636
15637@lisp
15638(setq mail-sources
15639 '((file)
15640 (pop :server "pop3.mail.server"
15641 :password "secret")))
15642@end lisp
15643
15644Or, if you don't want to use any of the keyword defaults:
15645
15646@lisp
15647(setq mail-sources
15648 '((file :path "/var/spool/mail/user-name")
15649 (pop :server "pop3.mail.server"
15650 :user "user-name"
15651 :port "pop3"
15652 :password "secret")))
15653@end lisp
15654
15655
15656When you use a mail back end, Gnus will slurp all your mail from your
15657inbox and plonk it down in your home directory. Gnus doesn't move any
15658mail if you're not using a mail back end---you have to do a lot of magic
15659invocations first. At the time when you have finished drawing the
15660pentagram, lightened the candles, and sacrificed the goat, you really
15661shouldn't be too surprised when Gnus moves your mail.
15662
15663
15664
15665@node Mail Back End Variables
15666@subsection Mail Back End Variables
15667
15668These variables are (for the most part) pertinent to all the various
15669mail back ends.
15670
15671@table @code
15672@vindex nnmail-read-incoming-hook
15673@item nnmail-read-incoming-hook
15674The mail back ends all call this hook after reading new mail. You can
15675use this hook to notify any mail watch programs, if you want to.
15676
15677@vindex nnmail-split-hook
15678@item nnmail-split-hook
15679@findex gnus-article-decode-encoded-words
15680@cindex RFC 1522 decoding
15681@cindex RFC 2047 decoding
15682Hook run in the buffer where the mail headers of each message is kept
15683just before the splitting based on these headers is done. The hook is
15684free to modify the buffer contents in any way it sees fit---the buffer
15685is discarded after the splitting has been done, and no changes performed
15686in the buffer will show up in any files.
15687@code{gnus-article-decode-encoded-words} is one likely function to add
15688to this hook.
15689
15690@vindex nnmail-pre-get-new-mail-hook
15691@vindex nnmail-post-get-new-mail-hook
15692@item nnmail-pre-get-new-mail-hook
15693@itemx nnmail-post-get-new-mail-hook
15694These are two useful hooks executed when treating new incoming
15695mail---@code{nnmail-pre-get-new-mail-hook} (is called just before
15696starting to handle the new mail) and
15697@code{nnmail-post-get-new-mail-hook} (is called when the mail handling
15698is done). Here's and example of using these two hooks to change the
15699default file modes the new mail files get:
15700
15701@lisp
15702(add-hook 'nnmail-pre-get-new-mail-hook
15703 (lambda () (set-default-file-modes 511)))
15704
15705(add-hook 'nnmail-post-get-new-mail-hook
15706 (lambda () (set-default-file-modes 551)))
15707@end lisp
15708
15709@item nnmail-use-long-file-names
15710@vindex nnmail-use-long-file-names
15711If non-@code{nil}, the mail back ends will use long file and directory
15712names. Groups like @samp{mail.misc} will end up in directories
15713(assuming use of @code{nnml} back end) or files (assuming use of
15714@code{nnfolder} back end) like @file{mail.misc}. If it is @code{nil},
15715the same group will end up in @file{mail/misc}.
15716
15717@item nnmail-delete-file-function
15718@vindex nnmail-delete-file-function
15719@findex delete-file
15720Function called to delete files. It is @code{delete-file} by default.
15721
15722@item nnmail-cache-accepted-message-ids
15723@vindex nnmail-cache-accepted-message-ids
15724If non-@code{nil}, put the @code{Message-ID}s of articles imported into
15725the back end (via @code{Gcc}, for instance) into the mail duplication
15726discovery cache. The default is @code{nil}.
15727
15728@item nnmail-cache-ignore-groups
15729@vindex nnmail-cache-ignore-groups
15730This can be a regular expression or a list of regular expressions.
15731Group names that match any of the regular expressions will never be
15732recorded in the @code{Message-ID} cache.
15733
15734This can be useful, for example, when using Fancy Splitting
15735(@pxref{Fancy Mail Splitting}) together with the function
15736@code{nnmail-split-fancy-with-parent}.
15737
15738@end table
15739
15740
15741@node Fancy Mail Splitting
15742@subsection Fancy Mail Splitting
15743@cindex mail splitting
15744@cindex fancy mail splitting
15745
15746@vindex nnmail-split-fancy
15747@findex nnmail-split-fancy
15748If the rather simple, standard method for specifying how to split mail
15749doesn't allow you to do what you want, you can set
15750@code{nnmail-split-methods} to @code{nnmail-split-fancy}. Then you can
15751play with the @code{nnmail-split-fancy} variable.
15752
15753Let's look at an example value of this variable first:
15754
15755@lisp
15756;; @r{Messages from the mailer daemon are not crossposted to any of}
15757;; @r{the ordinary groups. Warnings are put in a separate group}
15758;; @r{from real errors.}
15759(| ("from" mail (| ("subject" "warn.*" "mail.warning")
15760 "mail.misc"))
15761 ;; @r{Non-error messages are crossposted to all relevant}
15762 ;; @r{groups, but we don't crosspost between the group for the}
15763 ;; @r{(ding) list and the group for other (ding) related mail.}
15764 (& (| (any "ding@@ifi\\.uio\\.no" "ding.list")
15765 ("subject" "ding" "ding.misc"))
15766 ;; @r{Other mailing lists@dots{}}
15767 (any "procmail@@informatik\\.rwth-aachen\\.de" "procmail.list")
15768 (any "SmartList@@informatik\\.rwth-aachen\\.de" "SmartList.list")
15769 ;; @r{Both lists below have the same suffix, so prevent}
15770 ;; @r{cross-posting to mkpkg.list of messages posted only to}
15771 ;; @r{the bugs- list, but allow cross-posting when the}
15772 ;; @r{message was really cross-posted.}
15773 (any "bugs-mypackage@@somewhere" "mypkg.bugs")
15774 (any "mypackage@@somewhere" - "bugs-mypackage" "mypkg.list")
15775 ;; @r{People@dots{}}
15776 (any "larsi@@ifi\\.uio\\.no" "people.Lars_Magne_Ingebrigtsen"))
15777 ;; @r{Unmatched mail goes to the catch all group.}
15778 "misc.misc")
15779@end lisp
15780
15781This variable has the format of a @dfn{split}. A split is a
15782(possibly) recursive structure where each split may contain other
15783splits. Here are the possible split syntaxes:
15784
15785@table @code
15786
15787@item group
15788If the split is a string, that will be taken as a group name. Normal
15789regexp match expansion will be done. See below for examples.
15790
15791@c Don't fold this line.
15792@item (@var{field} @var{value} [- @var{restrict} [@dots{}] ] @var{split} [@var{invert-partial}])
15793The split can be a list containing at least three elements. If the
15794first element @var{field} (a regexp matching a header) contains
15795@var{value} (also a regexp) then store the message as specified by
15796@var{split}.
15797
15798If @var{restrict} (yet another regexp) matches some string after
15799@var{field} and before the end of the matched @var{value}, the
15800@var{split} is ignored. If none of the @var{restrict} clauses match,
15801@var{split} is processed.
15802
15803The last element @var{invert-partial} is optional. If it is
15804non-@code{nil}, the match-partial-words behavior controlled by the
15805variable @code{nnmail-split-fancy-match-partial-words} (see below) is
15806be inverted. (New in Gnus 5.10.7)
15807
15808@item (| @var{split} @dots{})
15809If the split is a list, and the first element is @code{|} (vertical
15810bar), then process each @var{split} until one of them matches. A
15811@var{split} is said to match if it will cause the mail message to be
15812stored in one or more groups.
15813
15814@item (& @var{split} @dots{})
15815If the split is a list, and the first element is @code{&}, then
15816process all @var{split}s in the list.
15817
15818@item junk
15819If the split is the symbol @code{junk}, then don't save (i.e., delete)
15820this message. Use with extreme caution.
15821
15822@item (: @var{function} @var{arg1} @var{arg2} @dots{})
15823If the split is a list, and the first element is @samp{:}, then the
15824second element will be called as a function with @var{args} given as
15825arguments. The function should return a @var{split}.
15826
15827@cindex body split
15828For instance, the following function could be used to split based on the
15829body of the messages:
15830
15831@lisp
15832(defun split-on-body ()
15833 (save-excursion
15834 (save-restriction
15835 (widen)
15836 (goto-char (point-min))
15837 (when (re-search-forward "Some.*string" nil t)
15838 "string.group"))))
15839@end lisp
15840
b890d447
MB
15841The buffer is narrowed to the header of the message in question when
15842@var{function} is run. That's why @code{(widen)} needs to be called
15843after @code{save-excursion} and @code{save-restriction} in the example
23f87bed 15844above. Also note that with the nnimap backend, message bodies will
4009494e
GM
15845not be downloaded by default. You need to set
15846@code{nnimap-split-download-body} to @code{t} to do that
15847(@pxref{Splitting in IMAP}).
15848
15849@item (! @var{func} @var{split})
15850If the split is a list, and the first element is @code{!}, then
15851@var{split} will be processed, and @var{func} will be called as a
15852function with the result of @var{split} as argument. @var{func}
15853should return a split.
15854
15855@item nil
15856If the split is @code{nil}, it is ignored.
15857
15858@end table
15859
15860In these splits, @var{field} must match a complete field name.
15861
15862Normally, @var{value} in these splits must match a complete @emph{word}
15863according to the fundamental mode syntax table. In other words, all
15864@var{value}'s will be implicitly surrounded by @code{\<...\>} markers,
15865which are word delimiters. Therefore, if you use the following split,
15866for example,
15867
15868@example
15869(any "joe" "joemail")
15870@end example
15871
15872@noindent
15873messages sent from @samp{joedavis@@foo.org} will normally not be filed
15874in @samp{joemail}. If you want to alter this behavior, you can use any
15875of the following three ways:
15876
15877@enumerate
15878@item
15879@vindex nnmail-split-fancy-match-partial-words
15880You can set the @code{nnmail-split-fancy-match-partial-words} variable
15881to non-@code{nil} in order to ignore word boundaries and instead the
15882match becomes more like a grep. This variable controls whether partial
15883words are matched during fancy splitting. The default value is
15884@code{nil}.
15885
15886Note that it influences all @var{value}'s in your split rules.
15887
15888@item
15889@var{value} beginning with @code{.*} ignores word boundaries in front of
15890a word. Similarly, if @var{value} ends with @code{.*}, word boundaries
15891in the rear of a word will be ignored. For example, the @var{value}
15892@code{"@@example\\.com"} does not match @samp{foo@@example.com} but
15893@code{".*@@example\\.com"} does.
15894
15895@item
15896You can set the @var{invert-partial} flag in your split rules of the
15897@samp{(@var{field} @var{value} @dots{})} types, aforementioned in this
15898section. If the flag is set, word boundaries on both sides of a word
15899are ignored even if @code{nnmail-split-fancy-match-partial-words} is
15900@code{nil}. Contrarily, if the flag is set, word boundaries are not
15901ignored even if @code{nnmail-split-fancy-match-partial-words} is
15902non-@code{nil}. (New in Gnus 5.10.7)
15903@end enumerate
15904
15905@vindex nnmail-split-abbrev-alist
15906@var{field} and @var{value} can also be Lisp symbols, in that case
15907they are expanded as specified by the variable
15908@code{nnmail-split-abbrev-alist}. This is an alist of cons cells,
15909where the @sc{car} of a cell contains the key, and the @sc{cdr}
15910contains the associated value. Predefined entries in
15911@code{nnmail-split-abbrev-alist} include:
15912
15913@table @code
15914@item from
15915Matches the @samp{From}, @samp{Sender} and @samp{Resent-From} fields.
15916@item to
15917Matches the @samp{To}, @samp{Cc}, @samp{Apparently-To},
15918@samp{Resent-To} and @samp{Resent-Cc} fields.
15919@item any
15920Is the union of the @code{from} and @code{to} entries.
15921@end table
15922
15923@vindex nnmail-split-fancy-syntax-table
15924@code{nnmail-split-fancy-syntax-table} is the syntax table in effect
15925when all this splitting is performed.
15926
15927If you want to have Gnus create groups dynamically based on some
15928information in the headers (i.e., do @code{replace-match}-like
15929substitutions in the group names), you can say things like:
15930
15931@example
15932(any "debian-\\b\\(\\w+\\)@@lists.debian.org" "mail.debian.\\1")
15933@end example
15934
15935In this example, messages sent to @samp{debian-foo@@lists.debian.org}
15936will be filed in @samp{mail.debian.foo}.
15937
15938If the string contains the element @samp{\&}, then the previously
15939matched string will be substituted. Similarly, the elements @samp{\\1}
15940up to @samp{\\9} will be substituted with the text matched by the
15941groupings 1 through 9.
15942
15943@vindex nnmail-split-lowercase-expanded
15944Where @code{nnmail-split-lowercase-expanded} controls whether the
15945lowercase of the matched string should be used for the substitution.
15946Setting it as non-@code{nil} is useful to avoid the creation of multiple
15947groups when users send to an address using different case
15948(i.e. mailing-list@@domain vs Mailing-List@@Domain). The default value
15949is @code{t}.
15950
15951@findex nnmail-split-fancy-with-parent
15952@code{nnmail-split-fancy-with-parent} is a function which allows you to
15953split followups into the same groups their parents are in. Sometimes
15954you can't make splitting rules for all your mail. For example, your
15955boss might send you personal mail regarding different projects you are
15956working on, and as you can't tell your boss to put a distinguishing
15957string into the subject line, you have to resort to manually moving the
15958messages into the right group. With this function, you only have to do
15959it once per thread.
15960
15961To use this feature, you have to set @code{nnmail-treat-duplicates}
15962and @code{nnmail-cache-accepted-message-ids} to a non-@code{nil}
15963value. And then you can include @code{nnmail-split-fancy-with-parent}
15964using the colon feature, like so:
15965@lisp
15966(setq nnmail-treat-duplicates 'warn ; @r{or @code{delete}}
15967 nnmail-cache-accepted-message-ids t
15968 nnmail-split-fancy
15969 '(| (: nnmail-split-fancy-with-parent)
15970 ;; @r{other splits go here}
15971 ))
15972@end lisp
15973
15974This feature works as follows: when @code{nnmail-treat-duplicates} is
15975non-@code{nil}, Gnus records the message id of every message it sees
15976in the file specified by the variable
15977@code{nnmail-message-id-cache-file}, together with the group it is in
15978(the group is omitted for non-mail messages). When mail splitting is
15979invoked, the function @code{nnmail-split-fancy-with-parent} then looks
15980at the References (and In-Reply-To) header of each message to split
15981and searches the file specified by @code{nnmail-message-id-cache-file}
15982for the message ids. When it has found a parent, it returns the
15983corresponding group name unless the group name matches the regexp
15984@code{nnmail-split-fancy-with-parent-ignore-groups}. It is
15985recommended that you set @code{nnmail-message-id-cache-length} to a
15986somewhat higher number than the default so that the message ids are
15987still in the cache. (A value of 5000 appears to create a file some
15988300 kBytes in size.)
15989@vindex nnmail-cache-accepted-message-ids
15990When @code{nnmail-cache-accepted-message-ids} is non-@code{nil}, Gnus
15991also records the message ids of moved articles, so that the followup
15992messages goes into the new group.
15993
15994Also see the variable @code{nnmail-cache-ignore-groups} if you don't
15995want certain groups to be recorded in the cache. For example, if all
15996outgoing messages are written to an ``outgoing'' group, you could set
15997@code{nnmail-cache-ignore-groups} to match that group name.
15998Otherwise, answers to all your messages would end up in the
15999``outgoing'' group.
16000
16001
16002@node Group Mail Splitting
16003@subsection Group Mail Splitting
16004@cindex mail splitting
16005@cindex group mail splitting
16006
16007@findex gnus-group-split
16008If you subscribe to dozens of mailing lists but you don't want to
16009maintain mail splitting rules manually, group mail splitting is for you.
16010You just have to set @code{to-list} and/or @code{to-address} in group
16011parameters or group customization and set @code{nnmail-split-methods} to
16012@code{gnus-group-split}. This splitting function will scan all groups
16013for those parameters and split mail accordingly, i.e., messages posted
16014from or to the addresses specified in the parameters @code{to-list} or
16015@code{to-address} of a mail group will be stored in that group.
16016
16017Sometimes, mailing lists have multiple addresses, and you may want mail
16018splitting to recognize them all: just set the @code{extra-aliases} group
16019parameter to the list of additional addresses and it's done. If you'd
16020rather use a regular expression, set @code{split-regexp}.
16021
16022All these parameters in a group will be used to create an
16023@code{nnmail-split-fancy} split, in which the @var{field} is @samp{any},
16024the @var{value} is a single regular expression that matches
16025@code{to-list}, @code{to-address}, all of @code{extra-aliases} and all
16026matches of @code{split-regexp}, and the @var{split} is the name of the
16027group. @var{restrict}s are also supported: just set the
16028@code{split-exclude} parameter to a list of regular expressions.
16029
16030If you can't get the right split to be generated using all these
16031parameters, or you just need something fancier, you can set the
16032parameter @code{split-spec} to an @code{nnmail-split-fancy} split. In
16033this case, all other aforementioned parameters will be ignored by
16034@code{gnus-group-split}. In particular, @code{split-spec} may be set to
16035@code{nil}, in which case the group will be ignored by
16036@code{gnus-group-split}.
16037
16038@vindex gnus-group-split-default-catch-all-group
16039@code{gnus-group-split} will do cross-posting on all groups that match,
16040by defining a single @code{&} fancy split containing one split for each
16041group. If a message doesn't match any split, it will be stored in the
16042group named in @code{gnus-group-split-default-catch-all-group}, unless
16043some group has @code{split-spec} set to @code{catch-all}, in which case
16044that group is used as the catch-all group. Even though this variable is
16045often used just to name a group, it may also be set to an arbitrarily
16046complex fancy split (after all, a group name is a fancy split), and this
16047may be useful to split mail that doesn't go to any mailing list to
16048personal mail folders. Note that this fancy split is added as the last
16049element of a @code{|} split list that also contains a @code{&} split
16050with the rules extracted from group parameters.
16051
16052It's time for an example. Assume the following group parameters have
16053been defined:
16054
16055@example
16056nnml:mail.bar:
16057((to-address . "bar@@femail.com")
16058 (split-regexp . ".*@@femail\\.com"))
16059nnml:mail.foo:
16060((to-list . "foo@@nowhere.gov")
16061 (extra-aliases "foo@@localhost" "foo-redist@@home")
16062 (split-exclude "bugs-foo" "rambling-foo")
16063 (admin-address . "foo-request@@nowhere.gov"))
16064nnml:mail.others:
16065((split-spec . catch-all))
16066@end example
16067
16068Setting @code{nnmail-split-methods} to @code{gnus-group-split} will
16069behave as if @code{nnmail-split-fancy} had been selected and variable
16070@code{nnmail-split-fancy} had been set as follows:
16071
16072@lisp
16073(| (& (any "\\(bar@@femail\\.com\\|.*@@femail\\.com\\)" "mail.bar")
16074 (any "\\(foo@@nowhere\\.gov\\|foo@@localhost\\|foo-redist@@home\\)"
16075 - "bugs-foo" - "rambling-foo" "mail.foo"))
16076 "mail.others")
16077@end lisp
16078
16079@findex gnus-group-split-fancy
16080If you'd rather not use group splitting for all your mail groups, you
16081may use it for only some of them, by using @code{nnmail-split-fancy}
16082splits like this:
16083
16084@lisp
16085(: gnus-group-split-fancy @var{groups} @var{no-crosspost} @var{catch-all})
16086@end lisp
16087
16088@var{groups} may be a regular expression or a list of group names whose
16089parameters will be scanned to generate the output split.
16090@var{no-crosspost} can be used to disable cross-posting; in this case, a
16091single @code{|} split will be output. @var{catch-all} is the fall back
16092fancy split, used like @code{gnus-group-split-default-catch-all-group}.
16093If @var{catch-all} is @code{nil}, or if @code{split-regexp} matches the
16094empty string in any selected group, no catch-all split will be issued.
16095Otherwise, if some group has @code{split-spec} set to @code{catch-all},
16096this group will override the value of the @var{catch-all} argument.
16097
16098@findex gnus-group-split-setup
16099Unfortunately, scanning all groups and their parameters can be quite
16100slow, especially considering that it has to be done for every message.
16101But don't despair! The function @code{gnus-group-split-setup} can be
16102used to enable @code{gnus-group-split} in a much more efficient way. It
16103sets @code{nnmail-split-methods} to @code{nnmail-split-fancy} and sets
16104@code{nnmail-split-fancy} to the split produced by
16105@code{gnus-group-split-fancy}. Thus, the group parameters are only
16106scanned once, no matter how many messages are split.
16107
16108@findex gnus-group-split-update
16109However, if you change group parameters, you'd have to update
16110@code{nnmail-split-fancy} manually. You can do it by running
16111@code{gnus-group-split-update}. If you'd rather have it updated
16112automatically, just tell @code{gnus-group-split-setup} to do it for
16113you. For example, add to your @file{~/.gnus.el}:
16114
16115@lisp
16116(gnus-group-split-setup @var{auto-update} @var{catch-all})
16117@end lisp
16118
16119If @var{auto-update} is non-@code{nil}, @code{gnus-group-split-update}
16120will be added to @code{nnmail-pre-get-new-mail-hook}, so you won't ever
16121have to worry about updating @code{nnmail-split-fancy} again. If you
16122don't omit @var{catch-all} (it's optional, equivalent to @code{nil}),
16123@code{gnus-group-split-default-catch-all-group} will be set to its
16124value.
16125
16126@vindex gnus-group-split-updated-hook
16127Because you may want to change @code{nnmail-split-fancy} after it is set
16128by @code{gnus-group-split-update}, this function will run
16129@code{gnus-group-split-updated-hook} just before finishing.
16130
16131@node Incorporating Old Mail
16132@subsection Incorporating Old Mail
16133@cindex incorporating old mail
16134@cindex import old mail
16135
16136Most people have lots of old mail stored in various file formats. If
16137you have set up Gnus to read mail using one of the spiffy Gnus mail
16138back ends, you'll probably wish to have that old mail incorporated into
16139your mail groups.
16140
16141Doing so can be quite easy.
16142
16143To take an example: You're reading mail using @code{nnml}
16144(@pxref{Mail Spool}), and have set @code{nnmail-split-methods} to a
16145satisfactory value (@pxref{Splitting Mail}). You have an old Unix mbox
16146file filled with important, but old, mail. You want to move it into
16147your @code{nnml} groups.
16148
16149Here's how:
16150
16151@enumerate
16152@item
16153Go to the group buffer.
16154
16155@item
16156Type @kbd{G f} and give the file name to the mbox file when prompted to create an
16157@code{nndoc} group from the mbox file (@pxref{Foreign Groups}).
16158
16159@item
16160Type @kbd{SPACE} to enter the newly created group.
16161
16162@item
16163Type @kbd{M P b} to process-mark all articles in this group's buffer
16164(@pxref{Setting Process Marks}).
16165
16166@item
16167Type @kbd{B r} to respool all the process-marked articles, and answer
16168@samp{nnml} when prompted (@pxref{Mail Group Commands}).
16169@end enumerate
16170
16171All the mail messages in the mbox file will now also be spread out over
16172all your @code{nnml} groups. Try entering them and check whether things
16173have gone without a glitch. If things look ok, you may consider
16174deleting the mbox file, but I wouldn't do that unless I was absolutely
16175sure that all the mail has ended up where it should be.
16176
16177Respooling is also a handy thing to do if you're switching from one mail
16178back end to another. Just respool all the mail in the old mail groups
16179using the new mail back end.
16180
16181
16182@node Expiring Mail
16183@subsection Expiring Mail
16184@cindex article expiry
16185@cindex expiring mail
16186
16187Traditional mail readers have a tendency to remove mail articles when
16188you mark them as read, in some way. Gnus takes a fundamentally
16189different approach to mail reading.
16190
16191Gnus basically considers mail just to be news that has been received in
16192a rather peculiar manner. It does not think that it has the power to
16193actually change the mail, or delete any mail messages. If you enter a
16194mail group, and mark articles as ``read'', or kill them in some other
16195fashion, the mail articles will still exist on the system. I repeat:
16196Gnus will not delete your old, read mail. Unless you ask it to, of
16197course.
16198
16199To make Gnus get rid of your unwanted mail, you have to mark the
16200articles as @dfn{expirable}. (With the default key bindings, this means
16201that you have to type @kbd{E}.) This does not mean that the articles
16202will disappear right away, however. In general, a mail article will be
16203deleted from your system if, 1) it is marked as expirable, AND 2) it is
16204more than one week old. If you do not mark an article as expirable, it
16205will remain on your system until hell freezes over. This bears
16206repeating one more time, with some spurious capitalizations: IF you do
16207NOT mark articles as EXPIRABLE, Gnus will NEVER delete those ARTICLES.
16208
16209You do not have to mark articles as expirable by hand. Gnus provides
16210two features, called ``auto-expire'' and ``total-expire'', that can help you
16211with this. In a nutshell, ``auto-expire'' means that Gnus hits @kbd{E}
16212for you when you select an article. And ``total-expire'' means that Gnus
16213considers all articles as expirable that are read. So, in addition to
16214the articles marked @samp{E}, also the articles marked @samp{r},
16215@samp{R}, @samp{O}, @samp{K}, @samp{Y} and so on are considered
16216expirable.
16217
16218When should either auto-expire or total-expire be used? Most people
16219who are subscribed to mailing lists split each list into its own group
16220and then turn on auto-expire or total-expire for those groups.
16221(@xref{Splitting Mail}, for more information on splitting each list
16222into its own group.)
16223
16224Which one is better, auto-expire or total-expire? It's not easy to
16225answer. Generally speaking, auto-expire is probably faster. Another
16226advantage of auto-expire is that you get more marks to work with: for
16227the articles that are supposed to stick around, you can still choose
16228between tick and dormant and read marks. But with total-expire, you
16229only have dormant and ticked to choose from. The advantage of
16230total-expire is that it works well with adaptive scoring (@pxref{Adaptive
16231Scoring}). Auto-expire works with normal scoring but not with adaptive
16232scoring.
16233
16234@vindex gnus-auto-expirable-newsgroups
16235Groups that match the regular expression
16236@code{gnus-auto-expirable-newsgroups} will have all articles that you
16237read marked as expirable automatically. All articles marked as
16238expirable have an @samp{E} in the first column in the summary buffer.
16239
16240By default, if you have auto expiry switched on, Gnus will mark all the
16241articles you read as expirable, no matter if they were read or unread
16242before. To avoid having articles marked as read marked as expirable
16243automatically, you can put something like the following in your
16244@file{~/.gnus.el} file:
16245
16246@vindex gnus-mark-article-hook
16247@lisp
16248(remove-hook 'gnus-mark-article-hook
16249 'gnus-summary-mark-read-and-unread-as-read)
16250(add-hook 'gnus-mark-article-hook 'gnus-summary-mark-unread-as-read)
16251@end lisp
16252
16253Note that making a group auto-expirable doesn't mean that all read
16254articles are expired---only the articles marked as expirable
16255will be expired. Also note that using the @kbd{d} command won't make
16256articles expirable---only semi-automatic marking of articles as read will
16257mark the articles as expirable in auto-expirable groups.
16258
16259Let's say you subscribe to a couple of mailing lists, and you want the
16260articles you have read to disappear after a while:
16261
16262@lisp
16263(setq gnus-auto-expirable-newsgroups
16264 "mail.nonsense-list\\|mail.nice-list")
16265@end lisp
16266
16267Another way to have auto-expiry happen is to have the element
16268@code{auto-expire} in the group parameters of the group.
16269
16270If you use adaptive scoring (@pxref{Adaptive Scoring}) and
16271auto-expiring, you'll have problems. Auto-expiring and adaptive scoring
16272don't really mix very well.
16273
16274@vindex nnmail-expiry-wait
16275The @code{nnmail-expiry-wait} variable supplies the default time an
16276expirable article has to live. Gnus starts counting days from when the
16277message @emph{arrived}, not from when it was sent. The default is seven
16278days.
16279
16280Gnus also supplies a function that lets you fine-tune how long articles
16281are to live, based on what group they are in. Let's say you want to
16282have one month expiry period in the @samp{mail.private} group, a one day
16283expiry period in the @samp{mail.junk} group, and a six day expiry period
16284everywhere else:
16285
16286@vindex nnmail-expiry-wait-function
16287@lisp
16288(setq nnmail-expiry-wait-function
16289 (lambda (group)
16290 (cond ((string= group "mail.private")
16291 31)
16292 ((string= group "mail.junk")
16293 1)
16294 ((string= group "important")
16295 'never)
16296 (t
16297 6))))
16298@end lisp
16299
16300The group names this function is fed are ``unadorned'' group
16301names---no @samp{nnml:} prefixes and the like.
16302
16303The @code{nnmail-expiry-wait} variable and
16304@code{nnmail-expiry-wait-function} function can either be a number (not
16305necessarily an integer) or one of the symbols @code{immediate} or
16306@code{never}.
16307
16308You can also use the @code{expiry-wait} group parameter to selectively
16309change the expiry period (@pxref{Group Parameters}).
16310
16311@vindex nnmail-expiry-target
16312The normal action taken when expiring articles is to delete them.
16313However, in some circumstances it might make more sense to move them
16314to other groups instead of deleting them. The variable
16315@code{nnmail-expiry-target} (and the @code{expiry-target} group
16316parameter) controls this. The variable supplies a default value for
16317all groups, which can be overridden for specific groups by the group
16318parameter. default value is @code{delete}, but this can also be a
16319string (which should be the name of the group the message should be
16320moved to), or a function (which will be called in a buffer narrowed to
16321the message in question, and with the name of the group being moved
16322from as its parameter) which should return a target---either a group
16323name or @code{delete}.
16324
16325Here's an example for specifying a group name:
16326@lisp
16327(setq nnmail-expiry-target "nnml:expired")
16328@end lisp
16329
16330@findex nnmail-fancy-expiry-target
16331@vindex nnmail-fancy-expiry-targets
16332Gnus provides a function @code{nnmail-fancy-expiry-target} which will
16333expire mail to groups according to the variable
16334@code{nnmail-fancy-expiry-targets}. Here's an example:
16335
16336@lisp
16337 (setq nnmail-expiry-target 'nnmail-fancy-expiry-target
16338 nnmail-fancy-expiry-targets
16339 '((to-from "boss" "nnfolder:Work")
16340 ("subject" "IMPORTANT" "nnfolder:IMPORTANT.%Y.%b")
16341 ("from" ".*" "nnfolder:Archive-%Y")))
16342@end lisp
16343
16344With this setup, any mail that has @code{IMPORTANT} in its Subject
16345header and was sent in the year @code{YYYY} and month @code{MMM}, will
16346get expired to the group @code{nnfolder:IMPORTANT.YYYY.MMM}. If its
16347From or To header contains the string @code{boss}, it will get expired
16348to @code{nnfolder:Work}. All other mail will get expired to
16349@code{nnfolder:Archive-YYYY}.
16350
16351@vindex nnmail-keep-last-article
16352If @code{nnmail-keep-last-article} is non-@code{nil}, Gnus will never
16353expire the final article in a mail newsgroup. This is to make life
16354easier for procmail users.
16355
16356@vindex gnus-total-expirable-newsgroups
16357By the way: That line up there, about Gnus never expiring non-expirable
16358articles, is a lie. If you put @code{total-expire} in the group
16359parameters, articles will not be marked as expirable, but all read
16360articles will be put through the expiry process. Use with extreme
16361caution. Even more dangerous is the
16362@code{gnus-total-expirable-newsgroups} variable. All groups that match
16363this regexp will have all read articles put through the expiry process,
16364which means that @emph{all} old mail articles in the groups in question
16365will be deleted after a while. Use with extreme caution, and don't come
16366crying to me when you discover that the regexp you used matched the
16367wrong group and all your important mail has disappeared. Be a
16368@emph{man}! Or a @emph{woman}! Whatever you feel more comfortable
16369with! So there!
16370
16371Most people make most of their mail groups total-expirable, though.
16372
16373@vindex gnus-inhibit-user-auto-expire
16374If @code{gnus-inhibit-user-auto-expire} is non-@code{nil}, user marking
16375commands will not mark an article as expirable, even if the group has
16376auto-expire turned on.
16377
b0b63450
MB
16378@vindex gnus-mark-copied-or-moved-articles-as-expirable
16379The expirable marks of articles will be removed when copying or moving
16380them to a group in which auto-expire is not turned on. This is for
16381preventing articles from being expired unintentionally. On the other
16382hand, to a group that has turned auto-expire on, the expirable marks of
16383articles that are copied or moved will not be changed by default. I.e.,
16384when copying or moving to such a group, articles that were expirable
16385will be left expirable and ones that were not expirable will not be
16386marked as expirable. So, even though in auto-expire groups, some
16387articles will never get expired (unless you read them again). If you
16388don't side with that behavior that unexpirable articles may be mixed
16389into auto-expire groups, you can set
16390@code{gnus-mark-copied-or-moved-articles-as-expirable} to a
16391non-@code{nil} value. In that case, articles that have been read will
16392be marked as expirable automatically when being copied or moved to a
16393group that has auto-expire turned on. The default value is @code{nil}.
16394
4009494e
GM
16395
16396@node Washing Mail
16397@subsection Washing Mail
16398@cindex mail washing
16399@cindex list server brain damage
16400@cindex incoming mail treatment
16401
16402Mailers and list servers are notorious for doing all sorts of really,
16403really stupid things with mail. ``Hey, RFC 822 doesn't explicitly
16404prohibit us from adding the string @code{wE aRe ElItE!!!!!1!!} to the
16405end of all lines passing through our server, so let's do that!!!!1!''
16406Yes, but RFC 822 wasn't designed to be read by morons. Things that were
16407considered to be self-evident were not discussed. So. Here we are.
16408
16409Case in point: The German version of Microsoft Exchange adds @samp{AW:
16410} to the subjects of replies instead of @samp{Re: }. I could pretend to
16411be shocked and dismayed by this, but I haven't got the energy. It is to
16412laugh.
16413
16414Gnus provides a plethora of functions for washing articles while
16415displaying them, but it might be nicer to do the filtering before
16416storing the mail to disk. For that purpose, we have three hooks and
16417various functions that can be put in these hooks.
16418
16419@table @code
16420@item nnmail-prepare-incoming-hook
16421@vindex nnmail-prepare-incoming-hook
16422This hook is called before doing anything with the mail and is meant for
16423grand, sweeping gestures. It is called in a buffer that contains all
16424the new, incoming mail. Functions to be used include:
16425
16426@table @code
16427@item nnheader-ms-strip-cr
16428@findex nnheader-ms-strip-cr
16429Remove trailing carriage returns from each line. This is default on
16430Emacs running on MS machines.
16431
16432@end table
16433
16434@item nnmail-prepare-incoming-header-hook
16435@vindex nnmail-prepare-incoming-header-hook
16436This hook is called narrowed to each header. It can be used when
16437cleaning up the headers. Functions that can be used include:
16438
16439@table @code
16440@item nnmail-remove-leading-whitespace
16441@findex nnmail-remove-leading-whitespace
16442Clear leading white space that ``helpful'' listservs have added to the
16443headers to make them look nice. Aaah.
16444
16445(Note that this function works on both the header on the body of all
16446messages, so it is a potentially dangerous function to use (if a body
16447of a message contains something that looks like a header line). So
16448rather than fix the bug, it is of course the right solution to make it
16449into a feature by documenting it.)
16450
16451@item nnmail-remove-list-identifiers
16452@findex nnmail-remove-list-identifiers
16453Some list servers add an identifier---for example, @samp{(idm)}---to the
16454beginning of all @code{Subject} headers. I'm sure that's nice for
16455people who use stone age mail readers. This function will remove
16456strings that match the @code{nnmail-list-identifiers} regexp, which can
16457also be a list of regexp. @code{nnmail-list-identifiers} may not contain
16458@code{\\(..\\)}.
16459
16460For instance, if you want to remove the @samp{(idm)} and the
16461@samp{nagnagnag} identifiers:
16462
16463@lisp
16464(setq nnmail-list-identifiers
16465 '("(idm)" "nagnagnag"))
16466@end lisp
16467
16468This can also be done non-destructively with
16469@code{gnus-list-identifiers}, @xref{Article Hiding}.
16470
16471@item nnmail-remove-tabs
16472@findex nnmail-remove-tabs
16473Translate all @samp{TAB} characters into @samp{SPACE} characters.
16474
01c52d31
MB
16475@item nnmail-ignore-broken-references
16476@findex nnmail-ignore-broken-references
16477@c @findex nnmail-fix-eudora-headers
4009494e 16478@cindex Eudora
01c52d31
MB
16479@cindex Pegasus
16480Some mail user agents (e.g. Eudora and Pegasus) produce broken
16481@code{References} headers, but correct @code{In-Reply-To} headers. This
16482function will get rid of the @code{References} header if the headers
16483contain a line matching the regular expression
16484@code{nnmail-broken-references-mailers}.
4009494e
GM
16485
16486@end table
16487
16488@item nnmail-prepare-incoming-message-hook
16489@vindex nnmail-prepare-incoming-message-hook
16490This hook is called narrowed to each message. Functions to be used
16491include:
16492
16493@table @code
16494@item article-de-quoted-unreadable
16495@findex article-de-quoted-unreadable
16496Decode Quoted Readable encoding.
16497
16498@end table
16499@end table
16500
16501
16502@node Duplicates
16503@subsection Duplicates
16504
16505@vindex nnmail-treat-duplicates
16506@vindex nnmail-message-id-cache-length
16507@vindex nnmail-message-id-cache-file
16508@cindex duplicate mails
16509If you are a member of a couple of mailing lists, you will sometimes
16510receive two copies of the same mail. This can be quite annoying, so
16511@code{nnmail} checks for and treats any duplicates it might find. To do
16512this, it keeps a cache of old @code{Message-ID}s---
16513@code{nnmail-message-id-cache-file}, which is @file{~/.nnmail-cache} by
16514default. The approximate maximum number of @code{Message-ID}s stored
16515there is controlled by the @code{nnmail-message-id-cache-length}
16516variable, which is 1000 by default. (So 1000 @code{Message-ID}s will be
16517stored.) If all this sounds scary to you, you can set
16518@code{nnmail-treat-duplicates} to @code{warn} (which is what it is by
16519default), and @code{nnmail} won't delete duplicate mails. Instead it
16520will insert a warning into the head of the mail saying that it thinks
16521that this is a duplicate of a different message.
16522
16523This variable can also be a function. If that's the case, the function
16524will be called from a buffer narrowed to the message in question with
16525the @code{Message-ID} as a parameter. The function must return either
16526@code{nil}, @code{warn}, or @code{delete}.
16527
16528You can turn this feature off completely by setting the variable to
16529@code{nil}.
16530
16531If you want all the duplicate mails to be put into a special
16532@dfn{duplicates} group, you could do that using the normal mail split
16533methods:
16534
16535@lisp
16536(setq nnmail-split-fancy
16537 '(| ;; @r{Messages duplicates go to a separate group.}
16538 ("gnus-warning" "duplicat\\(e\\|ion\\) of message" "duplicate")
16539 ;; @r{Message from daemons, postmaster, and the like to another.}
16540 (any mail "mail.misc")
16541 ;; @r{Other rules.}
16542 [...] ))
16543@end lisp
16544@noindent
16545Or something like:
16546@lisp
16547(setq nnmail-split-methods
16548 '(("duplicates" "^Gnus-Warning:.*duplicate")
16549 ;; @r{Other rules.}
16550 [...]))
16551@end lisp
16552
16553Here's a neat feature: If you know that the recipient reads her mail
16554with Gnus, and that she has @code{nnmail-treat-duplicates} set to
16555@code{delete}, you can send her as many insults as you like, just by
16556using a @code{Message-ID} of a mail that you know that she's already
16557received. Think of all the fun! She'll never see any of it! Whee!
16558
16559
16560@node Not Reading Mail
16561@subsection Not Reading Mail
16562
16563If you start using any of the mail back ends, they have the annoying
16564habit of assuming that you want to read mail with them. This might not
16565be unreasonable, but it might not be what you want.
16566
16567If you set @code{mail-sources} and @code{nnmail-spool-file} to
16568@code{nil}, none of the back ends will ever attempt to read incoming
16569mail, which should help.
16570
16571@vindex nnbabyl-get-new-mail
16572@vindex nnmbox-get-new-mail
16573@vindex nnml-get-new-mail
16574@vindex nnmh-get-new-mail
16575@vindex nnfolder-get-new-mail
16576This might be too much, if, for instance, you are reading mail quite
bc79f9ab
GM
16577happily with @code{nnml} and just want to peek at some old (pre-Emacs
1657823) Rmail file you have stashed away with @code{nnbabyl}. All back ends have
4009494e
GM
16579variables called back-end-@code{get-new-mail}. If you want to disable
16580the @code{nnbabyl} mail reading, you edit the virtual server for the
16581group to have a setting where @code{nnbabyl-get-new-mail} to @code{nil}.
16582
16583All the mail back ends will call @code{nn}*@code{-prepare-save-mail-hook}
16584narrowed to the article to be saved before saving it when reading
16585incoming mail.
16586
16587
16588@node Choosing a Mail Back End
16589@subsection Choosing a Mail Back End
16590
16591Gnus will read the mail spool when you activate a mail group. The mail
16592file is first copied to your home directory. What happens after that
16593depends on what format you want to store your mail in.
16594
16595There are six different mail back ends in the standard Gnus, and more
16596back ends are available separately. The mail back end most people use
16597(because it is possibly the fastest) is @code{nnml} (@pxref{Mail
16598Spool}).
16599
16600@menu
16601* Unix Mail Box:: Using the (quite) standard Un*x mbox.
bc79f9ab 16602* Babyl:: Babyl was used by older versions of Rmail.
4009494e
GM
16603* Mail Spool:: Store your mail in a private spool?
16604* MH Spool:: An mhspool-like back end.
16605* Maildir:: Another one-file-per-message format.
16606* Mail Folders:: Having one file for each group.
16607* Comparing Mail Back Ends:: An in-depth looks at pros and cons.
16608@end menu
16609
16610
16611@node Unix Mail Box
16612@subsubsection Unix Mail Box
16613@cindex nnmbox
16614@cindex unix mail box
16615
16616@vindex nnmbox-active-file
16617@vindex nnmbox-mbox-file
16618The @dfn{nnmbox} back end will use the standard Un*x mbox file to store
16619mail. @code{nnmbox} will add extra headers to each mail article to say
16620which group it belongs in.
16621
16622Virtual server settings:
16623
16624@table @code
16625@item nnmbox-mbox-file
16626@vindex nnmbox-mbox-file
16627The name of the mail box in the user's home directory. Default is
16628@file{~/mbox}.
16629
16630@item nnmbox-active-file
16631@vindex nnmbox-active-file
16632The name of the active file for the mail box. Default is
16633@file{~/.mbox-active}.
16634
16635@item nnmbox-get-new-mail
16636@vindex nnmbox-get-new-mail
16637If non-@code{nil}, @code{nnmbox} will read incoming mail and split it
16638into groups. Default is @code{t}.
16639@end table
16640
16641
bc79f9ab
GM
16642@node Babyl
16643@subsubsection Babyl
4009494e 16644@cindex nnbabyl
4009494e
GM
16645
16646@vindex nnbabyl-active-file
16647@vindex nnbabyl-mbox-file
bc79f9ab
GM
16648The @dfn{nnbabyl} back end will use a Babyl mail box to store mail.
16649@code{nnbabyl} will add extra headers to each mail article to say which
16650group it belongs in.
4009494e
GM
16651
16652Virtual server settings:
16653
16654@table @code
16655@item nnbabyl-mbox-file
16656@vindex nnbabyl-mbox-file
bc79f9ab 16657The name of the Babyl file. The default is @file{~/RMAIL}
4009494e
GM
16658
16659@item nnbabyl-active-file
16660@vindex nnbabyl-active-file
bc79f9ab 16661The name of the active file for the Babyl file. The default is
4009494e
GM
16662@file{~/.rmail-active}
16663
16664@item nnbabyl-get-new-mail
16665@vindex nnbabyl-get-new-mail
16666If non-@code{nil}, @code{nnbabyl} will read incoming mail. Default is
16667@code{t}
16668@end table
16669
16670
16671@node Mail Spool
16672@subsubsection Mail Spool
16673@cindex nnml
16674@cindex mail @acronym{NOV} spool
16675
16676The @dfn{nnml} spool mail format isn't compatible with any other known
16677format. It should be used with some caution.
16678
16679@vindex nnml-directory
16680If you use this back end, Gnus will split all incoming mail into files,
16681one file for each mail, and put the articles into the corresponding
16682directories under the directory specified by the @code{nnml-directory}
16683variable. The default value is @file{~/Mail/}.
16684
16685You do not have to create any directories beforehand; Gnus will take
16686care of all that.
16687
16688If you have a strict limit as to how many files you are allowed to store
16689in your account, you should not use this back end. As each mail gets its
16690own file, you might very well occupy thousands of inodes within a few
16691weeks. If this is no problem for you, and it isn't a problem for you
16692having your friendly systems administrator walking around, madly,
16693shouting ``Who is eating all my inodes?! Who? Who!?!'', then you should
16694know that this is probably the fastest format to use. You do not have
16695to trudge through a big mbox file just to read your new mail.
16696
16697@code{nnml} is probably the slowest back end when it comes to article
16698splitting. It has to create lots of files, and it also generates
16699@acronym{NOV} databases for the incoming mails. This makes it possibly the
16700fastest back end when it comes to reading mail.
16701
16702@cindex self contained nnml servers
16703@cindex marks
16704When the marks file is used (which it is by default), @code{nnml}
16705servers have the property that you may backup them using @code{tar} or
16706similar, and later be able to restore them into Gnus (by adding the
16707proper @code{nnml} server) and have all your marks be preserved. Marks
01c52d31 16708for a group are usually stored in the @code{.marks} file (but see
4009494e
GM
16709@code{nnml-marks-file-name}) within each @code{nnml} group's directory.
16710Individual @code{nnml} groups are also possible to backup, use @kbd{G m}
16711to restore the group (after restoring the backup into the nnml
16712directory).
16713
16714If for some reason you believe your @file{.marks} files are screwed
16715up, you can just delete them all. Gnus will then correctly regenerate
16716them next time it starts.
16717
16718Virtual server settings:
16719
16720@table @code
16721@item nnml-directory
16722@vindex nnml-directory
16723All @code{nnml} directories will be placed under this directory. The
16724default is the value of @code{message-directory} (whose default value
16725is @file{~/Mail}).
16726
16727@item nnml-active-file
16728@vindex nnml-active-file
16729The active file for the @code{nnml} server. The default is
16730@file{~/Mail/active}.
16731
16732@item nnml-newsgroups-file
16733@vindex nnml-newsgroups-file
16734The @code{nnml} group descriptions file. @xref{Newsgroups File
16735Format}. The default is @file{~/Mail/newsgroups}.
16736
16737@item nnml-get-new-mail
16738@vindex nnml-get-new-mail
16739If non-@code{nil}, @code{nnml} will read incoming mail. The default is
16740@code{t}.
16741
16742@item nnml-nov-is-evil
16743@vindex nnml-nov-is-evil
16744If non-@code{nil}, this back end will ignore any @acronym{NOV} files. The
16745default is @code{nil}.
16746
16747@item nnml-nov-file-name
16748@vindex nnml-nov-file-name
16749The name of the @acronym{NOV} files. The default is @file{.overview}.
16750
16751@item nnml-prepare-save-mail-hook
16752@vindex nnml-prepare-save-mail-hook
16753Hook run narrowed to an article before saving.
16754
16755@item nnml-marks-is-evil
16756@vindex nnml-marks-is-evil
16757If non-@code{nil}, this back end will ignore any @sc{marks} files. The
16758default is @code{nil}.
16759
16760@item nnml-marks-file-name
16761@vindex nnml-marks-file-name
16762The name of the @dfn{marks} files. The default is @file{.marks}.
16763
16764@item nnml-use-compressed-files
16765@vindex nnml-use-compressed-files
16766If non-@code{nil}, @code{nnml} will allow using compressed message
01c52d31
MB
16767files. This requires @code{auto-compression-mode} to be enabled
16768(@pxref{Compressed Files, ,Compressed Files, emacs, The Emacs Manual}).
16769If the value of @code{nnml-use-compressed-files} is a string, it is used
16770as the file extension specifying the compression program. You can set it
16771to @samp{.bz2} if your Emacs supports it. A value of @code{t} is
16772equivalent to @samp{.gz}.
16773
16774@item nnml-compressed-files-size-threshold
16775@vindex nnml-compressed-files-size-threshold
16776Default size threshold for compressed message files. Message files with
16777bodies larger than that many characters will be automatically compressed
16778if @code{nnml-use-compressed-files} is non-@code{nil}.
4009494e
GM
16779
16780@end table
16781
16782@findex nnml-generate-nov-databases
16783If your @code{nnml} groups and @acronym{NOV} files get totally out of
16784whack, you can do a complete update by typing @kbd{M-x
16785nnml-generate-nov-databases}. This command will trawl through the
16786entire @code{nnml} hierarchy, looking at each and every article, so it
16787might take a while to complete. A better interface to this
16788functionality can be found in the server buffer (@pxref{Server
16789Commands}).
16790
16791
16792@node MH Spool
16793@subsubsection MH Spool
16794@cindex nnmh
16795@cindex mh-e mail spool
16796
16797@code{nnmh} is just like @code{nnml}, except that is doesn't generate
16798@acronym{NOV} databases and it doesn't keep an active file or marks
16799file. This makes @code{nnmh} a @emph{much} slower back end than
16800@code{nnml}, but it also makes it easier to write procmail scripts
16801for.
16802
16803Virtual server settings:
16804
16805@table @code
16806@item nnmh-directory
16807@vindex nnmh-directory
16808All @code{nnmh} directories will be located under this directory. The
16809default is the value of @code{message-directory} (whose default is
16810@file{~/Mail})
16811
16812@item nnmh-get-new-mail
16813@vindex nnmh-get-new-mail
16814If non-@code{nil}, @code{nnmh} will read incoming mail. The default is
16815@code{t}.
16816
16817@item nnmh-be-safe
16818@vindex nnmh-be-safe
16819If non-@code{nil}, @code{nnmh} will go to ridiculous lengths to make
16820sure that the articles in the folder are actually what Gnus thinks
16821they are. It will check date stamps and stat everything in sight, so
16822setting this to @code{t} will mean a serious slow-down. If you never
16823use anything but Gnus to read the @code{nnmh} articles, you do not
16824have to set this variable to @code{t}. The default is @code{nil}.
16825@end table
16826
16827
16828@node Maildir
16829@subsubsection Maildir
16830@cindex nnmaildir
16831@cindex maildir
16832
16833@code{nnmaildir} stores mail in the maildir format, with each maildir
16834corresponding to a group in Gnus. This format is documented here:
16835@uref{http://cr.yp.to/proto/maildir.html} and here:
16836@uref{http://www.qmail.org/man/man5/maildir.html}. @code{nnmaildir}
16837also stores extra information in the @file{.nnmaildir/} directory
16838within a maildir.
16839
16840Maildir format was designed to allow concurrent deliveries and
16841reading, without needing locks. With other back ends, you would have
16842your mail delivered to a spool of some kind, and then you would
16843configure Gnus to split mail from that spool into your groups. You
16844can still do that with @code{nnmaildir}, but the more common
16845configuration is to have your mail delivered directly to the maildirs
16846that appear as group in Gnus.
16847
16848@code{nnmaildir} is designed to be perfectly reliable: @kbd{C-g} will
16849never corrupt its data in memory, and @code{SIGKILL} will never
16850corrupt its data in the filesystem.
16851
16852@code{nnmaildir} stores article marks and @acronym{NOV} data in each
16853maildir. So you can copy a whole maildir from one Gnus setup to
16854another, and you will keep your marks.
16855
16856Virtual server settings:
16857
16858@table @code
16859@item directory
16860For each of your @code{nnmaildir} servers (it's very unlikely that
16861you'd need more than one), you need to create a directory and populate
16862it with maildirs or symlinks to maildirs (and nothing else; do not
16863choose a directory already used for other purposes). Each maildir
16864will be represented in Gnus as a newsgroup on that server; the
16865filename of the symlink will be the name of the group. Any filenames
16866in the directory starting with @samp{.} are ignored. The directory is
16867scanned when you first start Gnus, and each time you type @kbd{g} in
16868the group buffer; if any maildirs have been removed or added,
16869@code{nnmaildir} notices at these times.
16870
16871The value of the @code{directory} parameter should be a Lisp form
16872which is processed by @code{eval} and @code{expand-file-name} to get
16873the path of the directory for this server. The form is @code{eval}ed
16874only when the server is opened; the resulting string is used until the
16875server is closed. (If you don't know about forms and @code{eval},
16876don't worry---a simple string will work.) This parameter is not
16877optional; you must specify it. I don't recommend using
16878@code{"~/Mail"} or a subdirectory of it; several other parts of Gnus
16879use that directory by default for various things, and may get confused
16880if @code{nnmaildir} uses it too. @code{"~/.nnmaildir"} is a typical
16881value.
16882
16883@item target-prefix
16884This should be a Lisp form which is processed by @code{eval} and
16885@code{expand-file-name}. The form is @code{eval}ed only when the
16886server is opened; the resulting string is used until the server is
16887closed.
16888
16889When you create a group on an @code{nnmaildir} server, the maildir is
16890created with @code{target-prefix} prepended to its name, and a symlink
16891pointing to that maildir is created, named with the plain group name.
16892So if @code{directory} is @code{"~/.nnmaildir"} and
16893@code{target-prefix} is @code{"../maildirs/"}, then when you create
16894the group @code{foo}, @code{nnmaildir} will create
16895@file{~/.nnmaildir/../maildirs/foo} as a maildir, and will create
16896@file{~/.nnmaildir/foo} as a symlink pointing to
16897@file{../maildirs/foo}.
16898
16899You can set @code{target-prefix} to a string without any slashes to
16900create both maildirs and symlinks in the same @code{directory}; in
16901this case, any maildirs found in @code{directory} whose names start
16902with @code{target-prefix} will not be listed as groups (but the
16903symlinks pointing to them will be).
16904
16905As a special case, if @code{target-prefix} is @code{""} (the default),
16906then when you create a group, the maildir will be created in
16907@code{directory} without a corresponding symlink. Beware that you
16908cannot use @code{gnus-group-delete-group} on such groups without the
16909@code{force} argument.
16910
16911@item directory-files
16912This should be a function with the same interface as
16913@code{directory-files} (such as @code{directory-files} itself). It is
16914used to scan the server's @code{directory} for maildirs. This
16915parameter is optional; the default is
16916@code{nnheader-directory-files-safe} if
16917@code{nnheader-directory-files-is-safe} is @code{nil}, and
16918@code{directory-files} otherwise.
16919(@code{nnheader-directory-files-is-safe} is checked only once when the
16920server is opened; if you want to check it each time the directory is
16921scanned, you'll have to provide your own function that does that.)
16922
16923@item get-new-mail
16924If non-@code{nil}, then after scanning for new mail in the group
16925maildirs themselves as usual, this server will also incorporate mail
16926the conventional Gnus way, from @code{mail-sources} according to
16927@code{nnmail-split-methods} or @code{nnmail-split-fancy}. The default
16928value is @code{nil}.
16929
16930Do @emph{not} use the same maildir both in @code{mail-sources} and as
16931an @code{nnmaildir} group. The results might happen to be useful, but
16932that would be by chance, not by design, and the results might be
16933different in the future. If your split rules create new groups,
16934remember to supply a @code{create-directory} server parameter.
16935@end table
16936
16937@subsubsection Group parameters
16938
16939@code{nnmaildir} uses several group parameters. It's safe to ignore
16940all this; the default behavior for @code{nnmaildir} is the same as the
16941default behavior for other mail back ends: articles are deleted after
16942one week, etc. Except for the expiry parameters, all this
16943functionality is unique to @code{nnmaildir}, so you can ignore it if
16944you're just trying to duplicate the behavior you already have with
16945another back end.
16946
16947If the value of any of these parameters is a vector, the first element
16948is evaluated as a Lisp form and the result is used, rather than the
16949original value. If the value is not a vector, the value itself is
16950evaluated as a Lisp form. (This is why these parameters use names
16951different from those of other, similar parameters supported by other
16952back ends: they have different, though similar, meanings.) (For
16953numbers, strings, @code{nil}, and @code{t}, you can ignore the
16954@code{eval} business again; for other values, remember to use an extra
16955quote and wrap the value in a vector when appropriate.)
16956
16957@table @code
16958@item expire-age
16959An integer specifying the minimum age, in seconds, of an article
16960before it will be expired, or the symbol @code{never} to specify that
16961articles should never be expired. If this parameter is not set,
16962@code{nnmaildir} falls back to the usual
16963@code{nnmail-expiry-wait}(@code{-function}) variables (the
16964@code{expiry-wait} group parameter overrides @code{nnmail-expiry-wait}
16965and makes @code{nnmail-expiry-wait-function} ineffective). If you
16966wanted a value of 3 days, you could use something like @code{[(* 3 24
1696760 60)]}; @code{nnmaildir} will evaluate the form and use the result.
16968An article's age is measured starting from the article file's
16969modification time. Normally, this is the same as the article's
16970delivery time, but editing an article makes it younger. Moving an
16971article (other than via expiry) may also make an article younger.
16972
16973@item expire-group
16974If this is set to a string such as a full Gnus group name, like
16975@example
16976"backend+server.address.string:group.name"
16977@end example
16978and if it is not the name of the same group that the parameter belongs
16979to, then articles will be moved to the specified group during expiry
16980before being deleted. @emph{If this is set to an @code{nnmaildir}
16981group, the article will be just as old in the destination group as it
16982was in the source group.} So be careful with @code{expire-age} in the
16983destination group. If this is set to the name of the same group that
16984the parameter belongs to, then the article is not expired at all. If
16985you use the vector form, the first element is evaluated once for each
16986article. So that form can refer to
16987@code{nnmaildir-article-file-name}, etc., to decide where to put the
16988article. @emph{Even if this parameter is not set, @code{nnmaildir}
16989does not fall back to the @code{expiry-target} group parameter or the
16990@code{nnmail-expiry-target} variable.}
16991
16992@item read-only
16993If this is set to @code{t}, @code{nnmaildir} will treat the articles
16994in this maildir as read-only. This means: articles are not renamed
16995from @file{new/} into @file{cur/}; articles are only found in
16996@file{new/}, not @file{cur/}; articles are never deleted; articles
16997cannot be edited. @file{new/} is expected to be a symlink to the
16998@file{new/} directory of another maildir---e.g., a system-wide mailbox
16999containing a mailing list of common interest. Everything in the
17000maildir outside @file{new/} is @emph{not} treated as read-only, so for
17001a shared mailbox, you do still need to set up your own maildir (or
17002have write permission to the shared mailbox); your maildir just won't
17003contain extra copies of the articles.
17004
17005@item directory-files
17006A function with the same interface as @code{directory-files}. It is
17007used to scan the directories in the maildir corresponding to this
17008group to find articles. The default is the function specified by the
17009server's @code{directory-files} parameter.
17010
17011@item distrust-Lines:
17012If non-@code{nil}, @code{nnmaildir} will always count the lines of an
17013article, rather than use the @code{Lines:} header field. If
17014@code{nil}, the header field will be used if present.
17015
17016@item always-marks
17017A list of mark symbols, such as @code{['(read expire)]}. Whenever
17018Gnus asks @code{nnmaildir} for article marks, @code{nnmaildir} will
17019say that all articles have these marks, regardless of whether the
17020marks stored in the filesystem say so. This is a proof-of-concept
17021feature that will probably be removed eventually; it ought to be done
17022in Gnus proper, or abandoned if it's not worthwhile.
17023
17024@item never-marks
17025A list of mark symbols, such as @code{['(tick expire)]}. Whenever
17026Gnus asks @code{nnmaildir} for article marks, @code{nnmaildir} will
17027say that no articles have these marks, regardless of whether the marks
17028stored in the filesystem say so. @code{never-marks} overrides
17029@code{always-marks}. This is a proof-of-concept feature that will
17030probably be removed eventually; it ought to be done in Gnus proper, or
17031abandoned if it's not worthwhile.
17032
17033@item nov-cache-size
17034An integer specifying the size of the @acronym{NOV} memory cache. To
17035speed things up, @code{nnmaildir} keeps @acronym{NOV} data in memory
17036for a limited number of articles in each group. (This is probably not
17037worthwhile, and will probably be removed in the future.) This
17038parameter's value is noticed only the first time a group is seen after
17039the server is opened---i.e., when you first start Gnus, typically.
17040The @acronym{NOV} cache is never resized until the server is closed
17041and reopened. The default is an estimate of the number of articles
17042that would be displayed in the summary buffer: a count of articles
17043that are either marked with @code{tick} or not marked with
17044@code{read}, plus a little extra.
17045@end table
17046
17047@subsubsection Article identification
17048Articles are stored in the @file{cur/} subdirectory of each maildir.
17049Each article file is named like @code{uniq:info}, where @code{uniq}
17050contains no colons. @code{nnmaildir} ignores, but preserves, the
17051@code{:info} part. (Other maildir readers typically use this part of
17052the filename to store marks.) The @code{uniq} part uniquely
17053identifies the article, and is used in various places in the
17054@file{.nnmaildir/} subdirectory of the maildir to store information
17055about the corresponding article. The full pathname of an article is
17056available in the variable @code{nnmaildir-article-file-name} after you
17057request the article in the summary buffer.
17058
17059@subsubsection NOV data
17060An article identified by @code{uniq} has its @acronym{NOV} data (used
17061to generate lines in the summary buffer) stored in
17062@code{.nnmaildir/nov/uniq}. There is no
17063@code{nnmaildir-generate-nov-databases} function. (There isn't much
17064need for it---an article's @acronym{NOV} data is updated automatically
17065when the article or @code{nnmail-extra-headers} has changed.) You can
17066force @code{nnmaildir} to regenerate the @acronym{NOV} data for a
17067single article simply by deleting the corresponding @acronym{NOV}
17068file, but @emph{beware}: this will also cause @code{nnmaildir} to
17069assign a new article number for this article, which may cause trouble
17070with @code{seen} marks, the Agent, and the cache.
17071
17072@subsubsection Article marks
17073An article identified by @code{uniq} is considered to have the mark
17074@code{flag} when the file @file{.nnmaildir/marks/flag/uniq} exists.
17075When Gnus asks @code{nnmaildir} for a group's marks, @code{nnmaildir}
17076looks for such files and reports the set of marks it finds. When Gnus
17077asks @code{nnmaildir} to store a new set of marks, @code{nnmaildir}
17078creates and deletes the corresponding files as needed. (Actually,
17079rather than create a new file for each mark, it just creates hard
17080links to @file{.nnmaildir/markfile}, to save inodes.)
17081
17082You can invent new marks by creating a new directory in
17083@file{.nnmaildir/marks/}. You can tar up a maildir and remove it from
17084your server, untar it later, and keep your marks. You can add and
17085remove marks yourself by creating and deleting mark files. If you do
17086this while Gnus is running and your @code{nnmaildir} server is open,
17087it's best to exit all summary buffers for @code{nnmaildir} groups and
17088type @kbd{s} in the group buffer first, and to type @kbd{g} or
17089@kbd{M-g} in the group buffer afterwards. Otherwise, Gnus might not
17090pick up the changes, and might undo them.
17091
17092
17093@node Mail Folders
17094@subsubsection Mail Folders
17095@cindex nnfolder
17096@cindex mbox folders
17097@cindex mail folders
17098
17099@code{nnfolder} is a back end for storing each mail group in a
17100separate file. Each file is in the standard Un*x mbox format.
17101@code{nnfolder} will add extra headers to keep track of article
17102numbers and arrival dates.
17103
17104@cindex self contained nnfolder servers
17105@cindex marks
17106When the marks file is used (which it is by default), @code{nnfolder}
17107servers have the property that you may backup them using @code{tar} or
17108similar, and later be able to restore them into Gnus (by adding the
17109proper @code{nnfolder} server) and have all your marks be preserved.
17110Marks for a group are usually stored in a file named as the mbox file
17111with @code{.mrk} concatenated to it (but see
17112@code{nnfolder-marks-file-suffix}) within the @code{nnfolder}
17113directory. Individual @code{nnfolder} groups are also possible to
17114backup, use @kbd{G m} to restore the group (after restoring the backup
17115into the @code{nnfolder} directory).
17116
17117Virtual server settings:
17118
17119@table @code
17120@item nnfolder-directory
17121@vindex nnfolder-directory
17122All the @code{nnfolder} mail boxes will be stored under this
17123directory. The default is the value of @code{message-directory}
17124(whose default is @file{~/Mail})
17125
17126@item nnfolder-active-file
17127@vindex nnfolder-active-file
17128The name of the active file. The default is @file{~/Mail/active}.
17129
17130@item nnfolder-newsgroups-file
17131@vindex nnfolder-newsgroups-file
17132The name of the group descriptions file. @xref{Newsgroups File
17133Format}. The default is @file{~/Mail/newsgroups}
17134
17135@item nnfolder-get-new-mail
17136@vindex nnfolder-get-new-mail
17137If non-@code{nil}, @code{nnfolder} will read incoming mail. The
17138default is @code{t}
17139
17140@item nnfolder-save-buffer-hook
17141@vindex nnfolder-save-buffer-hook
17142@cindex backup files
17143Hook run before saving the folders. Note that Emacs does the normal
17144backup renaming of files even with the @code{nnfolder} buffers. If
17145you wish to switch this off, you could say something like the
17146following in your @file{.emacs} file:
17147
17148@lisp
17149(defun turn-off-backup ()
17150 (set (make-local-variable 'backup-inhibited) t))
17151
17152(add-hook 'nnfolder-save-buffer-hook 'turn-off-backup)
17153@end lisp
17154
17155@item nnfolder-delete-mail-hook
17156@vindex nnfolder-delete-mail-hook
17157Hook run in a buffer narrowed to the message that is to be deleted.
17158This function can be used to copy the message to somewhere else, or to
17159extract some information from it before removing it.
17160
17161@item nnfolder-nov-is-evil
17162@vindex nnfolder-nov-is-evil
17163If non-@code{nil}, this back end will ignore any @acronym{NOV} files. The
17164default is @code{nil}.
17165
17166@item nnfolder-nov-file-suffix
17167@vindex nnfolder-nov-file-suffix
17168The extension for @acronym{NOV} files. The default is @file{.nov}.
17169
17170@item nnfolder-nov-directory
17171@vindex nnfolder-nov-directory
17172The directory where the @acronym{NOV} files should be stored. If
17173@code{nil}, @code{nnfolder-directory} is used.
17174
17175@item nnfolder-marks-is-evil
17176@vindex nnfolder-marks-is-evil
17177If non-@code{nil}, this back end will ignore any @sc{marks} files. The
17178default is @code{nil}.
17179
17180@item nnfolder-marks-file-suffix
17181@vindex nnfolder-marks-file-suffix
17182The extension for @sc{marks} files. The default is @file{.mrk}.
17183
17184@item nnfolder-marks-directory
17185@vindex nnfolder-marks-directory
17186The directory where the @sc{marks} files should be stored. If
17187@code{nil}, @code{nnfolder-directory} is used.
17188
17189@end table
17190
17191
17192@findex nnfolder-generate-active-file
17193@kindex M-x nnfolder-generate-active-file
17194If you have lots of @code{nnfolder}-like files you'd like to read with
17195@code{nnfolder}, you can use the @kbd{M-x nnfolder-generate-active-file}
17196command to make @code{nnfolder} aware of all likely files in
17197@code{nnfolder-directory}. This only works if you use long file names,
17198though.
17199
17200@node Comparing Mail Back Ends
17201@subsubsection Comparing Mail Back Ends
17202
17203First, just for terminology, the @dfn{back end} is the common word for a
17204low-level access method---a transport, if you will, by which something
17205is acquired. The sense is that one's mail has to come from somewhere,
17206and so selection of a suitable back end is required in order to get that
17207mail within spitting distance of Gnus.
17208
17209The same concept exists for Usenet itself: Though access to articles is
17210typically done by @acronym{NNTP} these days, once upon a midnight dreary, everyone
17211in the world got at Usenet by running a reader on the machine where the
17212articles lay (the machine which today we call an @acronym{NNTP} server), and
17213access was by the reader stepping into the articles' directory spool
17214area directly. One can still select between either the @code{nntp} or
17215@code{nnspool} back ends, to select between these methods, if one happens
17216actually to live on the server (or can see its spool directly, anyway,
17217via NFS).
17218
17219The goal in selecting a mail back end is to pick one which
17220simultaneously represents a suitable way of dealing with the original
17221format plus leaving mail in a form that is convenient to use in the
17222future. Here are some high and low points on each:
17223
17224@table @code
17225@item nnmbox
17226
17227UNIX systems have historically had a single, very common, and well-
17228defined format. All messages arrive in a single @dfn{spool file}, and
17229they are delineated by a line whose regular expression matches
17230@samp{^From_}. (My notational use of @samp{_} is to indicate a space,
17231to make it clear in this instance that this is not the RFC-specified
17232@samp{From:} header.) Because Emacs and therefore Gnus emanate
17233historically from the Unix environment, it is simplest if one does not
17234mess a great deal with the original mailbox format, so if one chooses
17235this back end, Gnus' primary activity in getting mail from the real spool
17236area to Gnus' preferred directory is simply to copy it, with no
17237(appreciable) format change in the process. It is the ``dumbest'' way
17238to move mail into availability in the Gnus environment. This makes it
17239fast to move into place, but slow to parse, when Gnus has to look at
17240what's where.
17241
17242@item nnbabyl
17243
17244Once upon a time, there was the DEC-10 and DEC-20, running operating
17245systems called TOPS and related things, and the usual (only?) mail
17246reading environment was a thing called Babyl. I don't know what format
17247was used for mail landing on the system, but Babyl had its own internal
17248format to which mail was converted, primarily involving creating a
17249spool-file-like entity with a scheme for inserting Babyl-specific
17250headers and status bits above the top of each message in the file.
17251Rmail was Emacs' first mail reader, it was written by Richard Stallman,
17252and Stallman came out of that TOPS/Babyl environment, so he wrote Rmail
17253to understand the mail files folks already had in existence. Gnus (and
17254VM, for that matter) continue to support this format because it's
17255perceived as having some good qualities in those mailer-specific
17256headers/status bits stuff. Rmail itself still exists as well, of
bc79f9ab
GM
17257course, and is still maintained within Emacs. Since Emacs 23, it
17258uses standard mbox format rather than Babyl.
4009494e
GM
17259
17260Both of the above forms leave your mail in a single file on your
17261file system, and they must parse that entire file each time you take a
17262look at your mail.
17263
17264@item nnml
17265
17266@code{nnml} is the back end which smells the most as though you were
17267actually operating with an @code{nnspool}-accessed Usenet system. (In
17268fact, I believe @code{nnml} actually derived from @code{nnspool} code,
17269lo these years ago.) One's mail is taken from the original spool file,
17270and is then cut up into individual message files, 1:1. It maintains a
17271Usenet-style active file (analogous to what one finds in an INN- or
17272CNews-based news system in (for instance) @file{/var/lib/news/active},
17273or what is returned via the @samp{NNTP LIST} verb) and also creates
17274@dfn{overview} files for efficient group entry, as has been defined for
17275@acronym{NNTP} servers for some years now. It is slower in mail-splitting,
17276due to the creation of lots of files, updates to the @code{nnml} active
17277file, and additions to overview files on a per-message basis, but it is
17278extremely fast on access because of what amounts to the indexing support
17279provided by the active file and overviews.
17280
17281@code{nnml} costs @dfn{inodes} in a big way; that is, it soaks up the
17282resource which defines available places in the file system to put new
17283files. Sysadmins take a dim view of heavy inode occupation within
17284tight, shared file systems. But if you live on a personal machine where
17285the file system is your own and space is not at a premium, @code{nnml}
17286wins big.
17287
17288It is also problematic using this back end if you are living in a
17289FAT16-based Windows world, since much space will be wasted on all these
17290tiny files.
17291
17292@item nnmh
17293
17294The Rand MH mail-reading system has been around UNIX systems for a very
17295long time; it operates by splitting one's spool file of messages into
17296individual files, but with little or no indexing support---@code{nnmh}
17297is considered to be semantically equivalent to ``@code{nnml} without
17298active file or overviews''. This is arguably the worst choice, because
17299one gets the slowness of individual file creation married to the
17300slowness of access parsing when learning what's new in one's groups.
17301
17302@item nnfolder
17303
17304Basically the effect of @code{nnfolder} is @code{nnmbox} (the first
17305method described above) on a per-group basis. That is, @code{nnmbox}
17306itself puts @emph{all} one's mail in one file; @code{nnfolder} provides a
17307little bit of optimization to this so that each of one's mail groups has
17308a Unix mail box file. It's faster than @code{nnmbox} because each group
17309can be parsed separately, and still provides the simple Unix mail box
17310format requiring minimal effort in moving the mail around. In addition,
17311it maintains an ``active'' file making it much faster for Gnus to figure
17312out how many messages there are in each separate group.
17313
17314If you have groups that are expected to have a massive amount of
17315messages, @code{nnfolder} is not the best choice, but if you receive
17316only a moderate amount of mail, @code{nnfolder} is probably the most
17317friendly mail back end all over.
17318
17319@item nnmaildir
17320
17321For configuring expiry and other things, @code{nnmaildir} uses
17322incompatible group parameters, slightly different from those of other
17323mail back ends.
17324
17325@code{nnmaildir} is largely similar to @code{nnml}, with some notable
17326differences. Each message is stored in a separate file, but the
17327filename is unrelated to the article number in Gnus. @code{nnmaildir}
17328also stores the equivalent of @code{nnml}'s overview files in one file
17329per article, so it uses about twice as many inodes as @code{nnml}. (Use
17330@code{df -i} to see how plentiful your inode supply is.) If this slows
17331you down or takes up very much space, consider switching to
17332@uref{http://www.namesys.com/, ReiserFS} or another non-block-structured
17333file system.
17334
17335Since maildirs don't require locking for delivery, the maildirs you use
17336as groups can also be the maildirs your mail is directly delivered to.
17337This means you can skip Gnus' mail splitting if your mail is already
17338organized into different mailboxes during delivery. A @code{directory}
17339entry in @code{mail-sources} would have a similar effect, but would
17340require one set of mailboxes for spooling deliveries (in mbox format,
17341thus damaging message bodies), and another set to be used as groups (in
17342whatever format you like). A maildir has a built-in spool, in the
17343@code{new/} subdirectory. Beware that currently, mail moved from
17344@code{new/} to @code{cur/} instead of via mail splitting will not
17345undergo treatment such as duplicate checking.
17346
17347@code{nnmaildir} stores article marks for a given group in the
17348corresponding maildir, in a way designed so that it's easy to manipulate
17349them from outside Gnus. You can tar up a maildir, unpack it somewhere
17350else, and still have your marks. @code{nnml} also stores marks, but
17351it's not as easy to work with them from outside Gnus as with
17352@code{nnmaildir}.
17353
17354@code{nnmaildir} uses a significant amount of memory to speed things up.
17355(It keeps in memory some of the things that @code{nnml} stores in files
17356and that @code{nnmh} repeatedly parses out of message files.) If this
17357is a problem for you, you can set the @code{nov-cache-size} group
17358parameter to something small (0 would probably not work, but 1 probably
17359would) to make it use less memory. This caching will probably be
17360removed in the future.
17361
17362Startup is likely to be slower with @code{nnmaildir} than with other
17363back ends. Everything else is likely to be faster, depending in part
17364on your file system.
17365
17366@code{nnmaildir} does not use @code{nnoo}, so you cannot use @code{nnoo}
17367to write an @code{nnmaildir}-derived back end.
17368
17369@end table
17370
17371
17372@node Browsing the Web
17373@section Browsing the Web
17374@cindex web
17375@cindex browsing the web
17376@cindex www
17377@cindex http
17378
17379Web-based discussion forums are getting more and more popular. On many
17380subjects, the web-based forums have become the most important forums,
17381eclipsing the importance of mailing lists and news groups. The reason
17382is easy to understand---they are friendly to new users; you just point
17383and click, and there's the discussion. With mailing lists, you have to
17384go through a cumbersome subscription procedure, and most people don't
17385even know what a news group is.
17386
17387The problem with this scenario is that web browsers are not very good at
17388being newsreaders. They do not keep track of what articles you've read;
17389they do not allow you to score on subjects you're interested in; they do
17390not allow off-line browsing; they require you to click around and drive
17391you mad in the end.
17392
17393So---if web browsers suck at reading discussion forums, why not use Gnus
17394to do it instead?
17395
17396Gnus has been getting a bit of a collection of back ends for providing
17397interfaces to these sources.
17398
17399@menu
17400* Archiving Mail::
17401* Web Searches:: Creating groups from articles that match a string.
4009494e
GM
17402* RSS:: Reading RDF site summary.
17403* Customizing W3:: Doing stuff to Emacs/W3 from Gnus.
17404@end menu
17405
17406All the web sources require Emacs/W3 and the url library or those
17407alternatives to work.
17408
17409The main caveat with all these web sources is that they probably won't
17410work for a very long time. Gleaning information from the @acronym{HTML} data
17411is guesswork at best, and when the layout is altered, the Gnus back end
17412will fail. If you have reasonably new versions of these back ends,
17413though, you should be ok.
17414
17415One thing all these Web methods have in common is that the Web sources
17416are often down, unavailable or just plain too slow to be fun. In those
17417cases, it makes a lot of sense to let the Gnus Agent (@pxref{Gnus
17418Unplugged}) handle downloading articles, and then you can read them at
17419leisure from your local disk. No more World Wide Wait for you.
17420
17421@node Archiving Mail
17422@subsection Archiving Mail
17423@cindex archiving mail
17424@cindex backup of mail
17425
17426Some of the back ends, notably @code{nnml}, @code{nnfolder}, and
17427@code{nnmaildir}, now actually store the article marks with each group.
17428For these servers, archiving and restoring a group while preserving
17429marks is fairly simple.
17430
17431(Preserving the group level and group parameters as well still
17432requires ritual dancing and sacrifices to the @file{.newsrc.eld} deity
17433though.)
17434
17435To archive an entire @code{nnml}, @code{nnfolder}, or @code{nnmaildir}
17436server, take a recursive copy of the server directory. There is no need
17437to shut down Gnus, so archiving may be invoked by @code{cron} or
17438similar. You restore the data by restoring the directory tree, and
17439adding a server definition pointing to that directory in Gnus. The
17440@ref{Article Backlog}, @ref{Asynchronous Fetching} and other things
17441might interfere with overwriting data, so you may want to shut down Gnus
17442before you restore the data.
17443
17444It is also possible to archive individual @code{nnml},
17445@code{nnfolder}, or @code{nnmaildir} groups, while preserving marks.
17446For @code{nnml} or @code{nnmaildir}, you copy all files in the group's
17447directory. For @code{nnfolder} you need to copy both the base folder
17448file itself (@file{FOO}, say), and the marks file (@file{FOO.mrk} in
17449this example). Restoring the group is done with @kbd{G m} from the Group
17450buffer. The last step makes Gnus notice the new directory.
17451@code{nnmaildir} notices the new directory automatically, so @kbd{G m}
17452is unnecessary in that case.
17453
17454@node Web Searches
17455@subsection Web Searches
17456@cindex nnweb
17457@cindex Google
17458@cindex dejanews
17459@cindex gmane
17460@cindex Usenet searches
17461@cindex searching the Usenet
17462
17463It's, like, too neat to search the Usenet for articles that match a
17464string, but it, like, totally @emph{sucks}, like, totally, to use one of
17465those, like, Web browsers, and you, like, have to, rilly, like, look at
17466the commercials, so, like, with Gnus you can do @emph{rad}, rilly,
17467searches without having to use a browser.
17468
17469The @code{nnweb} back end allows an easy interface to the mighty search
17470engine. You create an @code{nnweb} group, enter a search pattern, and
17471then enter the group and read the articles like you would any normal
17472group. The @kbd{G w} command in the group buffer (@pxref{Foreign
17473Groups}) will do this in an easy-to-use fashion.
17474
17475@code{nnweb} groups don't really lend themselves to being solid
17476groups---they have a very fleeting idea of article numbers. In fact,
17477each time you enter an @code{nnweb} group (not even changing the search
17478pattern), you are likely to get the articles ordered in a different
17479manner. Not even using duplicate suppression (@pxref{Duplicate
17480Suppression}) will help, since @code{nnweb} doesn't even know the
17481@code{Message-ID} of the articles before reading them using some search
17482engines (Google, for instance). The only possible way to keep track
17483of which articles you've read is by scoring on the @code{Date}
17484header---mark all articles posted before the last date you read the
17485group as read.
17486
17487If the search engine changes its output substantially, @code{nnweb}
17488won't be able to parse it and will fail. One could hardly fault the Web
01c52d31 17489providers if they were to do this---their @emph{raison d'@^etre} is to
4009494e
GM
17490make money off of advertisements, not to provide services to the
17491community. Since @code{nnweb} washes the ads off all the articles, one
17492might think that the providers might be somewhat miffed. We'll see.
17493
17494You must have the @code{url} and @code{W3} package or those alternatives
17495(try @code{customize-group} on the @samp{mm-url} variable group)
17496installed to be able to use @code{nnweb}.
17497
17498Virtual server variables:
17499
17500@table @code
17501@item nnweb-type
17502@vindex nnweb-type
17503What search engine type is being used. The currently supported types
17504are @code{google}, @code{dejanews}, and @code{gmane}. Note that
17505@code{dejanews} is an alias to @code{google}.
17506
17507@item nnweb-search
17508@vindex nnweb-search
17509The search string to feed to the search engine.
17510
17511@item nnweb-max-hits
17512@vindex nnweb-max-hits
17513Advisory maximum number of hits per search to display. The default is
17514999.
17515
17516@item nnweb-type-definition
17517@vindex nnweb-type-definition
17518Type-to-definition alist. This alist says what @code{nnweb} should do
17519with the various search engine types. The following elements must be
17520present:
17521
17522@table @code
17523@item article
17524Function to decode the article and provide something that Gnus
17525understands.
17526
17527@item map
17528Function to create an article number to message header and URL alist.
17529
17530@item search
17531Function to send the search string to the search engine.
17532
17533@item address
17534The address the aforementioned function should send the search string
17535to.
17536
17537@item id
17538Format string URL to fetch an article by @code{Message-ID}.
17539@end table
17540
17541@end table
17542
17543
4009494e
GM
17544@node RSS
17545@subsection RSS
17546@cindex nnrss
17547@cindex RSS
17548
17549Some web sites have an RDF Site Summary (@acronym{RSS}).
17550@acronym{RSS} is a format for summarizing headlines from news related
17551sites (such as BBC or CNN). But basically anything list-like can be
17552presented as an @acronym{RSS} feed: weblogs, changelogs or recent
17553changes to a wiki (e.g. @url{http://cliki.net/recent-changes.rdf}).
17554
17555@acronym{RSS} has a quite regular and nice interface, and it's
17556possible to get the information Gnus needs to keep groups updated.
17557
17558Note: you had better use Emacs which supports the @code{utf-8} coding
17559system because @acronym{RSS} uses UTF-8 for encoding non-@acronym{ASCII}
17560text by default. It is also used by default for non-@acronym{ASCII}
17561group names.
17562
17563@kindex G R (Group)
17564Use @kbd{G R} from the group buffer to subscribe to a feed---you will be
17565prompted for the location, the title and the description of the feed.
17566The title, which allows any characters, will be used for the group name
17567and the name of the group data file. The description can be omitted.
17568
17569An easy way to get started with @code{nnrss} is to say something like
17570the following in the group buffer: @kbd{B nnrss RET RET y}, then
17571subscribe to groups.
17572
17573The @code{nnrss} back end saves the group data file in
17574@code{nnrss-directory} (see below) for each @code{nnrss} group. File
17575names containing non-@acronym{ASCII} characters will be encoded by the
17576coding system specified with the @code{nnmail-pathname-coding-system}
26b9f88d
MB
17577variable or other. Also @xref{Non-ASCII Group Names}, for more
17578information.
4009494e
GM
17579
17580The @code{nnrss} back end generates @samp{multipart/alternative}
17581@acronym{MIME} articles in which each contains a @samp{text/plain} part
17582and a @samp{text/html} part.
17583
17584@cindex OPML
17585You can also use the following commands to import and export your
17586subscriptions from a file in @acronym{OPML} format (Outline Processor
17587Markup Language).
17588
17589@defun nnrss-opml-import file
17590Prompt for an @acronym{OPML} file, and subscribe to each feed in the
17591file.
17592@end defun
17593
17594@defun nnrss-opml-export
17595Write your current @acronym{RSS} subscriptions to a buffer in
17596@acronym{OPML} format.
17597@end defun
17598
17599The following @code{nnrss} variables can be altered:
17600
17601@table @code
17602@item nnrss-directory
17603@vindex nnrss-directory
17604The directory where @code{nnrss} stores its files. The default is
17605@file{~/News/rss/}.
17606
17607@item nnrss-file-coding-system
17608@vindex nnrss-file-coding-system
17609The coding system used when reading and writing the @code{nnrss} groups
17610data files. The default is the value of
17611@code{mm-universal-coding-system} (which defaults to @code{emacs-mule}
17612in Emacs or @code{escape-quoted} in XEmacs).
17613
01c52d31
MB
17614@item nnrss-ignore-article-fields
17615@vindex nnrss-ignore-article-fields
17616Some feeds update constantly article fields during their publications,
17617e.g. to indicate the number of comments. However, if there is
17618a difference between the local article and the distant one, the latter
17619is considered to be new. To avoid this and discard some fields, set this
17620variable to the list of fields to be ignored. The default is
17621@code{'(slash:comments)}.
17622
4009494e
GM
17623@item nnrss-use-local
17624@vindex nnrss-use-local
17625@findex nnrss-generate-download-script
17626If you set @code{nnrss-use-local} to @code{t}, @code{nnrss} will read
17627the feeds from local files in @code{nnrss-directory}. You can use
17628the command @code{nnrss-generate-download-script} to generate a
17629download script using @command{wget}.
17630
17631@item nnrss-wash-html-in-text-plain-parts
17632Non-@code{nil} means that @code{nnrss} renders text in @samp{text/plain}
17633parts as @acronym{HTML}. The function specified by the
17634@code{mm-text-html-renderer} variable (@pxref{Display Customization,
17635,Display Customization, emacs-mime, The Emacs MIME Manual}) will be used
17636to render text. If it is @code{nil}, which is the default, text will
17637simply be folded. Leave it @code{nil} if you prefer to see
17638@samp{text/html} parts.
17639@end table
17640
17641The following code may be helpful, if you want to show the description in
17642the summary buffer.
17643
17644@lisp
17645(add-to-list 'nnmail-extra-headers nnrss-description-field)
17646(setq gnus-summary-line-format "%U%R%z%I%(%[%4L: %-15,15f%]%) %s%uX\n")
17647
17648(defun gnus-user-format-function-X (header)
17649 (let ((descr
17650 (assq nnrss-description-field (mail-header-extra header))))
17651 (if descr (concat "\n\t" (cdr descr)) "")))
17652@end lisp
17653
17654The following code may be useful to open an nnrss url directly from the
17655summary buffer.
17656
17657@lisp
17658(require 'browse-url)
17659
01c52d31 17660(defun browse-nnrss-url (arg)
4009494e
GM
17661 (interactive "p")
17662 (let ((url (assq nnrss-url-field
17663 (mail-header-extra
17664 (gnus-data-header
17665 (assq (gnus-summary-article-number)
17666 gnus-newsgroup-data))))))
17667 (if url
17668 (progn
17669 (browse-url (cdr url))
17670 (gnus-summary-mark-as-read-forward 1))
17671 (gnus-summary-scroll-up arg))))
17672
17673(eval-after-load "gnus"
17674 #'(define-key gnus-summary-mode-map
17675 (kbd "<RET>") 'browse-nnrss-url))
17676(add-to-list 'nnmail-extra-headers nnrss-url-field)
17677@end lisp
17678
9b3ebcb6 17679Even if you have added @samp{text/html} to the
4009494e
GM
17680@code{mm-discouraged-alternatives} variable (@pxref{Display
17681Customization, ,Display Customization, emacs-mime, The Emacs MIME
17682Manual}) since you don't want to see @acronym{HTML} parts, it might be
17683more useful especially in @code{nnrss} groups to display
17684@samp{text/html} parts. Here's an example of setting
17685@code{mm-discouraged-alternatives} as a group parameter (@pxref{Group
17686Parameters}) in order to display @samp{text/html} parts only in
17687@code{nnrss} groups:
17688
17689@lisp
17690;; @r{Set the default value of @code{mm-discouraged-alternatives}.}
17691(eval-after-load "gnus-sum"
17692 '(add-to-list
17693 'gnus-newsgroup-variables
17694 '(mm-discouraged-alternatives
17695 . '("text/html" "image/.*"))))
17696
17697;; @r{Display @samp{text/html} parts in @code{nnrss} groups.}
17698(add-to-list
17699 'gnus-parameters
17700 '("\\`nnrss:" (mm-discouraged-alternatives nil)))
17701@end lisp
17702
17703
17704@node Customizing W3
17705@subsection Customizing W3
17706@cindex W3
17707@cindex html
17708@cindex url
17709@cindex Netscape
17710
17711Gnus uses the url library to fetch web pages and Emacs/W3 (or those
17712alternatives) to display web pages. Emacs/W3 is documented in its own
17713manual, but there are some things that may be more relevant for Gnus
17714users.
17715
17716For instance, a common question is how to make Emacs/W3 follow links
17717using the @code{browse-url} functions (which will call some external web
17718browser like Netscape). Here's one way:
17719
17720@lisp
17721(eval-after-load "w3"
17722 '(progn
17723 (fset 'w3-fetch-orig (symbol-function 'w3-fetch))
17724 (defun w3-fetch (&optional url target)
17725 (interactive (list (w3-read-url-with-default)))
17726 (if (eq major-mode 'gnus-article-mode)
17727 (browse-url url)
17728 (w3-fetch-orig url target)))))
17729@end lisp
17730
17731Put that in your @file{.emacs} file, and hitting links in W3-rendered
17732@acronym{HTML} in the Gnus article buffers will use @code{browse-url} to
17733follow the link.
17734
17735
17736@node IMAP
17737@section IMAP
17738@cindex nnimap
17739@cindex @acronym{IMAP}
17740
17741@acronym{IMAP} is a network protocol for reading mail (or news, or @dots{}),
17742think of it as a modernized @acronym{NNTP}. Connecting to a @acronym{IMAP}
17743server is much similar to connecting to a news server, you just
17744specify the network address of the server.
17745
17746@acronym{IMAP} has two properties. First, @acronym{IMAP} can do
17747everything that @acronym{POP} can, it can hence be viewed as a
17748@acronym{POP++}. Secondly, @acronym{IMAP} is a mail storage protocol,
17749similar to @acronym{NNTP} being a news storage protocol---however,
17750@acronym{IMAP} offers more features than @acronym{NNTP} because news
17751is more or less read-only whereas mail is read-write.
17752
17753If you want to use @acronym{IMAP} as a @acronym{POP++}, use an imap
17754entry in @code{mail-sources}. With this, Gnus will fetch mails from
17755the @acronym{IMAP} server and store them on the local disk. This is
17756not the usage described in this section---@xref{Mail Sources}.
17757
17758If you want to use @acronym{IMAP} as a mail storage protocol, use an nnimap
17759entry in @code{gnus-secondary-select-methods}. With this, Gnus will
17760manipulate mails stored on the @acronym{IMAP} server. This is the kind of
17761usage explained in this section.
17762
17763A server configuration in @file{~/.gnus.el} with a few @acronym{IMAP}
17764servers might look something like the following. (Note that for
17765@acronym{TLS}/@acronym{SSL}, you need external programs and libraries,
17766see below.)
17767
17768@lisp
17769(setq gnus-secondary-select-methods
17770 '((nnimap "simpleserver") ; @r{no special configuration}
17771 ; @r{perhaps a ssh port forwarded server:}
17772 (nnimap "dolk"
17773 (nnimap-address "localhost")
17774 (nnimap-server-port 1430))
17775 ; @r{a UW server running on localhost}
17776 (nnimap "barbar"
17777 (nnimap-server-port 143)
17778 (nnimap-address "localhost")
17779 (nnimap-list-pattern ("INBOX" "mail/*")))
17780 ; @r{anonymous public cyrus server:}
17781 (nnimap "cyrus.andrew.cmu.edu"
17782 (nnimap-authenticator anonymous)
17783 (nnimap-list-pattern "archive.*")
17784 (nnimap-stream network))
17785 ; @r{a ssl server on a non-standard port:}
17786 (nnimap "vic20"
17787 (nnimap-address "vic20.somewhere.com")
17788 (nnimap-server-port 9930)
17789 (nnimap-stream ssl))))
17790@end lisp
17791
17792After defining the new server, you can subscribe to groups on the
17793server using normal Gnus commands such as @kbd{U} in the Group Buffer
17794(@pxref{Subscription Commands}) or via the Server Buffer
17795(@pxref{Server Buffer}).
17796
17797The following variables can be used to create a virtual @code{nnimap}
17798server:
17799
17800@table @code
17801
17802@item nnimap-address
17803@vindex nnimap-address
17804
17805The address of the remote @acronym{IMAP} server. Defaults to the virtual
17806server name if not specified.
17807
17808@item nnimap-server-port
17809@vindex nnimap-server-port
17810Port on server to contact. Defaults to port 143, or 993 for @acronym{TLS}/@acronym{SSL}.
17811
17812Note that this should be an integer, example server specification:
17813
17814@lisp
17815(nnimap "mail.server.com"
17816 (nnimap-server-port 4711))
17817@end lisp
17818
17819@item nnimap-list-pattern
17820@vindex nnimap-list-pattern
17821String or list of strings of mailboxes to limit available groups to.
17822This is used when the server has very many mailboxes and you're only
17823interested in a few---some servers export your home directory via
17824@acronym{IMAP}, you'll probably want to limit the mailboxes to those in
17825@file{~/Mail/*} then.
17826
17827The string can also be a cons of REFERENCE and the string as above, what
17828REFERENCE is used for is server specific, but on the University of
17829Washington server it's a directory that will be concatenated with the
17830mailbox.
17831
17832Example server specification:
17833
17834@lisp
17835(nnimap "mail.server.com"
17836 (nnimap-list-pattern ("INBOX" "Mail/*" "alt.sex.*"
17837 ("~friend/Mail/" . "list/*"))))
17838@end lisp
17839
17840@item nnimap-stream
17841@vindex nnimap-stream
17842The type of stream used to connect to your server. By default, nnimap
17843will detect and automatically use all of the below, with the exception
17844of @acronym{TLS}/@acronym{SSL}. (@acronym{IMAP} over
17845@acronym{TLS}/@acronym{SSL} is being replaced by STARTTLS, which can
17846be automatically detected, but it's not widely deployed yet.)
17847
17848Example server specification:
17849
17850@lisp
17851(nnimap "mail.server.com"
17852 (nnimap-stream ssl))
17853@end lisp
17854
17855Please note that the value of @code{nnimap-stream} is a symbol!
17856
17857@itemize @bullet
17858@item
17859@dfn{gssapi:} Connect with GSSAPI (usually Kerberos 5). Requires the
17860@samp{gsasl} or @samp{imtest} program.
17861@item
17862@dfn{kerberos4:} Connect with Kerberos 4. Requires the @samp{imtest} program.
17863@item
17864@dfn{starttls:} Connect via the STARTTLS extension (similar to
17865@acronym{TLS}/@acronym{SSL}). Requires the external library @samp{starttls.el} and program
17866@samp{starttls}.
17867@item
17868@dfn{tls:} Connect through @acronym{TLS}. Requires GNUTLS (the program
17869@samp{gnutls-cli}).
17870@item
17871@dfn{ssl:} Connect through @acronym{SSL}. Requires OpenSSL (the program
17872@samp{openssl}) or SSLeay (@samp{s_client}).
17873@item
17874@dfn{shell:} Use a shell command to start @acronym{IMAP} connection.
17875@item
17876@dfn{network:} Plain, TCP/IP network connection.
17877@end itemize
17878
17879@vindex imap-kerberos4-program
17880The @samp{imtest} program is shipped with Cyrus IMAPD. If you're
17881using @samp{imtest} from Cyrus IMAPD < 2.0.14 (which includes version
178821.5.x and 1.6.x) you need to frob @code{imap-process-connection-type}
17883to make @code{imap.el} use a pty instead of a pipe when communicating
17884with @samp{imtest}. You will then suffer from a line length
17885restrictions on @acronym{IMAP} commands, which might make Gnus seem to hang
17886indefinitely if you have many articles in a mailbox. The variable
17887@code{imap-kerberos4-program} contain parameters to pass to the imtest
17888program.
17889
17890For @acronym{TLS} connection, the @code{gnutls-cli} program from GNUTLS is
17891needed. It is available from
17892@uref{http://www.gnu.org/software/gnutls/}.
17893
17894@vindex imap-gssapi-program
17895This parameter specifies a list of command lines that invoke a GSSAPI
17896authenticated @acronym{IMAP} stream in a subshell. They are tried
17897sequentially until a connection is made, or the list has been
17898exhausted. By default, @samp{gsasl} from GNU SASL, available from
17899@uref{http://www.gnu.org/software/gsasl/}, and the @samp{imtest}
17900program from Cyrus IMAPD (see @code{imap-kerberos4-program}), are
17901tried.
17902
17903@vindex imap-ssl-program
17904For @acronym{SSL} connections, the OpenSSL program is available from
17905@uref{http://www.openssl.org/}. OpenSSL was formerly known as SSLeay,
17906and nnimap support it too---although the most recent versions of
17907SSLeay, 0.9.x, are known to have serious bugs making it
17908useless. Earlier versions, especially 0.8.x, of SSLeay are known to
17909work. The variable @code{imap-ssl-program} contain parameters to pass
17910to OpenSSL/SSLeay.
17911
17912@vindex imap-shell-program
17913@vindex imap-shell-host
01c52d31
MB
17914For @acronym{IMAP} connections using the @code{shell} stream, the
17915variable @code{imap-shell-program} specify what program to call. Make
17916sure nothing is interfering with the output of the program, e.g., don't
17917forget to redirect the error output to the void.
4009494e
GM
17918
17919@item nnimap-authenticator
17920@vindex nnimap-authenticator
17921
17922The authenticator used to connect to the server. By default, nnimap
17923will use the most secure authenticator your server is capable of.
17924
17925Example server specification:
17926
17927@lisp
17928(nnimap "mail.server.com"
17929 (nnimap-authenticator anonymous))
17930@end lisp
17931
17932Please note that the value of @code{nnimap-authenticator} is a symbol!
17933
17934@itemize @bullet
17935@item
17936@dfn{gssapi:} GSSAPI (usually kerberos 5) authentication. Requires
17937external program @code{gsasl} or @code{imtest}.
17938@item
17939@dfn{kerberos4:} Kerberos 4 authentication. Requires external program
17940@code{imtest}.
17941@item
17942@dfn{digest-md5:} Encrypted username/password via DIGEST-MD5. Requires
17943external library @code{digest-md5.el}.
17944@item
17945@dfn{cram-md5:} Encrypted username/password via CRAM-MD5.
17946@item
17947@dfn{login:} Plain-text username/password via LOGIN.
17948@item
17949@dfn{anonymous:} Login as ``anonymous'', supplying your email address as password.
17950@end itemize
17951
17952@item nnimap-expunge-on-close
17953@cindex expunging
17954@vindex nnimap-expunge-on-close
17955Unlike Parmenides the @acronym{IMAP} designers have decided things that
17956don't exist actually do exist. More specifically, @acronym{IMAP} has
17957this concept of marking articles @code{Deleted} which doesn't actually
17958delete them, and this (marking them @code{Deleted}, that is) is what
17959nnimap does when you delete an article in Gnus (with @kbd{B DEL} or
17960similar).
17961
17962Since the articles aren't really removed when we mark them with the
17963@code{Deleted} flag we'll need a way to actually delete them. Feel like
17964running in circles yet?
17965
17966Traditionally, nnimap has removed all articles marked as @code{Deleted}
17967when closing a mailbox but this is now configurable by this server
17968variable.
17969
17970The possible options are:
17971
17972@table @code
17973
17974@item always
17975The default behavior, delete all articles marked as ``Deleted'' when
17976closing a mailbox.
17977@item never
17978Never actually delete articles. Currently there is no way of showing
17979the articles marked for deletion in nnimap, but other @acronym{IMAP} clients
17980may allow you to do this. If you ever want to run the EXPUNGE command
17981manually, @xref{Expunging mailboxes}.
17982@item ask
17983When closing mailboxes, nnimap will ask if you wish to expunge deleted
17984articles or not.
17985
17986@end table
17987
17988@item nnimap-importantize-dormant
17989@vindex nnimap-importantize-dormant
17990
17991If non-@code{nil} (the default), marks dormant articles as ticked (as
17992well), for other @acronym{IMAP} clients. Within Gnus, dormant articles will
17993naturally still (only) be marked as dormant. This is to make dormant
17994articles stand out, just like ticked articles, in other @acronym{IMAP}
17995clients. (In other words, Gnus has two ``Tick'' marks and @acronym{IMAP}
17996has only one.)
17997
17998Probably the only reason for frobbing this would be if you're trying
17999enable per-user persistent dormant flags, using something like:
18000
18001@lisp
18002(setcdr (assq 'dormant nnimap-mark-to-flag-alist)
18003 (format "gnus-dormant-%s" (user-login-name)))
18004(setcdr (assq 'dormant nnimap-mark-to-predicate-alist)
18005 (format "KEYWORD gnus-dormant-%s" (user-login-name)))
18006@end lisp
18007
18008In this case, you would not want the per-user dormant flag showing up
18009as ticked for other users.
18010
18011@item nnimap-expunge-search-string
18012@cindex expunging
18013@vindex nnimap-expunge-search-string
18014@cindex expiring @acronym{IMAP} mail
18015
18016This variable contain the @acronym{IMAP} search command sent to server when
18017searching for articles eligible for expiring. The default is
18018@code{"UID %s NOT SINCE %s"}, where the first @code{%s} is replaced by
18019UID set and the second @code{%s} is replaced by a date.
18020
18021Probably the only useful value to change this to is
18022@code{"UID %s NOT SENTSINCE %s"}, which makes nnimap use the Date: in
18023messages instead of the internal article date. See section 6.4.4 of
18024RFC 2060 for more information on valid strings.
18025
18026However, if @code{nnimap-search-uids-not-since-is-evil}
18027is true, this variable has no effect since the search logic
18028is reversed, as described below.
18029
18030@item nnimap-authinfo-file
18031@vindex nnimap-authinfo-file
18032
18033A file containing credentials used to log in on servers. The format is
18034(almost) the same as the @code{ftp} @file{~/.netrc} file. See the
18035variable @code{nntp-authinfo-file} for exact syntax; also see
18036@ref{NNTP}. An example of an .authinfo line for an IMAP server, is:
18037
18038@example
18039machine students.uio.no login larsi password geheimnis port imap
18040@end example
18041
18042Note that it should be @code{port imap}, or @code{port 143}, if you
18043use a @code{nnimap-stream} of @code{tls} or @code{ssl}, even if the
18044actual port number used is port 993 for secured IMAP. For
18045convenience, Gnus will accept @code{port imaps} as a synonym of
18046@code{port imap}.
18047
18048@item nnimap-need-unselect-to-notice-new-mail
18049@vindex nnimap-need-unselect-to-notice-new-mail
18050
18051Unselect mailboxes before looking for new mail in them. Some servers
18052seem to need this under some circumstances; it was reported that
18053Courier 1.7.1 did.
18054
18055@item nnimap-nov-is-evil
18056@vindex nnimap-nov-is-evil
18057@cindex Courier @acronym{IMAP} server
18058@cindex @acronym{NOV}
18059
18060Never generate or use a local @acronym{NOV} database. Defaults to the
18061value of @code{gnus-agent}.
18062
18063Using a @acronym{NOV} database usually makes header fetching much
18064faster, but it uses the @code{UID SEARCH UID} command, which is very
18065slow on some servers (notably some versions of Courier). Since the Gnus
18066Agent caches the information in the @acronym{NOV} database without using
18067the slow command, this variable defaults to true if the Agent is in use,
18068and false otherwise.
18069
18070@item nnimap-search-uids-not-since-is-evil
18071@vindex nnimap-search-uids-not-since-is-evil
18072@cindex Courier @acronym{IMAP} server
18073@cindex expiring @acronym{IMAP} mail
18074
18075Avoid the @code{UID SEARCH UID @var{message numbers} NOT SINCE
18076@var{date}} command, which is slow on some @acronym{IMAP} servers
18077(notably, some versions of Courier). Instead, use @code{UID SEARCH SINCE
18078@var{date}} and prune the list of expirable articles within Gnus.
18079
18080When Gnus expires your mail (@pxref{Expiring Mail}), it starts with a
18081list of expirable articles and asks the IMAP server questions like ``Of
18082these articles, which ones are older than a week?'' While this seems
18083like a perfectly reasonable question, some IMAP servers take a long time
18084to answer it, since they seemingly go looking into every old article to
18085see if it is one of the expirable ones. Curiously, the question ``Of
18086@emph{all} articles, which ones are newer than a week?'' seems to be
18087much faster to answer, so setting this variable causes Gnus to ask this
18088question and figure out the answer to the real question itself.
18089
18090This problem can really sneak up on you: when you first configure Gnus,
18091everything works fine, but once you accumulate a couple thousand
18092messages, you start cursing Gnus for being so slow. On the other hand,
18093if you get a lot of email within a week, setting this variable will
18094cause a lot of network traffic between Gnus and the IMAP server.
18095
01c52d31
MB
18096@item nnimap-logout-timeout
18097@vindex nnimap-logout-timeout
18098
18099There is a case where a connection to a @acronym{IMAP} server is unable
18100to close, when connecting to the server via a certain kind of network,
18101e.g. @acronym{VPN}. In that case, it will be observed that a connection
18102between Emacs and the local network looks alive even if the server has
18103closed a connection for some reason (typically, a timeout).
18104Consequently, Emacs continues waiting for a response from the server for
18105the @code{LOGOUT} command that Emacs sent, or hangs in other words. If
18106you are in such a network, setting this variable to a number of seconds
18107will be helpful. If it is set, a hung connection will be closed
18108forcibly, after this number of seconds from the time Emacs sends the
18109@code{LOGOUT} command. It should not be too small value but too large
18110value will be inconvenient too. Perhaps the value 1.0 will be a good
18111candidate but it might be worth trying some other values.
18112
18113Example server specification:
18114
18115@lisp
18116(nnimap "mail.server.com"
18117 (nnimap-logout-timeout 1.0))
18118@end lisp
18119
4009494e
GM
18120@end table
18121
18122@menu
18123* Splitting in IMAP:: Splitting mail with nnimap.
18124* Expiring in IMAP:: Expiring mail with nnimap.
18125* Editing IMAP ACLs:: Limiting/enabling other users access to a mailbox.
18126* Expunging mailboxes:: Equivalent of a ``compress mailbox'' button.
18127* A note on namespaces:: How to (not) use @acronym{IMAP} namespace in Gnus.
18128* Debugging IMAP:: What to do when things don't work.
18129@end menu
18130
18131
18132
18133@node Splitting in IMAP
18134@subsection Splitting in IMAP
18135@cindex splitting imap mail
18136
18137Splitting is something Gnus users have loved and used for years, and now
18138the rest of the world is catching up. Yeah, dream on, not many
18139@acronym{IMAP} servers have server side splitting and those that have
18140splitting seem to use some non-standard protocol. This means that
18141@acronym{IMAP} support for Gnus has to do its own splitting.
18142
18143And it does.
18144
18145(Incidentally, people seem to have been dreaming on, and Sieve has
18146gaining a market share and is supported by several IMAP servers.
18147Fortunately, Gnus support it too, @xref{Sieve Commands}.)
18148
18149Here are the variables of interest:
18150
18151@table @code
18152
18153@item nnimap-split-crosspost
18154@cindex splitting, crosspost
18155@cindex crosspost
18156@vindex nnimap-split-crosspost
18157
18158If non-@code{nil}, do crossposting if several split methods match the
18159mail. If @code{nil}, the first match in @code{nnimap-split-rule}
18160found will be used.
18161
18162Nnmail equivalent: @code{nnmail-crosspost}.
18163
18164@item nnimap-split-inbox
18165@cindex splitting, inbox
18166@cindex inbox
18167@vindex nnimap-split-inbox
18168
18169A string or a list of strings that gives the name(s) of @acronym{IMAP}
18170mailboxes to split from. Defaults to @code{nil}, which means that
18171splitting is disabled!
18172
18173@lisp
18174(setq nnimap-split-inbox
18175 '("INBOX" ("~/friend/Mail" . "lists/*") "lists.imap"))
18176@end lisp
18177
18178No nnmail equivalent.
18179
18180@item nnimap-split-rule
18181@cindex splitting, rules
18182@vindex nnimap-split-rule
18183
18184New mail found in @code{nnimap-split-inbox} will be split according to
18185this variable.
18186
18187This variable contains a list of lists, where the first element in the
18188sublist gives the name of the @acronym{IMAP} mailbox to move articles
18189matching the regexp in the second element in the sublist. Got that?
18190Neither did I, we need examples.
18191
18192@lisp
18193(setq nnimap-split-rule
18194 '(("INBOX.nnimap"
18195 "^Sender: owner-nnimap@@vic20.globalcom.se")
18196 ("INBOX.junk" "^Subject:.*MAKE MONEY")
18197 ("INBOX.private" "")))
18198@end lisp
18199
18200This will put all articles from the nnimap mailing list into mailbox
18201INBOX.nnimap, all articles containing MAKE MONEY in the Subject: line
18202into INBOX.junk and everything else in INBOX.private.
18203
18204The first string may contain @samp{\\1} forms, like the ones used by
18205replace-match to insert sub-expressions from the matched text. For
18206instance:
18207
18208@lisp
18209("INBOX.lists.\\1" "^Sender: owner-\\([a-z-]+\\)@@")
18210@end lisp
18211
18212The first element can also be the symbol @code{junk} to indicate that
18213matching messages should simply be deleted. Use with care.
18214
18215The second element can also be a function. In that case, it will be
18216called with the first element of the rule as the argument, in a buffer
18217containing the headers of the article. It should return a
18218non-@code{nil} value if it thinks that the mail belongs in that group.
18219
18220Nnmail users might recollect that the last regexp had to be empty to
18221match all articles (like in the example above). This is not required in
18222nnimap. Articles not matching any of the regexps will not be moved out
18223of your inbox. (This might affect performance if you keep lots of
18224unread articles in your inbox, since the splitting code would go over
18225them every time you fetch new mail.)
18226
18227These rules are processed from the beginning of the alist toward the
18228end. The first rule to make a match will ``win'', unless you have
18229crossposting enabled. In that case, all matching rules will ``win''.
18230
18231This variable can also have a function as its value, the function will
18232be called with the headers narrowed and should return a group where it
18233thinks the article should be split to. See @code{nnimap-split-fancy}.
18234
18235The splitting code tries to create mailboxes if it needs to.
18236
18237To allow for different split rules on different virtual servers, and
18238even different split rules in different inboxes on the same server,
18239the syntax of this variable have been extended along the lines of:
18240
18241@lisp
18242(setq nnimap-split-rule
18243 '(("my1server" (".*" (("ding" "ding@@gnus.org")
18244 ("junk" "From:.*Simon"))))
18245 ("my2server" ("INBOX" nnimap-split-fancy))
18246 ("my[34]server" (".*" (("private" "To:.*Simon")
18247 ("junk" my-junk-func))))))
18248@end lisp
18249
18250The virtual server name is in fact a regexp, so that the same rules
18251may apply to several servers. In the example, the servers
18252@code{my3server} and @code{my4server} both use the same rules.
18253Similarly, the inbox string is also a regexp. The actual splitting
18254rules are as before, either a function, or a list with group/regexp or
18255group/function elements.
18256
18257Nnmail equivalent: @code{nnmail-split-methods}.
18258
18259@item nnimap-split-predicate
18260@cindex splitting
18261@vindex nnimap-split-predicate
18262
18263Mail matching this predicate in @code{nnimap-split-inbox} will be
18264split, it is a string and the default is @samp{UNSEEN UNDELETED}.
18265
18266This might be useful if you use another @acronym{IMAP} client to read mail in
18267your inbox but would like Gnus to split all articles in the inbox
18268regardless of readedness. Then you might change this to
18269@samp{UNDELETED}.
18270
18271@item nnimap-split-fancy
18272@cindex splitting, fancy
18273@findex nnimap-split-fancy
18274@vindex nnimap-split-fancy
18275
18276It's possible to set @code{nnimap-split-rule} to
18277@code{nnmail-split-fancy} if you want to use fancy
18278splitting. @xref{Fancy Mail Splitting}.
18279
18280However, to be able to have different fancy split rules for nnmail and
18281nnimap back ends you can set @code{nnimap-split-rule} to
18282@code{nnimap-split-fancy} and define the nnimap specific fancy split
18283rule in @code{nnimap-split-fancy}.
18284
18285Example:
18286
18287@lisp
18288(setq nnimap-split-rule 'nnimap-split-fancy
18289 nnimap-split-fancy ...)
18290@end lisp
18291
18292Nnmail equivalent: @code{nnmail-split-fancy}.
18293
18294@item nnimap-split-download-body
18295@findex nnimap-split-download-body
18296@vindex nnimap-split-download-body
18297
18298Set to non-@code{nil} to download entire articles during splitting.
18299This is generally not required, and will slow things down
18300considerably. You may need it if you want to use an advanced
18301splitting function that analyzes the body to split the article.
18302
18303@end table
18304
18305@node Expiring in IMAP
18306@subsection Expiring in IMAP
18307@cindex expiring @acronym{IMAP} mail
18308
18309Even though @code{nnimap} is not a proper @code{nnmail} derived back
18310end, it supports most features in regular expiring (@pxref{Expiring
18311Mail}). Unlike splitting in @acronym{IMAP} (@pxref{Splitting in
18312IMAP}) it does not clone the @code{nnmail} variables (i.e., creating
18313@var{nnimap-expiry-wait}) but reuse the @code{nnmail} variables. What
18314follows below are the variables used by the @code{nnimap} expiry
18315process.
18316
18317A note on how the expire mark is stored on the @acronym{IMAP} server is
18318appropriate here as well. The expire mark is translated into a
18319@code{imap} client specific mark, @code{gnus-expire}, and stored on the
18320message. This means that likely only Gnus will understand and treat
18321the @code{gnus-expire} mark properly, although other clients may allow
18322you to view client specific flags on the message. It also means that
18323your server must support permanent storage of client specific flags on
18324messages. Most do, fortunately.
18325
18326If expiring @acronym{IMAP} mail seems very slow, try setting the server
18327variable @code{nnimap-search-uids-not-since-is-evil}.
18328
18329@table @code
18330
18331@item nnmail-expiry-wait
18332@item nnmail-expiry-wait-function
18333
18334These variables are fully supported. The expire value can be a
18335number, the symbol @code{immediate} or @code{never}.
18336
18337@item nnmail-expiry-target
18338
18339This variable is supported, and internally implemented by calling the
18340@code{nnmail} functions that handle this. It contains an optimization
18341that if the destination is a @acronym{IMAP} group on the same server, the
18342article is copied instead of appended (that is, uploaded again).
18343
18344@end table
18345
18346@node Editing IMAP ACLs
18347@subsection Editing IMAP ACLs
18348@cindex editing imap acls
18349@cindex Access Control Lists
18350@cindex Editing @acronym{IMAP} ACLs
18351@kindex G l (Group)
18352@findex gnus-group-nnimap-edit-acl
18353
18354ACL stands for Access Control List. ACLs are used in @acronym{IMAP} for
18355limiting (or enabling) other users access to your mail boxes. Not all
18356@acronym{IMAP} servers support this, this function will give an error if it
18357doesn't.
18358
18359To edit an ACL for a mailbox, type @kbd{G l}
18360(@code{gnus-group-edit-nnimap-acl}) and you'll be presented with an ACL
18361editing window with detailed instructions.
18362
18363Some possible uses:
18364
18365@itemize @bullet
18366@item
18367Giving ``anyone'' the ``lrs'' rights (lookup, read, keep seen/unseen flags)
18368on your mailing list mailboxes enables other users on the same server to
18369follow the list without subscribing to it.
18370@item
18371At least with the Cyrus server, you are required to give the user
18372``anyone'' posting ("p") capabilities to have ``plussing'' work (that is,
18373mail sent to user+mailbox@@domain ending up in the @acronym{IMAP} mailbox
18374INBOX.mailbox).
18375@end itemize
18376
18377@node Expunging mailboxes
18378@subsection Expunging mailboxes
18379@cindex expunging
18380
18381@cindex expunge
18382@cindex manual expunging
18383@kindex G x (Group)
18384@findex gnus-group-nnimap-expunge
18385
18386If you're using the @code{never} setting of @code{nnimap-expunge-on-close},
18387you may want the option of expunging all deleted articles in a mailbox
18388manually. This is exactly what @kbd{G x} does.
18389
18390Currently there is no way of showing deleted articles, you can just
18391delete them.
18392
18393@node A note on namespaces
18394@subsection A note on namespaces
18395@cindex IMAP namespace
18396@cindex namespaces
18397
18398The @acronym{IMAP} protocol has a concept called namespaces, described
18399by the following text in the RFC2060:
18400
18401@display
184025.1.2. Mailbox Namespace Naming Convention
18403
18404 By convention, the first hierarchical element of any mailbox name
18405 which begins with "#" identifies the "namespace" of the remainder of
18406 the name. This makes it possible to disambiguate between different
18407 types of mailbox stores, each of which have their own namespaces.
18408
18409 For example, implementations which offer access to USENET
18410 newsgroups MAY use the "#news" namespace to partition the USENET
18411 newsgroup namespace from that of other mailboxes. Thus, the
18412 comp.mail.misc newsgroup would have an mailbox name of
18413 "#news.comp.mail.misc", and the name "comp.mail.misc" could refer
18414 to a different object (e.g. a user's private mailbox).
18415@end display
18416
18417While there is nothing in this text that warrants concern for the
18418@acronym{IMAP} implementation in Gnus, some servers use namespace
18419prefixes in a way that does not work with how Gnus uses mailbox names.
18420
18421Specifically, University of Washington's @acronym{IMAP} server uses
18422mailbox names like @code{#driver.mbx/read-mail} which are valid only
18423in the @sc{create} and @sc{append} commands. After the mailbox is
18424created (or a messages is appended to a mailbox), it must be accessed
18425without the namespace prefix, i.e. @code{read-mail}. Since Gnus do
18426not make it possible for the user to guarantee that user entered
18427mailbox names will only be used with the CREATE and APPEND commands,
18428you should simply not use the namespace prefixed mailbox names in
18429Gnus.
18430
18431See the UoW IMAPD documentation for the @code{#driver.*/} prefix
18432for more information on how to use the prefixes. They are a power
18433tool and should be used only if you are sure what the effects are.
18434
18435@node Debugging IMAP
18436@subsection Debugging IMAP
18437@cindex IMAP debugging
18438@cindex protocol dump (IMAP)
18439
18440@acronym{IMAP} is a complex protocol, more so than @acronym{NNTP} or
18441@acronym{POP3}. Implementation bugs are not unlikely, and we do our
18442best to fix them right away. If you encounter odd behavior, chances
18443are that either the server or Gnus is buggy.
18444
18445If you are familiar with network protocols in general, you will
18446probably be able to extract some clues from the protocol dump of the
18447exchanges between Gnus and the server. Even if you are not familiar
18448with network protocols, when you include the protocol dump in
18449@acronym{IMAP}-related bug reports you are helping us with data
18450critical to solving the problem. Therefore, we strongly encourage you
18451to include the protocol dump when reporting IMAP bugs in Gnus.
18452
18453
18454@vindex imap-log
18455Because the protocol dump, when enabled, generates lots of data, it is
18456disabled by default. You can enable it by setting @code{imap-log} as
18457follows:
18458
18459@lisp
18460(setq imap-log t)
18461@end lisp
18462
18463This instructs the @code{imap.el} package to log any exchanges with
18464the server. The log is stored in the buffer @samp{*imap-log*}. Look
18465for error messages, which sometimes are tagged with the keyword
18466@code{BAD}---but when submitting a bug, make sure to include all the
18467data.
18468
18469@node Other Sources
18470@section Other Sources
18471
18472Gnus can do more than just read news or mail. The methods described
18473below allow Gnus to view directories and files as if they were
18474newsgroups.
18475
18476@menu
18477* Directory Groups:: You can read a directory as if it was a newsgroup.
18478* Anything Groups:: Dired? Who needs dired?
18479* Document Groups:: Single files can be the basis of a group.
4009494e
GM
18480* Mail-To-News Gateways:: Posting articles via mail-to-news gateways.
18481@end menu
18482
18483
18484@node Directory Groups
18485@subsection Directory Groups
18486@cindex nndir
18487@cindex directory groups
18488
18489If you have a directory that has lots of articles in separate files in
18490it, you might treat it as a newsgroup. The files have to have numerical
18491names, of course.
18492
18493This might be an opportune moment to mention @code{ange-ftp} (and its
18494successor @code{efs}), that most wonderful of all wonderful Emacs
18495packages. When I wrote @code{nndir}, I didn't think much about it---a
18496back end to read directories. Big deal.
18497
18498@code{ange-ftp} changes that picture dramatically. For instance, if you
18499enter the @code{ange-ftp} file name
18500@file{/ftp.hpc.uh.edu:/pub/emacs/ding-list/} as the directory name,
18501@code{ange-ftp} or @code{efs} will actually allow you to read this
18502directory over at @samp{sina} as a newsgroup. Distributed news ahoy!
18503
18504@code{nndir} will use @acronym{NOV} files if they are present.
18505
18506@code{nndir} is a ``read-only'' back end---you can't delete or expire
18507articles with this method. You can use @code{nnmh} or @code{nnml} for
18508whatever you use @code{nndir} for, so you could switch to any of those
18509methods if you feel the need to have a non-read-only @code{nndir}.
18510
18511
18512@node Anything Groups
18513@subsection Anything Groups
18514@cindex nneething
18515
18516From the @code{nndir} back end (which reads a single spool-like
18517directory), it's just a hop and a skip to @code{nneething}, which
18518pretends that any arbitrary directory is a newsgroup. Strange, but
18519true.
18520
18521When @code{nneething} is presented with a directory, it will scan this
18522directory and assign article numbers to each file. When you enter such
18523a group, @code{nneething} must create ``headers'' that Gnus can use.
18524After all, Gnus is a newsreader, in case you're forgetting.
18525@code{nneething} does this in a two-step process. First, it snoops each
18526file in question. If the file looks like an article (i.e., the first
18527few lines look like headers), it will use this as the head. If this is
18528just some arbitrary file without a head (e.g. a C source file),
18529@code{nneething} will cobble up a header out of thin air. It will use
18530file ownership, name and date and do whatever it can with these
18531elements.
18532
18533All this should happen automatically for you, and you will be presented
18534with something that looks very much like a newsgroup. Totally like a
18535newsgroup, to be precise. If you select an article, it will be displayed
18536in the article buffer, just as usual.
18537
18538If you select a line that represents a directory, Gnus will pop you into
18539a new summary buffer for this @code{nneething} group. And so on. You can
18540traverse the entire disk this way, if you feel like, but remember that
18541Gnus is not dired, really, and does not intend to be, either.
18542
18543There are two overall modes to this action---ephemeral or solid. When
18544doing the ephemeral thing (i.e., @kbd{G D} from the group buffer), Gnus
18545will not store information on what files you have read, and what files
18546are new, and so on. If you create a solid @code{nneething} group the
18547normal way with @kbd{G m}, Gnus will store a mapping table between
18548article numbers and file names, and you can treat this group like any
18549other groups. When you activate a solid @code{nneething} group, you will
18550be told how many unread articles it contains, etc., etc.
18551
18552Some variables:
18553
18554@table @code
18555@item nneething-map-file-directory
18556@vindex nneething-map-file-directory
18557All the mapping files for solid @code{nneething} groups will be stored
18558in this directory, which defaults to @file{~/.nneething/}.
18559
18560@item nneething-exclude-files
18561@vindex nneething-exclude-files
18562All files that match this regexp will be ignored. Nice to use to exclude
18563auto-save files and the like, which is what it does by default.
18564
18565@item nneething-include-files
18566@vindex nneething-include-files
18567Regexp saying what files to include in the group. If this variable is
18568non-@code{nil}, only files matching this regexp will be included.
18569
18570@item nneething-map-file
18571@vindex nneething-map-file
18572Name of the map files.
18573@end table
18574
18575
18576@node Document Groups
18577@subsection Document Groups
18578@cindex nndoc
18579@cindex documentation group
18580@cindex help group
18581
18582@code{nndoc} is a cute little thing that will let you read a single file
18583as a newsgroup. Several files types are supported:
18584
18585@table @code
18586@cindex Babyl
4009494e 18587@item babyl
bc79f9ab 18588The Babyl format.
4009494e
GM
18589
18590@cindex mbox
18591@cindex Unix mbox
18592@item mbox
18593The standard Unix mbox file.
18594
18595@cindex MMDF mail box
18596@item mmdf
18597The MMDF mail box format.
18598
18599@item news
18600Several news articles appended into a file.
18601
18602@cindex rnews batch files
18603@item rnews
18604The rnews batch transport format.
18605
18606@item nsmail
18607Netscape mail boxes.
18608
18609@item mime-parts
18610@acronym{MIME} multipart messages.
18611
18612@item standard-digest
18613The standard (RFC 1153) digest format.
18614
18615@item mime-digest
18616A @acronym{MIME} digest of messages.
18617
18618@item lanl-gov-announce
18619Announcement messages from LANL Gov Announce.
18620
18621@cindex forwarded messages
18622@item rfc822-forward
18623A message forwarded according to RFC822.
18624
18625@item outlook
18626The Outlook mail box.
18627
18628@item oe-dbx
18629The Outlook Express dbx mail box.
18630
18631@item exim-bounce
18632A bounce message from the Exim MTA.
18633
18634@item forward
18635A message forwarded according to informal rules.
18636
18637@item rfc934
18638An RFC934-forwarded message.
18639
18640@item mailman
18641A mailman digest.
18642
18643@item clari-briefs
18644A digest of Clarinet brief news items.
18645
18646@item slack-digest
18647Non-standard digest format---matches most things, but does it badly.
18648
18649@item mail-in-mail
18650The last resort.
18651@end table
18652
18653You can also use the special ``file type'' @code{guess}, which means
18654that @code{nndoc} will try to guess what file type it is looking at.
18655@code{digest} means that @code{nndoc} should guess what digest type the
18656file is.
18657
18658@code{nndoc} will not try to change the file or insert any extra headers into
18659it---it will simply, like, let you use the file as the basis for a
18660group. And that's it.
18661
18662If you have some old archived articles that you want to insert into your
18663new & spiffy Gnus mail back end, @code{nndoc} can probably help you with
18664that. Say you have an old @file{RMAIL} file with mail that you now want
18665to split into your new @code{nnml} groups. You look at that file using
18666@code{nndoc} (using the @kbd{G f} command in the group buffer
18667(@pxref{Foreign Groups})), set the process mark on all the articles in
18668the buffer (@kbd{M P b}, for instance), and then re-spool (@kbd{B r})
18669using @code{nnml}. If all goes well, all the mail in the @file{RMAIL}
18670file is now also stored in lots of @code{nnml} directories, and you can
18671delete that pesky @file{RMAIL} file. If you have the guts!
18672
18673Virtual server variables:
18674
18675@table @code
18676@item nndoc-article-type
18677@vindex nndoc-article-type
18678This should be one of @code{mbox}, @code{babyl}, @code{digest},
18679@code{news}, @code{rnews}, @code{mmdf}, @code{forward}, @code{rfc934},
18680@code{rfc822-forward}, @code{mime-parts}, @code{standard-digest},
18681@code{slack-digest}, @code{clari-briefs}, @code{nsmail}, @code{outlook},
18682@code{oe-dbx}, @code{mailman}, and @code{mail-in-mail} or @code{guess}.
18683
18684@item nndoc-post-type
18685@vindex nndoc-post-type
18686This variable says whether Gnus is to consider the group a news group or
18687a mail group. There are two valid values: @code{mail} (the default)
18688and @code{news}.
18689@end table
18690
18691@menu
18692* Document Server Internals:: How to add your own document types.
18693@end menu
18694
18695
18696@node Document Server Internals
18697@subsubsection Document Server Internals
18698
18699Adding new document types to be recognized by @code{nndoc} isn't
18700difficult. You just have to whip up a definition of what the document
18701looks like, write a predicate function to recognize that document type,
18702and then hook into @code{nndoc}.
18703
18704First, here's an example document type definition:
18705
18706@example
18707(mmdf
18708 (article-begin . "^\^A\^A\^A\^A\n")
18709 (body-end . "^\^A\^A\^A\^A\n"))
18710@end example
18711
18712The definition is simply a unique @dfn{name} followed by a series of
18713regexp pseudo-variable settings. Below are the possible
18714variables---don't be daunted by the number of variables; most document
18715types can be defined with very few settings:
18716
18717@table @code
18718@item first-article
18719If present, @code{nndoc} will skip past all text until it finds
18720something that match this regexp. All text before this will be
18721totally ignored.
18722
18723@item article-begin
18724This setting has to be present in all document type definitions. It
18725says what the beginning of each article looks like. To do more
18726complicated things that cannot be dealt with a simple regexp, you can
18727use @code{article-begin-function} instead of this.
18728
18729@item article-begin-function
18730If present, this should be a function that moves point to the beginning
18731of each article. This setting overrides @code{article-begin}.
18732
18733@item head-begin
18734If present, this should be a regexp that matches the head of the
18735article. To do more complicated things that cannot be dealt with a
18736simple regexp, you can use @code{head-begin-function} instead of this.
18737
18738@item head-begin-function
18739If present, this should be a function that moves point to the head of
18740the article. This setting overrides @code{head-begin}.
18741
18742@item head-end
18743This should match the end of the head of the article. It defaults to
18744@samp{^$}---the empty line.
18745
18746@item body-begin
18747This should match the beginning of the body of the article. It defaults
18748to @samp{^\n}. To do more complicated things that cannot be dealt with
18749a simple regexp, you can use @code{body-begin-function} instead of this.
18750
18751@item body-begin-function
18752If present, this function should move point to the beginning of the body
18753of the article. This setting overrides @code{body-begin}.
18754
18755@item body-end
18756If present, this should match the end of the body of the article. To do
18757more complicated things that cannot be dealt with a simple regexp, you
18758can use @code{body-end-function} instead of this.
18759
18760@item body-end-function
18761If present, this function should move point to the end of the body of
18762the article. This setting overrides @code{body-end}.
18763
18764@item file-begin
18765If present, this should match the beginning of the file. All text
18766before this regexp will be totally ignored.
18767
18768@item file-end
18769If present, this should match the end of the file. All text after this
18770regexp will be totally ignored.
18771
18772@end table
18773
18774So, using these variables @code{nndoc} is able to dissect a document
18775file into a series of articles, each with a head and a body. However, a
18776few more variables are needed since not all document types are all that
18777news-like---variables needed to transform the head or the body into
18778something that's palatable for Gnus:
18779
18780@table @code
18781@item prepare-body-function
18782If present, this function will be called when requesting an article. It
18783will be called with point at the start of the body, and is useful if the
18784document has encoded some parts of its contents.
18785
18786@item article-transform-function
18787If present, this function is called when requesting an article. It's
18788meant to be used for more wide-ranging transformation of both head and
18789body of the article.
18790
18791@item generate-head-function
18792If present, this function is called to generate a head that Gnus can
18793understand. It is called with the article number as a parameter, and is
18794expected to generate a nice head for the article in question. It is
18795called when requesting the headers of all articles.
18796
18797@item generate-article-function
18798If present, this function is called to generate an entire article that
18799Gnus can understand. It is called with the article number as a
18800parameter when requesting all articles.
18801
18802@item dissection-function
18803If present, this function is called to dissect a document by itself,
18804overriding @code{first-article}, @code{article-begin},
18805@code{article-begin-function}, @code{head-begin},
18806@code{head-begin-function}, @code{head-end}, @code{body-begin},
18807@code{body-begin-function}, @code{body-end}, @code{body-end-function},
18808@code{file-begin}, and @code{file-end}.
18809
18810@end table
18811
18812Let's look at the most complicated example I can come up with---standard
18813digests:
18814
18815@example
18816(standard-digest
18817 (first-article . ,(concat "^" (make-string 70 ?-) "\n\n+"))
18818 (article-begin . ,(concat "\n\n" (make-string 30 ?-) "\n\n+"))
18819 (prepare-body-function . nndoc-unquote-dashes)
18820 (body-end-function . nndoc-digest-body-end)
18821 (head-end . "^ ?$")
18822 (body-begin . "^ ?\n")
18823 (file-end . "^End of .*digest.*[0-9].*\n\\*\\*\\|^End of.*Digest *$")
18824 (subtype digest guess))
18825@end example
18826
18827We see that all text before a 70-width line of dashes is ignored; all
18828text after a line that starts with that @samp{^End of} is also ignored;
18829each article begins with a 30-width line of dashes; the line separating
18830the head from the body may contain a single space; and that the body is
18831run through @code{nndoc-unquote-dashes} before being delivered.
18832
18833To hook your own document definition into @code{nndoc}, use the
18834@code{nndoc-add-type} function. It takes two parameters---the first
18835is the definition itself and the second (optional) parameter says
18836where in the document type definition alist to put this definition.
18837The alist is traversed sequentially, and
18838@code{nndoc-@var{type}-type-p} is called for a given type @var{type}.
18839So @code{nndoc-mmdf-type-p} is called to see whether a document is of
18840@code{mmdf} type, and so on. These type predicates should return
18841@code{nil} if the document is not of the correct type; @code{t} if it
18842is of the correct type; and a number if the document might be of the
18843correct type. A high number means high probability; a low number
18844means low probability with @samp{0} being the lowest valid number.
18845
18846
4009494e
GM
18847@node Mail-To-News Gateways
18848@subsection Mail-To-News Gateways
18849@cindex mail-to-news gateways
18850@cindex gateways
18851
18852If your local @code{nntp} server doesn't allow posting, for some reason
18853or other, you can post using one of the numerous mail-to-news gateways.
18854The @code{nngateway} back end provides the interface.
18855
18856Note that you can't read anything from this back end---it can only be
18857used to post with.
18858
18859Server variables:
18860
18861@table @code
18862@item nngateway-address
18863@vindex nngateway-address
18864This is the address of the mail-to-news gateway.
18865
18866@item nngateway-header-transformation
18867@vindex nngateway-header-transformation
18868News headers often have to be transformed in some odd way or other
18869for the mail-to-news gateway to accept it. This variable says what
18870transformation should be called, and defaults to
18871@code{nngateway-simple-header-transformation}. The function is called
18872narrowed to the headers to be transformed and with one parameter---the
18873gateway address.
18874
18875This default function just inserts a new @code{To} header based on the
18876@code{Newsgroups} header and the gateway address.
18877For instance, an article with this @code{Newsgroups} header:
18878
18879@example
18880Newsgroups: alt.religion.emacs
18881@end example
18882
18883will get this @code{To} header inserted:
18884
18885@example
18886To: alt-religion-emacs@@GATEWAY
18887@end example
18888
18889The following pre-defined functions exist:
18890
18891@findex nngateway-simple-header-transformation
18892@table @code
18893
18894@item nngateway-simple-header-transformation
18895Creates a @code{To} header that looks like
18896@var{newsgroup}@@@code{nngateway-address}.
18897
18898@findex nngateway-mail2news-header-transformation
18899
18900@item nngateway-mail2news-header-transformation
18901Creates a @code{To} header that looks like
18902@code{nngateway-address}.
18903@end table
18904
18905@end table
18906
18907Here's an example:
18908
18909@lisp
18910(setq gnus-post-method
18911 '(nngateway
18912 "mail2news@@replay.com"
18913 (nngateway-header-transformation
18914 nngateway-mail2news-header-transformation)))
18915@end lisp
18916
18917So, to use this, simply say something like:
18918
18919@lisp
18920(setq gnus-post-method '(nngateway "GATEWAY.ADDRESS"))
18921@end lisp
18922
18923
18924
18925@node Combined Groups
18926@section Combined Groups
18927
18928Gnus allows combining a mixture of all the other group types into bigger
18929groups.
18930
18931@menu
18932* Virtual Groups:: Combining articles from many groups.
4009494e
GM
18933@end menu
18934
18935
18936@node Virtual Groups
18937@subsection Virtual Groups
18938@cindex nnvirtual
18939@cindex virtual groups
18940@cindex merging groups
18941
18942An @dfn{nnvirtual group} is really nothing more than a collection of
18943other groups.
18944
18945For instance, if you are tired of reading many small groups, you can
18946put them all in one big group, and then grow tired of reading one
18947big, unwieldy group. The joys of computing!
18948
18949You specify @code{nnvirtual} as the method. The address should be a
18950regexp to match component groups.
18951
18952All marks in the virtual group will stick to the articles in the
18953component groups. So if you tick an article in a virtual group, the
18954article will also be ticked in the component group from whence it
18955came. (And vice versa---marks from the component groups will also be
18956shown in the virtual group.). To create an empty virtual group, run
18957@kbd{G V} (@code{gnus-group-make-empty-virtual}) in the group buffer
18958and edit the method regexp with @kbd{M-e}
18959(@code{gnus-group-edit-group-method})
18960
18961Here's an example @code{nnvirtual} method that collects all Andrea Dworkin
18962newsgroups into one, big, happy newsgroup:
18963
18964@lisp
18965(nnvirtual "^alt\\.fan\\.andrea-dworkin$\\|^rec\\.dworkin.*")
18966@end lisp
18967
18968The component groups can be native or foreign; everything should work
18969smoothly, but if your computer explodes, it was probably my fault.
18970
18971Collecting the same group from several servers might actually be a good
18972idea if users have set the Distribution header to limit distribution.
18973If you would like to read @samp{soc.motss} both from a server in Japan
18974and a server in Norway, you could use the following as the group regexp:
18975
18976@example
18977"^nntp\\+server\\.jp:soc\\.motss$\\|^nntp\\+server\\.no:soc\\.motss$"
18978@end example
18979
18980(Remember, though, that if you're creating the group with @kbd{G m}, you
18981shouldn't double the backslashes, and you should leave off the quote
18982characters at the beginning and the end of the string.)
18983
18984This should work kinda smoothly---all articles from both groups should
18985end up in this one, and there should be no duplicates. Threading (and
18986the rest) will still work as usual, but there might be problems with the
18987sequence of articles. Sorting on date might be an option here
18988(@pxref{Selecting a Group}).
18989
18990One limitation, however---all groups included in a virtual
18991group have to be alive (i.e., subscribed or unsubscribed). Killed or
18992zombie groups can't be component groups for @code{nnvirtual} groups.
18993
18994@vindex nnvirtual-always-rescan
18995If the @code{nnvirtual-always-rescan} variable is non-@code{nil} (which
18996is the default), @code{nnvirtual} will always scan groups for unread
18997articles when entering a virtual group. If this variable is @code{nil}
18998and you read articles in a component group after the virtual group has
18999been activated, the read articles from the component group will show up
19000when you enter the virtual group. You'll also see this effect if you
19001have two virtual groups that have a component group in common. If
19002that's the case, you should set this variable to @code{t}. Or you can
19003just tap @code{M-g} on the virtual group every time before you enter
19004it---it'll have much the same effect.
19005
19006@code{nnvirtual} can have both mail and news groups as component groups.
19007When responding to articles in @code{nnvirtual} groups, @code{nnvirtual}
19008has to ask the back end of the component group the article comes from
19009whether it is a news or mail back end. However, when you do a @kbd{^},
19010there is typically no sure way for the component back end to know this,
19011and in that case @code{nnvirtual} tells Gnus that the article came from a
19012not-news back end. (Just to be on the safe side.)
19013
19014@kbd{C-c C-n} in the message buffer will insert the @code{Newsgroups}
19015line from the article you respond to in these cases.
19016
19017@code{nnvirtual} groups do not inherit anything but articles and marks
19018from component groups---group parameters, for instance, are not
19019inherited.
19020
19021
4009494e
GM
19022@node Email Based Diary
19023@section Email Based Diary
19024@cindex diary
19025@cindex email based diary
19026@cindex calendar
19027
19028This section describes a special mail back end called @code{nndiary},
19029and its companion library @code{gnus-diary}. It is ``special'' in the
19030sense that it is not meant to be one of the standard alternatives for
19031reading mail with Gnus. See @ref{Choosing a Mail Back End} for that.
19032Instead, it is used to treat @emph{some} of your mails in a special way,
19033namely, as event reminders.
19034
19035Here is a typical scenario:
19036
19037@itemize @bullet
19038@item
19039You've got a date with Andy Mc Dowell or Bruce Willis (select according
19040to your sexual preference) in one month. You don't want to forget it.
19041@item
19042So you send a ``reminder'' message (actually, a diary one) to yourself.
19043@item
19044You forget all about it and keep on getting and reading new mail, as usual.
19045@item
19046From time to time, as you type `g' in the group buffer and as the date
19047is getting closer, the message will pop up again to remind you of your
19048appointment, just as if it were new and unread.
19049@item
19050Read your ``new'' messages, this one included, and start dreaming again
19051of the night you're gonna have.
19052@item
19053Once the date is over (you actually fell asleep just after dinner), the
19054message will be automatically deleted if it is marked as expirable.
19055@end itemize
19056
19057The Gnus Diary back end has the ability to handle regular appointments
19058(that wouldn't ever be deleted) as well as punctual ones, operates as a
19059real mail back end and is configurable in many ways. All of this is
19060explained in the sections below.
19061
19062@menu
19063* The NNDiary Back End:: Basic setup and usage.
19064* The Gnus Diary Library:: Utility toolkit on top of nndiary.
19065* Sending or Not Sending:: A final note on sending diary messages.
19066@end menu
19067
19068
19069@node The NNDiary Back End
19070@subsection The NNDiary Back End
19071@cindex nndiary
19072@cindex the nndiary back end
19073
19074@code{nndiary} is a back end very similar to @code{nnml} (@pxref{Mail
19075Spool}). Actually, it could appear as a mix of @code{nnml} and
19076@code{nndraft}. If you know @code{nnml}, you're already familiar with
19077the message storing scheme of @code{nndiary}: one file per message, one
19078directory per group.
19079
19080 Before anything, there is one requirement to be able to run
19081@code{nndiary} properly: you @emph{must} use the group timestamp feature
19082of Gnus. This adds a timestamp to each group's parameters. @ref{Group
19083Timestamp} to see how it's done.
19084
19085@menu
19086* Diary Messages:: What makes a message valid for nndiary.
19087* Running NNDiary:: NNDiary has two modes of operation.
19088* Customizing NNDiary:: Bells and whistles.
19089@end menu
19090
19091@node Diary Messages
19092@subsubsection Diary Messages
19093@cindex nndiary messages
19094@cindex nndiary mails
19095
19096@code{nndiary} messages are just normal ones, except for the mandatory
19097presence of 7 special headers. These headers are of the form
19098@code{X-Diary-<something>}, @code{<something>} being one of
19099@code{Minute}, @code{Hour}, @code{Dom}, @code{Month}, @code{Year},
19100@code{Time-Zone} and @code{Dow}. @code{Dom} means ``Day of Month'', and
19101@code{dow} means ``Day of Week''. These headers actually behave like
19102crontab specifications and define the event date(s):
19103
19104@itemize @bullet
19105@item
19106For all headers except the @code{Time-Zone} one, a header value is
19107either a star (meaning all possible values), or a list of fields
19108(separated by a comma).
19109@item
19110A field is either an integer, or a range.
19111@item
19112A range is two integers separated by a dash.
19113@item
19114Possible integer values are 0--59 for @code{Minute}, 0--23 for
19115@code{Hour}, 1--31 for @code{Dom}, 1--12 for @code{Month}, above 1971
19116for @code{Year} and 0--6 for @code{Dow} (0 meaning Sunday).
19117@item
19118As a special case, a star in either @code{Dom} or @code{Dow} doesn't
19119mean ``all possible values'', but ``use only the other field''. Note
19120that if both are star'ed, the use of either one gives the same result.
19121@item
19122The @code{Time-Zone} header is special in that it can only have one
19123value (@code{GMT}, for instance). A star doesn't mean ``all possible
19124values'' (because it makes no sense), but ``the current local time
19125zone''. Most of the time, you'll be using a star here. However, for a
19126list of available time zone values, see the variable
19127@code{nndiary-headers}.
19128@end itemize
19129
19130As a concrete example, here are the diary headers to add to your message
19131for specifying ``Each Monday and each 1st of month, at 12:00, 20:00,
1913221:00, 22:00, 23:00 and 24:00, from 1999 to 2010'' (I'll let you find
19133what to do then):
19134
19135@example
19136X-Diary-Minute: 0
19137X-Diary-Hour: 12, 20-24
19138X-Diary-Dom: 1
19139X-Diary-Month: *
19140X-Diary-Year: 1999-2010
19141X-Diary-Dow: 1
19142X-Diary-Time-Zone: *
19143@end example
19144
19145@node Running NNDiary
19146@subsubsection Running NNDiary
19147@cindex running nndiary
19148@cindex nndiary operation modes
19149
19150@code{nndiary} has two modes of operation: ``traditional'' (the default)
19151and ``autonomous''. In traditional mode, @code{nndiary} does not get new
19152mail by itself. You have to move (@kbd{B m}) or copy (@kbd{B c}) mails
19153from your primary mail back end to nndiary groups in order to handle them
19154as diary messages. In autonomous mode, @code{nndiary} retrieves its own
19155mail and handles it independently from your primary mail back end.
19156
19157One should note that Gnus is not inherently designed to allow several
19158``master'' mail back ends at the same time. However, this does make
19159sense with @code{nndiary}: you really want to send and receive diary
19160messages to your diary groups directly. So, @code{nndiary} supports
19161being sort of a ``second primary mail back end'' (to my knowledge, it is
19162the only back end offering this feature). However, there is a limitation
19163(which I hope to fix some day): respooling doesn't work in autonomous
19164mode.
19165
19166In order to use @code{nndiary} in autonomous mode, you have several
19167things to do:
19168
19169@itemize @bullet
19170@item
19171Allow @code{nndiary} to retrieve new mail by itself. Put the following
19172line in your @file{~/.gnus.el} file:
19173
19174@lisp
19175(setq nndiary-get-new-mail t)
19176@end lisp
19177@item
19178You must arrange for diary messages (those containing @code{X-Diary-*}
19179headers) to be split in a private folder @emph{before} Gnus treat them.
19180Again, this is needed because Gnus cannot (yet ?) properly handle
19181multiple primary mail back ends. Getting those messages from a separate
19182source will compensate this misfeature to some extent.
19183
19184As an example, here's my procmailrc entry to store diary files in
19185@file{~/.nndiary} (the default @code{nndiary} mail source file):
19186
19187@example
19188:0 HD :
19189* ^X-Diary
19190.nndiary
19191@end example
19192@end itemize
19193
19194Once this is done, you might want to customize the following two options
19195that affect the diary mail retrieval and splitting processes:
19196
19197@defvar nndiary-mail-sources
19198This is the diary-specific replacement for the standard
19199@code{mail-sources} variable. It obeys the same syntax, and defaults to
19200@code{(file :path "~/.nndiary")}.
19201@end defvar
19202
19203@defvar nndiary-split-methods
19204This is the diary-specific replacement for the standard
19205@code{nnmail-split-methods} variable. It obeys the same syntax.
19206@end defvar
19207
19208 Finally, you may add a permanent @code{nndiary} virtual server
19209(something like @code{(nndiary "diary")} should do) to your
19210@code{gnus-secondary-select-methods}.
19211
19212 Hopefully, almost everything (see the TODO section in
19213@file{nndiary.el}) will work as expected when you restart Gnus: in
19214autonomous mode, typing @kbd{g} and @kbd{M-g} in the group buffer, will
19215also get your new diary mails and split them according to your
19216diary-specific rules, @kbd{F} will find your new diary groups etc.
19217
19218@node Customizing NNDiary
19219@subsubsection Customizing NNDiary
19220@cindex customizing nndiary
19221@cindex nndiary customization
19222
19223Now that @code{nndiary} is up and running, it's time to customize it.
19224The custom group is called @code{nndiary} (no, really ?!). You should
19225browse it to figure out which options you'd like to tweak. The following
19226two variables are probably the only ones you will want to change:
19227
19228@defvar nndiary-reminders
19229This is the list of times when you want to be reminded of your
19230appointments (e.g. 3 weeks before, then 2 days before, then 1 hour
19231before and that's it). Remember that ``being reminded'' means that the
19232diary message will pop up as brand new and unread again when you get new
19233mail.
19234@end defvar
19235
19236@defvar nndiary-week-starts-on-monday
19237Rather self-explanatory. Otherwise, Sunday is assumed (this is the
19238default).
19239@end defvar
19240
19241
19242@node The Gnus Diary Library
19243@subsection The Gnus Diary Library
19244@cindex gnus-diary
19245@cindex the gnus diary library
19246
19247Using @code{nndiary} manually (I mean, writing the headers by hand and
19248so on) would be rather boring. Fortunately, there is a library called
19249@code{gnus-diary} written on top of @code{nndiary}, that does many
19250useful things for you.
19251
19252 In order to use it, add the following line to your @file{~/.gnus.el} file:
19253
19254@lisp
19255(require 'gnus-diary)
19256@end lisp
19257
19258 Also, you shouldn't use any @code{gnus-user-format-function-[d|D]}
19259(@pxref{Summary Buffer Lines}). @code{gnus-diary} provides both of these
19260(sorry if you used them before).
19261
19262
19263@menu
19264* Diary Summary Line Format:: A nicer summary buffer line format.
19265* Diary Articles Sorting:: A nicer way to sort messages.
19266* Diary Headers Generation:: Not doing it manually.
19267* Diary Group Parameters:: Not handling them manually.
19268@end menu
19269
19270@node Diary Summary Line Format
19271@subsubsection Diary Summary Line Format
19272@cindex diary summary buffer line
19273@cindex diary summary line format
19274
19275Displaying diary messages in standard summary line format (usually
19276something like @samp{From Joe: Subject}) is pretty useless. Most of
19277the time, you're the one who wrote the message, and you mostly want to
19278see the event's date.
19279
19280 @code{gnus-diary} provides two supplemental user formats to be used in
19281summary line formats. @code{D} corresponds to a formatted time string
19282for the next occurrence of the event (e.g. ``Sat, Sep 22 01, 12:00''),
19283while @code{d} corresponds to an approximative remaining time until the
19284next occurrence of the event (e.g. ``in 6 months, 1 week'').
19285
19286 For example, here's how Joe's birthday is displayed in my
19287@code{nndiary+diary:birthdays} summary buffer (note that the message is
19288expirable, but will never be deleted, as it specifies a periodic event):
19289
19290@example
19291 E Sat, Sep 22 01, 12:00: Joe's birthday (in 6 months, 1 week)
19292@end example
19293
19294In order to get something like the above, you would normally add the
19295following line to your diary groups'parameters:
19296
19297@lisp
19298(gnus-summary-line-format "%U%R%z %uD: %(%s%) (%ud)\n")
19299@end lisp
19300
19301However, @code{gnus-diary} does it automatically (@pxref{Diary Group
19302Parameters}). You can however customize the provided summary line format
19303with the following user options:
19304
19305@defvar gnus-diary-summary-line-format
19306Defines the summary line format used for diary groups (@pxref{Summary
19307Buffer Lines}). @code{gnus-diary} uses it to automatically update the
19308diary groups'parameters.
19309@end defvar
19310
19311@defvar gnus-diary-time-format
19312Defines the format to display dates in diary summary buffers. This is
19313used by the @code{D} user format. See the docstring for details.
19314@end defvar
19315
19316@defvar gnus-diary-delay-format-function
19317Defines the format function to use for displaying delays (remaining
19318times) in diary summary buffers. This is used by the @code{d} user
19319format. There are currently built-in functions for English and French;
19320you can also define your own. See the docstring for details.
19321@end defvar
19322
19323@node Diary Articles Sorting
19324@subsubsection Diary Articles Sorting
19325@cindex diary articles sorting
19326@cindex diary summary lines sorting
19327@findex gnus-summary-sort-by-schedule
19328@findex gnus-thread-sort-by-schedule
19329@findex gnus-article-sort-by-schedule
19330
19331@code{gnus-diary} provides new sorting functions (@pxref{Sorting the
19332Summary Buffer} ) called @code{gnus-summary-sort-by-schedule},
19333@code{gnus-thread-sort-by-schedule} and
19334@code{gnus-article-sort-by-schedule}. These functions let you organize
19335your diary summary buffers from the closest event to the farthest one.
19336
19337@code{gnus-diary} automatically installs
19338@code{gnus-summary-sort-by-schedule} as a menu item in the summary
19339buffer's ``sort'' menu, and the two others as the primary (hence
19340default) sorting functions in the group parameters (@pxref{Diary Group
19341Parameters}).
19342
19343@node Diary Headers Generation
19344@subsubsection Diary Headers Generation
19345@cindex diary headers generation
19346@findex gnus-diary-check-message
19347
19348@code{gnus-diary} provides a function called
19349@code{gnus-diary-check-message} to help you handle the @code{X-Diary-*}
19350headers. This function ensures that the current message contains all the
19351required diary headers, and prompts you for values or corrections if
19352needed.
19353
19354 This function is hooked into the @code{nndiary} back end, so that
19355moving or copying an article to a diary group will trigger it
d55fe5bb
MB
19356automatically. It is also bound to @kbd{C-c C-f d} in
19357@code{message-mode} and @code{article-edit-mode} in order to ease the
19358process of converting a usual mail to a diary one.
4009494e
GM
19359
19360 This function takes a prefix argument which will force prompting of
19361all diary headers, regardless of their presence or validity. That way,
19362you can very easily reschedule an already valid diary message, for
19363instance.
19364
19365@node Diary Group Parameters
19366@subsubsection Diary Group Parameters
19367@cindex diary group parameters
19368
19369When you create a new diary group, or visit one, @code{gnus-diary}
19370automatically checks your group parameters and if needed, sets the
19371summary line format to the diary-specific value, installs the
19372diary-specific sorting functions, and also adds the different
19373@code{X-Diary-*} headers to the group's posting-style. It is then easier
19374to send a diary message, because if you use @kbd{C-u a} or @kbd{C-u m}
19375on a diary group to prepare a message, these headers will be inserted
19376automatically (although not filled with proper values yet).
19377
19378@node Sending or Not Sending
19379@subsection Sending or Not Sending
19380
19381Well, assuming you've read all of the above, here are two final notes on
19382mail sending with @code{nndiary}:
19383
19384@itemize @bullet
19385@item
19386@code{nndiary} is a @emph{real} mail back end. You really send real diary
19387messsages for real. This means for instance that you can give
19388appointments to anybody (provided they use Gnus and @code{nndiary}) by
19389sending the diary message to them as well.
19390@item
19391However, since @code{nndiary} also has a @code{request-post} method, you
19392can also use @kbd{C-u a} instead of @kbd{C-u m} on a diary group and the
19393message won't actually be sent; just stored locally in the group. This
19394comes in very handy for private appointments.
19395@end itemize
19396
19397@node Gnus Unplugged
19398@section Gnus Unplugged
19399@cindex offline
19400@cindex unplugged
19401@cindex agent
19402@cindex Gnus agent
19403@cindex Gnus unplugged
19404
19405In olden times (ca. February '88), people used to run their newsreaders
19406on big machines with permanent connections to the net. News transport
19407was dealt with by news servers, and all the newsreaders had to do was to
19408read news. Believe it or not.
19409
19410Nowadays most people read news and mail at home, and use some sort of
19411modem to connect to the net. To avoid running up huge phone bills, it
19412would be nice to have a way to slurp down all the news and mail, hang up
19413the phone, read for several hours, and then upload any responses you
19414have to make. And then you repeat the procedure.
19415
19416Of course, you can use news servers for doing this as well. I've used
19417@code{inn} together with @code{slurp}, @code{pop} and @code{sendmail}
19418for some years, but doing that's a bore. Moving the news server
19419functionality up to the newsreader makes sense if you're the only person
19420reading news on a machine.
19421
19422Setting up Gnus as an ``offline'' newsreader is quite simple. In
01c52d31
MB
19423fact, you don't have to configure anything as the agent is now enabled
19424by default (@pxref{Agent Variables, gnus-agent}).
4009494e
GM
19425
19426Of course, to use it as such, you have to learn a few new commands.
19427
19428@menu
19429* Agent Basics:: How it all is supposed to work.
19430* Agent Categories:: How to tell the Gnus Agent what to download.
19431* Agent Commands:: New commands for all the buffers.
19432* Agent Visuals:: Ways that the agent may effect your summary buffer.
19433* Agent as Cache:: The Agent is a big cache too.
19434* Agent Expiry:: How to make old articles go away.
19435* Agent Regeneration:: How to recover from lost connections and other accidents.
01c52d31 19436* Agent and flags:: How the Agent maintains flags.
4009494e
GM
19437* Agent and IMAP:: How to use the Agent with @acronym{IMAP}.
19438* Outgoing Messages:: What happens when you post/mail something?
19439* Agent Variables:: Customizing is fun.
19440* Example Setup:: An example @file{~/.gnus.el} file for offline people.
19441* Batching Agents:: How to fetch news from a @code{cron} job.
19442* Agent Caveats:: What you think it'll do and what it does.
19443@end menu
19444
19445
19446@node Agent Basics
19447@subsection Agent Basics
19448
19449First, let's get some terminology out of the way.
19450
19451The Gnus Agent is said to be @dfn{unplugged} when you have severed the
19452connection to the net (and notified the Agent that this is the case).
19453When the connection to the net is up again (and Gnus knows this), the
19454Agent is @dfn{plugged}.
19455
19456The @dfn{local} machine is the one you're running on, and which isn't
19457connected to the net continuously.
19458
19459@dfn{Downloading} means fetching things from the net to your local
19460machine. @dfn{Uploading} is doing the opposite.
19461
19462You know that Gnus gives you all the opportunity you'd ever want for
19463shooting yourself in the foot. Some people call it flexibility. Gnus
19464is also customizable to a great extent, which means that the user has a
19465say on how Gnus behaves. Other newsreaders might unconditionally shoot
19466you in your foot, but with Gnus, you have a choice!
19467
19468Gnus is never really in plugged or unplugged state. Rather, it applies
19469that state to each server individually. This means that some servers
19470can be plugged while others can be unplugged. Additionally, some
19471servers can be ignored by the Agent altogether (which means that
19472they're kinda like plugged always).
19473
19474So when you unplug the Agent and then wonder why is Gnus opening a
19475connection to the Net, the next step to do is to look whether all
19476servers are agentized. If there is an unagentized server, you found
19477the culprit.
19478
19479Another thing is the @dfn{offline} state. Sometimes, servers aren't
19480reachable. When Gnus notices this, it asks you whether you want the
19481server to be switched to offline state. If you say yes, then the
19482server will behave somewhat as if it was unplugged, except that Gnus
19483will ask you whether you want to switch it back online again.
19484
19485Let's take a typical Gnus session using the Agent.
19486
19487@itemize @bullet
19488
19489@item
19490@findex gnus-unplugged
19491You start Gnus with @code{gnus-unplugged}. This brings up the Gnus
19492Agent in a disconnected state. You can read all the news that you have
19493already fetched while in this mode.
19494
19495@item
19496You then decide to see whether any new news has arrived. You connect
19497your machine to the net (using PPP or whatever), and then hit @kbd{J j}
19498to make Gnus become @dfn{plugged} and use @kbd{g} to check for new mail
19499as usual. To check for new mail in unplugged mode (@pxref{Mail
19500Source Specifiers}).
19501
19502@item
19503You can then read the new news immediately, or you can download the
19504news onto your local machine. If you want to do the latter, you press
19505@kbd{g} to check if there are any new news and then @kbd{J s} to fetch
19506all the eligible articles in all the groups. (To let Gnus know which
19507articles you want to download, @pxref{Agent Categories}).
19508
19509@item
19510After fetching the articles, you press @kbd{J j} to make Gnus become
19511unplugged again, and you shut down the PPP thing (or whatever). And
19512then you read the news offline.
19513
19514@item
19515And then you go to step 2.
19516@end itemize
19517
19518Here are some things you should do the first time (or so) that you use
19519the Agent.
19520
19521@itemize @bullet
19522
19523@item
19524Decide which servers should be covered by the Agent. If you have a mail
19525back end, it would probably be nonsensical to have it covered by the
19526Agent. Go to the server buffer (@kbd{^} in the group buffer) and press
19527@kbd{J a} on the server (or servers) that you wish to have covered by the
19528Agent (@pxref{Server Agent Commands}), or @kbd{J r} on automatically
19529added servers you do not wish to have covered by the Agent. By default,
19530all @code{nntp} and @code{nnimap} servers in @code{gnus-select-method} and
19531@code{gnus-secondary-select-methods} are agentized.
19532
19533@item
19534Decide on download policy. It's fairly simple once you decide whether
19535you are going to use agent categories, topic parameters, and/or group
19536parameters to implement your policy. If you're new to gnus, it
19537is probably best to start with a category, @xref{Agent Categories}.
19538
19539Both topic parameters (@pxref{Topic Parameters}) and agent categories
19540(@pxref{Agent Categories}) provide for setting a policy that applies
19541to multiple groups. Which you use is entirely up to you. Topic
19542parameters do override categories so, if you mix the two, you'll have
19543to take that into account. If you have a few groups that deviate from
19544your policy, you can use group parameters (@pxref{Group Parameters}) to
19545configure them.
19546
19547@item
19548Uhm@dots{} that's it.
19549@end itemize
19550
19551
19552@node Agent Categories
19553@subsection Agent Categories
19554
19555One of the main reasons to integrate the news transport layer into the
19556newsreader is to allow greater control over what articles to download.
19557There's not much point in downloading huge amounts of articles, just to
19558find out that you're not interested in reading any of them. It's better
19559to be somewhat more conservative in choosing what to download, and then
19560mark the articles for downloading manually if it should turn out that
19561you're interested in the articles anyway.
19562
19563One of the more effective methods for controlling what is to be
19564downloaded is to create a @dfn{category} and then assign some (or all)
19565groups to this category. Groups that do not belong in any other
19566category belong to the @code{default} category. Gnus has its own
19567buffer for creating and managing categories.
19568
19569If you prefer, you can also use group parameters (@pxref{Group
19570Parameters}) and topic parameters (@pxref{Topic Parameters}) for an
19571alternative approach to controlling the agent. The only real
19572difference is that categories are specific to the agent (so there is
19573less to learn) while group and topic parameters include the kitchen
19574sink.
19575
19576Since you can set agent parameters in several different places we have
19577a rule to decide which source to believe. This rule specifies that
19578the parameter sources are checked in the following order: group
19579parameters, topic parameters, agent category, and finally customizable
19580variables. So you can mix all of these sources to produce a wide range
19581of behavior, just don't blame me if you don't remember where you put
19582your settings.
19583
19584@menu
19585* Category Syntax:: What a category looks like.
19586* Category Buffer:: A buffer for maintaining categories.
19587* Category Variables:: Customize'r'Us.
19588@end menu
19589
19590
19591@node Category Syntax
19592@subsubsection Category Syntax
19593
19594A category consists of a name, the list of groups belonging to the
19595category, and a number of optional parameters that override the
19596customizable variables. The complete list of agent parameters are
19597listed below.
19598
19599@cindex Agent Parameters
19600@table @code
01c52d31 19601@item agent-groups
4009494e
GM
19602The list of groups that are in this category.
19603
01c52d31 19604@item agent-predicate
4009494e
GM
19605A predicate which (generally) gives a rough outline of which articles
19606are eligible for downloading; and
19607
01c52d31 19608@item agent-score
4009494e
GM
19609a score rule which (generally) gives you a finer granularity when
19610deciding what articles to download. (Note that this @dfn{download
19611score} is not necessarily related to normal scores.)
19612
01c52d31 19613@item agent-enable-expiration
4009494e
GM
19614a boolean indicating whether the agent should expire old articles in
19615this group. Most groups should be expired to conserve disk space. In
19616fact, its probably safe to say that the gnus.* hierarchy contains the
19617only groups that should not be expired.
19618
01c52d31 19619@item agent-days-until-old
4009494e
GM
19620an integer indicating the number of days that the agent should wait
19621before deciding that a read article is safe to expire.
19622
01c52d31 19623@item agent-low-score
4009494e
GM
19624an integer that overrides the value of @code{gnus-agent-low-score}.
19625
01c52d31 19626@item agent-high-score
4009494e
GM
19627an integer that overrides the value of @code{gnus-agent-high-score}.
19628
01c52d31 19629@item agent-short-article
4009494e
GM
19630an integer that overrides the value of
19631@code{gnus-agent-short-article}.
19632
01c52d31 19633@item agent-long-article
4009494e
GM
19634an integer that overrides the value of @code{gnus-agent-long-article}.
19635
01c52d31 19636@item agent-enable-undownloaded-faces
4009494e 19637a symbol indicating whether the summary buffer should display
01c52d31
MB
19638undownloaded articles using the @code{gnus-summary-*-undownloaded-face}
19639faces. Any symbol other than @code{nil} will enable the use of
19640undownloaded faces.
4009494e
GM
19641@end table
19642
19643The name of a category can not be changed once the category has been
19644created.
19645
19646Each category maintains a list of groups that are exclusive members of
19647that category. The exclusivity rule is automatically enforced, add a
19648group to a new category and it is automatically removed from its old
19649category.
19650
19651A predicate in its simplest form can be a single predicate such as
19652@code{true} or @code{false}. These two will download every available
19653article or nothing respectively. In the case of these two special
19654predicates an additional score rule is superfluous.
19655
19656Predicates of @code{high} or @code{low} download articles in respect of
19657their scores in relationship to @code{gnus-agent-high-score} and
19658@code{gnus-agent-low-score} as described below.
19659
19660To gain even finer control of what is to be regarded eligible for
19661download a predicate can consist of a number of predicates with logical
19662operators sprinkled in between.
19663
19664Perhaps some examples are in order.
19665
19666Here's a simple predicate. (It's the default predicate, in fact, used
19667for all groups that don't belong to any other category.)
19668
19669@lisp
19670short
19671@end lisp
19672
19673Quite simple, eh? This predicate is true if and only if the article is
19674short (for some value of ``short'').
19675
19676Here's a more complex predicate:
19677
19678@lisp
19679(or high
19680 (and
19681 (not low)
19682 (not long)))
19683@end lisp
19684
19685This means that an article should be downloaded if it has a high score,
19686or if the score is not low and the article is not long. You get the
19687drift.
19688
19689The available logical operators are @code{or}, @code{and} and
19690@code{not}. (If you prefer, you can use the more ``C''-ish operators
19691@samp{|}, @code{&} and @code{!} instead.)
19692
19693The following predicates are pre-defined, but if none of these fit what
19694you want to do, you can write your own.
19695
19696When evaluating each of these predicates, the named constant will be
19697bound to the value determined by calling
19698@code{gnus-agent-find-parameter} on the appropriate parameter. For
19699example, gnus-agent-short-article will be bound to
19700@code{(gnus-agent-find-parameter group 'agent-short-article)}. This
19701means that you can specify a predicate in your category then tune that
19702predicate to individual groups.
19703
19704@table @code
19705@item short
19706True if the article is shorter than @code{gnus-agent-short-article}
19707lines; default 100.
19708
19709@item long
19710True if the article is longer than @code{gnus-agent-long-article}
19711lines; default 200.
19712
19713@item low
19714True if the article has a download score less than
19715@code{gnus-agent-low-score}; default 0.
19716
19717@item high
19718True if the article has a download score greater than
19719@code{gnus-agent-high-score}; default 0.
19720
19721@item spam
19722True if the Gnus Agent guesses that the article is spam. The
19723heuristics may change over time, but at present it just computes a
19724checksum and sees whether articles match.
19725
19726@item true
19727Always true.
19728
19729@item false
19730Always false.
19731@end table
19732
19733If you want to create your own predicate function, here's what you have
19734to know: The functions are called with no parameters, but the
19735@code{gnus-headers} and @code{gnus-score} dynamic variables are bound to
19736useful values.
19737
19738For example, you could decide that you don't want to download articles
19739that were posted more than a certain number of days ago (e.g. posted
19740more than @code{gnus-agent-expire-days} ago) you might write a function
19741something along the lines of the following:
19742
19743@lisp
19744(defun my-article-old-p ()
19745 "Say whether an article is old."
19746 (< (time-to-days (date-to-time (mail-header-date gnus-headers)))
19747 (- (time-to-days (current-time)) gnus-agent-expire-days)))
19748@end lisp
19749
19750with the predicate then defined as:
19751
19752@lisp
19753(not my-article-old-p)
19754@end lisp
19755
19756or you could append your predicate to the predefined
19757@code{gnus-category-predicate-alist} in your @file{~/.gnus.el} or
19758wherever.
19759
19760@lisp
19761(require 'gnus-agent)
19762(setq gnus-category-predicate-alist
19763 (append gnus-category-predicate-alist
19764 '((old . my-article-old-p))))
19765@end lisp
19766
19767and simply specify your predicate as:
19768
19769@lisp
19770(not old)
19771@end lisp
19772
19773If/when using something like the above, be aware that there are many
19774misconfigured systems/mailers out there and so an article's date is not
19775always a reliable indication of when it was posted. Hell, some people
19776just don't give a damn.
19777
19778The above predicates apply to @emph{all} the groups which belong to the
19779category. However, if you wish to have a specific predicate for an
19780individual group within a category, or you're just too lazy to set up a
19781new category, you can enter a group's individual predicate in its group
19782parameters like so:
19783
19784@lisp
19785(agent-predicate . short)
19786@end lisp
19787
19788This is the group/topic parameter equivalent of the agent category default.
19789Note that when specifying a single word predicate like this, the
19790@code{agent-predicate} specification must be in dotted pair notation.
19791
19792The equivalent of the longer example from above would be:
19793
19794@lisp
19795(agent-predicate or high (and (not low) (not long)))
19796@end lisp
19797
19798The outer parenthesis required in the category specification are not
19799entered here as, not being in dotted pair notation, the value of the
19800predicate is assumed to be a list.
19801
19802
19803Now, the syntax of the download score is the same as the syntax of
19804normal score files, except that all elements that require actually
19805seeing the article itself are verboten. This means that only the
19806following headers can be scored on: @code{Subject}, @code{From},
19807@code{Date}, @code{Message-ID}, @code{References}, @code{Chars},
19808@code{Lines}, and @code{Xref}.
19809
19810As with predicates, the specification of the @code{download score rule}
19811to use in respect of a group can be in either the category definition if
19812it's to be applicable to all groups in therein, or a group's parameters
19813if it's to be specific to that group.
19814
19815In both of these places the @code{download score rule} can take one of
19816three forms:
19817
19818@enumerate
19819@item
19820Score rule
19821
19822This has the same syntax as a normal Gnus score file except only a
19823subset of scoring keywords are available as mentioned above.
19824
19825example:
19826
19827@itemize @bullet
19828@item
19829Category specification
19830
19831@lisp
19832(("from"
19833 ("Lars Ingebrigtsen" 1000000 nil s))
19834("lines"
19835 (500 -100 nil <)))
19836@end lisp
19837
19838@item
19839Group/Topic Parameter specification
19840
19841@lisp
19842(agent-score ("from"
19843 ("Lars Ingebrigtsen" 1000000 nil s))
19844 ("lines"
19845 (500 -100 nil <)))
19846@end lisp
19847
19848Again, note the omission of the outermost parenthesis here.
19849@end itemize
19850
19851@item
19852Agent score file
19853
19854These score files must @emph{only} contain the permitted scoring
19855keywords stated above.
19856
19857example:
19858
19859@itemize @bullet
19860@item
19861Category specification
19862
19863@lisp
19864("~/News/agent.SCORE")
19865@end lisp
19866
19867or perhaps
19868
19869@lisp
19870("~/News/agent.SCORE" "~/News/agent.group.SCORE")
19871@end lisp
19872
19873@item
19874Group Parameter specification
19875
19876@lisp
19877(agent-score "~/News/agent.SCORE")
19878@end lisp
19879
19880Additional score files can be specified as above. Need I say anything
19881about parenthesis?
19882@end itemize
19883
19884@item
19885Use @code{normal} score files
19886
19887If you don't want to maintain two sets of scoring rules for a group, and
19888your desired @code{downloading} criteria for a group are the same as your
19889@code{reading} criteria then you can tell the agent to refer to your
19890@code{normal} score files when deciding what to download.
19891
19892These directives in either the category definition or a group's
19893parameters will cause the agent to read in all the applicable score
19894files for a group, @emph{filtering out} those sections that do not
19895relate to one of the permitted subset of scoring keywords.
19896
19897@itemize @bullet
19898@item
19899Category Specification
19900
19901@lisp
19902file
19903@end lisp
19904
19905@item
19906Group Parameter specification
19907
19908@lisp
19909(agent-score . file)
19910@end lisp
19911@end itemize
19912@end enumerate
19913
19914@node Category Buffer
19915@subsubsection Category Buffer
19916
19917You'd normally do all category maintenance from the category buffer.
19918When you enter it for the first time (with the @kbd{J c} command from
19919the group buffer), you'll only see the @code{default} category.
19920
19921The following commands are available in this buffer:
19922
19923@table @kbd
19924@item q
19925@kindex q (Category)
19926@findex gnus-category-exit
19927Return to the group buffer (@code{gnus-category-exit}).
19928
19929@item e
19930@kindex e (Category)
19931@findex gnus-category-customize-category
19932Use a customization buffer to set all of the selected category's
19933parameters at one time (@code{gnus-category-customize-category}).
19934
19935@item k
19936@kindex k (Category)
19937@findex gnus-category-kill
19938Kill the current category (@code{gnus-category-kill}).
19939
19940@item c
19941@kindex c (Category)
19942@findex gnus-category-copy
19943Copy the current category (@code{gnus-category-copy}).
19944
19945@item a
19946@kindex a (Category)
19947@findex gnus-category-add
19948Add a new category (@code{gnus-category-add}).
19949
19950@item p
19951@kindex p (Category)
19952@findex gnus-category-edit-predicate
19953Edit the predicate of the current category
19954(@code{gnus-category-edit-predicate}).
19955
19956@item g
19957@kindex g (Category)
19958@findex gnus-category-edit-groups
19959Edit the list of groups belonging to the current category
19960(@code{gnus-category-edit-groups}).
19961
19962@item s
19963@kindex s (Category)
19964@findex gnus-category-edit-score
19965Edit the download score rule of the current category
19966(@code{gnus-category-edit-score}).
19967
19968@item l
19969@kindex l (Category)
19970@findex gnus-category-list
19971List all the categories (@code{gnus-category-list}).
19972@end table
19973
19974
19975@node Category Variables
19976@subsubsection Category Variables
19977
19978@table @code
19979@item gnus-category-mode-hook
19980@vindex gnus-category-mode-hook
19981Hook run in category buffers.
19982
19983@item gnus-category-line-format
19984@vindex gnus-category-line-format
19985Format of the lines in the category buffer (@pxref{Formatting
19986Variables}). Valid elements are:
19987
19988@table @samp
19989@item c
19990The name of the category.
19991
19992@item g
19993The number of groups in the category.
19994@end table
19995
19996@item gnus-category-mode-line-format
19997@vindex gnus-category-mode-line-format
19998Format of the category mode line (@pxref{Mode Line Formatting}).
19999
20000@item gnus-agent-short-article
20001@vindex gnus-agent-short-article
20002Articles that have fewer lines than this are short. Default 100.
20003
20004@item gnus-agent-long-article
20005@vindex gnus-agent-long-article
20006Articles that have more lines than this are long. Default 200.
20007
20008@item gnus-agent-low-score
20009@vindex gnus-agent-low-score
20010Articles that have a score lower than this have a low score. Default
200110.
20012
20013@item gnus-agent-high-score
20014@vindex gnus-agent-high-score
20015Articles that have a score higher than this have a high score. Default
200160.
20017
20018@item gnus-agent-expire-days
20019@vindex gnus-agent-expire-days
20020The number of days that a @samp{read} article must stay in the agent's
20021local disk before becoming eligible for expiration (While the name is
20022the same, this doesn't mean expiring the article on the server. It
20023just means deleting the local copy of the article). What is also
20024important to understand is that the counter starts with the time the
20025article was written to the local disk and not the time the article was
20026read.
20027Default 7.
20028
20029@item gnus-agent-enable-expiration
20030@vindex gnus-agent-enable-expiration
20031Determines whether articles in a group are, by default, expired or
20032retained indefinitely. The default is @code{ENABLE} which means that
20033you'll have to disable expiration when desired. On the other hand,
20034you could set this to @code{DISABLE}. In that case, you would then
20035have to enable expiration in selected groups.
20036
20037@end table
20038
20039
20040@node Agent Commands
20041@subsection Agent Commands
20042@findex gnus-agent-toggle-plugged
20043@kindex J j (Agent)
20044
20045All the Gnus Agent commands are on the @kbd{J} submap. The @kbd{J j}
20046(@code{gnus-agent-toggle-plugged}) command works in all modes, and
20047toggles the plugged/unplugged state of the Gnus Agent.
20048
20049
20050@menu
20051* Group Agent Commands:: Configure groups and fetch their contents.
20052* Summary Agent Commands:: Manually select then fetch specific articles.
20053* Server Agent Commands:: Select the servers that are supported by the agent.
20054@end menu
20055
20056
20057
20058
20059@node Group Agent Commands
20060@subsubsection Group Agent Commands
20061
20062@table @kbd
20063@item J u
20064@kindex J u (Agent Group)
20065@findex gnus-agent-fetch-groups
20066Fetch all eligible articles in the current group
20067(@code{gnus-agent-fetch-groups}).
20068
20069@item J c
20070@kindex J c (Agent Group)
20071@findex gnus-enter-category-buffer
20072Enter the Agent category buffer (@code{gnus-enter-category-buffer}).
20073
20074@item J s
20075@kindex J s (Agent Group)
20076@findex gnus-agent-fetch-session
20077Fetch all eligible articles in all groups
20078(@code{gnus-agent-fetch-session}).
20079
20080@item J S
20081@kindex J S (Agent Group)
20082@findex gnus-group-send-queue
20083Send all sendable messages in the queue group
20084(@code{gnus-group-send-queue}). @xref{Drafts}.
20085
20086@item J a
20087@kindex J a (Agent Group)
20088@findex gnus-agent-add-group
20089Add the current group to an Agent category
20090(@code{gnus-agent-add-group}). This command understands the
20091process/prefix convention (@pxref{Process/Prefix}).
20092
20093@item J r
20094@kindex J r (Agent Group)
20095@findex gnus-agent-remove-group
20096Remove the current group from its category, if any
20097(@code{gnus-agent-remove-group}). This command understands the
20098process/prefix convention (@pxref{Process/Prefix}).
20099
20100@item J Y
20101@kindex J Y (Agent Group)
20102@findex gnus-agent-synchronize-flags
20103Synchronize flags changed while unplugged with remote server, if any.
20104
20105
20106@end table
20107
20108
20109@node Summary Agent Commands
20110@subsubsection Summary Agent Commands
20111
20112@table @kbd
20113@item J #
20114@kindex J # (Agent Summary)
20115@findex gnus-agent-mark-article
20116Mark the article for downloading (@code{gnus-agent-mark-article}).
20117
20118@item J M-#
20119@kindex J M-# (Agent Summary)
20120@findex gnus-agent-unmark-article
20121Remove the downloading mark from the article
20122(@code{gnus-agent-unmark-article}).
20123
20124@cindex %
20125@item @@
20126@kindex @@ (Agent Summary)
20127@findex gnus-agent-toggle-mark
20128Toggle whether to download the article
20129(@code{gnus-agent-toggle-mark}). The download mark is @samp{%} by
20130default.
20131
20132@item J c
20133@kindex J c (Agent Summary)
20134@findex gnus-agent-catchup
20135Mark all articles as read (@code{gnus-agent-catchup}) that are neither cached, downloaded, nor downloadable.
20136
20137@item J S
20138@kindex J S (Agent Summary)
20139@findex gnus-agent-fetch-group
20140Download all eligible (@pxref{Agent Categories}) articles in this group.
20141(@code{gnus-agent-fetch-group}).
20142
20143@item J s
20144@kindex J s (Agent Summary)
01c52d31 20145@findex gnus-agent-summary-fetch-series
4009494e 20146Download all processable articles in this group.
01c52d31 20147(@code{gnus-agent-summary-fetch-series}).
4009494e
GM
20148
20149@item J u
20150@kindex J u (Agent Summary)
20151@findex gnus-agent-summary-fetch-group
20152Download all downloadable articles in the current group
20153(@code{gnus-agent-summary-fetch-group}).
20154
20155@end table
20156
20157
20158@node Server Agent Commands
20159@subsubsection Server Agent Commands
20160
20161@table @kbd
20162@item J a
20163@kindex J a (Agent Server)
20164@findex gnus-agent-add-server
20165Add the current server to the list of servers covered by the Gnus Agent
20166(@code{gnus-agent-add-server}).
20167
20168@item J r
20169@kindex J r (Agent Server)
20170@findex gnus-agent-remove-server
20171Remove the current server from the list of servers covered by the Gnus
20172Agent (@code{gnus-agent-remove-server}).
20173
20174@end table
20175
20176
20177@node Agent Visuals
20178@subsection Agent Visuals
20179
20180If you open a summary while unplugged and, Gnus knows from the group's
20181active range that there are more articles than the headers currently
20182stored in the Agent, you may see some articles whose subject looks
20183something like @samp{[Undownloaded article #####]}. These are
20184placeholders for the missing headers. Aside from setting a mark,
20185there is not much that can be done with one of these placeholders.
20186When Gnus finally gets a chance to fetch the group's headers, the
20187placeholders will automatically be replaced by the actual headers.
20188You can configure the summary buffer's maneuvering to skip over the
20189placeholders if you care (See @code{gnus-auto-goto-ignores}).
20190
20191While it may be obvious to all, the only headers and articles
20192available while unplugged are those headers and articles that were
20193fetched into the Agent while previously plugged. To put it another
20194way, ``If you forget to fetch something while plugged, you might have a
20195less than satisfying unplugged session''. For this reason, the Agent
20196adds two visual effects to your summary buffer. These effects display
20197the download status of each article so that you always know which
20198articles will be available when unplugged.
20199
20200The first visual effect is the @samp{%O} spec. If you customize
20201@code{gnus-summary-line-format} to include this specifier, you will add
20202a single character field that indicates an article's download status.
20203Articles that have been fetched into either the Agent or the Cache,
20204will display @code{gnus-downloaded-mark} (defaults to @samp{+}). All
20205other articles will display @code{gnus-undownloaded-mark} (defaults to
20206@samp{-}). If you open a group that has not been agentized, a space
20207(@samp{ }) will be displayed.
20208
20209The second visual effect are the undownloaded faces. The faces, there
20210are three indicating the article's score (low, normal, high), seem to
20211result in a love/hate response from many Gnus users. The problem is
20212that the face selection is controlled by a list of condition tests and
20213face names (See @code{gnus-summary-highlight}). Each condition is
20214tested in the order in which it appears in the list so early
20215conditions have precedence over later conditions. All of this means
20216that, if you tick an undownloaded article, the article will continue
20217to be displayed in the undownloaded face rather than the ticked face.
20218
20219If you use the Agent as a cache (to avoid downloading the same article
20220each time you visit it or to minimize your connection time), the
20221undownloaded face will probably seem like a good idea. The reason
20222being that you do all of our work (marking, reading, deleting) with
01c52d31
MB
20223downloaded articles so the normal faces always appear. For those
20224users using the agent to improve online performance by caching the NOV
20225database (most users since 5.10.2), the undownloaded faces may appear
20226to be an absolutely horrible idea. The issue being that, since none
20227of their articles have been fetched into the Agent, all of the
20228normal faces will be obscured by the undownloaded faces.
20229
20230If you would like to use the undownloaded faces, you must enable the
20231undownloaded faces by setting the @code{agent-enable-undownloaded-faces}
20232group parameter to @code{t}. This parameter, like all other agent
20233parameters, may be set on an Agent Category (@pxref{Agent Categories}),
20234a Group Topic (@pxref{Topic Parameters}), or an individual group
20235(@pxref{Group Parameters}).
20236
20237The one problem common to all users using the agent is how quickly it
20238can consume disk space. If you using the agent on many groups, it is
20239even more difficult to effectively recover disk space. One solution
20240is the @samp{%F} format available in @code{gnus-group-line-format}.
20241This format will display the actual disk space used by articles
20242fetched into both the agent and cache. By knowing which groups use
20243the most space, users know where to focus their efforts when ``agent
20244expiring'' articles.
4009494e
GM
20245
20246@node Agent as Cache
20247@subsection Agent as Cache
20248
20249When Gnus is plugged, it is not efficient to download headers or
20250articles from the server again, if they are already stored in the
20251Agent. So, Gnus normally only downloads headers once, and stores them
20252in the Agent. These headers are later used when generating the summary
20253buffer, regardless of whether you are plugged or unplugged. Articles
20254are not cached in the Agent by default though (that would potentially
20255consume lots of disk space), but if you have already downloaded an
20256article into the Agent, Gnus will not download the article from the
20257server again but use the locally stored copy instead.
20258
20259If you so desire, you can configure the agent (see @code{gnus-agent-cache}
20260@pxref{Agent Variables}) to always download headers and articles while
20261plugged. Gnus will almost certainly be slower, but it will be kept
20262synchronized with the server. That last point probably won't make any
20263sense if you are using a nntp or nnimap back end.
20264
20265@node Agent Expiry
20266@subsection Agent Expiry
20267
20268@vindex gnus-agent-expire-days
20269@findex gnus-agent-expire
20270@kindex M-x gnus-agent-expire
20271@kindex M-x gnus-agent-expire-group
20272@findex gnus-agent-expire-group
20273@cindex agent expiry
20274@cindex Gnus agent expiry
20275@cindex expiry, in Gnus agent
20276
20277The Agent back end, @code{nnagent}, doesn't handle expiry. Well, at
20278least it doesn't handle it like other back ends. Instead, there are
20279special @code{gnus-agent-expire} and @code{gnus-agent-expire-group}
20280commands that will expire all read articles that are older than
20281@code{gnus-agent-expire-days} days. They can be run whenever you feel
20282that you're running out of space. Neither are particularly fast or
20283efficient, and it's not a particularly good idea to interrupt them (with
20284@kbd{C-g} or anything else) once you've started one of them.
20285
20286Note that other functions, e.g. @code{gnus-request-expire-articles},
20287might run @code{gnus-agent-expire} for you to keep the agent
20288synchronized with the group.
20289
20290The agent parameter @code{agent-enable-expiration} may be used to
20291prevent expiration in selected groups.
20292
20293@vindex gnus-agent-expire-all
20294If @code{gnus-agent-expire-all} is non-@code{nil}, the agent
20295expiration commands will expire all articles---unread, read, ticked
20296and dormant. If @code{nil} (which is the default), only read articles
20297are eligible for expiry, and unread, ticked and dormant articles will
20298be kept indefinitely.
20299
20300If you find that some articles eligible for expiry are never expired,
20301perhaps some Gnus Agent files are corrupted. There's are special
20302commands, @code{gnus-agent-regenerate} and
20303@code{gnus-agent-regenerate-group}, to fix possible problems.
20304
20305@node Agent Regeneration
20306@subsection Agent Regeneration
20307
20308@cindex agent regeneration
20309@cindex Gnus agent regeneration
20310@cindex regeneration
20311
20312The local data structures used by @code{nnagent} may become corrupted
20313due to certain exceptional conditions. When this happens,
20314@code{nnagent} functionality may degrade or even fail. The solution
20315to this problem is to repair the local data structures by removing all
20316internal inconsistencies.
20317
20318For example, if your connection to your server is lost while
20319downloaded articles into the agent, the local data structures will not
20320know about articles successfully downloaded prior to the connection
20321failure. Running @code{gnus-agent-regenerate} or
20322@code{gnus-agent-regenerate-group} will update the data structures
20323such that you don't need to download these articles a second time.
20324
20325@findex gnus-agent-regenerate
20326@kindex M-x gnus-agent-regenerate
20327The command @code{gnus-agent-regenerate} will perform
20328@code{gnus-agent-regenerate-group} on every agentized group. While
20329you can run @code{gnus-agent-regenerate} in any buffer, it is strongly
20330recommended that you first close all summary buffers.
20331
20332@findex gnus-agent-regenerate-group
20333@kindex M-x gnus-agent-regenerate-group
20334The command @code{gnus-agent-regenerate-group} uses the local copies
20335of individual articles to repair the local @acronym{NOV}(header) database. It
20336then updates the internal data structures that document which articles
20337are stored locally. An optional argument will mark articles in the
20338agent as unread.
20339
01c52d31
MB
20340@node Agent and flags
20341@subsection Agent and flags
4009494e 20342
01c52d31
MB
20343The Agent works with any Gnus back end including those, such as
20344nnimap, that store flags (read, ticked, etc) on the server. Sadly,
20345the Agent does not actually know which backends keep their flags in
20346the backend server rather than in @file{.newsrc}. This means that the
20347Agent, while unplugged or disconnected, will always record all changes
20348to the flags in its own files.
4009494e 20349
01c52d31
MB
20350When you plug back in, Gnus will then check to see if you have any
20351changed any flags and ask if you wish to synchronize these with the
20352server. This behavior is customizable by @code{gnus-agent-synchronize-flags}.
4009494e
GM
20353
20354@vindex gnus-agent-synchronize-flags
20355If @code{gnus-agent-synchronize-flags} is @code{nil}, the Agent will
20356never automatically synchronize flags. If it is @code{ask}, which is
20357the default, the Agent will check if you made any changes and if so
20358ask if you wish to synchronize these when you re-connect. If it has
20359any other value, all flags will be synchronized automatically.
20360
20361If you do not wish to synchronize flags automatically when you
20362re-connect, you can do it manually with the
20363@code{gnus-agent-synchronize-flags} command that is bound to @kbd{J Y}
20364in the group buffer.
20365
01c52d31
MB
20366Technical note: the synchronization algorithm does not work by ``pushing''
20367all local flags to the server, but rather by incrementally updated the
20368server view of flags by changing only those flags that were changed by
20369the user. Thus, if you set one flag on an article, quit the group then
20370re-select the group and remove the flag; the flag will be set and
20371removed from the server when you ``synchronize''. The queued flag
20372operations can be found in the per-server @code{flags} file in the Agent
20373directory. It's emptied when you synchronize flags.
20374
20375@node Agent and IMAP
20376@subsection Agent and IMAP
20377
20378The Agent works with any Gnus back end, including nnimap. However,
20379since there are some conceptual differences between @acronym{NNTP} and
20380@acronym{IMAP}, this section (should) provide you with some information to
20381make Gnus Agent work smoother as a @acronym{IMAP} Disconnected Mode client.
20382
4009494e
GM
20383Some things are currently not implemented in the Agent that you'd might
20384expect from a disconnected @acronym{IMAP} client, including:
20385
20386@itemize @bullet
20387
20388@item
20389Copying/moving articles into nnimap groups when unplugged.
20390
20391@item
20392Creating/deleting nnimap groups when unplugged.
20393
20394@end itemize
20395
4009494e
GM
20396@node Outgoing Messages
20397@subsection Outgoing Messages
20398
01c52d31
MB
20399By default, when Gnus is unplugged, all outgoing messages (both mail
20400and news) are stored in the draft group ``queue'' (@pxref{Drafts}).
20401You can view them there after posting, and edit them at will.
4009494e 20402
01c52d31
MB
20403You can control the circumstances under which outgoing mail is queued
20404(see @code{gnus-agent-queue-mail}, @pxref{Agent Variables}). Outgoing
20405news is always queued when Gnus is unplugged, and never otherwise.
4009494e 20406
01c52d31
MB
20407You can send the messages either from the draft group with the special
20408commands available there, or you can use the @kbd{J S} command in the
20409group buffer to send all the sendable messages in the draft group.
20410Posting news will only work when Gnus is plugged, but you can send
20411mail at any time.
4009494e 20412
01c52d31
MB
20413If sending mail while unplugged does not work for you and you worry
20414about hitting @kbd{J S} by accident when unplugged, you can have Gnus
20415ask you to confirm your action (see
20416@code{gnus-agent-prompt-send-queue}, @pxref{Agent Variables}).
4009494e
GM
20417
20418@node Agent Variables
20419@subsection Agent Variables
20420
20421@table @code
01c52d31
MB
20422@item gnus-agent
20423@vindex gnus-agent
20424Is the agent enabled? The default is @code{t}. When first enabled,
20425the agent will use @code{gnus-agent-auto-agentize-methods} to
20426automatically mark some back ends as agentized. You may change which
20427back ends are agentized using the agent commands in the server buffer.
20428
20429To enter the server buffer, use the @kbd{^}
20430(@code{gnus-group-enter-server-mode}) command in the group buffer.
20431
20432
4009494e
GM
20433@item gnus-agent-directory
20434@vindex gnus-agent-directory
20435Where the Gnus Agent will store its files. The default is
20436@file{~/News/agent/}.
20437
20438@item gnus-agent-handle-level
20439@vindex gnus-agent-handle-level
20440Groups on levels (@pxref{Group Levels}) higher than this variable will
20441be ignored by the Agent. The default is @code{gnus-level-subscribed},
20442which means that only subscribed group will be considered by the Agent
20443by default.
20444
20445@item gnus-agent-plugged-hook
20446@vindex gnus-agent-plugged-hook
20447Hook run when connecting to the network.
20448
20449@item gnus-agent-unplugged-hook
20450@vindex gnus-agent-unplugged-hook
20451Hook run when disconnecting from the network.
20452
20453@item gnus-agent-fetched-hook
20454@vindex gnus-agent-fetched-hook
20455Hook run when finished fetching articles.
20456
20457@item gnus-agent-cache
20458@vindex gnus-agent-cache
20459Variable to control whether use the locally stored @acronym{NOV} and
20460articles when plugged, e.g. essentially using the Agent as a cache.
20461The default is non-@code{nil}, which means to use the Agent as a cache.
20462
20463@item gnus-agent-go-online
20464@vindex gnus-agent-go-online
20465If @code{gnus-agent-go-online} is @code{nil}, the Agent will never
20466automatically switch offline servers into online status. If it is
20467@code{ask}, the default, the Agent will ask if you wish to switch
20468offline servers into online status when you re-connect. If it has any
20469other value, all offline servers will be automatically switched into
20470online status.
20471
20472@item gnus-agent-mark-unread-after-downloaded
20473@vindex gnus-agent-mark-unread-after-downloaded
20474If @code{gnus-agent-mark-unread-after-downloaded} is non-@code{nil},
20475mark articles as unread after downloading. This is usually a safe
20476thing to do as the newly downloaded article has obviously not been
20477read. The default is @code{t}.
20478
01c52d31
MB
20479@item gnus-agent-synchronize-flags
20480@vindex gnus-agent-synchronize-flags
20481If @code{gnus-agent-synchronize-flags} is @code{nil}, the Agent will
20482never automatically synchronize flags. If it is @code{ask}, which is
20483the default, the Agent will check if you made any changes and if so
20484ask if you wish to synchronize these when you re-connect. If it has
20485any other value, all flags will be synchronized automatically.
20486
4009494e
GM
20487@item gnus-agent-consider-all-articles
20488@vindex gnus-agent-consider-all-articles
20489If @code{gnus-agent-consider-all-articles} is non-@code{nil}, the
20490agent will let the agent predicate decide whether articles need to be
20491downloaded or not, for all articles. When @code{nil}, the default,
20492the agent will only let the predicate decide whether unread articles
20493are downloaded or not. If you enable this, you may also want to look
20494into the agent expiry settings (@pxref{Category Variables}), so that
20495the agent doesn't download articles which the agent will later expire,
20496over and over again.
20497
20498@item gnus-agent-max-fetch-size
20499@vindex gnus-agent-max-fetch-size
20500The agent fetches articles into a temporary buffer prior to parsing
20501them into individual files. To avoid exceeding the max. buffer size,
20502the agent alternates between fetching and parsing until all articles
20503have been fetched. @code{gnus-agent-max-fetch-size} provides a size
20504limit to control how often the cycling occurs. A large value improves
20505performance. A small value minimizes the time lost should the
20506connection be lost while fetching (You may need to run
20507@code{gnus-agent-regenerate-group} to update the group's state.
20508However, all articles parsed prior to loosing the connection will be
20509available while unplugged). The default is 10M so it is unusual to
20510see any cycling.
20511
20512@item gnus-server-unopen-status
20513@vindex gnus-server-unopen-status
20514Perhaps not an Agent variable, but closely related to the Agent, this
20515variable says what will happen if Gnus cannot open a server. If the
20516Agent is enabled, the default, @code{nil}, makes Gnus ask the user
20517whether to deny the server or whether to unplug the agent. If the
20518Agent is disabled, Gnus always simply deny the server. Other choices
20519for this variable include @code{denied} and @code{offline} the latter
20520is only valid if the Agent is used.
20521
20522@item gnus-auto-goto-ignores
20523@vindex gnus-auto-goto-ignores
20524Another variable that isn't an Agent variable, yet so closely related
20525that most will look for it here, this variable tells the summary
20526buffer how to maneuver around undownloaded (only headers stored in the
20527agent) and unfetched (neither article nor headers stored) articles.
20528
20529The valid values are @code{nil} (maneuver to any article),
20530@code{undownloaded} (maneuvering while unplugged ignores articles that
20531have not been fetched), @code{always-undownloaded} (maneuvering always
20532ignores articles that have not been fetched), @code{unfetched}
20533(maneuvering ignores articles whose headers have not been fetched).
20534
01c52d31
MB
20535@item gnus-agent-queue-mail
20536@vindex gnus-agent-queue-mail
20537When @code{gnus-agent-queue-mail} is @code{always}, Gnus will always
20538queue mail rather than sending it straight away. When @code{t}, Gnus
20539will queue mail when unplugged only. When @code{nil}, never queue
20540mail. The default is @code{t}.
20541
20542@item gnus-agent-prompt-send-queue
20543@vindex gnus-agent-prompt-send-queue
20544When @code{gnus-agent-prompt-send-queue} is non-@code{nil} Gnus will
20545prompt you to confirm that you really wish to proceed if you hit
20546@kbd{J S} while unplugged. The default is @code{nil}.
20547
4009494e
GM
20548@item gnus-agent-auto-agentize-methods
20549@vindex gnus-agent-auto-agentize-methods
20550If you have never used the Agent before (or more technically, if
20551@file{~/News/agent/lib/servers} does not exist), Gnus will
20552automatically agentize a few servers for you. This variable control
01c52d31
MB
20553which back ends should be auto-agentized. It is typically only useful
20554to agentize remote back ends. The auto-agentizing has the same effect
4009494e
GM
20555as running @kbd{J a} on the servers (@pxref{Server Agent Commands}).
20556If the file exist, you must manage the servers manually by adding or
20557removing them, this variable is only applicable the first time you
20558start Gnus. The default is @samp{(nntp nnimap)}.
20559
20560@end table
20561
20562
20563@node Example Setup
20564@subsection Example Setup
20565
20566If you don't want to read this manual, and you have a fairly standard
20567setup, you may be able to use something like the following as your
20568@file{~/.gnus.el} file to get started.
20569
20570@lisp
20571;; @r{Define how Gnus is to fetch news. We do this over @acronym{NNTP}}
20572;; @r{from your ISP's server.}
20573(setq gnus-select-method '(nntp "news.your-isp.com"))
20574
20575;; @r{Define how Gnus is to read your mail. We read mail from}
20576;; @r{your ISP's @acronym{POP} server.}
20577(setq mail-sources '((pop :server "pop.your-isp.com")))
20578
20579;; @r{Say how Gnus is to store the mail. We use nnml groups.}
20580(setq gnus-secondary-select-methods '((nnml "")))
20581
20582;; @r{Make Gnus into an offline newsreader.}
20583;; (gnus-agentize) ; @r{The obsolete setting.}
20584;; (setq gnus-agent t) ; @r{Now the default.}
20585@end lisp
20586
20587That should be it, basically. Put that in your @file{~/.gnus.el} file,
20588edit to suit your needs, start up PPP (or whatever), and type @kbd{M-x
20589gnus}.
20590
20591If this is the first time you've run Gnus, you will be subscribed
20592automatically to a few default newsgroups. You'll probably want to
20593subscribe to more groups, and to do that, you have to query the
20594@acronym{NNTP} server for a complete list of groups with the @kbd{A A}
20595command. This usually takes quite a while, but you only have to do it
20596once.
20597
20598After reading and parsing a while, you'll be presented with a list of
20599groups. Subscribe to the ones you want to read with the @kbd{u}
20600command. @kbd{l} to make all the killed groups disappear after you've
20601subscribe to all the groups you want to read. (@kbd{A k} will bring
20602back all the killed groups.)
20603
20604You can now read the groups at once, or you can download the articles
20605with the @kbd{J s} command. And then read the rest of this manual to
20606find out which of the other gazillion things you want to customize.
20607
20608
20609@node Batching Agents
20610@subsection Batching Agents
20611@findex gnus-agent-batch
20612
20613Having the Gnus Agent fetch articles (and post whatever messages you've
20614written) is quite easy once you've gotten things set up properly. The
20615following shell script will do everything that is necessary:
20616
20617You can run a complete batch command from the command line with the
20618following incantation:
20619
20620@example
20621#!/bin/sh
20622emacs -batch -l ~/.emacs -l ~/.gnus.el -f gnus-agent-batch >/dev/null 2>&1
20623@end example
20624
20625
20626@node Agent Caveats
20627@subsection Agent Caveats
20628
20629The Gnus Agent doesn't seem to work like most other offline
20630newsreaders. Here are some common questions that some imaginary people
20631may ask:
20632
20633@table @dfn
20634@item If I read an article while plugged, do they get entered into the Agent?
20635
20636@strong{No}. If you want this behavior, add
20637@code{gnus-agent-fetch-selected-article} to
20638@code{gnus-select-article-hook}.
20639
20640@item If I read an article while plugged, and the article already exists in
20641the Agent, will it get downloaded once more?
20642
20643@strong{No}, unless @code{gnus-agent-cache} is @code{nil}.
20644
20645@end table
20646
20647In short, when Gnus is unplugged, it only looks into the locally stored
20648articles; when it's plugged, it talks to your ISP and may also use the
20649locally stored articles.
20650
20651
20652@node Scoring
20653@chapter Scoring
20654@cindex scoring
20655
20656Other people use @dfn{kill files}, but we here at Gnus Towers like
20657scoring better than killing, so we'd rather switch than fight. They do
20658something completely different as well, so sit up straight and pay
20659attention!
20660
20661@vindex gnus-summary-mark-below
20662All articles have a default score (@code{gnus-summary-default-score}),
20663which is 0 by default. This score may be raised or lowered either
20664interactively or by score files. Articles that have a score lower than
20665@code{gnus-summary-mark-below} are marked as read.
20666
20667Gnus will read any @dfn{score files} that apply to the current group
20668before generating the summary buffer.
20669
20670There are several commands in the summary buffer that insert score
20671entries based on the current article. You can, for instance, ask Gnus to
20672lower or increase the score of all articles with a certain subject.
20673
20674There are two sorts of scoring entries: Permanent and temporary.
20675Temporary score entries are self-expiring entries. Any entries that are
20676temporary and have not been used for, say, a week, will be removed
20677silently to help keep the sizes of the score files down.
20678
20679@menu
20680* Summary Score Commands:: Adding score entries for the current group.
20681* Group Score Commands:: General score commands.
20682* Score Variables:: Customize your scoring. (My, what terminology).
20683* Score File Format:: What a score file may contain.
20684* Score File Editing:: You can edit score files by hand as well.
20685* Adaptive Scoring:: Big Sister Gnus knows what you read.
20686* Home Score File:: How to say where new score entries are to go.
20687* Followups To Yourself:: Having Gnus notice when people answer you.
20688* Scoring On Other Headers:: Scoring on non-standard headers.
20689* Scoring Tips:: How to score effectively.
20690* Reverse Scoring:: That problem child of old is not problem.
20691* Global Score Files:: Earth-spanning, ear-splitting score files.
20692* Kill Files:: They are still here, but they can be ignored.
20693* Converting Kill Files:: Translating kill files to score files.
4009494e
GM
20694* Advanced Scoring:: Using logical expressions to build score rules.
20695* Score Decays:: It can be useful to let scores wither away.
20696@end menu
20697
20698
20699@node Summary Score Commands
20700@section Summary Score Commands
20701@cindex score commands
20702
20703The score commands that alter score entries do not actually modify real
20704score files. That would be too inefficient. Gnus maintains a cache of
20705previously loaded score files, one of which is considered the
20706@dfn{current score file alist}. The score commands simply insert
20707entries into this list, and upon group exit, this list is saved.
20708
20709The current score file is by default the group's local score file, even
20710if no such score file actually exists. To insert score commands into
20711some other score file (e.g. @file{all.SCORE}), you must first make this
20712score file the current one.
20713
20714General score commands that don't actually change the score file:
20715
20716@table @kbd
20717
20718@item V s
20719@kindex V s (Summary)
20720@findex gnus-summary-set-score
20721Set the score of the current article (@code{gnus-summary-set-score}).
20722
20723@item V S
20724@kindex V S (Summary)
20725@findex gnus-summary-current-score
20726Display the score of the current article
20727(@code{gnus-summary-current-score}).
20728
20729@item V t
20730@kindex V t (Summary)
20731@findex gnus-score-find-trace
20732Display all score rules that have been used on the current article
20733(@code{gnus-score-find-trace}). In the @code{*Score Trace*} buffer, you
20734may type @kbd{e} to edit score file corresponding to the score rule on
20735current line and @kbd{f} to format (@code{gnus-score-pretty-print}) the
20736score file and edit it.
20737
20738@item V w
20739@kindex V w (Summary)
20740@findex gnus-score-find-favourite-words
20741List words used in scoring (@code{gnus-score-find-favourite-words}).
20742
20743@item V R
20744@kindex V R (Summary)
20745@findex gnus-summary-rescore
20746Run the current summary through the scoring process
20747(@code{gnus-summary-rescore}). This might be useful if you're playing
20748around with your score files behind Gnus' back and want to see the
20749effect you're having.
20750
20751@item V c
20752@kindex V c (Summary)
20753@findex gnus-score-change-score-file
20754Make a different score file the current
20755(@code{gnus-score-change-score-file}).
20756
20757@item V e
20758@kindex V e (Summary)
20759@findex gnus-score-edit-current-scores
20760Edit the current score file (@code{gnus-score-edit-current-scores}).
20761You will be popped into a @code{gnus-score-mode} buffer (@pxref{Score
20762File Editing}).
20763
20764@item V f
20765@kindex V f (Summary)
20766@findex gnus-score-edit-file
20767Edit a score file and make this score file the current one
20768(@code{gnus-score-edit-file}).
20769
20770@item V F
20771@kindex V F (Summary)
20772@findex gnus-score-flush-cache
20773Flush the score cache (@code{gnus-score-flush-cache}). This is useful
20774after editing score files.
20775
20776@item V C
20777@kindex V C (Summary)
20778@findex gnus-score-customize
20779Customize a score file in a visually pleasing manner
20780(@code{gnus-score-customize}).
20781
20782@end table
20783
20784The rest of these commands modify the local score file.
20785
20786@table @kbd
20787
20788@item V m
20789@kindex V m (Summary)
20790@findex gnus-score-set-mark-below
20791Prompt for a score, and mark all articles with a score below this as
20792read (@code{gnus-score-set-mark-below}).
20793
20794@item V x
20795@kindex V x (Summary)
20796@findex gnus-score-set-expunge-below
20797Prompt for a score, and add a score rule to the current score file to
20798expunge all articles below this score
20799(@code{gnus-score-set-expunge-below}).
20800@end table
20801
20802The keystrokes for actually making score entries follow a very regular
20803pattern, so there's no need to list all the commands. (Hundreds of
20804them.)
20805
20806@findex gnus-summary-increase-score
20807@findex gnus-summary-lower-score
20808
20809@enumerate
20810@item
20811The first key is either @kbd{I} (upper case i) for increasing the score
20812or @kbd{L} for lowering the score.
20813@item
20814The second key says what header you want to score on. The following
20815keys are available:
20816@table @kbd
20817
20818@item a
20819Score on the author name.
20820
20821@item s
20822Score on the subject line.
20823
20824@item x
20825Score on the @code{Xref} line---i.e., the cross-posting line.
20826
20827@item r
20828Score on the @code{References} line.
20829
20830@item d
20831Score on the date.
20832
20833@item l
20834Score on the number of lines.
20835
20836@item i
20837Score on the @code{Message-ID} header.
20838
20839@item e
20840Score on an ``extra'' header, that is, one of those in gnus-extra-headers,
20841if your @acronym{NNTP} server tracks additional header data in overviews.
20842
20843@item f
20844Score on followups---this matches the author name, and adds scores to
20845the followups to this author. (Using this key leads to the creation of
20846@file{ADAPT} files.)
20847
20848@item b
20849Score on the body.
20850
20851@item h
20852Score on the head.
20853
20854@item t
20855Score on thread. (Using this key leads to the creation of @file{ADAPT}
20856files.)
20857
20858@end table
20859
20860@item
20861The third key is the match type. Which match types are valid depends on
20862what headers you are scoring on.
20863
20864@table @code
20865
20866@item strings
20867
20868@table @kbd
20869
20870@item e
20871Exact matching.
20872
20873@item s
20874Substring matching.
20875
20876@item f
20877Fuzzy matching (@pxref{Fuzzy Matching}).
20878
20879@item r
20880Regexp matching
20881@end table
20882
20883@item date
20884@table @kbd
20885
20886@item b
20887Before date.
20888
20889@item a
20890After date.
20891
20892@item n
20893This date.
20894@end table
20895
20896@item number
20897@table @kbd
20898
20899@item <
20900Less than number.
20901
20902@item =
20903Equal to number.
20904
20905@item >
20906Greater than number.
20907@end table
20908@end table
20909
20910@item
20911The fourth and usually final key says whether this is a temporary (i.e.,
20912expiring) score entry, or a permanent (i.e., non-expiring) score entry,
20913or whether it is to be done immediately, without adding to the score
20914file.
20915@table @kbd
20916
20917@item t
20918Temporary score entry.
20919
20920@item p
20921Permanent score entry.
20922
20923@item i
20924Immediately scoring.
20925@end table
20926
20927@item
20928If you are scoring on `e' (extra) headers, you will then be prompted for
20929the header name on which you wish to score. This must be a header named
20930in gnus-extra-headers, and @samp{TAB} completion is available.
20931
20932@end enumerate
20933
20934So, let's say you want to increase the score on the current author with
20935exact matching permanently: @kbd{I a e p}. If you want to lower the
20936score based on the subject line, using substring matching, and make a
20937temporary score entry: @kbd{L s s t}. Pretty easy.
20938
20939To make things a bit more complicated, there are shortcuts. If you use
20940a capital letter on either the second or third keys, Gnus will use
20941defaults for the remaining one or two keystrokes. The defaults are
20942``substring'' and ``temporary''. So @kbd{I A} is the same as @kbd{I a s
20943t}, and @kbd{I a R} is the same as @kbd{I a r t}.
20944
20945These functions take both the numerical prefix and the symbolic prefix
20946(@pxref{Symbolic Prefixes}). A numerical prefix says how much to lower
20947(or increase) the score of the article. A symbolic prefix of @code{a}
20948says to use the @file{all.SCORE} file for the command instead of the
20949current score file.
20950
20951@vindex gnus-score-mimic-keymap
20952The @code{gnus-score-mimic-keymap} says whether these commands will
20953pretend they are keymaps or not.
20954
20955
20956@node Group Score Commands
20957@section Group Score Commands
20958@cindex group score commands
20959
20960There aren't many of these as yet, I'm afraid.
20961
20962@table @kbd
20963
01c52d31
MB
20964@item W e
20965@kindex W e (Group)
20966@findex gnus-score-edit-all-score
20967Edit the apply-to-all-groups all.SCORE file. You will be popped into
20968a @code{gnus-score-mode} buffer (@pxref{Score File Editing}).
20969
4009494e
GM
20970@item W f
20971@kindex W f (Group)
20972@findex gnus-score-flush-cache
20973Gnus maintains a cache of score alists to avoid having to reload them
20974all the time. This command will flush the cache
20975(@code{gnus-score-flush-cache}).
20976
20977@end table
20978
20979You can do scoring from the command line by saying something like:
20980
20981@findex gnus-batch-score
20982@cindex batch scoring
20983@example
20984$ emacs -batch -l ~/.emacs -l ~/.gnus.el -f gnus-batch-score
20985@end example
20986
20987
20988@node Score Variables
20989@section Score Variables
20990@cindex score variables
20991
20992@table @code
20993
20994@item gnus-use-scoring
20995@vindex gnus-use-scoring
20996If @code{nil}, Gnus will not check for score files, and will not, in
20997general, do any score-related work. This is @code{t} by default.
20998
20999@item gnus-kill-killed
21000@vindex gnus-kill-killed
21001If this variable is @code{nil}, Gnus will never apply score files to
21002articles that have already been through the kill process. While this
21003may save you lots of time, it also means that if you apply a kill file
21004to a group, and then change the kill file and want to run it over you
21005group again to kill more articles, it won't work. You have to set this
21006variable to @code{t} to do that. (It is @code{t} by default.)
21007
21008@item gnus-kill-files-directory
21009@vindex gnus-kill-files-directory
21010All kill and score files will be stored in this directory, which is
21011initialized from the @env{SAVEDIR} environment variable by default.
21012This is @file{~/News/} by default.
21013
21014@item gnus-score-file-suffix
21015@vindex gnus-score-file-suffix
21016Suffix to add to the group name to arrive at the score file name
21017(@file{SCORE} by default.)
21018
21019@item gnus-score-uncacheable-files
21020@vindex gnus-score-uncacheable-files
21021@cindex score cache
21022All score files are normally cached to avoid excessive re-loading of
bbbe940b 21023score files. However, this might make your Emacs grow big and
4009494e
GM
21024bloated, so this regexp can be used to weed out score files unlikely
21025to be needed again. It would be a bad idea to deny caching of
21026@file{all.SCORE}, while it might be a good idea to not cache
21027@file{comp.infosystems.www.authoring.misc.ADAPT}. In fact, this
21028variable is @samp{ADAPT$} by default, so no adaptive score files will
21029be cached.
21030
21031@item gnus-save-score
21032@vindex gnus-save-score
21033If you have really complicated score files, and do lots of batch
21034scoring, then you might set this variable to @code{t}. This will make
21035Gnus save the scores into the @file{.newsrc.eld} file.
21036
21037If you do not set this to @code{t}, then manual scores (like those set
21038with @kbd{V s} (@code{gnus-summary-set-score})) will not be preserved
21039across group visits.
21040
21041@item gnus-score-interactive-default-score
21042@vindex gnus-score-interactive-default-score
21043Score used by all the interactive raise/lower commands to raise/lower
21044score with. Default is 1000, which may seem excessive, but this is to
21045ensure that the adaptive scoring scheme gets enough room to play with.
21046We don't want the small changes from the adaptive scoring to overwrite
21047manually entered data.
21048
21049@item gnus-summary-default-score
21050@vindex gnus-summary-default-score
21051Default score of an article, which is 0 by default.
21052
21053@item gnus-summary-expunge-below
21054@vindex gnus-summary-expunge-below
21055Don't display the summary lines of articles that have scores lower than
21056this variable. This is @code{nil} by default, which means that no
21057articles will be hidden. This variable is local to the summary buffers,
21058and has to be set from @code{gnus-summary-mode-hook}.
21059
21060@item gnus-score-over-mark
21061@vindex gnus-score-over-mark
21062Mark (in the third column) used for articles with a score over the
21063default. Default is @samp{+}.
21064
21065@item gnus-score-below-mark
21066@vindex gnus-score-below-mark
21067Mark (in the third column) used for articles with a score below the
21068default. Default is @samp{-}.
21069
21070@item gnus-score-find-score-files-function
21071@vindex gnus-score-find-score-files-function
21072Function used to find score files for the current group. This function
21073is called with the name of the group as the argument.
21074
21075Predefined functions available are:
21076@table @code
21077
21078@item gnus-score-find-single
21079@findex gnus-score-find-single
21080Only apply the group's own score file.
21081
21082@item gnus-score-find-bnews
21083@findex gnus-score-find-bnews
21084Apply all score files that match, using bnews syntax. This is the
21085default. If the current group is @samp{gnu.emacs.gnus}, for instance,
21086@file{all.emacs.all.SCORE}, @file{not.alt.all.SCORE} and
21087@file{gnu.all.SCORE} would all apply. In short, the instances of
21088@samp{all} in the score file names are translated into @samp{.*}, and
21089then a regexp match is done.
21090
21091This means that if you have some score entries that you want to apply to
21092all groups, then you put those entries in the @file{all.SCORE} file.
21093
21094The score files are applied in a semi-random order, although Gnus will
21095try to apply the more general score files before the more specific score
21096files. It does this by looking at the number of elements in the score
21097file names---discarding the @samp{all} elements.
21098
21099@item gnus-score-find-hierarchical
21100@findex gnus-score-find-hierarchical
21101Apply all score files from all the parent groups. This means that you
21102can't have score files like @file{all.SCORE}, but you can have
21103@file{SCORE}, @file{comp.SCORE} and @file{comp.emacs.SCORE} for each
21104server.
21105
21106@end table
21107This variable can also be a list of functions. In that case, all
21108these functions will be called with the group name as argument, and
21109all the returned lists of score files will be applied. These
21110functions can also return lists of lists of score alists directly. In
21111that case, the functions that return these non-file score alists
21112should probably be placed before the ``real'' score file functions, to
21113ensure that the last score file returned is the local score file.
21114Phu.
21115
21116For example, to do hierarchical scoring but use a non-server-specific
21117overall score file, you could use the value
21118@example
21119(list (lambda (group) ("all.SCORE"))
21120 'gnus-score-find-hierarchical)
21121@end example
21122
21123@item gnus-score-expiry-days
21124@vindex gnus-score-expiry-days
21125This variable says how many days should pass before an unused score file
21126entry is expired. If this variable is @code{nil}, no score file entries
21127are expired. It's 7 by default.
21128
21129@item gnus-update-score-entry-dates
21130@vindex gnus-update-score-entry-dates
21131If this variable is non-@code{nil}, temporary score entries that have
21132been triggered (matched) will have their dates updated. (This is how Gnus
21133controls expiry---all non-matched-entries will become too old while
21134matched entries will stay fresh and young.) However, if you set this
21135variable to @code{nil}, even matched entries will grow old and will
21136have to face that oh-so grim reaper.
21137
21138@item gnus-score-after-write-file-function
21139@vindex gnus-score-after-write-file-function
21140Function called with the name of the score file just written.
21141
21142@item gnus-score-thread-simplify
21143@vindex gnus-score-thread-simplify
21144If this variable is non-@code{nil}, article subjects will be
21145simplified for subject scoring purposes in the same manner as with
21146threading---according to the current value of
21147@code{gnus-simplify-subject-functions}. If the scoring entry uses
21148@code{substring} or @code{exact} matching, the match will also be
21149simplified in this manner.
21150
21151@end table
21152
21153
21154@node Score File Format
21155@section Score File Format
21156@cindex score file format
21157
21158A score file is an @code{emacs-lisp} file that normally contains just a
21159single form. Casual users are not expected to edit these files;
21160everything can be changed from the summary buffer.
21161
21162Anyway, if you'd like to dig into it yourself, here's an example:
21163
21164@lisp
21165(("from"
21166 ("Lars Ingebrigtsen" -10000)
21167 ("Per Abrahamsen")
21168 ("larsi\\|lmi" -50000 nil R))
21169 ("subject"
21170 ("Ding is Badd" nil 728373))
21171 ("xref"
21172 ("alt.politics" -1000 728372 s))
21173 ("lines"
21174 (2 -100 nil <))
21175 (mark 0)
21176 (expunge -1000)
21177 (mark-and-expunge -10)
21178 (read-only nil)
21179 (orphan -10)
21180 (adapt t)
21181 (files "/hom/larsi/News/gnu.SCORE")
21182 (exclude-files "all.SCORE")
21183 (local (gnus-newsgroup-auto-expire t)
21184 (gnus-summary-make-false-root empty))
21185 (eval (ding)))
21186@end lisp
21187
21188This example demonstrates most score file elements. @xref{Advanced
21189Scoring}, for a different approach.
21190
21191Even though this looks much like Lisp code, nothing here is actually
21192@code{eval}ed. The Lisp reader is used to read this form, though, so it
21193has to be valid syntactically, if not semantically.
21194
21195Six keys are supported by this alist:
21196
21197@table @code
21198
21199@item STRING
21200If the key is a string, it is the name of the header to perform the
21201match on. Scoring can only be performed on these eight headers:
21202@code{From}, @code{Subject}, @code{References}, @code{Message-ID},
21203@code{Xref}, @code{Lines}, @code{Chars} and @code{Date}. In addition to
21204these headers, there are three strings to tell Gnus to fetch the entire
21205article and do the match on larger parts of the article: @code{Body}
21206will perform the match on the body of the article, @code{Head} will
21207perform the match on the head of the article, and @code{All} will
21208perform the match on the entire article. Note that using any of these
21209last three keys will slow down group entry @emph{considerably}. The
21210final ``header'' you can score on is @code{Followup}. These score
21211entries will result in new score entries being added for all follow-ups
21212to articles that matches these score entries.
21213
21214Following this key is an arbitrary number of score entries, where each
21215score entry has one to four elements.
21216@enumerate
21217
21218@item
21219The first element is the @dfn{match element}. On most headers this will
21220be a string, but on the Lines and Chars headers, this must be an
21221integer.
21222
21223@item
21224If the second element is present, it should be a number---the @dfn{score
21225element}. This number should be an integer in the neginf to posinf
21226interval. This number is added to the score of the article if the match
21227is successful. If this element is not present, the
21228@code{gnus-score-interactive-default-score} number will be used
21229instead. This is 1000 by default.
21230
21231@item
21232If the third element is present, it should be a number---the @dfn{date
21233element}. This date says when the last time this score entry matched,
21234which provides a mechanism for expiring the score entries. It this
21235element is not present, the score entry is permanent. The date is
21236represented by the number of days since December 31, 1 BCE.
21237
21238@item
21239If the fourth element is present, it should be a symbol---the @dfn{type
21240element}. This element specifies what function should be used to see
21241whether this score entry matches the article. What match types that can
21242be used depends on what header you wish to perform the match on.
21243@table @dfn
21244
21245@item From, Subject, References, Xref, Message-ID
21246For most header types, there are the @code{r} and @code{R} (regexp), as
21247well as @code{s} and @code{S} (substring) types, and @code{e} and
21248@code{E} (exact match), and @code{w} (word match) types. If this
21249element is not present, Gnus will assume that substring matching should
21250be used. @code{R}, @code{S}, and @code{E} differ from the others in
21251that the matches will be done in a case-sensitive manner. All these
21252one-letter types are really just abbreviations for the @code{regexp},
21253@code{string}, @code{exact}, and @code{word} types, which you can use
21254instead, if you feel like.
21255
21256@item Extra
21257Just as for the standard string overview headers, if you are using
21258gnus-extra-headers, you can score on these headers' values. In this
21259case, there is a 5th element in the score entry, being the name of the
21260header to be scored. The following entry is useful in your
21261@file{all.SCORE} file in case of spam attacks from a single origin
21262host, if your @acronym{NNTP} server tracks @samp{NNTP-Posting-Host} in
21263overviews:
21264
21265@lisp
21266("111.222.333.444" -1000 nil s
21267 "NNTP-Posting-Host")
21268@end lisp
21269
21270@item Lines, Chars
21271These two headers use different match types: @code{<}, @code{>},
21272@code{=}, @code{>=} and @code{<=}.
21273
21274These predicates are true if
21275
21276@example
21277(PREDICATE HEADER MATCH)
21278@end example
21279
21280evaluates to non-@code{nil}. For instance, the advanced match
21281@code{("lines" 4 <)} (@pxref{Advanced Scoring}) will result in the
21282following form:
21283
21284@lisp
21285(< header-value 4)
21286@end lisp
21287
21288Or to put it another way: When using @code{<} on @code{Lines} with 4 as
21289the match, we get the score added if the article has less than 4 lines.
21290(It's easy to get confused and think it's the other way around. But
21291it's not. I think.)
21292
21293When matching on @code{Lines}, be careful because some back ends (like
21294@code{nndir}) do not generate @code{Lines} header, so every article ends
21295up being marked as having 0 lines. This can lead to strange results if
21296you happen to lower score of the articles with few lines.
21297
21298@item Date
21299For the Date header we have three kinda silly match types:
21300@code{before}, @code{at} and @code{after}. I can't really imagine this
21301ever being useful, but, like, it would feel kinda silly not to provide
21302this function. Just in case. You never know. Better safe than sorry.
21303Once burnt, twice shy. Don't judge a book by its cover. Never not have
21304sex on a first date. (I have been told that at least one person, and I
21305quote, ``found this function indispensable'', however.)
21306
21307@cindex ISO8601
21308@cindex date
21309A more useful match type is @code{regexp}. With it, you can match the
21310date string using a regular expression. The date is normalized to
21311ISO8601 compact format first---@var{YYYYMMDD}@code{T}@var{HHMMSS}. If
21312you want to match all articles that have been posted on April 1st in
21313every year, you could use @samp{....0401.........} as a match string,
21314for instance. (Note that the date is kept in its original time zone, so
21315this will match articles that were posted when it was April 1st where
21316the article was posted from. Time zones are such wholesome fun for the
21317whole family, eh?)
21318
21319@item Head, Body, All
21320These three match keys use the same match types as the @code{From} (etc)
21321header uses.
21322
21323@item Followup
21324This match key is somewhat special, in that it will match the
21325@code{From} header, and affect the score of not only the matching
21326articles, but also all followups to the matching articles. This allows
21327you e.g. increase the score of followups to your own articles, or
21328decrease the score of followups to the articles of some known
21329trouble-maker. Uses the same match types as the @code{From} header
21330uses. (Using this match key will lead to creation of @file{ADAPT}
21331files.)
21332
21333@item Thread
21334This match key works along the same lines as the @code{Followup} match
21335key. If you say that you want to score on a (sub-)thread started by an
21336article with a @code{Message-ID} @var{x}, then you add a @samp{thread}
21337match. This will add a new @samp{thread} match for each article that
21338has @var{x} in its @code{References} header. (These new @samp{thread}
21339matches will use the @code{Message-ID}s of these matching articles.)
21340This will ensure that you can raise/lower the score of an entire thread,
21341even though some articles in the thread may not have complete
21342@code{References} headers. Note that using this may lead to
21343undeterministic scores of the articles in the thread. (Using this match
21344key will lead to creation of @file{ADAPT} files.)
21345@end table
21346@end enumerate
21347
21348@cindex score file atoms
21349@item mark
21350The value of this entry should be a number. Any articles with a score
21351lower than this number will be marked as read.
21352
21353@item expunge
21354The value of this entry should be a number. Any articles with a score
21355lower than this number will be removed from the summary buffer.
21356
21357@item mark-and-expunge
21358The value of this entry should be a number. Any articles with a score
21359lower than this number will be marked as read and removed from the
21360summary buffer.
21361
21362@item thread-mark-and-expunge
21363The value of this entry should be a number. All articles that belong to
21364a thread that has a total score below this number will be marked as read
21365and removed from the summary buffer. @code{gnus-thread-score-function}
21366says how to compute the total score for a thread.
21367
21368@item files
21369The value of this entry should be any number of file names. These files
21370are assumed to be score files as well, and will be loaded the same way
21371this one was.
21372
21373@item exclude-files
21374The clue of this entry should be any number of files. These files will
21375not be loaded, even though they would normally be so, for some reason or
21376other.
21377
21378@item eval
994ff697 21379The value of this entry will be @code{eval}ed. This element will be
4009494e
GM
21380ignored when handling global score files.
21381
21382@item read-only
21383Read-only score files will not be updated or saved. Global score files
21384should feature this atom (@pxref{Global Score Files}). (Note:
21385@dfn{Global} here really means @dfn{global}; not your personal
21386apply-to-all-groups score files.)
21387
21388@item orphan
21389The value of this entry should be a number. Articles that do not have
21390parents will get this number added to their scores. Imagine you follow
21391some high-volume newsgroup, like @samp{comp.lang.c}. Most likely you
21392will only follow a few of the threads, also want to see any new threads.
21393
21394You can do this with the following two score file entries:
21395
21396@example
21397 (orphan -500)
21398 (mark-and-expunge -100)
21399@end example
21400
21401When you enter the group the first time, you will only see the new
21402threads. You then raise the score of the threads that you find
b1519d85 21403interesting (with @kbd{I T} or @kbd{I S}), and ignore (@kbd{c y}) the
4009494e
GM
21404rest. Next time you enter the group, you will see new articles in the
21405interesting threads, plus any new threads.
21406
21407I.e.---the orphan score atom is for high-volume groups where a few
21408interesting threads which can't be found automatically by ordinary
21409scoring rules exist.
21410
21411@item adapt
21412This entry controls the adaptive scoring. If it is @code{t}, the
21413default adaptive scoring rules will be used. If it is @code{ignore}, no
21414adaptive scoring will be performed on this group. If it is a list, this
21415list will be used as the adaptive scoring rules. If it isn't present,
21416or is something other than @code{t} or @code{ignore}, the default
21417adaptive scoring rules will be used. If you want to use adaptive
21418scoring on most groups, you'd set @code{gnus-use-adaptive-scoring} to
21419@code{t}, and insert an @code{(adapt ignore)} in the groups where you do
21420not want adaptive scoring. If you only want adaptive scoring in a few
21421groups, you'd set @code{gnus-use-adaptive-scoring} to @code{nil}, and
21422insert @code{(adapt t)} in the score files of the groups where you want
21423it.
21424
21425@item adapt-file
21426All adaptive score entries will go to the file named by this entry. It
21427will also be applied when entering the group. This atom might be handy
21428if you want to adapt on several groups at once, using the same adaptive
21429file for a number of groups.
21430
21431@item local
21432@cindex local variables
21433The value of this entry should be a list of @code{(@var{var}
21434@var{value})} pairs. Each @var{var} will be made buffer-local to the
21435current summary buffer, and set to the value specified. This is a
21436convenient, if somewhat strange, way of setting variables in some
21437groups if you don't like hooks much. Note that the @var{value} won't
21438be evaluated.
21439@end table
21440
21441
21442@node Score File Editing
21443@section Score File Editing
21444
21445You normally enter all scoring commands from the summary buffer, but you
21446might feel the urge to edit them by hand as well, so we've supplied you
21447with a mode for that.
21448
21449It's simply a slightly customized @code{emacs-lisp} mode, with these
21450additional commands:
21451
21452@table @kbd
21453
21454@item C-c C-c
21455@kindex C-c C-c (Score)
87035689 21456@findex gnus-score-edit-exit
4009494e 21457Save the changes you have made and return to the summary buffer
87035689 21458(@code{gnus-score-edit-exit}).
4009494e
GM
21459
21460@item C-c C-d
21461@kindex C-c C-d (Score)
21462@findex gnus-score-edit-insert-date
21463Insert the current date in numerical format
21464(@code{gnus-score-edit-insert-date}). This is really the day number, if
21465you were wondering.
21466
21467@item C-c C-p
21468@kindex C-c C-p (Score)
21469@findex gnus-score-pretty-print
21470The adaptive score files are saved in an unformatted fashion. If you
21471intend to read one of these files, you want to @dfn{pretty print} it
21472first. This command (@code{gnus-score-pretty-print}) does that for
21473you.
21474
21475@end table
21476
21477Type @kbd{M-x gnus-score-mode} to use this mode.
21478
21479@vindex gnus-score-mode-hook
21480@code{gnus-score-menu-hook} is run in score mode buffers.
21481
21482In the summary buffer you can use commands like @kbd{V f}, @kbd{V e} and
21483@kbd{V t} to begin editing score files.
21484
21485
21486@node Adaptive Scoring
21487@section Adaptive Scoring
21488@cindex adaptive scoring
21489
21490If all this scoring is getting you down, Gnus has a way of making it all
21491happen automatically---as if by magic. Or rather, as if by artificial
21492stupidity, to be precise.
21493
21494@vindex gnus-use-adaptive-scoring
21495When you read an article, or mark an article as read, or kill an
21496article, you leave marks behind. On exit from the group, Gnus can sniff
21497these marks and add score elements depending on what marks it finds.
21498You turn on this ability by setting @code{gnus-use-adaptive-scoring} to
21499@code{t} or @code{(line)}. If you want score adaptively on separate
21500words appearing in the subjects, you should set this variable to
21501@code{(word)}. If you want to use both adaptive methods, set this
21502variable to @code{(word line)}.
21503
21504@vindex gnus-default-adaptive-score-alist
21505To give you complete control over the scoring process, you can customize
21506the @code{gnus-default-adaptive-score-alist} variable. For instance, it
21507might look something like this:
21508
21509@lisp
21510(setq gnus-default-adaptive-score-alist
21511 '((gnus-unread-mark)
21512 (gnus-ticked-mark (from 4))
21513 (gnus-dormant-mark (from 5))
21514 (gnus-del-mark (from -4) (subject -1))
21515 (gnus-read-mark (from 4) (subject 2))
21516 (gnus-expirable-mark (from -1) (subject -1))
21517 (gnus-killed-mark (from -1) (subject -3))
21518 (gnus-kill-file-mark)
21519 (gnus-ancient-mark)
21520 (gnus-low-score-mark)
21521 (gnus-catchup-mark (from -1) (subject -1))))
21522@end lisp
21523
21524As you see, each element in this alist has a mark as a key (either a
21525variable name or a ``real'' mark---a character). Following this key is
21526a arbitrary number of header/score pairs. If there are no header/score
21527pairs following the key, no adaptive scoring will be done on articles
21528that have that key as the article mark. For instance, articles with
21529@code{gnus-unread-mark} in the example above will not get adaptive score
21530entries.
21531
21532Each article can have only one mark, so just a single of these rules
21533will be applied to each article.
21534
21535To take @code{gnus-del-mark} as an example---this alist says that all
21536articles that have that mark (i.e., are marked with @samp{e}) will have a
21537score entry added to lower based on the @code{From} header by -4, and
21538lowered by @code{Subject} by -1. Change this to fit your prejudices.
21539
21540If you have marked 10 articles with the same subject with
21541@code{gnus-del-mark}, the rule for that mark will be applied ten times.
21542That means that that subject will get a score of ten times -1, which
21543should be, unless I'm much mistaken, -10.
21544
21545If you have auto-expirable (mail) groups (@pxref{Expiring Mail}), all
21546the read articles will be marked with the @samp{E} mark. This'll
21547probably make adaptive scoring slightly impossible, so auto-expiring and
21548adaptive scoring doesn't really mix very well.
21549
21550The headers you can score on are @code{from}, @code{subject},
21551@code{message-id}, @code{references}, @code{xref}, @code{lines},
21552@code{chars} and @code{date}. In addition, you can score on
21553@code{followup}, which will create an adaptive score entry that matches
21554on the @code{References} header using the @code{Message-ID} of the
21555current article, thereby matching the following thread.
21556
21557If you use this scheme, you should set the score file atom @code{mark}
21558to something small---like -300, perhaps, to avoid having small random
21559changes result in articles getting marked as read.
21560
21561After using adaptive scoring for a week or so, Gnus should start to
21562become properly trained and enhance the authors you like best, and kill
21563the authors you like least, without you having to say so explicitly.
21564
21565You can control what groups the adaptive scoring is to be performed on
21566by using the score files (@pxref{Score File Format}). This will also
21567let you use different rules in different groups.
21568
21569@vindex gnus-adaptive-file-suffix
21570The adaptive score entries will be put into a file where the name is the
21571group name with @code{gnus-adaptive-file-suffix} appended. The default
21572is @file{ADAPT}.
21573
01c52d31
MB
21574@vindex gnus-adaptive-pretty-print
21575Adaptive score files can get huge and are not meant to be edited by
21576human hands. If @code{gnus-adaptive-pretty-print} is @code{nil} (the
21577deafult) those files will not be written in a human readable way.
21578
4009494e
GM
21579@vindex gnus-score-exact-adapt-limit
21580When doing adaptive scoring, substring or fuzzy matching would probably
21581give you the best results in most cases. However, if the header one
21582matches is short, the possibility for false positives is great, so if
21583the length of the match is less than
21584@code{gnus-score-exact-adapt-limit}, exact matching will be used. If
21585this variable is @code{nil}, exact matching will always be used to avoid
21586this problem.
21587
21588@vindex gnus-default-adaptive-word-score-alist
21589As mentioned above, you can adapt either on individual words or entire
21590headers. If you adapt on words, the
21591@code{gnus-default-adaptive-word-score-alist} variable says what score
21592each instance of a word should add given a mark.
21593
21594@lisp
21595(setq gnus-default-adaptive-word-score-alist
21596 `((,gnus-read-mark . 30)
21597 (,gnus-catchup-mark . -10)
21598 (,gnus-killed-mark . -20)
21599 (,gnus-del-mark . -15)))
21600@end lisp
21601
21602This is the default value. If you have adaption on words enabled, every
21603word that appears in subjects of articles marked with
21604@code{gnus-read-mark} will result in a score rule that increase the
21605score with 30 points.
21606
21607@vindex gnus-default-ignored-adaptive-words
21608@vindex gnus-ignored-adaptive-words
21609Words that appear in the @code{gnus-default-ignored-adaptive-words} list
21610will be ignored. If you wish to add more words to be ignored, use the
21611@code{gnus-ignored-adaptive-words} list instead.
21612
21613@vindex gnus-adaptive-word-length-limit
21614Some may feel that short words shouldn't count when doing adaptive
21615scoring. If so, you may set @code{gnus-adaptive-word-length-limit} to
21616an integer. Words shorter than this number will be ignored. This
21617variable defaults to @code{nil}.
21618
21619@vindex gnus-adaptive-word-syntax-table
21620When the scoring is done, @code{gnus-adaptive-word-syntax-table} is the
21621syntax table in effect. It is similar to the standard syntax table, but
21622it considers numbers to be non-word-constituent characters.
21623
21624@vindex gnus-adaptive-word-minimum
21625If @code{gnus-adaptive-word-minimum} is set to a number, the adaptive
21626word scoring process will never bring down the score of an article to
21627below this number. The default is @code{nil}.
21628
21629@vindex gnus-adaptive-word-no-group-words
21630If @code{gnus-adaptive-word-no-group-words} is set to @code{t}, gnus
21631won't adaptively word score any of the words in the group name. Useful
21632for groups like @samp{comp.editors.emacs}, where most of the subject
21633lines contain the word @samp{emacs}.
21634
21635After using this scheme for a while, it might be nice to write a
21636@code{gnus-psychoanalyze-user} command to go through the rules and see
21637what words you like and what words you don't like. Or perhaps not.
21638
21639Note that the adaptive word scoring thing is highly experimental and is
21640likely to change in the future. Initial impressions seem to indicate
21641that it's totally useless as it stands. Some more work (involving more
21642rigorous statistical methods) will have to be done to make this useful.
21643
21644
21645@node Home Score File
21646@section Home Score File
21647
21648The score file where new score file entries will go is called the
21649@dfn{home score file}. This is normally (and by default) the score file
21650for the group itself. For instance, the home score file for
21651@samp{gnu.emacs.gnus} is @file{gnu.emacs.gnus.SCORE}.
21652
21653However, this may not be what you want. It is often convenient to share
21654a common home score file among many groups---all @samp{emacs} groups
21655could perhaps use the same home score file.
21656
21657@vindex gnus-home-score-file
21658The variable that controls this is @code{gnus-home-score-file}. It can
21659be:
21660
21661@enumerate
21662@item
21663A string. Then this file will be used as the home score file for all
21664groups.
21665
21666@item
21667A function. The result of this function will be used as the home score
21668file. The function will be called with the name of the group as the
21669parameter.
21670
21671@item
21672A list. The elements in this list can be:
21673
21674@enumerate
21675@item
21676@code{(@var{regexp} @var{file-name})}. If the @var{regexp} matches the
21677group name, the @var{file-name} will be used as the home score file.
21678
21679@item
21680A function. If the function returns non-@code{nil}, the result will
21681be used as the home score file. The function will be called with the
21682name of the group as the parameter.
21683
21684@item
21685A string. Use the string as the home score file.
21686@end enumerate
21687
21688The list will be traversed from the beginning towards the end looking
21689for matches.
21690
21691@end enumerate
21692
21693So, if you want to use just a single score file, you could say:
21694
21695@lisp
21696(setq gnus-home-score-file
21697 "my-total-score-file.SCORE")
21698@end lisp
21699
21700If you want to use @file{gnu.SCORE} for all @samp{gnu} groups and
21701@file{rec.SCORE} for all @samp{rec} groups (and so on), you can say:
21702
21703@findex gnus-hierarchial-home-score-file
21704@lisp
21705(setq gnus-home-score-file
21706 'gnus-hierarchial-home-score-file)
21707@end lisp
21708
21709This is a ready-made function provided for your convenience.
21710Other functions include
21711
21712@table @code
21713@item gnus-current-home-score-file
21714@findex gnus-current-home-score-file
21715Return the ``current'' regular score file. This will make scoring
21716commands add entry to the ``innermost'' matching score file.
21717
21718@end table
21719
21720If you want to have one score file for the @samp{emacs} groups and
21721another for the @samp{comp} groups, while letting all other groups use
21722their own home score files:
21723
21724@lisp
21725(setq gnus-home-score-file
21726 ;; @r{All groups that match the regexp @code{"\\.emacs"}}
21727 '(("\\.emacs" "emacs.SCORE")
21728 ;; @r{All the comp groups in one score file}
21729 ("^comp" "comp.SCORE")))
21730@end lisp
21731
21732@vindex gnus-home-adapt-file
21733@code{gnus-home-adapt-file} works exactly the same way as
21734@code{gnus-home-score-file}, but says what the home adaptive score file
21735is instead. All new adaptive file entries will go into the file
21736specified by this variable, and the same syntax is allowed.
21737
21738In addition to using @code{gnus-home-score-file} and
21739@code{gnus-home-adapt-file}, you can also use group parameters
21740(@pxref{Group Parameters}) and topic parameters (@pxref{Topic
21741Parameters}) to achieve much the same. Group and topic parameters take
21742precedence over this variable.
21743
21744
21745@node Followups To Yourself
21746@section Followups To Yourself
21747
21748Gnus offers two commands for picking out the @code{Message-ID} header in
21749the current buffer. Gnus will then add a score rule that scores using
21750this @code{Message-ID} on the @code{References} header of other
21751articles. This will, in effect, increase the score of all articles that
21752respond to the article in the current buffer. Quite useful if you want
21753to easily note when people answer what you've said.
21754
21755@table @code
21756
21757@item gnus-score-followup-article
21758@findex gnus-score-followup-article
21759This will add a score to articles that directly follow up your own
21760article.
21761
21762@item gnus-score-followup-thread
21763@findex gnus-score-followup-thread
21764This will add a score to all articles that appear in a thread ``below''
21765your own article.
21766@end table
21767
21768@vindex message-sent-hook
21769These two functions are both primarily meant to be used in hooks like
21770@code{message-sent-hook}, like this:
21771@lisp
21772(add-hook 'message-sent-hook 'gnus-score-followup-thread)
21773@end lisp
21774
21775
21776If you look closely at your own @code{Message-ID}, you'll notice that
21777the first two or three characters are always the same. Here's two of
21778mine:
21779
21780@example
21781<x6u3u47icf.fsf@@eyesore.no>
21782<x6sp9o7ibw.fsf@@eyesore.no>
21783@end example
21784
21785So ``my'' ident on this machine is @samp{x6}. This can be
21786exploited---the following rule will raise the score on all followups to
21787myself:
21788
21789@lisp
21790("references"
21791 ("<x6[0-9a-z]+\\.fsf\\(_-_\\)?@@.*eyesore\\.no>"
21792 1000 nil r))
21793@end lisp
21794
21795Whether it's the first two or first three characters that are ``yours''
21796is system-dependent.
21797
21798
21799@node Scoring On Other Headers
21800@section Scoring On Other Headers
21801@cindex scoring on other headers
21802
21803Gnus is quite fast when scoring the ``traditional''
21804headers---@samp{From}, @samp{Subject} and so on. However, scoring
21805other headers requires writing a @code{head} scoring rule, which means
21806that Gnus has to request every single article from the back end to find
21807matches. This takes a long time in big groups.
21808
58333467
MB
21809@vindex gnus-inhibit-slow-scoring
21810You can inhibit this slow scoring on headers or body by setting the
21811variable @code{gnus-inhibit-slow-scoring}. If
21812@code{gnus-inhibit-slow-scoring} is regexp, slow scoring is inhibited if
21813the group matches the regexp. If it is t, slow scoring on it is
21814inhibited for all groups.
21815
21816Now, there's not much you can do about the slowness for news groups, but for
4009494e
GM
21817mail groups, you have greater control. In @ref{To From Newsgroups},
21818it's explained in greater detail what this mechanism does, but here's
21819a cookbook example for @code{nnml} on how to allow scoring on the
21820@samp{To} and @samp{Cc} headers.
21821
21822Put the following in your @file{~/.gnus.el} file.
21823
21824@lisp
21825(setq gnus-extra-headers '(To Cc Newsgroups Keywords)
21826 nnmail-extra-headers gnus-extra-headers)
21827@end lisp
21828
21829Restart Gnus and rebuild your @code{nnml} overview files with the
21830@kbd{M-x nnml-generate-nov-databases} command. This will take a long
21831time if you have much mail.
21832
21833Now you can score on @samp{To} and @samp{Cc} as ``extra headers'' like
21834so: @kbd{I e s p To RET <your name> RET}.
21835
21836See? Simple.
21837
21838
21839@node Scoring Tips
21840@section Scoring Tips
21841@cindex scoring tips
21842
21843@table @dfn
21844
21845@item Crossposts
21846@cindex crossposts
21847@cindex scoring crossposts
21848If you want to lower the score of crossposts, the line to match on is
21849the @code{Xref} header.
21850@lisp
21851("xref" (" talk.politics.misc:" -1000))
21852@end lisp
21853
21854@item Multiple crossposts
21855If you want to lower the score of articles that have been crossposted to
21856more than, say, 3 groups:
21857@lisp
21858("xref"
21859 ("[^:\n]+:[0-9]+ +[^:\n]+:[0-9]+ +[^:\n]+:[0-9]+"
21860 -1000 nil r))
21861@end lisp
21862
21863@item Matching on the body
21864This is generally not a very good idea---it takes a very long time.
21865Gnus actually has to fetch each individual article from the server. But
21866you might want to anyway, I guess. Even though there are three match
21867keys (@code{Head}, @code{Body} and @code{All}), you should choose one
21868and stick with it in each score file. If you use any two, each article
21869will be fetched @emph{twice}. If you want to match a bit on the
21870@code{Head} and a bit on the @code{Body}, just use @code{All} for all
21871the matches.
21872
21873@item Marking as read
21874You will probably want to mark articles that have scores below a certain
21875number as read. This is most easily achieved by putting the following
21876in your @file{all.SCORE} file:
21877@lisp
21878((mark -100))
21879@end lisp
21880You may also consider doing something similar with @code{expunge}.
21881
21882@item Negated character classes
21883If you say stuff like @code{[^abcd]*}, you may get unexpected results.
21884That will match newlines, which might lead to, well, The Unknown. Say
21885@code{[^abcd\n]*} instead.
21886@end table
21887
21888
21889@node Reverse Scoring
21890@section Reverse Scoring
21891@cindex reverse scoring
21892
21893If you want to keep just articles that have @samp{Sex with Emacs} in the
21894subject header, and expunge all other articles, you could put something
21895like this in your score file:
21896
21897@lisp
21898(("subject"
21899 ("Sex with Emacs" 2))
21900 (mark 1)
21901 (expunge 1))
21902@end lisp
21903
21904So, you raise all articles that match @samp{Sex with Emacs} and mark the
21905rest as read, and expunge them to boot.
21906
21907
21908@node Global Score Files
21909@section Global Score Files
21910@cindex global score files
21911
21912Sure, other newsreaders have ``global kill files''. These are usually
21913nothing more than a single kill file that applies to all groups, stored
21914in the user's home directory. Bah! Puny, weak newsreaders!
21915
21916What I'm talking about here are Global Score Files. Score files from
21917all over the world, from users everywhere, uniting all nations in one
21918big, happy score file union! Ange-score! New and untested!
21919
21920@vindex gnus-global-score-files
21921All you have to do to use other people's score files is to set the
21922@code{gnus-global-score-files} variable. One entry for each score file,
21923or each score file directory. Gnus will decide by itself what score
21924files are applicable to which group.
21925
21926To use the score file
21927@file{/ftp@@ftp.gnus.org:/pub/larsi/ding/score/soc.motss.SCORE} and
21928all score files in the @file{/ftp@@ftp.some-where:/pub/score} directory,
21929say this:
21930
21931@lisp
21932(setq gnus-global-score-files
21933 '("/ftp@@ftp.gnus.org:/pub/larsi/ding/score/soc.motss.SCORE"
21934 "/ftp@@ftp.some-where:/pub/score/"))
21935@end lisp
21936
21937@findex gnus-score-search-global-directories
21938@noindent
21939Simple, eh? Directory names must end with a @samp{/}. These
21940directories are typically scanned only once during each Gnus session.
21941If you feel the need to manually re-scan the remote directories, you can
21942use the @code{gnus-score-search-global-directories} command.
21943
21944Note that, at present, using this option will slow down group entry
21945somewhat. (That is---a lot.)
21946
21947If you want to start maintaining score files for other people to use,
21948just put your score file up for anonymous ftp and announce it to the
21949world. Become a retro-moderator! Participate in the retro-moderator
21950wars sure to ensue, where retro-moderators battle it out for the
21951sympathy of the people, luring them to use their score files on false
21952premises! Yay! The net is saved!
21953
21954Here are some tips for the would-be retro-moderator, off the top of my
21955head:
21956
21957@itemize @bullet
21958
21959@item
21960Articles heavily crossposted are probably junk.
21961@item
21962To lower a single inappropriate article, lower by @code{Message-ID}.
21963@item
21964Particularly brilliant authors can be raised on a permanent basis.
21965@item
21966Authors that repeatedly post off-charter for the group can safely be
21967lowered out of existence.
21968@item
21969Set the @code{mark} and @code{expunge} atoms to obliterate the nastiest
21970articles completely.
21971
21972@item
21973Use expiring score entries to keep the size of the file down. You
21974should probably have a long expiry period, though, as some sites keep
21975old articles for a long time.
21976@end itemize
21977
21978@dots{} I wonder whether other newsreaders will support global score files
21979in the future. @emph{Snicker}. Yup, any day now, newsreaders like Blue
21980Wave, xrn and 1stReader are bound to implement scoring. Should we start
21981holding our breath yet?
21982
21983
21984@node Kill Files
21985@section Kill Files
21986@cindex kill files
21987
21988Gnus still supports those pesky old kill files. In fact, the kill file
21989entries can now be expiring, which is something I wrote before Daniel
21990Quinlan thought of doing score files, so I've left the code in there.
21991
21992In short, kill processing is a lot slower (and I do mean @emph{a lot})
21993than score processing, so it might be a good idea to rewrite your kill
21994files into score files.
21995
21996Anyway, a kill file is a normal @code{emacs-lisp} file. You can put any
21997forms into this file, which means that you can use kill files as some
21998sort of primitive hook function to be run on group entry, even though
21999that isn't a very good idea.
22000
22001Normal kill files look like this:
22002
22003@lisp
22004(gnus-kill "From" "Lars Ingebrigtsen")
22005(gnus-kill "Subject" "ding")
22006(gnus-expunge "X")
22007@end lisp
22008
22009This will mark every article written by me as read, and remove the
22010marked articles from the summary buffer. Very useful, you'll agree.
22011
22012Other programs use a totally different kill file syntax. If Gnus
22013encounters what looks like a @code{rn} kill file, it will take a stab at
22014interpreting it.
22015
22016Two summary functions for editing a @sc{gnus} kill file:
22017
22018@table @kbd
22019
22020@item M-k
22021@kindex M-k (Summary)
22022@findex gnus-summary-edit-local-kill
22023Edit this group's kill file (@code{gnus-summary-edit-local-kill}).
22024
22025@item M-K
22026@kindex M-K (Summary)
22027@findex gnus-summary-edit-global-kill
22028Edit the general kill file (@code{gnus-summary-edit-global-kill}).
22029@end table
22030
22031Two group mode functions for editing the kill files:
22032
22033@table @kbd
22034
22035@item M-k
22036@kindex M-k (Group)
22037@findex gnus-group-edit-local-kill
22038Edit this group's kill file (@code{gnus-group-edit-local-kill}).
22039
22040@item M-K
22041@kindex M-K (Group)
22042@findex gnus-group-edit-global-kill
22043Edit the general kill file (@code{gnus-group-edit-global-kill}).
22044@end table
22045
22046Kill file variables:
22047
22048@table @code
22049@item gnus-kill-file-name
22050@vindex gnus-kill-file-name
22051A kill file for the group @samp{soc.motss} is normally called
22052@file{soc.motss.KILL}. The suffix appended to the group name to get
22053this file name is detailed by the @code{gnus-kill-file-name} variable.
22054The ``global'' kill file (not in the score file sense of ``global'', of
22055course) is just called @file{KILL}.
22056
22057@vindex gnus-kill-save-kill-file
22058@item gnus-kill-save-kill-file
22059If this variable is non-@code{nil}, Gnus will save the
22060kill file after processing, which is necessary if you use expiring
22061kills.
22062
22063@item gnus-apply-kill-hook
22064@vindex gnus-apply-kill-hook
22065@findex gnus-apply-kill-file-unless-scored
22066@findex gnus-apply-kill-file
22067A hook called to apply kill files to a group. It is
22068@code{(gnus-apply-kill-file)} by default. If you want to ignore the
22069kill file if you have a score file for the same group, you can set this
22070hook to @code{(gnus-apply-kill-file-unless-scored)}. If you don't want
22071kill files to be processed, you should set this variable to @code{nil}.
22072
22073@item gnus-kill-file-mode-hook
22074@vindex gnus-kill-file-mode-hook
22075A hook called in kill-file mode buffers.
22076
22077@end table
22078
22079
22080@node Converting Kill Files
22081@section Converting Kill Files
22082@cindex kill files
22083@cindex converting kill files
22084
22085If you have loads of old kill files, you may want to convert them into
22086score files. If they are ``regular'', you can use
22087the @file{gnus-kill-to-score.el} package; if not, you'll have to do it
22088by hand.
22089
e3e955fe
MB
22090The kill to score conversion package isn't included in Emacs by default.
22091You can fetch it from the contrib directory of the Gnus distribution or
22092from
22093@uref{http://heim.ifi.uio.no/~larsi/ding-various/gnus-kill-to-score.el}.
4009494e
GM
22094
22095If your old kill files are very complex---if they contain more
22096non-@code{gnus-kill} forms than not, you'll have to convert them by
22097hand. Or just let them be as they are. Gnus will still use them as
22098before.
22099
22100
4009494e
GM
22101@node Advanced Scoring
22102@section Advanced Scoring
22103
22104Scoring on Subjects and From headers is nice enough, but what if you're
22105really interested in what a person has to say only when she's talking
22106about a particular subject? Or what if you really don't want to
22107read what person A has to say when she's following up to person B, but
22108want to read what she says when she's following up to person C?
22109
22110By using advanced scoring rules you may create arbitrarily complex
22111scoring patterns.
22112
22113@menu
22114* Advanced Scoring Syntax:: A definition.
22115* Advanced Scoring Examples:: What they look like.
22116* Advanced Scoring Tips:: Getting the most out of it.
22117@end menu
22118
22119
22120@node Advanced Scoring Syntax
22121@subsection Advanced Scoring Syntax
22122
22123Ordinary scoring rules have a string as the first element in the rule.
22124Advanced scoring rules have a list as the first element. The second
22125element is the score to be applied if the first element evaluated to a
22126non-@code{nil} value.
22127
22128These lists may consist of three logical operators, one redirection
22129operator, and various match operators.
22130
22131Logical operators:
22132
22133@table @code
22134@item &
22135@itemx and
22136This logical operator will evaluate each of its arguments until it finds
22137one that evaluates to @code{false}, and then it'll stop. If all arguments
22138evaluate to @code{true} values, then this operator will return
22139@code{true}.
22140
22141@item |
22142@itemx or
22143This logical operator will evaluate each of its arguments until it finds
22144one that evaluates to @code{true}. If no arguments are @code{true},
22145then this operator will return @code{false}.
22146
22147@item !
22148@itemx not
22149