annotate lisp/gnus/spam.el @ 112129:5a83a0764cb0

allout.el: (allout-back-to-current-heading): Ensure return to the visible containing topic, rather than a collapsed one. (allout-view-change-hook): Remove hook that was deprecated long ago. (allout-exposure-change-hook): Remove documentation remarks concerning removed allout-view-change-hook. (allout-flag-region): Remove invocation of and documentation remarks concerning allout-view-change-hook.
author Ken Manheimer <ken.manheimer@gmail.com>
date Thu, 06 Jan 2011 02:19:05 -0500
parents 1156a55fd2a9
children 417b1e4d63cd
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1 ;;; spam.el --- Identifying spam
64754
fafd692d1e40 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64085
diff changeset
2
106815
1d1d5d9bd884 Add 2010 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 105253
diff changeset
3 ;; Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010
95820
645fb33380d6 Remove unnecessary eval-and-compile of autoloads.
Glenn Morris <rgm@gnu.org>
parents: 94662
diff changeset
4 ;; Free Software Foundation, Inc.
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
5
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
6 ;; Author: Lars Magne Ingebrigtsen <larsi@gnus.org>
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
7 ;; Maintainer: Ted Zlatanov <tzz@lifelogs.com>
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
8 ;; Keywords: network, spam, mail, bogofilter, BBDB, dspam, dig, whitelist, blacklist, gmane, hashcash, spamassassin, bsfilter, ifile, stat, crm114, spamoracle
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
9
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
10 ;; This file is part of GNU Emacs.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
11
94662
f42ef85caf91 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93975
diff changeset
12 ;; GNU Emacs is free software: you can redistribute it and/or modify
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
13 ;; it under the terms of the GNU General Public License as published by
94662
f42ef85caf91 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93975
diff changeset
14 ;; the Free Software Foundation, either version 3 of the License, or
f42ef85caf91 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93975
diff changeset
15 ;; (at your option) any later version.
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
16
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
17 ;; GNU Emacs is distributed in the hope that it will be useful,
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
94662
f42ef85caf91 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93975
diff changeset
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
20 ;; GNU General Public License for more details.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
21
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
22 ;; You should have received a copy of the GNU General Public License
94662
f42ef85caf91 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 93975
diff changeset
23 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
24
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
25 ;;; Commentary:
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
26
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
27 ;;; This module addresses a few aspects of spam control under Gnus. Page
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
28 ;;; breaks are used for grouping declarations and documentation relating to
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
29 ;;; each particular aspect.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
30
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
31 ;;; The integration with Gnus is not yet complete. See various `FIXME'
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
32 ;;; comments, below, for supplementary explanations or discussions.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
33
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
34 ;;; Several TODO items are marked as such
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
35
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
36 ;; TODO: cross-server splitting, remote processing, training through files
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
37
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
38 ;;; Code:
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
39
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
40 ;;{{{ compilation directives and autoloads/requires
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
41
110918
236342431786 nnimap.el (gnutls-negotiate): Silence the byte compiler.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 110898
diff changeset
42 ;; For Emacs <22.2 and XEmacs.
87226
8088d508b758 Move `require's before `eval-when-compile's.
Glenn Morris <rgm@gnu.org>
parents: 86328
diff changeset
43 (eval-and-compile
8088d508b758 Move `require's before `eval-when-compile's.
Glenn Morris <rgm@gnu.org>
parents: 86328
diff changeset
44 (unless (fboundp 'declare-function) (defmacro declare-function (&rest r))))
8088d508b758 Move `require's before `eval-when-compile's.
Glenn Morris <rgm@gnu.org>
parents: 86328
diff changeset
45
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
46 (eval-when-compile (require 'cl))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
47
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
48 (require 'message) ;for the message-fetch-field functions
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
49 (require 'gnus-sum)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
50 (require 'gnus-uu) ; because of key prefix issues
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
51 ;;; for the definitions of group content classification and spam processors
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
52 (require 'gnus)
87226
8088d508b758 Move `require's before `eval-when-compile's.
Glenn Morris <rgm@gnu.org>
parents: 86328
diff changeset
53
8088d508b758 Move `require's before `eval-when-compile's.
Glenn Morris <rgm@gnu.org>
parents: 86328
diff changeset
54 (eval-when-compile (require 'spam-report))
8088d508b758 Move `require's before `eval-when-compile's.
Glenn Morris <rgm@gnu.org>
parents: 86328
diff changeset
55 (eval-when-compile (require 'hashcash))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
56
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
57 ;; for nnimap-split-download-body-default
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
58 (eval-when-compile (require 'nnimap))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
59
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
60 ;; autoload query-dig
95820
645fb33380d6 Remove unnecessary eval-and-compile of autoloads.
Glenn Morris <rgm@gnu.org>
parents: 94662
diff changeset
61 (autoload 'query-dig "dig")
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
62
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
63 ;; autoload spam-report
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
64 (eval-and-compile
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
65 (autoload 'spam-report-gmane "spam-report")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
66 (autoload 'spam-report-gmane-spam "spam-report")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
67 (autoload 'spam-report-gmane-ham "spam-report")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
68 (autoload 'spam-report-resend "spam-report"))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
69
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
70 ;; autoload gnus-registry
95820
645fb33380d6 Remove unnecessary eval-and-compile of autoloads.
Glenn Morris <rgm@gnu.org>
parents: 94662
diff changeset
71 (autoload 'gnus-registry-group-count "gnus-registry")
645fb33380d6 Remove unnecessary eval-and-compile of autoloads.
Glenn Morris <rgm@gnu.org>
parents: 94662
diff changeset
72 (autoload 'gnus-registry-add-group "gnus-registry")
645fb33380d6 Remove unnecessary eval-and-compile of autoloads.
Glenn Morris <rgm@gnu.org>
parents: 94662
diff changeset
73 (autoload 'gnus-registry-store-extra-entry "gnus-registry")
645fb33380d6 Remove unnecessary eval-and-compile of autoloads.
Glenn Morris <rgm@gnu.org>
parents: 94662
diff changeset
74 (autoload 'gnus-registry-fetch-extra "gnus-registry")
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
75
103091
0062b68a76c3 Use dns-query instead of query-dns. Was renamed on 2008-12-25 in dns.el.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 100908
diff changeset
76 ;; autoload dns-query
0062b68a76c3 Use dns-query instead of query-dns. Was renamed on 2008-12-25 in dns.el.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 100908
diff changeset
77 (autoload 'dns-query "dns")
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
78
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
79 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
80
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
81 ;;{{{ Main parameters.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
82 (defvar spam-backends nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
83 "List of spam.el backends with all the pertinent data.
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
84 Populated by `spam-install-backend-super'.")
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
85
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
86 (defgroup spam nil
57931
a40ae7cf2194 (spam group): Add :version.
Richard M. Stallman <rms@gnu.org>
parents: 57581
diff changeset
87 "Spam configuration."
62755
0d1a48b1ca68 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-324
Miles Bader <miles@gnu.org>
parents: 59996
diff changeset
88 :version "22.1"
0d1a48b1ca68 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-324
Miles Bader <miles@gnu.org>
parents: 59996
diff changeset
89 :group 'mail
0d1a48b1ca68 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-324
Miles Bader <miles@gnu.org>
parents: 59996
diff changeset
90 :group 'news)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
91
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
92 (defcustom spam-summary-exit-behavior 'default
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
93 "Exit behavior at the time of summary exit.
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
94 Note that setting the `spam-use-move' or `spam-use-copy' backends on
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
95 a group through group/topic parameters overrides this mechanism."
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
96 :type '(choice
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
97 (const
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
98 'default
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
99 :tag "Move spam out of all groups and ham out of spam groups.")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
100 (const
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
101 'move-all
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
102 :tag "Move spam out of all groups and ham out of all groups.")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
103 (const
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
104 'move-none
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
105 :tag "Never move spam or ham out of any groups."))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
106 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
107
57581
645f020dcc8a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-626
Miles Bader <miles@gnu.org>
parents: 57549
diff changeset
108 (defcustom spam-directory (nnheader-concat gnus-directory "spam/")
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
109 "Directory for spam whitelists and blacklists."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
110 :type 'directory
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
111 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
112
69625
17473f7e626b Revision: emacs@sv.gnu.org/emacs--devo--0--patch-170
Miles Bader <miles@gnu.org>
parents: 68633
diff changeset
113 (defcustom spam-mark-new-messages-in-spam-group-as-spam t
17473f7e626b Revision: emacs@sv.gnu.org/emacs--devo--0--patch-170
Miles Bader <miles@gnu.org>
parents: 68633
diff changeset
114 "Whether new messages in a spam group should get the spam-mark."
17473f7e626b Revision: emacs@sv.gnu.org/emacs--devo--0--patch-170
Miles Bader <miles@gnu.org>
parents: 68633
diff changeset
115 :type 'boolean
17473f7e626b Revision: emacs@sv.gnu.org/emacs--devo--0--patch-170
Miles Bader <miles@gnu.org>
parents: 68633
diff changeset
116 ;; :version "22.1" ;; Gnus 5.10.8 / No Gnus 0.3
17473f7e626b Revision: emacs@sv.gnu.org/emacs--devo--0--patch-170
Miles Bader <miles@gnu.org>
parents: 68633
diff changeset
117 :group 'spam)
17473f7e626b Revision: emacs@sv.gnu.org/emacs--devo--0--patch-170
Miles Bader <miles@gnu.org>
parents: 68633
diff changeset
118
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
119 (defcustom spam-log-to-registry nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
120 "Whether spam/ham processing should be logged in the registry."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
121 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
122 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
123
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
124 (defcustom spam-split-symbolic-return nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
125 "Whether `spam-split' should work with symbols or group names."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
126 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
127 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
128
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
129 (defcustom spam-split-symbolic-return-positive nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
130 "Whether `spam-split' should ALWAYS work with symbols or group names.
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
131 Do not set this if you use `spam-split' in a fancy split method."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
132 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
133 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
134
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
135 (defcustom spam-mark-only-unseen-as-spam t
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
136 "Whether only unseen articles should be marked as spam in spam groups.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
137 When nil, all unread articles in a spam group are marked as
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
138 spam. Set this if you want to leave an article unread in a spam group
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
139 without losing it to the automatic spam-marking process."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
140 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
141 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
142
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
143 (defcustom spam-mark-ham-unread-before-move-from-spam-group nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
144 "Whether ham should be marked unread before it's moved.
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
145 The article is moved out of a spam group according to `ham-process-destination'.
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
146 This variable is an official entry in the international Longest Variable Name
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
147 Competition."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
148 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
149 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
150
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
151 (defcustom spam-disable-spam-split-during-ham-respool nil
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
152 "Whether `spam-split' should be ignored while resplitting ham.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
153 This is useful to prevent ham from ending up in the same spam
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
154 group after the resplit. Don't set this to t if you have `spam-split' as the
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
155 last rule in your split configuration."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
156 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
157 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
158
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
159 (defcustom spam-autodetect-recheck-messages nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
160 "Should spam.el recheck all meessages when autodetecting?
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
161 Normally this is nil, so only unseen messages will be checked."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
162 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
163 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
164
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
165 (defcustom spam-whitelist (expand-file-name "whitelist" spam-directory)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
166 "The location of the whitelist.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
167 The file format is one regular expression per line.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
168 The regular expression is matched against the address."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
169 :type 'file
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
170 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
171
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
172 (defcustom spam-blacklist (expand-file-name "blacklist" spam-directory)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
173 "The location of the blacklist.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
174 The file format is one regular expression per line.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
175 The regular expression is matched against the address."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
176 :type 'file
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
177 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
178
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
179 (defcustom spam-use-dig t
103091
0062b68a76c3 Use dns-query instead of query-dns. Was renamed on 2008-12-25 in dns.el.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 100908
diff changeset
180 "Whether `query-dig' should be used instead of `dns-query'."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
181 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
182 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
183
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
184 (defcustom spam-use-gmane-xref nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
185 "Whether the Gmane spam xref should be used by `spam-split'."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
186 :type 'boolean
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
187 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
188
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
189 (defcustom spam-use-blacklist nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
190 "Whether the blacklist should be used by `spam-split'."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
191 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
192 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
193
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
194 (defcustom spam-blacklist-ignored-regexes nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
195 "Regular expressions that the blacklist should ignore."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
196 :type '(repeat (regexp :tag "Regular expression to ignore when blacklisting"))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
197 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
198
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
199 (defcustom spam-use-whitelist nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
200 "Whether the whitelist should be used by `spam-split'."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
201 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
202 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
203
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
204 (defcustom spam-use-whitelist-exclusive nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
205 "Whether whitelist-exclusive should be used by `spam-split'.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
206 Exclusive whitelisting means that all messages from senders not in the whitelist
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
207 are considered spam."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
208 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
209 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
210
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
211 (defcustom spam-use-blackholes nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
212 "Whether blackholes should be used by `spam-split'."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
213 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
214 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
215
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
216 (defcustom spam-use-hashcash nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
217 "Whether hashcash payments should be detected by `spam-split'."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
218 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
219 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
220
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
221 (defcustom spam-use-regex-headers nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
222 "Whether a header regular expression match should be used by `spam-split'.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
223 Also see the variables `spam-regex-headers-spam' and `spam-regex-headers-ham'."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
224 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
225 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
226
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
227 (defcustom spam-use-regex-body nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
228 "Whether a body regular expression match should be used by `spam-split'.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
229 Also see the variables `spam-regex-body-spam' and `spam-regex-body-ham'."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
230 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
231 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
232
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
233 (defcustom spam-use-bogofilter-headers nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
234 "Whether bogofilter headers should be used by `spam-split'.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
235 Enable this if you pre-process messages with Bogofilter BEFORE Gnus sees them."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
236 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
237 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
238
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
239 (defcustom spam-use-bogofilter nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
240 "Whether bogofilter should be invoked by `spam-split'.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
241 Enable this if you want Gnus to invoke Bogofilter on new messages."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
242 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
243 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
244
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
245 (defcustom spam-use-bsfilter-headers nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
246 "Whether bsfilter headers should be used by `spam-split'.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
247 Enable this if you pre-process messages with Bsfilter BEFORE Gnus sees them."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
248 :type 'boolean
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
249 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
250
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
251 (defcustom spam-use-bsfilter nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
252 "Whether bsfilter should be invoked by `spam-split'.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
253 Enable this if you want Gnus to invoke Bsfilter on new messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
254 :type 'boolean
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
255 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
256
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
257 (defcustom spam-use-BBDB nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
258 "Whether BBDB should be used by `spam-split'."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
259 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
260 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
261
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
262 (defcustom spam-use-BBDB-exclusive nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
263 "Whether BBDB-exclusive should be used by `spam-split'.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
264 Exclusive BBDB means that all messages from senders not in the BBDB are
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
265 considered spam."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
266 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
267 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
268
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
269 (defcustom spam-use-ifile nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
270 "Whether ifile should be used by `spam-split'."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
271 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
272 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
273
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
274 (defcustom spam-use-stat nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
275 "Whether `spam-stat' should be used by `spam-split'."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
276 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
277 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
278
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
279 (defcustom spam-use-spamoracle nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
280 "Whether spamoracle should be used by `spam-split'."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
281 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
282 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
283
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
284 (defcustom spam-use-spamassassin nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
285 "Whether spamassassin should be invoked by `spam-split'.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
286 Enable this if you want Gnus to invoke SpamAssassin on new messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
287 :type 'boolean
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
288 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
289
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
290 (defcustom spam-use-spamassassin-headers nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
291 "Whether spamassassin headers should be checked by `spam-split'.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
292 Enable this if you pre-process messages with SpamAssassin BEFORE Gnus sees
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
293 them."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
294 :type 'boolean
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
295 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
296
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
297 (defcustom spam-use-crm114 nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
298 "Whether the CRM114 Mailfilter should be used by `spam-split'."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
299 :type 'boolean
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
300 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
301
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
302 (defcustom spam-install-hooks (or
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
303 spam-use-dig
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
304 spam-use-gmane-xref
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
305 spam-use-blacklist
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
306 spam-use-whitelist
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
307 spam-use-whitelist-exclusive
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
308 spam-use-blackholes
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
309 spam-use-hashcash
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
310 spam-use-regex-headers
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
311 spam-use-regex-body
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
312 spam-use-bogofilter
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
313 spam-use-bogofilter-headers
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
314 spam-use-spamassassin
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
315 spam-use-spamassassin-headers
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
316 spam-use-bsfilter
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
317 spam-use-bsfilter-headers
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
318 spam-use-BBDB
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
319 spam-use-BBDB-exclusive
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
320 spam-use-ifile
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
321 spam-use-stat
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
322 spam-use-spamoracle
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
323 spam-use-crm114)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
324 "Whether the spam hooks should be installed.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
325 Default to t if one of the spam-use-* variables is set."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
326 :group 'spam
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
327 :type 'boolean)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
328
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
329 (defcustom spam-split-group "spam"
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
330 "Group name where incoming spam should be put by `spam-split'."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
331 :type 'string
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
332 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
333
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
334 ;;; TODO: deprecate this variable, it's confusing since it's a list of strings,
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
335 ;;; not regular expressions
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
336 (defcustom spam-junk-mailgroups (cons
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
337 spam-split-group
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
338 '("mail.junk" "poste.pourriel"))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
339 "Mailgroups with spam contents.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
340 All unmarked article in such group receive the spam mark on group entry."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
341 :type '(repeat (string :tag "Group"))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
342 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
343
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
344
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
345 (defcustom spam-gmane-xref-spam-group "gmane.spam.detected"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
346 "The group where spam xrefs can be found on Gmane.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
347 Only meaningful if you enable `spam-use-gmane-xref'."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
348 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
349 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
350
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
351 (defcustom spam-blackhole-servers '("bl.spamcop.net" "relays.ordb.org"
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
352 "dev.null.dk" "relays.visi.com")
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
353 "List of blackhole servers.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
354 Only meaningful if you enable `spam-use-blackholes'."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
355 :type '(repeat (string :tag "Server"))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
356 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
357
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
358 (defcustom spam-blackhole-good-server-regex nil
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
359 "String matching IP addresses that should not be checked in the blackholes.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
360 Only meaningful if you enable `spam-use-blackholes'."
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
361 :type '(radio (const nil) regexp)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
362 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
363
63480
53e7abe8917f Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-425
Miles Bader <miles@gnu.org>
parents: 62755
diff changeset
364 (defface spam
59406
cf93431040c9 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-17
Miles Bader <miles@gnu.org>
parents: 58835
diff changeset
365 '((((class color) (type tty) (background dark))
cf93431040c9 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-17
Miles Bader <miles@gnu.org>
parents: 58835
diff changeset
366 (:foreground "gray80" :background "gray50"))
cf93431040c9 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-17
Miles Bader <miles@gnu.org>
parents: 58835
diff changeset
367 (((class color) (type tty) (background light))
cf93431040c9 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-17
Miles Bader <miles@gnu.org>
parents: 58835
diff changeset
368 (:foreground "gray50" :background "gray80"))
cf93431040c9 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-17
Miles Bader <miles@gnu.org>
parents: 58835
diff changeset
369 (((class color) (background dark))
cf93431040c9 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-17
Miles Bader <miles@gnu.org>
parents: 58835
diff changeset
370 (:foreground "ivory2"))
cf93431040c9 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-17
Miles Bader <miles@gnu.org>
parents: 58835
diff changeset
371 (((class color) (background light))
cf93431040c9 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-17
Miles Bader <miles@gnu.org>
parents: 58835
diff changeset
372 (:foreground "ivory4"))
cf93431040c9 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-17
Miles Bader <miles@gnu.org>
parents: 58835
diff changeset
373 (t :inverse-video t))
62755
0d1a48b1ca68 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-324
Miles Bader <miles@gnu.org>
parents: 59996
diff changeset
374 "Face for spam-marked articles."
0d1a48b1ca68 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-324
Miles Bader <miles@gnu.org>
parents: 59996
diff changeset
375 :group 'spam)
63480
53e7abe8917f Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-425
Miles Bader <miles@gnu.org>
parents: 62755
diff changeset
376 ;; backward-compatibility alias
53e7abe8917f Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-425
Miles Bader <miles@gnu.org>
parents: 62755
diff changeset
377 (put 'spam-face 'face-alias 'spam)
104789
aa91debbb2f2 Mark face aliases with "-face" in the name as obsolete.
Glenn Morris <rgm@gnu.org>
parents: 104700
diff changeset
378 (put 'spam-face 'obsolete-face "22.1")
59406
cf93431040c9 Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-17
Miles Bader <miles@gnu.org>
parents: 58835
diff changeset
379
63480
53e7abe8917f Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-425
Miles Bader <miles@gnu.org>
parents: 62755
diff changeset
380 (defcustom spam-face 'spam
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
381 "Face for spam-marked articles."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
382 :type 'face
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
383 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
384
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
385 (defcustom spam-regex-headers-spam '("^X-Spam-Flag: YES")
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
386 "Regular expression for positive header spam matches.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
387 Only meaningful if you enable `spam-use-regex-headers'."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
388 :type '(repeat (regexp :tag "Regular expression to match spam header"))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
389 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
390
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
391 (defcustom spam-regex-headers-ham '("^X-Spam-Flag: NO")
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
392 "Regular expression for positive header ham matches.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
393 Only meaningful if you enable `spam-use-regex-headers'."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
394 :type '(repeat (regexp :tag "Regular expression to match ham header"))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
395 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
396
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
397 (defcustom spam-regex-body-spam '()
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
398 "Regular expression for positive body spam matches.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
399 Only meaningful if you enable `spam-use-regex-body'."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
400 :type '(repeat (regexp :tag "Regular expression to match spam body"))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
401 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
402
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
403 (defcustom spam-regex-body-ham '()
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
404 "Regular expression for positive body ham matches.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
405 Only meaningful if you enable `spam-use-regex-body'."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
406 :type '(repeat (regexp :tag "Regular expression to match ham body"))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
407 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
408
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
409 (defcustom spam-summary-score-preferred-header nil
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
410 "Preferred header to use for `spam-summary-score'."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
411 :type '(choice :tag "Header name"
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
412 (symbol :tag "SpamAssassin etc" X-Spam-Status)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
413 (symbol :tag "Bogofilter" X-Bogosity)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
414 (const :tag "No preference, take best guess." nil))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
415 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
416
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
417 (defgroup spam-ifile nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
418 "Spam ifile configuration."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
419 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
420
104700
9866b069527c * spam.el (spam-ifile-path, spam-bogofilter-path, spam-sa-learn-path)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103091
diff changeset
421 (make-obsolete-variable 'spam-ifile-path 'spam-ifile-program
9866b069527c * spam.el (spam-ifile-path, spam-bogofilter-path, spam-sa-learn-path)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103091
diff changeset
422 "Gnus 5.10.9 (Emacs 22.1)")
74984
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
423 (defcustom spam-ifile-program (executable-find "ifile")
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
424 "Name of the ifile program."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
425 :type '(choice (file :tag "Location of ifile")
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
426 (const :tag "ifile is not installed"))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
427 :group 'spam-ifile)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
428
104700
9866b069527c * spam.el (spam-ifile-path, spam-bogofilter-path, spam-sa-learn-path)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103091
diff changeset
429 (make-obsolete-variable 'spam-ifile-database-path 'spam-ifile-database
9866b069527c * spam.el (spam-ifile-path, spam-bogofilter-path, spam-sa-learn-path)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103091
diff changeset
430 "Gnus 5.10.9 (Emacs 22.1)")
74984
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
431 (defcustom spam-ifile-database nil
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
432 "File name of the ifile database."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
433 :type '(choice (file :tag "Location of the ifile database")
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
434 (const :tag "Use the default"))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
435 :group 'spam-ifile)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
436
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
437 (defcustom spam-ifile-spam-category "spam"
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
438 "Name of the spam ifile category."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
439 :type 'string
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
440 :group 'spam-ifile)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
441
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
442 (defcustom spam-ifile-ham-category nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
443 "Name of the ham ifile category.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
444 If nil, the current group name will be used."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
445 :type '(choice (string :tag "Use a fixed category")
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
446 (const :tag "Use the current group name"))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
447 :group 'spam-ifile)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
448
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
449 (defcustom spam-ifile-all-categories nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
450 "Whether the ifile check will return all categories, or just spam.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
451 Set this to t if you want to use the `spam-split' invocation of ifile as
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
452 your main source of newsgroup names."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
453 :type 'boolean
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
454 :group 'spam-ifile)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
455
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
456 (defgroup spam-bogofilter nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
457 "Spam bogofilter configuration."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
458 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
459
104700
9866b069527c * spam.el (spam-ifile-path, spam-bogofilter-path, spam-sa-learn-path)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103091
diff changeset
460 (make-obsolete-variable 'spam-bogofilter-path 'spam-bogofilter-program
9866b069527c * spam.el (spam-ifile-path, spam-bogofilter-path, spam-sa-learn-path)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103091
diff changeset
461 "Gnus 5.10.9 (Emacs 22.1)")
74984
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
462 (defcustom spam-bogofilter-program (executable-find "bogofilter")
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
463 "Name of the Bogofilter program."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
464 :type '(choice (file :tag "Location of bogofilter")
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
465 (const :tag "Bogofilter is not installed"))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
466 :group 'spam-bogofilter)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
467
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
468 (defvar spam-bogofilter-valid 'unknown "Is the bogofilter version valid?")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
469
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
470 (defcustom spam-bogofilter-header "X-Bogosity"
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
471 "The header that Bogofilter inserts in messages."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
472 :type 'string
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
473 :group 'spam-bogofilter)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
474
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
475 (defcustom spam-bogofilter-spam-switch "-s"
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
476 "The switch that Bogofilter uses to register spam messages."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
477 :type 'string
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
478 :group 'spam-bogofilter)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
479
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
480 (defcustom spam-bogofilter-ham-switch "-n"
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
481 "The switch that Bogofilter uses to register ham messages."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
482 :type 'string
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
483 :group 'spam-bogofilter)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
484
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
485 (defcustom spam-bogofilter-spam-strong-switch "-S"
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
486 "The switch that Bogofilter uses to unregister ham messages."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
487 :type 'string
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
488 :group 'spam-bogofilter)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
489
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
490 (defcustom spam-bogofilter-ham-strong-switch "-N"
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
491 "The switch that Bogofilter uses to unregister spam messages."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
492 :type 'string
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
493 :group 'spam-bogofilter)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
494
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
495 (defcustom spam-bogofilter-bogosity-positive-spam-header "^\\(Yes\\|Spam\\)"
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
496 "The regex on `spam-bogofilter-header' for positive spam identification."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
497 :type 'regexp
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
498 :group 'spam-bogofilter)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
499
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
500 (defcustom spam-bogofilter-database-directory nil
74984
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
501 "Location of the Bogofilter database.
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
502 When nil, use the default location."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
503 :type '(choice (directory
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
504 :tag "Location of the Bogofilter database directory")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
505 (const :tag "Use the default"))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
506 :group 'spam-bogofilter)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
507
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
508 (defgroup spam-bsfilter nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
509 "Spam bsfilter configuration."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
510 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
511
104700
9866b069527c * spam.el (spam-ifile-path, spam-bogofilter-path, spam-sa-learn-path)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103091
diff changeset
512 (make-obsolete-variable 'spam-bsfilter-path 'spam-bsfilter-program
9866b069527c * spam.el (spam-ifile-path, spam-bogofilter-path, spam-sa-learn-path)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103091
diff changeset
513 "Gnus 5.10.9 (Emacs 22.1)")
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
514 (defcustom spam-bsfilter-program (executable-find "bsfilter")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
515 "Name of the Bsfilter program."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
516 :type '(choice (file :tag "Location of bsfilter")
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
517 (const :tag "Bsfilter is not installed"))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
518 :group 'spam-bsfilter)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
519
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
520 (defcustom spam-bsfilter-header "X-Spam-Flag"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
521 "The header inserted by Bsfilter to flag spam."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
522 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
523 :group 'spam-bsfilter)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
524
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
525 (defcustom spam-bsfilter-probability-header "X-Spam-Probability"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
526 "The header that Bsfilter inserts in messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
527 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
528 :group 'spam-bsfilter)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
529
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
530 (defcustom spam-bsfilter-spam-switch "--add-spam"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
531 "The switch that Bsfilter uses to register spam messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
532 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
533 :group 'spam-bsfilter)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
534
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
535 (defcustom spam-bsfilter-ham-switch "--add-clean"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
536 "The switch that Bsfilter uses to register ham messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
537 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
538 :group 'spam-bsfilter)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
539
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
540 (defcustom spam-bsfilter-spam-strong-switch "--sub-spam"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
541 "The switch that Bsfilter uses to unregister ham messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
542 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
543 :group 'spam-bsfilter)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
544
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
545 (defcustom spam-bsfilter-ham-strong-switch "--sub-clean"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
546 "The switch that Bsfilter uses to unregister spam messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
547 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
548 :group 'spam-bsfilter)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
549
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
550 (defcustom spam-bsfilter-database-directory nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
551 "Directory path of the Bsfilter databases."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
552 :type '(choice (directory
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
553 :tag "Location of the Bsfilter database directory")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
554 (const :tag "Use the default"))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
555 :group 'spam-bsfilter)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
556
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
557 (defgroup spam-spamoracle nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
558 "Spam spamoracle configuration."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
559 :group 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
560
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
561 (defcustom spam-spamoracle-database nil
74984
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
562 "Location of spamoracle database file.
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
563 When nil, use the default spamoracle database."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
564 :type '(choice (directory :tag "Location of spamoracle database file.")
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
565 (const :tag "Use the default"))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
566 :group 'spam-spamoracle)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
567
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
568 (defcustom spam-spamoracle-binary (executable-find "spamoracle")
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
569 "Location of the spamoracle binary."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
570 :type '(choice (directory :tag "Location of the spamoracle binary")
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
571 (const :tag "Use the default"))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
572 :group 'spam-spamoracle)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
573
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
574 (defgroup spam-spamassassin nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
575 "Spam SpamAssassin configuration."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
576 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
577
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
578 (make-obsolete-variable 'spam-spamassassin-path
104700
9866b069527c * spam.el (spam-ifile-path, spam-bogofilter-path, spam-sa-learn-path)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103091
diff changeset
579 'spam-spamassassin-program "Gnus 5.10.9 (Emacs 22.1)")
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
580 (defcustom spam-assassin-program (executable-find "spamassassin")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
581 "Name of the spamassassin program.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
582 Hint: set this to \"spamc\" if you have spamd running. See the spamc and
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
583 spamd man pages for more information on these programs."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
584 :type '(choice (file :tag "Location of spamc")
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
585 (const :tag "spamassassin is not installed"))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
586 :group 'spam-spamassassin)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
587
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
588 (defcustom spam-spamassassin-arguments ()
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
589 "Arguments to pass to the spamassassin executable.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
590 This must be a list. For example, `(\"-C\" \"configfile\")'."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
591 :type '(restricted-sexp :match-alternatives (listp))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
592 :group 'spam-spamassassin)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
593
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
594 (defcustom spam-spamassassin-spam-flag-header "X-Spam-Flag"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
595 "The header inserted by SpamAssassin to flag spam."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
596 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
597 :group 'spam-spamassassin)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
598
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
599 (defcustom spam-spamassassin-positive-spam-flag-header "YES"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
600 "The regex on `spam-spamassassin-spam-flag-header' for positive spam
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
601 identification"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
602 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
603 :group 'spam-spamassassin)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
604
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
605 (defcustom spam-spamassassin-spam-status-header "X-Spam-Status"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
606 "The header inserted by SpamAssassin, giving extended scoring information"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
607 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
608 :group 'spam-spamassassin)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
609
104700
9866b069527c * spam.el (spam-ifile-path, spam-bogofilter-path, spam-sa-learn-path)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103091
diff changeset
610 (make-obsolete-variable 'spam-sa-learn-path 'spam-sa-learn-program
9866b069527c * spam.el (spam-ifile-path, spam-bogofilter-path, spam-sa-learn-path)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103091
diff changeset
611 "Gnus 5.10.9 (Emacs 22.1)")
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
612 (defcustom spam-sa-learn-program (executable-find "sa-learn")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
613 "Name of the sa-learn program."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
614 :type '(choice (file :tag "Location of spamassassin")
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
615 (const :tag "spamassassin is not installed"))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
616 :group 'spam-spamassassin)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
617
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
618 (defcustom spam-sa-learn-rebuild t
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
619 "Whether sa-learn should rebuild the database every time it is called
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
620 Enable this if you want sa-learn to rebuild the database automatically. Doing
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
621 this will slightly increase the running time of the spam registration process.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
622 If you choose not to do this, you will have to run \"sa-learn --rebuild\" in
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
623 order for SpamAssassin to recognize the new registered spam."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
624 :type 'boolean
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
625 :group 'spam-spamassassin)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
626
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
627 (defcustom spam-sa-learn-spam-switch "--spam"
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
628 "The switch that sa-learn uses to register spam messages."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
629 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
630 :group 'spam-spamassassin)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
631
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
632 (defcustom spam-sa-learn-ham-switch "--ham"
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
633 "The switch that sa-learn uses to register ham messages."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
634 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
635 :group 'spam-spamassassin)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
636
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
637 (defcustom spam-sa-learn-unregister-switch "--forget"
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
638 "The switch that sa-learn uses to unregister messages messages."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
639 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
640 :group 'spam-spamassassin)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
641
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
642 (defgroup spam-crm114 nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
643 "Spam CRM114 Mailfilter configuration."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
644 :group 'spam)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
645
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
646 (defcustom spam-crm114-program (executable-find "mailfilter.crm")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
647 "File path of the CRM114 Mailfilter executable program."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
648 :type '(choice (file :tag "Location of CRM114 Mailfilter")
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
649 (const :tag "CRM114 Mailfilter is not installed"))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
650 :group 'spam-crm114)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
651
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
652 (defcustom spam-crm114-header "X-CRM114-Status"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
653 "The header that CRM114 Mailfilter inserts in messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
654 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
655 :group 'spam-crm114)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
656
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
657 (defcustom spam-crm114-spam-switch "--learnspam"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
658 "The switch that CRM114 Mailfilter uses to register spam messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
659 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
660 :group 'spam-crm114)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
661
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
662 (defcustom spam-crm114-ham-switch "--learnnonspam"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
663 "The switch that CRM114 Mailfilter uses to register ham messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
664 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
665 :group 'spam-crm114)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
666
105253
baa4e6ac9e46 Synch with Gnus trunk.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 104789
diff changeset
667 (defcustom spam-crm114-spam-strong-switch "--unlearn"
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
668 "The switch that CRM114 Mailfilter uses to unregister ham messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
669 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
670 :group 'spam-crm114)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
671
105253
baa4e6ac9e46 Synch with Gnus trunk.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 104789
diff changeset
672 (defcustom spam-crm114-ham-strong-switch "--unlearn"
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
673 "The switch that CRM114 Mailfilter uses to unregister spam messages."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
674 :type 'string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
675 :group 'spam-crm114)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
676
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
677 (defcustom spam-crm114-positive-spam-header "^SPAM"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
678 "The regex on `spam-crm114-header' for positive spam identification."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
679 :type 'regexp
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
680 :group 'spam-crm114)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
681
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
682 (defcustom spam-crm114-database-directory nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
683 "Directory path of the CRM114 Mailfilter databases."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
684 :type '(choice (directory
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
685 :tag "Location of the CRM114 Mailfilter database directory")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
686 (const :tag "Use the default"))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
687 :group 'spam-crm114)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
688
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
689 ;;; Key bindings for spam control.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
690
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
691 (gnus-define-keys gnus-summary-mode-map
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
692 "St" spam-generic-score
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
693 "Sx" gnus-summary-mark-as-spam
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
694 "Mst" spam-generic-score
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
695 "Msx" gnus-summary-mark-as-spam
110898
069deed4cdec Merge changes made in Gnus trunk.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 110410
diff changeset
696 "\M-d" gnus-summary-mark-as-spam
069deed4cdec Merge changes made in Gnus trunk.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 110410
diff changeset
697 "$" gnus-summary-mark-as-spam)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
698
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
699 (defvar spam-cache-lookups t
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
700 "Whether spam.el will try to cache lookups using `spam-caches'.")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
701
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
702 (defvar spam-caches (make-hash-table
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
703 :size 10
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
704 :test 'equal)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
705 "Cache of spam detection entries.")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
706
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
707 (defvar spam-old-articles nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
708 "List of old ham and spam articles, generated when a group is entered.")
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
709
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
710 (defvar spam-split-disabled nil
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
711 "If non-nil, `spam-split' is disabled, and always returns nil.")
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
712
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
713 (defvar spam-split-last-successful-check nil
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
714 "Internal variable.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
715 `spam-split' will set this to nil or a spam-use-XYZ check if it
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
716 finds ham or spam.")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
717
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
718 ;; internal variables for backends
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
719 ;; TODO: find a way to create these on the fly in spam-install-backend-super
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
720 (defvar spam-use-copy nil)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
721 (defvar spam-use-move nil)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
722 (defvar spam-use-gmane nil)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
723 (defvar spam-use-resend nil)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
724
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
725 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
726
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
727 ;;{{{ convenience functions
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
728
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
729 (defun spam-clear-cache (symbol)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
730 "Clear the `spam-caches' entry for a check."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
731 (remhash symbol spam-caches))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
732
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
733 (defun spam-xor (a b)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
734 "Logical A xor B."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
735 (and (or a b) (not (and a b))))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
736
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
737 (defun spam-set-difference (list1 list2)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
738 "Return a set difference of LIST1 and LIST2.
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
739 When either list is nil, the other is returned."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
740 (if (and list1 list2)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
741 ;; we have two non-nil lists
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
742 (progn
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
743 (dolist (item (append list1 list2))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
744 (when (and (memq item list1) (memq item list2))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
745 (setq list1 (delq item list1))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
746 (setq list2 (delq item list2))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
747 (append list1 list2))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
748 ;; if either of the lists was nil, return the other one
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
749 (if list1 list1 list2)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
750
68276
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
751 (defun spam-group-ham-mark-p (group mark &optional spam)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
752 "Checks if MARK is considered a ham mark in GROUP."
68276
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
753 (when (stringp group)
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
754 (let* ((marks (spam-group-ham-marks group spam))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
755 (marks (if (symbolp mark)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
756 marks
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
757 (mapcar 'symbol-value marks))))
68276
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
758 (memq mark marks))))
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
759
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
760 (defun spam-group-spam-mark-p (group mark)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
761 "Checks if MARK is considered a spam mark in GROUP."
68276
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
762 (spam-group-ham-mark-p group mark t))
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
763
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
764 (defun spam-group-ham-marks (group &optional spam)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
765 "In GROUP, get all the ham marks."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
766 (when (stringp group)
68276
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
767 (let* ((marks (if spam
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
768 (gnus-parameter-spam-marks group)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
769 (gnus-parameter-ham-marks group)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
770 (marks (car marks))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
771 (marks (if (listp (car marks)) (car marks) marks)))
68276
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
772 marks)))
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
773
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
774 (defun spam-group-spam-marks (group)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
775 "In GROUP, get all the spam marks."
68276
873a6f48b596 (spam-group-ham-mark-p, spam-group-spam-mark-p)
Reiner Steib <Reiner.Steib@gmx.de>
parents: 68093
diff changeset
776 (spam-group-ham-marks group t))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
777
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
778 (defun spam-group-spam-contents-p (group)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
779 "Is GROUP a spam group?"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
780 (if (and (stringp group) (< 0 (length group)))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
781 (or (member group spam-junk-mailgroups)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
782 (memq 'gnus-group-spam-classification-spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
783 (gnus-parameter-spam-contents group)))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
784 nil))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
785
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
786 (defun spam-group-ham-contents-p (group)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
787 "Is GROUP a ham group?"
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
788 (if (stringp group)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
789 (memq 'gnus-group-spam-classification-ham
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
790 (gnus-parameter-spam-contents group))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
791 nil))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
792
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
793 (defun spam-classifications ()
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
794 "Return list of valid classifications"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
795 '(spam ham))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
796
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
797 (defun spam-classification-valid-p (classification)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
798 "Is CLASSIFICATION a valid spam/ham classification?"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
799 (memq classification (spam-classifications)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
800
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
801 (defun spam-backend-properties ()
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
802 "Return list of valid classifications."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
803 '(statistical mover check hrf srf huf suf))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
804
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
805 (defun spam-backend-property-valid-p (property)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
806 "Is PROPERTY a valid backend property?"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
807 (memq property (spam-backend-properties)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
808
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
809 (defun spam-backend-function-type-valid-p (type)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
810 (or (eq type 'registration)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
811 (eq type 'unregistration)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
812
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
813 (defun spam-process-type-valid-p (process-type)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
814 (or (eq process-type 'incoming)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
815 (eq process-type 'process)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
816
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
817 (defun spam-list-articles (articles classification)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
818 (let ((mark-check (if (eq classification 'spam)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
819 'spam-group-spam-mark-p
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
820 'spam-group-ham-mark-p))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
821 alist mark-cache-yes mark-cache-no)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
822 (dolist (article articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
823 (let ((mark (gnus-summary-article-mark article)))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
824 (unless (or (memq mark mark-cache-yes)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
825 (memq mark mark-cache-no))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
826 (if (funcall mark-check
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
827 gnus-newsgroup-name
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
828 mark)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
829 (push mark mark-cache-yes)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
830 (push mark mark-cache-no)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
831 (when (memq mark mark-cache-yes)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
832 (push article alist))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
833 alist))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
834
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
835 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
836
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
837 ;;{{{ backend installation functions and procedures
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
838
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
839 (defun spam-install-backend-super (backend &rest properties)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
840 "Install BACKEND for spam.el.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
841 Accepts incoming CHECK, ham registration function HRF, spam
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
842 registration function SRF, ham unregistration function HUF, spam
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
843 unregistration function SUF, and an indication whether the
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
844 backend is STATISTICAL."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
845 (setq spam-backends (add-to-list 'spam-backends backend))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
846 (while properties
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
847 (let ((property (pop properties))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
848 (value (pop properties)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
849 (if (spam-backend-property-valid-p property)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
850 (put backend property value)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
851 (gnus-error
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
852 5
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
853 "spam-install-backend-super got an invalid property %s"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
854 property)))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
855
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
856 (defun spam-backend-list (&optional type)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
857 "Return a list of all the backend symbols, constrained by TYPE.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
858 When TYPE is 'non-mover, only non-mover backends are returned.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
859 When TYPE is 'mover, only mover backends are returned."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
860 (let (list)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
861 (dolist (backend spam-backends)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
862 (when (or
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
863 (null type) ;either no type was requested
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
864 ;; or the type is 'mover and the backend is a mover
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
865 (and
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
866 (eq type 'mover)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
867 (spam-backend-mover-p backend))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
868 ;; or the type is 'non-mover and the backend is not a mover
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
869 (and
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
870 (eq type 'non-mover)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
871 (not (spam-backend-mover-p backend))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
872 (push backend list)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
873 list))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
874
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
875 (defun spam-backend-check (backend)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
876 "Get the check function for BACKEND.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
877 Each individual check may return nil, t, or a mailgroup name.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
878 The value nil means that the check does not yield a decision, and
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
879 so, that further checks are needed. The value t means that the
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
880 message is definitely not spam, and that further spam checks
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
881 should be inhibited. Otherwise, a mailgroup name or the symbol
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
882 'spam (depending on `spam-split-symbolic-return') is returned where
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
883 the mail should go, and further checks are also inhibited. The
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
884 usual mailgroup name is the value of `spam-split-group', meaning
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
885 that the message is definitely a spam."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
886 (get backend 'check))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
887
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
888 (defun spam-backend-valid-p (backend)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
889 "Is BACKEND valid?"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
890 (member backend (spam-backend-list)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
891
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
892 (defun spam-backend-info (backend)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
893 "Return information about BACKEND."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
894 (if (spam-backend-valid-p backend)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
895 (let (info)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
896 (setq info (format "Backend %s has the following properties:\n"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
897 backend))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
898 (dolist (property (spam-backend-properties))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
899 (setq info (format "%s%s=%s\n"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
900 info
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
901 property
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
902 (get backend property))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
903 info)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
904 (gnus-error 5 "spam-backend-info was asked about an invalid backend %s"
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
905 backend)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
906
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
907 (defun spam-backend-function (backend classification type)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
908 "Get the BACKEND function for CLASSIFICATION and TYPE.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
909 TYPE is 'registration or 'unregistration.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
910 CLASSIFICATION is 'ham or 'spam."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
911 (if (and
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
912 (spam-classification-valid-p classification)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
913 (spam-backend-function-type-valid-p type))
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
914 (let ((retrieval
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
915 (intern
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
916 (format "spam-backend-%s-%s-function"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
917 classification
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
918 type))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
919 (funcall retrieval backend))
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
920 (gnus-error
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
921 5
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
922 "%s was passed invalid backend %s, classification %s, or type %s"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
923 "spam-backend-function"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
924 backend
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
925 classification
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
926 type)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
927
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
928 (defun spam-backend-article-list-property (classification
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
929 &optional unregister)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
930 "Property name of article list with CLASSIFICATION and UNREGISTER."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
931 (let* ((r (if unregister "unregister" "register"))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
932 (prop (format "%s-%s" classification r)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
933 prop))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
934
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
935 (defun spam-backend-get-article-todo-list (backend
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
936 classification
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
937 &optional unregister)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
938 "Get the articles to be processed for BACKEND and CLASSIFICATION.
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
939 With UNREGISTER, get articles to be unregistered.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
940 This is a temporary storage function - nothing here persists."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
941 (get
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
942 backend
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
943 (intern (spam-backend-article-list-property classification unregister))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
944
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
945 (defun spam-backend-put-article-todo-list (backend classification list
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
946 &optional unregister)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
947 "Set the LIST of articles to be processed for BACKEND and CLASSIFICATION.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
948 With UNREGISTER, set articles to be unregistered.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
949 This is a temporary storage function - nothing here persists."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
950 (put
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
951 backend
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
952 (intern (spam-backend-article-list-property classification unregister))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
953 list))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
954
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
955 (defun spam-backend-ham-registration-function (backend)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
956 "Get the ham registration function for BACKEND."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
957 (get backend 'hrf))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
958
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
959 (defun spam-backend-spam-registration-function (backend)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
960 "Get the spam registration function for BACKEND."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
961 (get backend 'srf))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
962
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
963 (defun spam-backend-ham-unregistration-function (backend)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
964 "Get the ham unregistration function for BACKEND."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
965 (get backend 'huf))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
966
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
967 (defun spam-backend-spam-unregistration-function (backend)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
968 "Get the spam unregistration function for BACKEND."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
969 (get backend 'suf))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
970
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
971 (defun spam-backend-statistical-p (backend)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
972 "Is BACKEND statistical?"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
973 (get backend 'statistical))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
974
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
975 (defun spam-backend-mover-p (backend)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
976 "Is BACKEND a mover?"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
977 (get backend 'mover))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
978
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
979 (defun spam-install-backend-alias (backend alias)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
980 "Add ALIAS to an existing BACKEND.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
981 The previous backend settings for ALIAS are erased."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
982
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
983 ;; install alias with no properties at first
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
984 (spam-install-backend-super alias)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
985
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
986 (dolist (property (spam-backend-properties))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
987 (put alias property (get backend property))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
988
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
989 (defun spam-install-checkonly-backend (backend check)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
990 "Install a BACKEND than can only CHECK for spam."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
991 (spam-install-backend-super backend 'check check))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
992
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
993 (defun spam-install-mover-backend (backend hrf srf huf suf)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
994 "Install a BACKEND than can move articles at summary exit.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
995 Accepts ham registration function HRF, spam registration function
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
996 SRF, ham unregistration function HUF, spam unregistration
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
997 function SUF. The backend has no incoming check and can't be
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
998 statistical."
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
999 (spam-install-backend-super
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1000 backend
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1001 'hrf hrf 'srf srf 'huf huf 'suf suf 'mover t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1002
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1003 (defun spam-install-nocheck-backend (backend hrf srf huf suf)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1004 "Install a BACKEND than has no check.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1005 Accepts ham registration function HRF, spam registration function
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1006 SRF, ham unregistration function HUF, spam unregistration
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1007 function SUF. The backend has no incoming check and can't be
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1008 statistical (it could be, but in practice that doesn't happen)."
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1009 (spam-install-backend-super
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1010 backend
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1011 'hrf hrf 'srf srf 'huf huf 'suf suf))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1012
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1013 (defun spam-install-backend (backend check hrf srf huf suf)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1014 "Install a BACKEND.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1015 Accepts incoming CHECK, ham registration function HRF, spam
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1016 registration function SRF, ham unregistration function HUF, spam
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1017 unregistration function SUF. The backend won't be
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1018 statistical (use `spam-install-statistical-backend' for that)."
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1019 (spam-install-backend-super
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1020 backend
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1021 'check check 'hrf hrf 'srf srf 'huf huf 'suf suf))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1022
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1023 (defun spam-install-statistical-backend (backend check hrf srf huf suf)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1024 "Install a BACKEND.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1025 Accepts incoming CHECK, ham registration function HRF, spam
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1026 registration function SRF, ham unregistration function HUF, spam
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1027 unregistration function SUF. The backend will be
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1028 statistical (use `spam-install-backend' for non-statistical
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1029 backends)."
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1030 (spam-install-backend-super
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1031 backend
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1032 'check check 'statistical t 'hrf hrf 'srf srf 'huf huf 'suf suf))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1033
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1034 (defun spam-install-statistical-checkonly-backend (backend check)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1035 "Install a statistical BACKEND than can only CHECK for spam."
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1036 (spam-install-backend-super
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1037 backend
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1038 'check check 'statistical t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1039
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1040 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1041
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1042 ;;{{{ backend installations
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1043 (spam-install-checkonly-backend 'spam-use-blackholes
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1044 'spam-check-blackholes)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1045
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1046 (spam-install-checkonly-backend 'spam-use-hashcash
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1047 'spam-check-hashcash)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1048
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1049 (spam-install-checkonly-backend 'spam-use-spamassassin-headers
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1050 'spam-check-spamassassin-headers)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1051
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1052 (spam-install-checkonly-backend 'spam-use-bogofilter-headers
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1053 'spam-check-bogofilter-headers)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1054
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1055 (spam-install-checkonly-backend 'spam-use-bsfilter-headers
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1056 'spam-check-bsfilter-headers)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1057
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1058 (spam-install-checkonly-backend 'spam-use-gmane-xref
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1059 'spam-check-gmane-xref)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1060
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1061 (spam-install-checkonly-backend 'spam-use-regex-headers
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1062 'spam-check-regex-headers)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1063
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1064 (spam-install-statistical-checkonly-backend 'spam-use-regex-body
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1065 'spam-check-regex-body)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1066
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1067 ;; TODO: NOTE: spam-use-ham-copy is now obsolete, use (ham spam-use-copy)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1068 (spam-install-mover-backend 'spam-use-move
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1069 'spam-move-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1070 'spam-move-spam-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1071 nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1072 nil)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1073
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1074 (spam-install-nocheck-backend 'spam-use-copy
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1075 'spam-copy-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1076 'spam-copy-spam-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1077 nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1078 nil)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1079
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1080 (spam-install-nocheck-backend 'spam-use-gmane
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1081 'spam-report-gmane-unregister-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1082 'spam-report-gmane-register-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1083 'spam-report-gmane-register-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1084 'spam-report-gmane-unregister-routine)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1085
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1086 (spam-install-nocheck-backend 'spam-use-resend
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1087 'spam-report-resend-register-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1088 'spam-report-resend-register-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1089 nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1090 nil)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1091
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1092 (spam-install-backend 'spam-use-BBDB
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1093 'spam-check-BBDB
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1094 'spam-BBDB-register-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1095 nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1096 'spam-BBDB-unregister-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1097 nil)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1098
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1099 (spam-install-backend-alias 'spam-use-BBDB 'spam-use-BBDB-exclusive)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1100
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1101 (spam-install-backend 'spam-use-blacklist
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1102 'spam-check-blacklist
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1103 nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1104 'spam-blacklist-register-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1105 nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1106 'spam-blacklist-unregister-routine)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1107
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1108 (spam-install-backend 'spam-use-whitelist
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1109 'spam-check-whitelist
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1110 'spam-whitelist-register-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1111 nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1112 'spam-whitelist-unregister-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1113 nil)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1114
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1115 (spam-install-statistical-backend 'spam-use-ifile
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1116 'spam-check-ifile
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1117 'spam-ifile-register-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1118 'spam-ifile-register-spam-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1119 'spam-ifile-unregister-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1120 'spam-ifile-unregister-spam-routine)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1121
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1122 (spam-install-statistical-backend 'spam-use-spamoracle
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1123 'spam-check-spamoracle
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1124 'spam-spamoracle-learn-ham
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1125 'spam-spamoracle-learn-spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1126 'spam-spamoracle-unlearn-ham
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1127 'spam-spamoracle-unlearn-spam)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1128
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1129 (spam-install-statistical-backend 'spam-use-stat
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1130 'spam-check-stat
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1131 'spam-stat-register-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1132 'spam-stat-register-spam-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1133 'spam-stat-unregister-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1134 'spam-stat-unregister-spam-routine)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1135
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1136 (spam-install-statistical-backend 'spam-use-spamassassin
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1137 'spam-check-spamassassin
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1138 'spam-spamassassin-register-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1139 'spam-spamassassin-register-spam-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1140 'spam-spamassassin-unregister-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1141 'spam-spamassassin-unregister-spam-routine)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1142
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1143 (spam-install-statistical-backend 'spam-use-bogofilter
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1144 'spam-check-bogofilter
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1145 'spam-bogofilter-register-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1146 'spam-bogofilter-register-spam-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1147 'spam-bogofilter-unregister-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1148 'spam-bogofilter-unregister-spam-routine)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1149
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1150 (spam-install-statistical-backend 'spam-use-bsfilter
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1151 'spam-check-bsfilter
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1152 'spam-bsfilter-register-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1153 'spam-bsfilter-register-spam-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1154 'spam-bsfilter-unregister-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1155 'spam-bsfilter-unregister-spam-routine)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1156
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1157 (spam-install-statistical-backend 'spam-use-crm114
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1158 'spam-check-crm114
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1159 'spam-crm114-register-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1160 'spam-crm114-register-spam-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1161 'spam-crm114-unregister-ham-routine
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1162 'spam-crm114-unregister-spam-routine)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1163 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1164
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1165 ;;{{{ scoring and summary formatting
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1166 (defun spam-necessary-extra-headers ()
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1167 "Return the extra headers spam.el thinks are necessary."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1168 (let (list)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1169 (when (or spam-use-spamassassin
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1170 spam-use-spamassassin-headers
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1171 spam-use-regex-headers)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1172 (push 'X-Spam-Status list))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1173 (when (or spam-use-bogofilter
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1174 spam-use-regex-headers)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1175 (push 'X-Bogosity list))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1176 (when (or spam-use-crm114
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1177 spam-use-regex-headers)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1178 (push 'X-CRM114-Status list))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1179 list))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1180
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1181 (defun spam-user-format-function-S (headers)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1182 (when headers
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1183 (format "%3.2f"
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1184 (spam-summary-score headers spam-summary-score-preferred-header))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1185
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1186 (defun spam-article-sort-by-spam-status (h1 h2)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1187 "Sort articles by score."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1188 (let (result)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1189 (dolist (header (spam-necessary-extra-headers))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1190 (let ((s1 (spam-summary-score h1 header))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1191 (s2 (spam-summary-score h2 header)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1192 (unless (= s1 s2)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1193 (setq result (< s1 s2))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1194 (return))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1195 result))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1196
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1197 (defvar spam-spamassassin-score-regexp
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1198 ".*\\b\\(?:score\\|hits\\)=\\(-?[0-9.]+\\)"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1199 "Regexp matching SpamAssassin score header.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1200 The first group must match the number.")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1201
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1202 (defun spam-extra-header-to-number (header headers)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1203 "Transform an extra HEADER to a number, using list of HEADERS.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1204 Note this has to be fast."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1205 (let ((header-content (gnus-extra-header header headers)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1206 (if header-content
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1207 (cond
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1208 ((eq header 'X-Spam-Status)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1209 (string-to-number (gnus-replace-in-string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1210 header-content
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1211 spam-spamassassin-score-regexp
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1212 "\\1")))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1213 ;; for CRM checking, it's probably faster to just do the string match
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1214 ((string-match "( pR: \\([0-9.-]+\\)" header-content)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1215 (- (string-to-number (match-string 1 header-content))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1216 ((eq header 'X-Bogosity)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1217 (string-to-number (gnus-replace-in-string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1218 (gnus-replace-in-string
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1219 header-content
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1220 ".*spamicity=" "")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1221 ",.*" "")))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1222 (t nil))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1223 nil)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1224
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1225 (defun spam-summary-score (headers &optional specific-header)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1226 "Score an article for the summary buffer, as fast as possible.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1227 With SPECIFIC-HEADER, returns only that header's score.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1228 Will not return a nil score."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1229 (let (score)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1230 (dolist (header
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1231 (if specific-header
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1232 (list specific-header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1233 (spam-necessary-extra-headers)))
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1234 (setq score
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1235 (spam-extra-header-to-number header headers))
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1236 (when score
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1237 (return)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1238 (or score 0)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1239
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1240 (defun spam-generic-score (&optional recheck)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1241 "Invoke whatever scoring method we can."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1242 (interactive "P")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1243 (cond
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1244 ((or spam-use-spamassassin spam-use-spamassassin-headers)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1245 (spam-spamassassin-score recheck))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1246 ((or spam-use-bsfilter spam-use-bsfilter-headers)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1247 (spam-bsfilter-score recheck))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1248 (spam-use-crm114
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1249 (spam-crm114-score))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1250 (t (spam-bogofilter-score recheck))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1251 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1252
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1253 ;;{{{ set up widening, processor checks
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1254
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1255 ;;; set up IMAP widening if it's necessary
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1256 (defun spam-setup-widening ()
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1257 (when (spam-widening-needed-p)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1258 (setq nnimap-split-download-body-default t)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1259
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1260 (defun spam-widening-needed-p (&optional force-symbols)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1261 (let (found)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1262 (dolist (backend (spam-backend-list))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1263 (when (and (spam-backend-statistical-p backend)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1264 (or (symbol-value backend)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1265 (memq backend force-symbols)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1266 (setq found backend)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1267 found))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1268
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1269 (defvar spam-list-of-processors
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1270 ;; note the nil processors are not defined in gnus.el
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1271 '((gnus-group-spam-exit-processor-bogofilter spam spam-use-bogofilter)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1272 (gnus-group-spam-exit-processor-bsfilter spam spam-use-bsfilter)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1273 (gnus-group-spam-exit-processor-blacklist spam spam-use-blacklist)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1274 (gnus-group-spam-exit-processor-ifile spam spam-use-ifile)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1275 (gnus-group-spam-exit-processor-stat spam spam-use-stat)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1276 (gnus-group-spam-exit-processor-spamoracle spam spam-use-spamoracle)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1277 (gnus-group-spam-exit-processor-spamassassin spam spam-use-spamassassin)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1278 (gnus-group-spam-exit-processor-report-gmane spam spam-use-gmane) ;; Buggy?
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1279 (gnus-group-ham-exit-processor-ifile ham spam-use-ifile)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1280 (gnus-group-ham-exit-processor-bogofilter ham spam-use-bogofilter)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1281 (gnus-group-ham-exit-processor-bsfilter ham spam-use-bsfilter)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1282 (gnus-group-ham-exit-processor-stat ham spam-use-stat)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1283 (gnus-group-ham-exit-processor-whitelist ham spam-use-whitelist)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1284 (gnus-group-ham-exit-processor-BBDB ham spam-use-BBDB)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1285 (gnus-group-ham-exit-processor-copy ham spam-use-ham-copy)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1286 (gnus-group-ham-exit-processor-spamassassin ham spam-use-spamassassin)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1287 (gnus-group-ham-exit-processor-spamoracle ham spam-use-spamoracle))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1288 "The OBSOLETE `spam-list-of-processors' list.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1289 This list contains pairs associating the obsolete ham/spam exit
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1290 processor variables with a classification and a spam-use-*
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1291 variable. When the processor variable is nil, just the
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1292 classification and spam-use-* check variable are used. This is
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1293 superseded by the new spam backend code, so it's only consulted
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1294 for backwards compatibility.")
111067
e36c65ac23bf Merge changes made in Gnus trunk.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 110918
diff changeset
1295 (make-obsolete-variable 'spam-list-of-processors nil "22.1")
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1296
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1297 (defun spam-group-processor-p (group backend &optional classification)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1298 "Checks if GROUP has a BACKEND with CLASSIFICATION registered.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1299 Also accepts the obsolete processors, which can be found in
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1300 gnus.el and in spam-list-of-processors. In the case of mover
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1301 backends, checks the setting of `spam-summary-exit-behavior' in
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1302 addition to the set values for the group."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1303 (if (and (stringp group)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1304 (symbolp backend))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1305 (let ((old-style (assq backend spam-list-of-processors))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1306 (parameters (nth 0 (gnus-parameter-spam-process group)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1307 found)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1308 (if old-style ; old-style processor
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1309 (spam-group-processor-p group (nth 2 old-style) (nth 1 old-style))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1310 ;; now search for the parameter
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1311 (dolist (parameter parameters)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1312 (when (and (null found)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1313 (listp parameter)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1314 (eq classification (nth 0 parameter))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1315 (eq backend (nth 1 parameter)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1316 (setq found t)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1317
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1318 ;; now, if the parameter was not found, do the
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1319 ;; spam-summary-exit-behavior-logic for mover backends
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1320 (unless found
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1321 (when (spam-backend-mover-p backend)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1322 (setq
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1323 found
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1324 (cond
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1325 ((eq spam-summary-exit-behavior 'move-all) t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1326 ((eq spam-summary-exit-behavior 'move-none) nil)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1327 ((eq spam-summary-exit-behavior 'default)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1328 (or (eq classification 'spam) ;move spam out of all groups
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1329 ;; move ham out of spam groups
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1330 (and (eq classification 'ham)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1331 (spam-group-spam-contents-p group))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1332 (t (gnus-error 5 "Unknown spam-summary-exit-behavior: %s"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1333 spam-summary-exit-behavior))))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1334
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1335 found))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1336 nil))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1337
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1338 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1339
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1340 ;;{{{ Summary entry and exit processing.
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1341
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1342 (defun spam-mark-junk-as-spam-routine ()
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1343 ;; check the global list of group names spam-junk-mailgroups and the
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1344 ;; group parameters
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1345 (when (spam-group-spam-contents-p gnus-newsgroup-name)
69625
17473f7e626b Revision: emacs@sv.gnu.org/emacs--devo--0--patch-170
Miles Bader <miles@gnu.org>
parents: 68633
diff changeset
1346 (gnus-message 6 "Marking %s articles as spam"
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1347 (if spam-mark-only-unseen-as-spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1348 "unseen"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1349 "unread"))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1350 (let ((articles (if spam-mark-only-unseen-as-spam
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1351 gnus-newsgroup-unseen
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1352 gnus-newsgroup-unreads)))
69625
17473f7e626b Revision: emacs@sv.gnu.org/emacs--devo--0--patch-170
Miles Bader <miles@gnu.org>
parents: 68633
diff changeset
1353 (if spam-mark-new-messages-in-spam-group-as-spam
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1354 (dolist (article articles)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1355 (gnus-summary-mark-article article gnus-spam-mark))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1356 (gnus-message 9 "Did not mark new messages as spam.")))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1357
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1358 (defun spam-summary-prepare ()
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1359 (setq spam-old-articles
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1360 (list (cons 'ham (spam-list-articles gnus-newsgroup-articles 'ham))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1361 (cons 'spam (spam-list-articles gnus-newsgroup-articles 'spam))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1362 (spam-mark-junk-as-spam-routine))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1363
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1364 ;; The spam processors are invoked for any group, spam or ham or neither
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1365 (defun spam-summary-prepare-exit ()
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1366 (unless gnus-group-is-exiting-without-update-p
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1367 (gnus-message 6 "Exiting summary buffer and applying spam rules")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1368
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1369 ;; before we begin, remove any article limits
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1370 ; (ignore-errors
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1371 ; (gnus-summary-pop-limit t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1372
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1373 ;; first of all, unregister any articles that are no longer ham or spam
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1374 ;; we have to iterate over the processors, or else we'll be too slow
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1375 (dolist (classification (spam-classifications))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1376 (let* ((old-articles (cdr-safe (assq classification spam-old-articles)))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1377 (new-articles (spam-list-articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1378 gnus-newsgroup-articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1379 classification))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1380 (changed-articles (spam-set-difference new-articles old-articles)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1381 ;; now that we have the changed articles, we go through the processors
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1382 (dolist (backend (spam-backend-list))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1383 (let (unregister-list)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1384 (dolist (article changed-articles)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1385 (let ((id (spam-fetch-field-message-id-fast article)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1386 (when (spam-log-unregistration-needed-p
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1387 id 'process classification backend)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1388 (push article unregister-list))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1389 ;; call spam-register-routine with specific articles to unregister,
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1390 ;; when there are articles to unregister and the check is enabled
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1391 (when (and unregister-list (symbol-value backend))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1392 (spam-backend-put-article-todo-list backend
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1393 classification
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1394 unregister-list
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1395 t))))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1396
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1397 ;; do the non-moving backends first, then the moving ones
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1398 (dolist (backend-type '(non-mover mover))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1399 (dolist (classification (spam-classifications))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1400 (dolist (backend (spam-backend-list backend-type))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1401 (when (spam-group-processor-p
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1402 gnus-newsgroup-name
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1403 backend
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1404 classification)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1405 (spam-backend-put-article-todo-list backend
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1406 classification
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1407 (spam-list-articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1408 gnus-newsgroup-articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1409 classification))))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1410
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1411 (spam-resolve-registrations-routine) ; do the registrations now
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1412
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1413 ;; we mark all the leftover spam articles as expired at the end
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1414 (dolist (article (spam-list-articles
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1415 gnus-newsgroup-articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1416 'spam))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1417 (gnus-summary-mark-article article gnus-expirable-mark)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1418
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1419 (setq spam-old-articles nil))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1420
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1421 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1422
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1423 ;;{{{ spam-use-move and spam-use-copy backend support functions
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1424
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1425 (defun spam-copy-or-move-routine (copy groups articles classification)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1426
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1427 (when (and (car-safe groups) (listp (car-safe groups)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1428 (setq groups (pop groups)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1429
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1430 (unless (listp groups)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1431 (setq groups (list groups)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1432
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1433 ;; remove the current process mark
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1434 (gnus-summary-kill-process-mark)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1435
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1436 (let ((backend-supports-deletions
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1437 (gnus-check-backend-function
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1438 'request-move-article gnus-newsgroup-name))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1439 (respool-method (gnus-find-method-for-group gnus-newsgroup-name))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1440 article mark deletep respool valid-move-destinations)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1441
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1442 (when (member 'respool groups)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1443 (setq respool t) ; boolean for later
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1444 (setq groups '("fake"))) ; when respooling, groups are dynamic so fake it
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1445
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1446 ;; exclude invalid move destinations
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1447 (dolist (group groups)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1448 (unless
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1449 (or
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1450 (and
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1451 (eq classification 'spam)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1452 (spam-group-spam-contents-p gnus-newsgroup-name)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1453 (spam-group-spam-contents-p group)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1454 (gnus-message
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1455 3
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1456 "Sorry, can't move spam from spam group %s to spam group %s"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1457 gnus-newsgroup-name
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1458 group))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1459 (and
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1460 (eq classification 'ham)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1461 (spam-group-ham-contents-p gnus-newsgroup-name)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1462 (spam-group-ham-contents-p group)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1463 (gnus-message
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1464 3
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1465 "Sorry, can't move ham from ham group %s to ham group %s"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1466 gnus-newsgroup-name
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1467 group)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1468 (push group valid-move-destinations)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1469
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1470 (setq groups (nreverse valid-move-destinations))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1471
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1472 ;; now do the actual move
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1473 (dolist (group groups)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1474
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1475 (when (and articles (stringp group))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1476
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1477 ;; first, mark the article with the process mark and, if needed,
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1478 ;; the unread or expired mark (for ham and spam respectively)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1479 (dolist (article articles)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1480 (when (and (eq classification 'ham)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1481 spam-mark-ham-unread-before-move-from-spam-group)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1482 (gnus-message 9 "Marking ham article %d unread before move"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1483 article)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1484 (gnus-summary-mark-article article gnus-unread-mark))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1485 (when (and (eq classification 'spam)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1486 (not copy))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1487 (gnus-message 9 "Marking spam article %d expirable before move"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1488 article)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1489 (gnus-summary-mark-article article gnus-expirable-mark))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1490 (gnus-summary-set-process-mark article)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1491
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1492 (if respool ; respooling is with a "fake" group
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1493 (let ((spam-split-disabled
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1494 (or spam-split-disabled
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1495 (and (eq classification 'ham)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1496 spam-disable-spam-split-during-ham-respool))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1497 (gnus-message 9 "Respooling article %d with method %s"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1498 article respool-method)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1499 (gnus-summary-respool-article nil respool-method))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1500 ;; else, we are not respooling
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1501 (if (or (not backend-supports-deletions)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1502 (> (length groups) 1))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1503 (progn ; if copying, copy and set deletep
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1504 (gnus-message 9 "Copying article %d to group %s"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1505 article group)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1506 (gnus-summary-copy-article nil group)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1507 (setq deletep t))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1508 (gnus-message 9 "Moving article %d to group %s"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1509 article group)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1510 (gnus-summary-move-article nil group)))))) ; else move articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1511
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1512 ;; now delete the articles, unless a) copy is t, and there was a copy done
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1513 ;; b) a move was done to a single group
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1514 ;; c) backend-supports-deletions is nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1515 (unless copy
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1516 (when (and deletep backend-supports-deletions)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1517 (dolist (article articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1518 (gnus-summary-set-process-mark article)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1519 (gnus-message 9 "Deleting article %d" article))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1520 (when articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1521 (let ((gnus-novice-user nil)) ; don't ask me if I'm sure
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1522 (gnus-summary-delete-article nil)))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1523 (gnus-summary-yank-process-mark)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1524 (length articles)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1525
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1526 (defun spam-copy-spam-routine (articles)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1527 (spam-copy-or-move-routine
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1528 t
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1529 (gnus-parameter-spam-process-destination gnus-newsgroup-name)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1530 articles
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1531 'spam))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1532
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1533 (defun spam-move-spam-routine (articles)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1534 (spam-copy-or-move-routine
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1535 nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1536 (gnus-parameter-spam-process-destination gnus-newsgroup-name)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1537 articles
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1538 'spam))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1539
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1540 (defun spam-copy-ham-routine (articles)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1541 (spam-copy-or-move-routine
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1542 t
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1543 (gnus-parameter-ham-process-destination gnus-newsgroup-name)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1544 articles
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1545 'ham))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1546
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1547 (defun spam-move-ham-routine (articles)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1548 (spam-copy-or-move-routine
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1549 nil
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1550 (gnus-parameter-ham-process-destination gnus-newsgroup-name)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1551 articles
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1552 'ham))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1553
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1554 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1555
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1556 ;;{{{ article and field retrieval code
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1557 (defun spam-get-article-as-string (article)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1558 (when (numberp article)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1559 (with-temp-buffer
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1560 (gnus-request-article-this-buffer
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1561 article
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1562 gnus-newsgroup-name)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1563 (buffer-string))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1564
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1565 ;; disabled for now
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1566 ;; (defun spam-get-article-as-filename (article)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1567 ;; (let ((article-filename))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1568 ;; (when (numberp article)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1569 ;; (nnml-possibly-change-directory
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1570 ;; (gnus-group-real-name gnus-newsgroup-name))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1571 ;; (setq article-filename (expand-file-name
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1572 ;; (int-to-string article) nnml-current-directory)))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1573 ;; (if (file-exists-p article-filename)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1574 ;; article-filename
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1575 ;; nil)))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1576
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1577 (defun spam-fetch-field-fast (article field &optional prepared-data-header)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1578 "Fetch a FIELD for ARTICLE with the internal `gnus-data-list' function.
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1579 When PREPARED-DATA-HEADER is given, don't look in the Gnus data.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1580 When FIELD is 'number, ARTICLE can be any number (since we want
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1581 to find it out)."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1582 (when (numberp article)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1583 (let* ((data-header (or prepared-data-header
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1584 (spam-fetch-article-header article))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1585 (if (arrayp data-header)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1586 (cond
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1587 ((equal field 'number)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1588 (mail-header-number data-header))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1589 ((equal field 'from)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1590 (mail-header-from data-header))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1591 ((equal field 'message-id)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1592 (mail-header-message-id data-header))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1593 ((equal field 'subject)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1594 (mail-header-subject data-header))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1595 ((equal field 'references)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1596 (mail-header-references data-header))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1597 ((equal field 'date)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1598 (mail-header-date data-header))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1599 ((equal field 'xref)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1600 (mail-header-xref data-header))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1601 ((equal field 'extra)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1602 (mail-header-extra data-header))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1603 (t
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1604 (gnus-error
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1605 5
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1606 "spam-fetch-field-fast: unknown field %s requested"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1607 field)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1608 nil))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1609 (gnus-message 6 "Article %d has a nil data header" article)))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1610
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1611 (defun spam-fetch-field-from-fast (article &optional prepared-data-header)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1612 (spam-fetch-field-fast article 'from prepared-data-header))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1613
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1614 (defun spam-fetch-field-subject-fast (article &optional prepared-data-header)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1615 (spam-fetch-field-fast article 'subject prepared-data-header))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1616
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1617 (defun spam-fetch-field-message-id-fast (article &optional prepared-data-header)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1618 (spam-fetch-field-fast article 'message-id prepared-data-header))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1619
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1620 (defun spam-generate-fake-headers (article)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1621 (let ((dh (spam-fetch-article-header article)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1622 (if dh
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1623 (concat
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1624 (format
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1625 ;; 80-character limit makes for strange constructs
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1626 (concat "From: %s\nSubject: %s\nMessage-ID: %s\n"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1627 "Date: %s\nReferences: %s\nXref: %s\n")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1628 (spam-fetch-field-fast article 'from dh)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1629 (spam-fetch-field-fast article 'subject dh)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1630 (spam-fetch-field-fast article 'message-id dh)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1631 (spam-fetch-field-fast article 'date dh)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1632 (spam-fetch-field-fast article 'references dh)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1633 (spam-fetch-field-fast article 'xref dh))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1634 (when (spam-fetch-field-fast article 'extra dh)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1635 (format "%s\n" (spam-fetch-field-fast article 'extra dh))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1636 (gnus-message
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1637 5
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1638 "spam-generate-fake-headers: article %d didn't have a valid header"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1639 article))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1640
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1641 (defun spam-fetch-article-header (article)
110410
f2e111723c3a Merge changes made in Gnus trunk.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 110102
diff changeset
1642 (with-current-buffer gnus-summary-buffer
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1643 (gnus-read-header article)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1644 (nth 3 (assq article gnus-newsgroup-data))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1645 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1646
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1647 ;;{{{ Spam determination.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1648
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1649 (defun spam-split (&rest specific-checks)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1650 "Split this message into the `spam' group if it is spam.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1651 This function can be used as an entry in the variable `nnmail-split-fancy',
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1652 for example like this: (: spam-split). It can take checks as
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1653 parameters. A string as a parameter will set the
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1654 `spam-split-group' to that string.
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1655
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1656 See the Info node `(gnus)Fancy Mail Splitting' for more details."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1657 (interactive)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1658 (setq spam-split-last-successful-check nil)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1659 (unless spam-split-disabled
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1660 (let ((spam-split-group-choice spam-split-group))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1661 (dolist (check specific-checks)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1662 (when (stringp check)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1663 (setq spam-split-group-choice check)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1664 (setq specific-checks (delq check specific-checks))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1665
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1666 (let ((spam-split-group spam-split-group-choice)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1667 (widening-needed-check (spam-widening-needed-p specific-checks)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1668 (save-excursion
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1669 (save-restriction
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1670 (when widening-needed-check
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1671 (widen)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1672 (gnus-message 8 "spam-split: widening the buffer (%s requires it)"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1673 widening-needed-check))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1674 (let ((backends (spam-backend-list))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1675 decision)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1676 (while (and backends (not decision))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1677 (let* ((backend (pop backends))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1678 (check-function (spam-backend-check backend))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1679 (spam-split-group (if spam-split-symbolic-return
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1680 'spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1681 spam-split-group)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1682 (when (or
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1683 ;; either, given specific checks, this is one of them
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1684 (memq backend specific-checks)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1685 ;; or, given no specific checks, spam-use-CHECK is set
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1686 (and (null specific-checks) (symbol-value backend)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1687 (gnus-message 6 "spam-split: calling the %s function"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1688 check-function)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1689 (setq decision (funcall check-function))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1690 ;; if we got a decision at all, save the current check
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1691 (when decision
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1692 (setq spam-split-last-successful-check backend))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1693
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1694 (when (eq decision 'spam)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1695 (unless spam-split-symbolic-return
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1696 (gnus-error
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1697 5
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1698 (format "spam-split got %s but %s is nil"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1699 decision
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1700 spam-split-symbolic-return)))))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1701 (if (eq decision t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1702 (if spam-split-symbolic-return-positive 'ham nil)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1703 decision))))))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1704
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1705 (defun spam-find-spam ()
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1706 "Detect spam in the current newsgroup using `spam-split'."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1707 (interactive)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1708
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1709 (let* ((group gnus-newsgroup-name)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1710 (autodetect (gnus-parameter-spam-autodetect group))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1711 (methods (gnus-parameter-spam-autodetect-methods group))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1712 (first-method (nth 0 methods))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1713 (articles (if spam-autodetect-recheck-messages
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1714 gnus-newsgroup-articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1715 gnus-newsgroup-unseen))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1716 article-cannot-be-faked)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1717
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
1718
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1719 (dolist (backend methods)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1720 (when (spam-backend-statistical-p backend)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1721 (setq article-cannot-be-faked t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1722 (return)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1723
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1724 (when (memq 'default methods)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1725 (setq article-cannot-be-faked t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1726
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1727 (when (and autodetect
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1728 (not (equal first-method 'none)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1729 (mapcar
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1730 (lambda (article)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1731 (let ((id (spam-fetch-field-message-id-fast article))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1732 (subject (spam-fetch-field-subject-fast article))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1733 (sender (spam-fetch-field-from-fast article))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1734 registry-lookup)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1735
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1736 (unless id
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1737 (gnus-message 6 "Article %d has no message ID!" article))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1738
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1739 (when (and id spam-log-to-registry)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1740 (setq registry-lookup (spam-log-registration-type id 'incoming))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1741 (when registry-lookup
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1742 (gnus-message
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1743 9
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1744 "spam-find-spam: message %s was already registered incoming"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1745 id)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1746
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1747 (let* ((spam-split-symbolic-return t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1748 (spam-split-symbolic-return-positive t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1749 (fake-headers (spam-generate-fake-headers article))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1750 (split-return
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1751 (or registry-lookup
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1752 (with-temp-buffer
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1753 (if article-cannot-be-faked
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1754 (gnus-request-article-this-buffer
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1755 article
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1756 group)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1757 ;; else, we fake the article
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1758 (when fake-headers (insert fake-headers)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1759 (if (or (null first-method)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1760 (equal first-method 'default))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1761 (spam-split)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1762 (apply 'spam-split methods))))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1763 (if (equal split-return 'spam)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1764 (gnus-summary-mark-article article gnus-spam-mark))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1765
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1766 (when (and id split-return spam-log-to-registry)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1767 (when (zerop (gnus-registry-group-count id))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1768 (gnus-registry-add-group
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1769 id group subject sender))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1770
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1771 (unless registry-lookup
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1772 (spam-log-processing-to-registry
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1773 id
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1774 'incoming
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1775 split-return
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1776 spam-split-last-successful-check
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1777 group))))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1778 articles))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1779
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1780 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1781
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1782 ;;{{{ registration/unregistration functions
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1783
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1784 (defun spam-resolve-registrations-routine ()
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1785 "Go through the backends and register or unregister articles as needed."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1786 (dolist (backend-type '(non-mover mover))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1787 (dolist (classification (spam-classifications))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1788 (dolist (backend (spam-backend-list backend-type))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1789 (let ((rlist (spam-backend-get-article-todo-list
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1790 backend classification))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1791 (ulist (spam-backend-get-article-todo-list
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1792 backend classification t))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1793 (delcount 0))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1794
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1795 ;; clear the old lists right away
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1796 (spam-backend-put-article-todo-list backend
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1797 classification
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1798 nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1799 nil)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1800 (spam-backend-put-article-todo-list backend
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1801 classification
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1802 nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1803 t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1804
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1805 ;; eliminate duplicates
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1806 (dolist (article (copy-sequence ulist))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1807 (when (memq article rlist)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1808 (incf delcount)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1809 (setq rlist (delq article rlist))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1810 (setq ulist (delq article ulist))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1811
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1812 (unless (zerop delcount)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1813 (gnus-message
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1814 9
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1815 "%d messages did not have to unregister and then register"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1816 delcount))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1817
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1818 ;; unregister articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1819 (unless (zerop (length ulist))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1820 (let ((num (spam-unregister-routine classification backend ulist)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1821 (when (> num 0)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1822 (gnus-message
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1823 6
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1824 "%d %s messages were unregistered by backend %s."
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1825 num
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1826 classification
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1827 backend))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1828
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1829 ;; register articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1830 (unless (zerop (length rlist))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1831 (let ((num (spam-register-routine classification backend rlist)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1832 (when (> num 0)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1833 (gnus-message
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1834 6
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1835 "%d %s messages were registered by backend %s."
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1836 num
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1837 classification
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1838 backend)))))))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1839
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1840 (defun spam-unregister-routine (classification
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1841 backend
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1842 specific-articles)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1843 (spam-register-routine classification backend specific-articles t))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1844
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1845 (defun spam-register-routine (classification
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1846 backend
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1847 specific-articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1848 &optional unregister)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1849 (when (and (spam-classification-valid-p classification)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1850 (spam-backend-valid-p backend))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1851 (let* ((register-function
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1852 (spam-backend-function backend classification 'registration))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1853 (unregister-function
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1854 (spam-backend-function backend classification 'unregistration))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1855 (run-function (if unregister
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1856 unregister-function
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1857 register-function))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1858 (log-function (if unregister
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1859 'spam-log-undo-registration
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1860 'spam-log-processing-to-registry))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1861 article articles)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1862
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1863 (when run-function
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1864 ;; make list of articles, using specific-articles if given
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1865 (setq articles (or specific-articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1866 (spam-list-articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1867 gnus-newsgroup-articles
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1868 classification)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1869 ;; process them
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1870 (when (> (length articles) 0)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1871 (gnus-message 5 "%s %d %s articles as %s using backend %s"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1872 (if unregister "Unregistering" "Registering")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1873 (length articles)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1874 (if specific-articles "specific" "")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1875 classification
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1876 backend)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1877 (funcall run-function articles)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1878 ;; now log all the registrations (or undo them, depending on
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1879 ;; unregister)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1880 (dolist (article articles)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1881 (funcall log-function
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1882 (spam-fetch-field-message-id-fast article)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1883 'process
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1884 classification
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1885 backend
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1886 gnus-newsgroup-name))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1887 ;; return the number of articles processed
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1888 (length articles))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1889
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1890 ;;; log a ham- or spam-processor invocation to the registry
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1891 (defun spam-log-processing-to-registry (id type classification backend group)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1892 (when spam-log-to-registry
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1893 (if (and (stringp id)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1894 (stringp group)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1895 (spam-process-type-valid-p type)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1896 (spam-classification-valid-p classification)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1897 (spam-backend-valid-p backend))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1898 (let ((cell-list (cdr-safe (gnus-registry-fetch-extra id type)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1899 (cell (list classification backend group)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1900 (push cell cell-list)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1901 (gnus-registry-store-extra-entry
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1902 id
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1903 type
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1904 cell-list))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1905
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1906 (gnus-error
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1907 7
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1908 (format
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1909 "%s call with bad ID, type, classification, spam-backend, or group"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1910 "spam-log-processing-to-registry")))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1911
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1912 ;;; check if a ham- or spam-processor registration has been done
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1913 (defun spam-log-registered-p (id type)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1914 (when spam-log-to-registry
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1915 (if (and (stringp id)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1916 (spam-process-type-valid-p type))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1917 (cdr-safe (gnus-registry-fetch-extra id type))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1918 (progn
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1919 (gnus-error
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1920 7
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1921 (format "%s called with bad ID, type, classification, or spam-backend"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1922 "spam-log-registered-p"))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1923 nil))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1924
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1925 ;;; check what a ham- or spam-processor registration says
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1926 ;;; returns nil if conflicting registrations are found
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1927 (defun spam-log-registration-type (id type)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1928 (let ((count 0)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1929 decision)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1930 (dolist (reg (spam-log-registered-p id type))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1931 (let ((classification (nth 0 reg)))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1932 (when (spam-classification-valid-p classification)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1933 (when (and decision
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1934 (not (eq classification decision)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1935 (setq count (+ 1 count)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1936 (setq decision classification))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1937 (if (< 0 count)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1938 nil
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1939 decision)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1940
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1941
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1942 ;;; check if a ham- or spam-processor registration needs to be undone
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1943 (defun spam-log-unregistration-needed-p (id type classification backend)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1944 (when spam-log-to-registry
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1945 (if (and (stringp id)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1946 (spam-process-type-valid-p type)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1947 (spam-classification-valid-p classification)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1948 (spam-backend-valid-p backend))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1949 (let ((cell-list (cdr-safe (gnus-registry-fetch-extra id type)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1950 found)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1951 (dolist (cell cell-list)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1952 (unless found
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1953 (when (and (eq classification (nth 0 cell))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1954 (eq backend (nth 1 cell)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1955 (setq found t))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1956 found)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1957 (progn
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1958 (gnus-error
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1959 7
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1960 (format "%s called with bad ID, type, classification, or spam-backend"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1961 "spam-log-unregistration-needed-p"))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1962 nil))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1963
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1964
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1965 ;;; undo a ham- or spam-processor registration (the group is not used)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1966 (defun spam-log-undo-registration (id type classification backend
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1967 &optional group)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1968 (when (and spam-log-to-registry
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1969 (spam-log-unregistration-needed-p id type classification backend))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1970 (if (and (stringp id)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1971 (spam-process-type-valid-p type)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1972 (spam-classification-valid-p classification)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1973 (spam-backend-valid-p backend))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1974 (let ((cell-list (cdr-safe (gnus-registry-fetch-extra id type)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1975 new-cell-list found)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1976 (dolist (cell cell-list)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1977 (unless (and (eq classification (nth 0 cell))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1978 (eq backend (nth 1 cell)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1979 (push cell new-cell-list)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1980 (gnus-registry-store-extra-entry
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1981 id
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1982 type
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1983 new-cell-list))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1984 (progn
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1985 (gnus-error 7 (format
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1986 "%s call with bad ID, type, spam-backend, or group"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1987 "spam-log-undo-registration"))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1988 nil))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
1989
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1990 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1991
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1992 ;;{{{ backend functions
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1993
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1994 ;;{{{ Gmane xrefs
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1995 (defun spam-check-gmane-xref ()
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
1996 (let ((header (or
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1997 (message-fetch-field "Xref")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1998 (message-fetch-field "Newsgroups"))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
1999 (when header ; return nil when no header
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2000 (when (string-match spam-gmane-xref-spam-group
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2001 header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2002 spam-split-group))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2003
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2004 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2005
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2006 ;;{{{ Regex body
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2007
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2008 (defun spam-check-regex-body ()
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2009 (let ((spam-regex-headers-ham spam-regex-body-ham)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2010 (spam-regex-headers-spam spam-regex-body-spam))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2011 (spam-check-regex-headers t)))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2012
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2013 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2014
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2015 ;;{{{ Regex headers
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2016
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2017 (defun spam-check-regex-headers (&optional body)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2018 (let ((type (if body "body" "header"))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2019 ret found)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2020 (dolist (h-regex spam-regex-headers-ham)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2021 (unless found
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2022 (goto-char (point-min))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2023 (when (re-search-forward h-regex nil t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2024 (message "Ham regex %s search positive." type)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2025 (setq found t))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2026 (dolist (s-regex spam-regex-headers-spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2027 (unless found
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2028 (goto-char (point-min))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2029 (when (re-search-forward s-regex nil t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2030 (message "Spam regex %s search positive." type)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2031 (setq found t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2032 (setq ret spam-split-group))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2033 ret))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2034
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2035 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2036
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2037 ;;{{{ Blackholes.
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2038
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2039 (defun spam-reverse-ip-string (ip)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2040 (when (stringp ip)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2041 (mapconcat 'identity
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2042 (nreverse (split-string ip "\\."))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2043 ".")))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2044
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2045 (defun spam-check-blackholes ()
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2046 "Check the Received headers for blackholed relays."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2047 (let ((headers (message-fetch-field "received"))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2048 ips matches)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2049 (when headers
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2050 (with-temp-buffer
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2051 (insert headers)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2052 (goto-char (point-min))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2053 (gnus-message 6 "Checking headers for relay addresses")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2054 (while (re-search-forward
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2055 "\\([0-9]+\\.[0-9]+\\.[0-9]+\\.[0-9]+\\)" nil t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2056 (gnus-message 9 "Blackhole search found host IP %s." (match-string 1))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2057 (push (spam-reverse-ip-string (match-string 1))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2058 ips)))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2059 (dolist (server spam-blackhole-servers)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2060 (dolist (ip ips)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2061 (unless (and spam-blackhole-good-server-regex
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2062 ;; match against the reversed (again) IP string
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2063 (string-match
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2064 spam-blackhole-good-server-regex
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2065 (spam-reverse-ip-string ip)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2066 (unless matches
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2067 (let ((query-string (concat ip "." server)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2068 (if spam-use-dig
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2069 (let ((query-result (query-dig query-string)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2070 (when query-result
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2071 (gnus-message 6 "(DIG): positive blackhole check '%s'"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2072 query-result)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2073 (push (list ip server query-result)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2074 matches)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2075 ;; else, if not using dig.el
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2076 (when (dns-query query-string)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2077 (gnus-message 6 "positive blackhole check")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2078 (push (list ip server (dns-query query-string 'TXT))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2079 matches)))))))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2080 (when matches
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2081 spam-split-group)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2082 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2083
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2084 ;;{{{ Hashcash.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2085
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2086 (defun spam-check-hashcash ()
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2087 "Check the headers for hashcash payments."
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2088 (ignore-errors (mail-check-payment))) ;mail-check-payment returns a boolean
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2089
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2090 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2091
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2092 ;;{{{ BBDB
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2093
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2094 ;;; original idea for spam-check-BBDB from Alexander Kotelnikov
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2095 ;;; <sacha@giotto.sj.ru>
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2096
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2097 ;; all this is done inside a condition-case to trap errors
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2098
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2099 (eval-when-compile
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2100 (autoload 'bbdb-buffer "bbdb")
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2101 (autoload 'bbdb-create-internal "bbdb")
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2102 (autoload 'bbdb-search-simple "bbdb"))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2103
87226
8088d508b758 Move `require's before `eval-when-compile's.
Glenn Morris <rgm@gnu.org>
parents: 86328
diff changeset
2104 ;; Autoloaded in message, which we require.
8088d508b758 Move `require's before `eval-when-compile's.
Glenn Morris <rgm@gnu.org>
parents: 86328
diff changeset
2105 (declare-function gnus-extract-address-components "gnus-util" (from))
8088d508b758 Move `require's before `eval-when-compile's.
Glenn Morris <rgm@gnu.org>
parents: 86328
diff changeset
2106
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2107 (eval-and-compile
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2108 (when (condition-case nil
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2109 (progn
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2110 (require 'bbdb)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2111 (require 'bbdb-com))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2112 (file-error
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2113 ;; `bbdb-records' should not be bound as an autoload function
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2114 ;; before loading bbdb because of `bbdb-hashtable-size'.
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2115 (defalias 'bbdb-records 'ignore)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2116 (defalias 'spam-BBDB-register-routine 'ignore)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2117 (defalias 'spam-enter-ham-BBDB 'ignore)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2118 nil))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2119
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2120 ;; when the BBDB changes, we want to clear out our cache
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2121 (defun spam-clear-cache-BBDB (&rest immaterial)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2122 (spam-clear-cache 'spam-use-BBDB))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2123
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2124 (add-hook 'bbdb-change-hook 'spam-clear-cache-BBDB)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2125
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2126 (defun spam-enter-ham-BBDB (addresses &optional remove)
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2127 "Enter an address into the BBDB; implies ham (non-spam) sender"
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2128 (dolist (from addresses)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2129 (when (stringp from)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2130 (let* ((parsed-address (gnus-extract-address-components from))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2131 (name (or (nth 0 parsed-address) "Ham Sender"))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2132 (remove-function (if remove
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2133 'bbdb-delete-record-internal
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2134 'ignore))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2135 (net-address (nth 1 parsed-address))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2136 (record (and net-address
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2137 (bbdb-search-simple nil net-address))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2138 (when net-address
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2139 (gnus-message 6 "%s address %s %s BBDB"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2140 (if remove "Deleting" "Adding")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2141 from
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2142 (if remove "from" "to"))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2143 (if record
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2144 (funcall remove-function record)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2145 (bbdb-create-internal name nil net-address nil nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2146 "ham sender added by spam.el")))))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2147
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2148 (defun spam-BBDB-register-routine (articles &optional unregister)
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2149 (let (addresses)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2150 (dolist (article articles)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2151 (when (stringp (spam-fetch-field-from-fast article))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2152 (push (spam-fetch-field-from-fast article) addresses)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2153 ;; now do the register/unregister action
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2154 (spam-enter-ham-BBDB addresses unregister)))
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2155
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2156 (defun spam-BBDB-unregister-routine (articles)
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2157 (spam-BBDB-register-routine articles t))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2158
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2159 (defun spam-check-BBDB ()
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2160 "Mail from people in the BBDB is classified as ham or non-spam"
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2161 (let ((who (message-fetch-field "from"))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2162 bbdb-cache bbdb-hashtable)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2163 (when spam-cache-lookups
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2164 (setq bbdb-cache (gethash 'spam-use-BBDB spam-caches))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2165 (unless bbdb-cache
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2166 (setq bbdb-cache (make-vector 17 0)) ; a good starting hash value
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2167 ;; this is based on the expanded (bbdb-hashtable) macro
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2168 ;; without the debugging support
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2169 (with-current-buffer (bbdb-buffer)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2170 (save-excursion
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2171 (save-window-excursion
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2172 (bbdb-records nil t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2173 (mapatoms
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2174 (lambda (symbol)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2175 (intern (downcase (symbol-name symbol)) bbdb-cache))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2176 bbdb-hashtable))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2177 (puthash 'spam-use-BBDB bbdb-cache spam-caches)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2178 (when who
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2179 (setq who (nth 1 (gnus-extract-address-components who)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2180 (if
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2181 (if spam-cache-lookups
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2182 (intern-soft (downcase who) bbdb-cache)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2183 (bbdb-search-simple nil who))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2184 t
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2185 (if spam-use-BBDB-exclusive
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2186 spam-split-group
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2187 nil)))))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2188
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2189 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2190
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2191 ;;{{{ ifile
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2192
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2193 ;;; check the ifile backend; return nil if the mail was NOT classified
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2194 ;;; as spam
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2195
74984
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
2196
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2197 (defun spam-get-ifile-database-parameter ()
74984
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
2198 "Return the command-line parameter for ifile's database.
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
2199 See `spam-ifile-database'."
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
2200 (if spam-ifile-database
21f28d10d73a Merge from gnus--rel--5.10
Miles Bader <miles@gnu.org>
parents: 69625
diff changeset
2201 (format "--db-file=%s" spam-ifile-database)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2202 nil))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2203
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2204 (defun spam-check-ifile ()
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2205 "Check the ifile backend for the classification of this message."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2206 (let ((article-buffer-name (buffer-name))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2207 category return)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2208 (with-temp-buffer
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2209 (let ((temp-buffer-name (buffer-name))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2210 (db-param (spam-get-ifile-database-parameter)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2211 (with-current-buffer article-buffer-name
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2212 (apply 'call-process-region
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2213 (point-min) (point-max) spam-ifile-program
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2214 nil temp-buffer-name nil "-c"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2215 (if db-param `(,db-param "-q") `("-q"))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2216 ;; check the return now (we're back in the temp buffer)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2217 (goto-char (point-min))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2218 (if (not (eobp))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2219 (setq category (buffer-substring (point) (point-at-eol))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2220 (when (not (zerop (length category))) ; we need a category here
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2221 (if spam-ifile-all-categories
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2222 (setq return category)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2223 ;; else, if spam-ifile-all-categories is not set...
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2224 (when (string-equal spam-ifile-spam-category category)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2225 (setq return spam-split-group)))))) ; note return is nil otherwise
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2226 return))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2227
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2228 (defun spam-ifile-register-with-ifile (articles category &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2229 "Register an article, given as a string, with a category.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2230 Uses `gnus-newsgroup-name' if category is nil (for ham registration)."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2231 (let ((category (or category gnus-newsgroup-name))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2232 (add-or-delete-option (if unregister "-d" "-i"))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2233 (db (spam-get-ifile-database-parameter))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2234 parameters)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2235 (with-temp-buffer
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2236 (dolist (article articles)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2237 (let ((article-string (spam-get-article-as-string article)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2238 (when (stringp article-string)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2239 (insert article-string))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2240 (apply 'call-process-region
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2241 (point-min) (point-max) spam-ifile-program
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2242 nil nil nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2243 add-or-delete-option category
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2244 (if db `(,db "-h") `("-h"))))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2245
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2246 (defun spam-ifile-register-spam-routine (articles &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2247 (spam-ifile-register-with-ifile articles spam-ifile-spam-category unregister))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2248
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2249 (defun spam-ifile-unregister-spam-routine (articles)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2250 (spam-ifile-register-spam-routine articles t))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2251
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2252 (defun spam-ifile-register-ham-routine (articles &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2253 (spam-ifile-register-with-ifile articles spam-ifile-ham-category unregister))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2254
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2255 (defun spam-ifile-unregister-ham-routine (articles)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2256 (spam-ifile-register-ham-routine articles t))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2257
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2258 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2259
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2260 ;;{{{ spam-stat
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2261
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2262 (eval-when-compile
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2263 (autoload 'spam-stat-buffer-change-to-non-spam "spam-stat")
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2264 (autoload 'spam-stat-buffer-change-to-spam "spam-stat")
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2265 (autoload 'spam-stat-buffer-is-non-spam "spam-stat")
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2266 (autoload 'spam-stat-buffer-is-spam "spam-stat")
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2267 (autoload 'spam-stat-load "spam-stat")
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2268 (autoload 'spam-stat-save "spam-stat")
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2269 (autoload 'spam-stat-split-fancy "spam-stat"))
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2270
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2271 (eval-and-compile
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2272 (when (condition-case nil
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2273 (let ((spam-stat-install-hooks nil))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2274 (require 'spam-stat))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2275 (file-error
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2276 (defalias 'spam-stat-register-ham-routine 'ignore)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2277 (defalias 'spam-stat-register-spam-routine 'ignore)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2278 nil))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2279
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2280 (defun spam-check-stat ()
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2281 "Check the spam-stat backend for the classification of this message"
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2282 (let ((spam-stat-split-fancy-spam-group spam-split-group) ; override
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2283 (spam-stat-buffer (buffer-name)) ; stat the current buffer
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2284 category return)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2285 (spam-stat-split-fancy)))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2286
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2287 (defun spam-stat-register-spam-routine (articles &optional unregister)
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2288 (dolist (article articles)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2289 (let ((article-string (spam-get-article-as-string article)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2290 (with-temp-buffer
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2291 (insert article-string)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2292 (if unregister
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2293 (spam-stat-buffer-change-to-non-spam)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2294 (spam-stat-buffer-is-spam))))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2295
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2296 (defun spam-stat-unregister-spam-routine (articles)
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2297 (spam-stat-register-spam-routine articles t))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2298
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2299 (defun spam-stat-register-ham-routine (articles &optional unregister)
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2300 (dolist (article articles)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2301 (let ((article-string (spam-get-article-as-string article)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2302 (with-temp-buffer
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2303 (insert article-string)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2304 (if unregister
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2305 (spam-stat-buffer-change-to-spam)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2306 (spam-stat-buffer-is-non-spam))))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2307
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2308 (defun spam-stat-unregister-ham-routine (articles)
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2309 (spam-stat-register-ham-routine articles t))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2310
58835
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2311 (defun spam-maybe-spam-stat-load ()
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2312 (when spam-use-stat (spam-stat-load)))
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2313
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2314 (defun spam-maybe-spam-stat-save ()
9bdd97960431 Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-716
Miles Bader <miles@gnu.org>
parents: 57931
diff changeset
2315 (when spam-use-stat (spam-stat-save)))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2316
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2317 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2318
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2319 ;;{{{ Blacklists and whitelists.
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2320
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2321 (defvar spam-whitelist-cache nil)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2322 (defvar spam-blacklist-cache nil)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2323
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2324 (defun spam-kill-whole-line ()
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2325 (beginning-of-line)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2326 (let ((kill-whole-line t))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2327 (kill-line)))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2328
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2329 ;;; address can be a list, too
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2330 (defun spam-enter-whitelist (address &optional remove)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2331 "Enter ADDRESS (list or single) into the whitelist.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2332 With a non-nil REMOVE, remove them."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2333 (interactive "sAddress: ")
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2334 (spam-enter-list address spam-whitelist remove)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2335 (setq spam-whitelist-cache nil)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2336 (spam-clear-cache 'spam-use-whitelist))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2337
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2338 ;;; address can be a list, too
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2339 (defun spam-enter-blacklist (address &optional remove)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2340 "Enter ADDRESS (list or single) into the blacklist.
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2341 With a non-nil REMOVE, remove them."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2342 (interactive "sAddress: ")
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2343 (spam-enter-list address spam-blacklist remove)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2344 (setq spam-blacklist-cache nil)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2345 (spam-clear-cache 'spam-use-whitelist))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2346
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2347 (defun spam-enter-list (addresses file &optional remove)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2348 "Enter ADDRESSES into the given FILE.
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
2349 Either the whitelist or the blacklist files can be used.
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
2350 With a non-nil REMOVE, remove the ADDRESSES."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2351 (if (stringp addresses)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2352 (spam-enter-list (list addresses) file remove)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2353 ;; else, we have a list of addresses here
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2354 (unless (file-exists-p (file-name-directory file))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2355 (make-directory (file-name-directory file) t))
110410
f2e111723c3a Merge changes made in Gnus trunk.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 110102
diff changeset
2356 (with-current-buffer
f2e111723c3a Merge changes made in Gnus trunk.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 110102
diff changeset
2357 (find-file-noselect file)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2358 (dolist (a addresses)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2359 (when (stringp a)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2360 (goto-char (point-min))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2361 (if (re-search-forward (regexp-quote a) nil t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2362 ;; found the address
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2363 (when remove
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2364 (spam-kill-whole-line))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2365 ;; else, the address was not found
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2366 (unless remove
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2367 (goto-char (point-max))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2368 (unless (bobp)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2369 (insert "\n"))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2370 (insert a "\n")))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2371 (save-buffer))))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2372
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2373 (defun spam-filelist-build-cache (type)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2374 (let ((cache (if (eq type 'spam-use-blacklist)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2375 spam-blacklist-cache
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2376 spam-whitelist-cache))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2377 parsed-cache)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2378 (unless (gethash type spam-caches)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2379 (while cache
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2380 (let ((address (pop cache)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2381 (unless (zerop (length address)) ; 0 for a nil address too
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2382 (setq address (regexp-quote address))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2383 ;; fix regexp-quote's treatment of user-intended regexes
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2384 (while (string-match "\\\\\\*" address)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2385 (setq address (replace-match ".*" t t address))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2386 (push address parsed-cache)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2387 (puthash type parsed-cache spam-caches))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2388
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2389 (defun spam-filelist-check-cache (type from)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2390 (when (stringp from)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2391 (spam-filelist-build-cache type)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2392 (let (found)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2393 (dolist (address (gethash type spam-caches))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2394 (when (and address (string-match address from))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2395 (setq found t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2396 (return)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2397 found)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2398
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2399 ;;; returns t if the sender is in the whitelist, nil or
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2400 ;;; spam-split-group otherwise
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2401 (defun spam-check-whitelist ()
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2402 ;; FIXME! Should it detect when file timestamps change?
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2403 (unless spam-whitelist-cache
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2404 (setq spam-whitelist-cache (spam-parse-list spam-whitelist)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2405 (if (spam-from-listed-p 'spam-use-whitelist)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2406 t
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2407 (if spam-use-whitelist-exclusive
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2408 spam-split-group
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2409 nil)))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2410
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2411 (defun spam-check-blacklist ()
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2412 ;; FIXME! Should it detect when file timestamps change?
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2413 (unless spam-blacklist-cache
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2414 (setq spam-blacklist-cache (spam-parse-list spam-blacklist)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2415 (and (spam-from-listed-p 'spam-use-blacklist)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2416 spam-split-group))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2417
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2418 (defun spam-parse-list (file)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2419 (when (file-readable-p file)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2420 (let (contents address)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2421 (with-temp-buffer
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2422 (insert-file-contents file)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2423 (while (not (eobp))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2424 (setq address (buffer-substring (point) (point-at-eol)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2425 (forward-line 1)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2426 ;; insert the e-mail address if detected, otherwise the raw data
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2427 (unless (zerop (length address))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2428 (let ((pure-address
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2429 (nth 1 (gnus-extract-address-components address))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2430 (push (or pure-address address) contents)))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2431 (nreverse contents))))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2432
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2433 (defun spam-from-listed-p (type)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2434 (let ((from (message-fetch-field "from"))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2435 found)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2436 (spam-filelist-check-cache type from)))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2437
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2438 (defun spam-filelist-register-routine (articles blacklist &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2439 (let ((de-symbol (if blacklist 'spam-use-whitelist 'spam-use-blacklist))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2440 (declassification (if blacklist 'ham 'spam))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2441 (enter-function
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2442 (if blacklist 'spam-enter-blacklist 'spam-enter-whitelist))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2443 (remove-function
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2444 (if blacklist 'spam-enter-whitelist 'spam-enter-blacklist))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2445 from addresses unregister-list article-unregister-list)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2446 (dolist (article articles)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2447 (let ((from (spam-fetch-field-from-fast article))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2448 (id (spam-fetch-field-message-id-fast article))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2449 sender-ignored)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2450 (when (stringp from)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2451 (dolist (ignore-regex spam-blacklist-ignored-regexes)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2452 (when (and (not sender-ignored)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2453 (stringp ignore-regex)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2454 (string-match ignore-regex from))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2455 (setq sender-ignored t)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2456 ;; remember the messages we need to unregister, unless remove is set
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2457 (when (and
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2458 (null unregister)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2459 (spam-log-unregistration-needed-p
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2460 id 'process declassification de-symbol))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2461 (push article article-unregister-list)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2462 (push from unregister-list))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2463 (unless sender-ignored
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2464 (push from addresses)))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2465
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2466 (if unregister
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2467 (funcall enter-function addresses t) ; unregister all these addresses
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2468 ;; else, register normally and unregister what we need to
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2469 (funcall remove-function unregister-list t)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2470 (dolist (article article-unregister-list)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2471 (spam-log-undo-registration
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2472 (spam-fetch-field-message-id-fast article)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2473 'process
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2474 declassification
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2475 de-symbol))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2476 (funcall enter-function addresses nil))))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2477
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2478 (defun spam-blacklist-unregister-routine (articles)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2479 (spam-blacklist-register-routine articles t))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2480
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2481 (defun spam-blacklist-register-routine (articles &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2482 (spam-filelist-register-routine articles t unregister))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2483
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2484 (defun spam-whitelist-unregister-routine (articles)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2485 (spam-whitelist-register-routine articles t))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2486
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2487 (defun spam-whitelist-register-routine (articles &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2488 (spam-filelist-register-routine articles nil unregister))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2489
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2490 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2491
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2492 ;;{{{ Spam-report glue (gmane and resend reporting)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2493 (defun spam-report-gmane-register-routine (articles)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2494 (when articles
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2495 (apply 'spam-report-gmane-spam articles)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2496
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2497 (defun spam-report-gmane-unregister-routine (articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2498 (when articles
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2499 (apply 'spam-report-gmane-ham articles)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2500
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2501 (defun spam-report-resend-register-ham-routine (articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2502 (spam-report-resend-register-routine articles t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2503
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2504 (defun spam-report-resend-register-routine (articles &optional ham)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
2505 (let* ((resend-to-gp
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2506 (if ham
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2507 (gnus-parameter-ham-resend-to gnus-newsgroup-name)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2508 (gnus-parameter-spam-resend-to gnus-newsgroup-name)))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2509 (spam-report-resend-to (or (car-safe resend-to-gp)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2510 spam-report-resend-to)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2511 (spam-report-resend articles ham)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2512
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2513 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2514
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2515 ;;{{{ Bogofilter
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2516 (defun spam-check-bogofilter-headers (&optional score)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2517 (let ((header (message-fetch-field spam-bogofilter-header)))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2518 (when header ; return nil when no header
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2519 (if score ; scoring mode
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2520 (if (string-match "spamicity=\\([0-9.]+\\)" header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2521 (match-string 1 header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2522 "0")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2523 ;; spam detection mode
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2524 (when (string-match spam-bogofilter-bogosity-positive-spam-header
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2525 header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2526 spam-split-group)))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2527
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2528 ;; return something sensible if the score can't be determined
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2529 (defun spam-bogofilter-score (&optional recheck)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
2530 "Get the Bogofilter spamicity score."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2531 (interactive "P")
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2532 (save-window-excursion
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2533 (gnus-summary-show-article t)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2534 (set-buffer gnus-article-buffer)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2535 (let ((score (or (unless recheck
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2536 (spam-check-bogofilter-headers t))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2537 (spam-check-bogofilter t))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2538 (gnus-summary-show-article)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2539 (message "Spamicity score %s" score)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2540 (or score "0"))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2541
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2542 (defun spam-verify-bogofilter ()
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2543 "Verify the Bogofilter version is sufficient."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2544 (when (eq spam-bogofilter-valid 'unknown)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2545 (setq spam-bogofilter-valid
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2546 (not (string-match "^bogofilter version 0\\.\\([0-9]\\|1[01]\\)\\."
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2547 (shell-command-to-string
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2548 (format "%s -V" spam-bogofilter-program))))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2549 spam-bogofilter-valid)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2550
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2551 (defun spam-check-bogofilter (&optional score)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2552 "Check the Bogofilter backend for the classification of this message."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2553 (if (spam-verify-bogofilter)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2554 (let ((article-buffer-name (buffer-name))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2555 (db spam-bogofilter-database-directory)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2556 return)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2557 (with-temp-buffer
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2558 (let ((temp-buffer-name (buffer-name)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2559 (with-current-buffer article-buffer-name
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2560 (apply 'call-process-region
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2561 (point-min) (point-max)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2562 spam-bogofilter-program
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2563 nil temp-buffer-name nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2564 (if db `("-d" ,db "-v") `("-v"))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2565 (setq return (spam-check-bogofilter-headers score))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2566 return)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2567 (gnus-error 5 "`spam.el' doesn't support obsolete bogofilter versions")))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2568
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2569 (defun spam-bogofilter-register-with-bogofilter (articles
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2570 spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2571 &optional unregister)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2572 "Register an article, given as a string, as spam or non-spam."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2573 (if (spam-verify-bogofilter)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2574 (dolist (article articles)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2575 (let ((article-string (spam-get-article-as-string article))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2576 (db spam-bogofilter-database-directory)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2577 (switch (if unregister
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2578 (if spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2579 spam-bogofilter-spam-strong-switch
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2580 spam-bogofilter-ham-strong-switch)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2581 (if spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2582 spam-bogofilter-spam-switch
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2583 spam-bogofilter-ham-switch))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2584 (when (stringp article-string)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2585 (with-temp-buffer
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2586 (insert article-string)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2587
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2588 (apply 'call-process-region
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2589 (point-min) (point-max)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2590 spam-bogofilter-program
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2591 nil nil nil switch
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2592 (if db `("-d" ,db "-v") `("-v")))))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2593 (gnus-error 5 "`spam.el' doesn't support obsolete bogofilter versions")))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2594
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2595 (defun spam-bogofilter-register-spam-routine (articles &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2596 (spam-bogofilter-register-with-bogofilter articles t unregister))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2597
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2598 (defun spam-bogofilter-unregister-spam-routine (articles)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2599 (spam-bogofilter-register-spam-routine articles t))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2600
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2601 (defun spam-bogofilter-register-ham-routine (articles &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2602 (spam-bogofilter-register-with-bogofilter articles nil unregister))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2603
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2604 (defun spam-bogofilter-unregister-ham-routine (articles)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2605 (spam-bogofilter-register-ham-routine articles t))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2606
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2607
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2608 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2609
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2610 ;;{{{ spamoracle
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2611 (defun spam-check-spamoracle ()
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2612 "Run spamoracle on an article to determine whether it's spam."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2613 (let ((article-buffer-name (buffer-name)))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2614 (with-temp-buffer
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2615 (let ((temp-buffer-name (buffer-name)))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2616 (with-current-buffer article-buffer-name
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2617 (let ((status
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2618 (apply 'call-process-region
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2619 (point-min) (point-max)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2620 spam-spamoracle-binary
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2621 nil temp-buffer-name nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2622 (if spam-spamoracle-database
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2623 `("-f" ,spam-spamoracle-database "mark")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2624 '("mark")))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2625 (if (eq 0 status)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2626 (progn
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2627 (set-buffer temp-buffer-name)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2628 (goto-char (point-min))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2629 (when (re-search-forward "^X-Spam: yes;" nil t)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2630 spam-split-group))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2631 (error "Error running spamoracle: %s" status))))))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2632
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2633 (defun spam-spamoracle-learn (articles article-is-spam-p &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2634 "Run spamoracle in training mode."
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2635 (with-temp-buffer
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2636 (let ((temp-buffer-name (buffer-name)))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2637 (save-excursion
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2638 (goto-char (point-min))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2639 (dolist (article articles)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2640 (insert (spam-get-article-as-string article)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2641 (let* ((arg (if (spam-xor unregister article-is-spam-p)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2642 "-spam"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2643 "-good"))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2644 (status
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2645 (apply 'call-process-region
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2646 (point-min) (point-max)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2647 spam-spamoracle-binary
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2648 nil temp-buffer-name nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2649 (if spam-spamoracle-database
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2650 `("-f" ,spam-spamoracle-database
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2651 "add" ,arg)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2652 `("add" ,arg)))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2653 (unless (eq 0 status)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2654 (error "Error running spamoracle: %s" status)))))))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2655
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2656 (defun spam-spamoracle-learn-ham (articles &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2657 (spam-spamoracle-learn articles nil unregister))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2658
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2659 (defun spam-spamoracle-unlearn-ham (articles &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2660 (spam-spamoracle-learn-ham articles t))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2661
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2662 (defun spam-spamoracle-learn-spam (articles &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2663 (spam-spamoracle-learn articles t unregister))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2664
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2665 (defun spam-spamoracle-unlearn-spam (articles &optional unregister)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2666 (spam-spamoracle-learn-spam articles t))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2667
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2668 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2669
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2670 ;;{{{ SpamAssassin
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2671 ;;; based mostly on the bogofilter code
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2672 (defun spam-check-spamassassin-headers (&optional score)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2673 "Check the SpamAssassin headers for the classification of this message."
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2674 (if score ; scoring mode
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2675 (let ((header (message-fetch-field spam-spamassassin-spam-status-header)))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2676 (when header
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2677 (if (string-match spam-spamassassin-score-regexp header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2678 (match-string 1 header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2679 "0")))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2680 ;; spam detection mode
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2681 (let ((header (message-fetch-field spam-spamassassin-spam-flag-header)))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2682 (when header ; return nil when no header
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2683 (when (string-match spam-spamassassin-positive-spam-flag-header
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2684 header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2685 spam-split-group)))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2686
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2687 (defun spam-check-spamassassin (&optional score)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2688 "Check the SpamAssassin backend for the classification of this message."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2689 (let ((article-buffer-name (buffer-name)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2690 (with-temp-buffer
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2691 (let ((temp-buffer-name (buffer-name)))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2692 (with-current-buffer article-buffer-name
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2693 (apply 'call-process-region
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2694 (point-min) (point-max) spam-assassin-program
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2695 nil temp-buffer-name nil spam-spamassassin-arguments))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2696 ;; check the return now (we're back in the temp buffer)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2697 (goto-char (point-min))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2698 (spam-check-spamassassin-headers score)))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2699
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2700 ;; return something sensible if the score can't be determined
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2701 (defun spam-spamassassin-score (&optional recheck)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2702 "Get the SpamAssassin score"
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2703 (interactive "P")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2704 (save-window-excursion
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2705 (gnus-summary-show-article t)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2706 (set-buffer gnus-article-buffer)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2707 (let ((score (or (unless recheck
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2708 (spam-check-spamassassin-headers t))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2709 (spam-check-spamassassin t))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2710 (gnus-summary-show-article)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2711 (message "SpamAssassin score %s" score)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2712 (or score "0"))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2713
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2714 (defun spam-spamassassin-register-with-sa-learn (articles spam
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2715 &optional unregister)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2716 "Register articles with spamassassin's sa-learn as spam or non-spam."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2717 (if articles
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2718 (let ((action (if unregister spam-sa-learn-unregister-switch
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2719 (if spam spam-sa-learn-spam-switch
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2720 spam-sa-learn-ham-switch)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2721 (summary-buffer-name (buffer-name)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2722 (with-temp-buffer
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2723 ;; group the articles into mbox format
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2724 (dolist (article articles)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2725 (let (article-string)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2726 (with-current-buffer summary-buffer-name
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2727 (setq article-string (spam-get-article-as-string article)))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2728 (when (stringp article-string)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2729 (insert "From \n") ; mbox separator (sa-learn only checks the
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2730 ; first five chars, so we can get away with
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2731 ; a bogus line))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2732 (insert article-string)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2733 (insert "\n"))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2734 ;; call sa-learn on all messages at the same time
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2735 (apply 'call-process-region
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2736 (point-min) (point-max)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2737 spam-sa-learn-program
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2738 nil nil nil "--mbox"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2739 (if spam-sa-learn-rebuild
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2740 (list action)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2741 `("--no-rebuild" ,action)))))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2742
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2743 (defun spam-spamassassin-register-spam-routine (articles &optional unregister)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2744 (spam-spamassassin-register-with-sa-learn articles t unregister))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2745
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2746 (defun spam-spamassassin-register-ham-routine (articles &optional unregister)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2747 (spam-spamassassin-register-with-sa-learn articles nil unregister))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2748
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2749 (defun spam-spamassassin-unregister-spam-routine (articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2750 (spam-spamassassin-register-with-sa-learn articles t t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2751
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2752 (defun spam-spamassassin-unregister-ham-routine (articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2753 (spam-spamassassin-register-with-sa-learn articles nil t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2754
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2755 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2756
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2757 ;;{{{ Bsfilter
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2758 ;;; based mostly on the bogofilter code
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2759 (defun spam-check-bsfilter-headers (&optional score)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2760 (if score
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2761 (or (nnmail-fetch-field spam-bsfilter-probability-header)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2762 "0")
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2763 (let ((header (nnmail-fetch-field spam-bsfilter-header)))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2764 (when header ; return nil when no header
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2765 (when (string-match "YES" header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2766 spam-split-group)))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2767
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2768 ;; return something sensible if the score can't be determined
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2769 (defun spam-bsfilter-score (&optional recheck)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
2770 "Get the Bsfilter spamicity score."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2771 (interactive "P")
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2772 (save-window-excursion
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2773 (gnus-summary-show-article t)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2774 (set-buffer gnus-article-buffer)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2775 (let ((score (or (unless recheck
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2776 (spam-check-bsfilter-headers t))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2777 (spam-check-bsfilter t))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2778 (gnus-summary-show-article)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2779 (message "Spamicity score %s" score)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2780 (or score "0"))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2781
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2782 (defun spam-check-bsfilter (&optional score)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
2783 "Check the Bsfilter backend for the classification of this message."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2784 (let ((article-buffer-name (buffer-name))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2785 (dir spam-bsfilter-database-directory)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2786 return)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2787 (with-temp-buffer
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2788 (let ((temp-buffer-name (buffer-name)))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2789 (with-current-buffer article-buffer-name
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2790 (apply 'call-process-region
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2791 (point-min) (point-max)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2792 spam-bsfilter-program
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2793 nil temp-buffer-name nil
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2794 "--pipe"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2795 "--insert-flag"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2796 "--insert-probability"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2797 (when dir
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2798 (list "--homedir" dir))))
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2799 (setq return (spam-check-bsfilter-headers score))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2800 return))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2801
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2802 (defun spam-bsfilter-register-with-bsfilter (articles
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2803 spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2804 &optional unregister)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2805 "Register an article, given as a string, as spam or non-spam."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2806 (dolist (article articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2807 (let ((article-string (spam-get-article-as-string article))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2808 (switch (if unregister
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2809 (if spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2810 spam-bsfilter-spam-strong-switch
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2811 spam-bsfilter-ham-strong-switch)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2812 (if spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2813 spam-bsfilter-spam-switch
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2814 spam-bsfilter-ham-switch))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2815 (when (stringp article-string)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2816 (with-temp-buffer
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2817 (insert article-string)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2818 (apply 'call-process-region
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2819 (point-min) (point-max)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2820 spam-bsfilter-program
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2821 nil nil nil switch
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2822 "--update"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2823 (when spam-bsfilter-database-directory
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2824 (list "--homedir"
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2825 spam-bsfilter-database-directory))))))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2826
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2827 (defun spam-bsfilter-register-spam-routine (articles &optional unregister)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2828 (spam-bsfilter-register-with-bsfilter articles t unregister))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2829
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2830 (defun spam-bsfilter-unregister-spam-routine (articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2831 (spam-bsfilter-register-spam-routine articles t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2832
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2833 (defun spam-bsfilter-register-ham-routine (articles &optional unregister)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2834 (spam-bsfilter-register-with-bsfilter articles nil unregister))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2835
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2836 (defun spam-bsfilter-unregister-ham-routine (articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2837 (spam-bsfilter-register-ham-routine articles t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2838
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2839 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2840
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2841 ;;{{{ CRM114 Mailfilter
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2842 (defun spam-check-crm114-headers (&optional score)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2843 (let ((header (message-fetch-field spam-crm114-header)))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2844 (when header ; return nil when no header
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2845 (if score ; scoring mode
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2846 (if (string-match "( pR: \\([0-9.-]+\\)" header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2847 (match-string 1 header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2848 "0")
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2849 ;; spam detection mode
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2850 (when (string-match spam-crm114-positive-spam-header
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2851 header)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2852 spam-split-group)))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2853
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2854 ;; return something sensible if the score can't be determined
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2855 (defun spam-crm114-score ()
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
2856 "Get the CRM114 Mailfilter pR."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2857 (interactive)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2858 (save-window-excursion
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2859 (gnus-summary-show-article t)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2860 (set-buffer gnus-article-buffer)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2861 (let ((score (or (spam-check-crm114-headers t)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2862 (spam-check-crm114 t))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2863 (gnus-summary-show-article)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2864 (message "pR: %s" score)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2865 (or score "0"))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2866
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2867 (defun spam-check-crm114 (&optional score)
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
2868 "Check the CRM114 Mailfilter backend for the classification of this message."
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2869 (let ((article-buffer-name (buffer-name))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2870 (db spam-crm114-database-directory)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2871 return)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2872 (with-temp-buffer
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2873 (let ((temp-buffer-name (buffer-name)))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2874 (with-current-buffer article-buffer-name
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2875 (apply 'call-process-region
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2876 (point-min) (point-max)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2877 spam-crm114-program
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2878 nil temp-buffer-name nil
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2879 (when db (list (concat "--fileprefix=" db)))))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2880 (setq return (spam-check-crm114-headers score))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2881 return))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2882
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2883 (defun spam-crm114-register-with-crm114 (articles
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2884 spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2885 &optional unregister)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2886 "Register an article, given as a string, as spam or non-spam."
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2887 (dolist (article articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2888 (let ((article-string (spam-get-article-as-string article))
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2889 (db spam-crm114-database-directory)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2890 (switch (if unregister
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2891 (if spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2892 spam-crm114-spam-strong-switch
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2893 spam-crm114-ham-strong-switch)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2894 (if spam
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2895 spam-crm114-spam-switch
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2896 spam-crm114-ham-switch))))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2897 (when (stringp article-string)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2898 (with-temp-buffer
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2899 (insert article-string)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2900
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2901 (apply 'call-process-region
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2902 (point-min) (point-max)
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2903 spam-crm114-program
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2904 nil nil nil
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2905 (when db (list switch (concat "--fileprefix=" db)))))))))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2906
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2907 (defun spam-crm114-register-spam-routine (articles &optional unregister)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2908 (spam-crm114-register-with-crm114 articles t unregister))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2909
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2910 (defun spam-crm114-unregister-spam-routine (articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2911 (spam-crm114-register-spam-routine articles t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2912
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2913 (defun spam-crm114-register-ham-routine (articles &optional unregister)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2914 (spam-crm114-register-with-crm114 articles nil unregister))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2915
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2916 (defun spam-crm114-unregister-ham-routine (articles)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2917 (spam-crm114-register-ham-routine articles t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2918
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2919 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2920
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2921 ;;}}}
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2922
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2923 ;;{{{ Hooks
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2924
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2925 ;;;###autoload
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2926 (defun spam-initialize (&rest symbols)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2927 "Install the spam.el hooks and do other initialization.
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2928 When SYMBOLS is given, set those variables to t. This is so you
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
2929 can call `spam-initialize' before you set spam-use-* variables on
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2930 explicitly, and matters only if you need the extra headers
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
2931 installed through `spam-necessary-extra-headers'."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2932 (interactive)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2933
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2934 (dolist (var symbols)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2935 (set var t))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2936
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2937 (dolist (header (spam-necessary-extra-headers))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2938 (add-to-list 'nnmail-extra-headers header)
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2939 (add-to-list 'gnus-extra-headers header))
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2940
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2941 (setq spam-install-hooks t)
63480
53e7abe8917f Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-425
Miles Bader <miles@gnu.org>
parents: 62755
diff changeset
2942 ;; TODO: How do we redo this every time the `spam' face is customized?
53e7abe8917f Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-425
Miles Bader <miles@gnu.org>
parents: 62755
diff changeset
2943 (push '((eq mark gnus-spam-mark) . spam)
111968
1156a55fd2a9 spam.el: Reindent and fix long lines.
Katsumi Yamaoka <yamaoka@jpl.org>
parents: 111067
diff changeset
2944 gnus-summary-highlight)
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2945 ;; Add hooks for loading and saving the spam stats
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2946 (add-hook 'gnus-save-newsrc-hook 'spam-maybe-spam-stat-save)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2947 (add-hook 'gnus-get-top-new-news-hook 'spam-maybe-spam-stat-load)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2948 (add-hook 'gnus-startup-hook 'spam-maybe-spam-stat-load)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2949 (add-hook 'gnus-summary-prepare-exit-hook 'spam-summary-prepare-exit)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2950 (add-hook 'gnus-summary-prepare-hook 'spam-summary-prepare)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2951 (add-hook 'gnus-get-new-news-hook 'spam-setup-widening)
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2952 (add-hook 'gnus-summary-prepared-hook 'spam-find-spam))
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2953
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2954 (defun spam-unload-hook ()
86328
6276fcac4dc8 (spam-find-spam, spam-enter-list): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 85712
diff changeset
2955 "Uninstall the spam.el hooks."
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2956 (interactive)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2957 (remove-hook 'gnus-save-newsrc-hook 'spam-maybe-spam-stat-save)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2958 (remove-hook 'gnus-get-top-new-news-hook 'spam-maybe-spam-stat-load)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2959 (remove-hook 'gnus-startup-hook 'spam-maybe-spam-stat-load)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2960 (remove-hook 'gnus-summary-prepare-exit-hook 'spam-summary-prepare-exit)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2961 (remove-hook 'gnus-summary-prepare-hook 'spam-summary-prepare)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2962 (remove-hook 'gnus-get-new-news-hook 'spam-setup-widening)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2963 (remove-hook 'gnus-summary-prepare-hook 'spam-find-spam))
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2964
57549
8479451930d1 Delete duplicate `provide'.
Richard M. Stallman <rms@gnu.org>
parents: 57265
diff changeset
2965 (add-hook 'spam-unload-hook 'spam-unload-hook)
8479451930d1 Delete duplicate `provide'.
Richard M. Stallman <rms@gnu.org>
parents: 57265
diff changeset
2966
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2967 (when spam-install-hooks
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2968 (spam-initialize))
85712
a3c27999decb Update Gnus to No Gnus 0.7 from the Gnus CVS trunk
Miles Bader <miles@gnu.org>
parents: 78224
diff changeset
2969 ;;}}}
56927
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2970
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2971 (provide 'spam)
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2972
55fd4f77387a Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Miles Bader <miles@gnu.org>
parents:
diff changeset
2973 ;;; spam.el ends here