annotate my-news.el @ 67:a9b2a2335782 default tip

make setting advert whiten as well if needed, handle naked div in replying to html
author Henry S Thompson <ht@inf.ed.ac.uk>
date Sat, 21 Dec 2024 20:00:43 +0000
parents e7c2deb7de20
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
1 (message "my-news")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
2 ; (debug-on-entry 'gnus-start-news-server)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
3 (setq
43
eee08de75336 try to do better at where news/mail/init stuff is handled,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 34
diff changeset
4 ;gnus-select-method '(nntp "news.usenet.farm")
eee08de75336 try to do better at where news/mail/init stuff is handled,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 34
diff changeset
5 ;gnus-post-method '(nntp "usenet.inf.ed.ac.uk")
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
6 gnus-nntp-server nil ; override local default
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
7 )
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
8
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
9 (setq gnus-use-scoring nil ; not used yet
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
10 gnus-summary-gather-subject-limit nil
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
11 gnus-thread-sort-functions
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
12 '(gnus-thread-sort-by-number gnus-thread-sort-by-simpl-subject)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
13 gnus-summary-line-format "%U%R%5N%I%(%[%4L: %-12,12A%]%) %s\n"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
14 gnus-summary-make-false-root 'none
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
15 gnus-mime-display-multipart-related-as-mixed t
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
16 gnus-simplify-subject-regexp "^\\(re[:;.]\\| \\|fwd:\\)*")
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
17
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
18 (defsubst gnus-trim-simplify-subject (text)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
19 (if (string-match gnus-simplify-subject-regexp text)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
20 (substring text (match-end 0))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
21 text))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
22
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
23 (defun gnus-thread-sort-by-simpl-subject (h1 h2)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
24 "sort by slightly simplified subject"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
25 ; (message (format "%s:%s %s:%s" (mail-header-number (gnus-thread-header h1))(mail-header-subject (gnus-thread-header h1))(mail-header-number (gnus-thread-header h2))(mail-header-subject (gnus-thread-header h2))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
26 (let ((case-fold-search t))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
27 (let ((result
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
28 (string-lessp
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
29 (downcase (gnus-trim-simplify-subject (mail-header-subject
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
30 (gnus-thread-header h1))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
31 (downcase (gnus-trim-simplify-subject (mail-header-subject
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
32 (gnus-thread-header h2)))))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
33 ; (message (format " %s\n" result))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
34 result)))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
35
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
36
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
37 (setq nnfolder-get-new-mail nil
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
38 nnfolder-inhibit-expiry t
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
39 gnus-secondary-select-methods
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
40 '((nnml "ht"
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
41 (gnus-show-threads nil)
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
42 (gnus-article-sort-functions
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
43 (gnus-article-sort-by-subject gnus-article-sort-by-date))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
44 )))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
45 ;;; fixup clarinews
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
46 ;(autoload 'gnus-clarinews-fun "clari-clean" "Clean ClariNews articles" t)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
47 ;(add-hook 'gnus-article-prepare-hook 'gnus-clarinews-fun)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
48
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
49
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
50 (defun gnus-Subject-sort-by-subject-and-date (reverse)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
51 "Sort subject display buffer by subject alphabetically. `Re:'s are ignored.
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
52 If case-fold-search is non-nil, case of letters is ignored. Date is used
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
53 if subjects are equal
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
54 Argument REVERSE means reverse order."
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
55 (interactive "P")
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
56 (gnus-summary-sort-summary
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
57 (function
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
58 (lambda (a b)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
59 (let ((s-a (gnus-trim-simplify-subject (nntp-header-subject a)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
60 (s-b (gnus-trim-simplify-subject (nntp-header-subject b)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
61 )
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
62 (or (gnus-string-lessp s-a s-b)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
63 (and (gnus-string-equal s-a s-b)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
64 (gnus-date-lessp (nntp-header-date a)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
65 (nntp-header-date b)))))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
66 reverse
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
67 ))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
68
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
69 ;(require 'util-mde) ; for string-replace-regexp-2
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
70
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
71
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
72 (defun gnus-string-equal (a b)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
73 "Return T if first arg string is equal than second in lexicographic order.
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
74 If case-fold-search is non-nil, case of letters is ignored."
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
75 (if case-fold-search
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
76 (string-equal (downcase a) (downcase b)) (string-equal a b)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
77
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
78 (defun gnus-Group-update-and-vanish ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
79 "update newsrc and restore config pre-group selection"
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
80 (interactive)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
81 (gnus-group-force-update)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
82 (if gnus-pre-config
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
83 (set-window-configuration gnus-pre-config))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
84 ; (setq gnus-pre-config nil)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
85 )
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
86
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
87 ;; Database stuff
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
88 (defun open-white ()
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
89 (setq whitelist-db (open-database (concat my-mail-dir "/white") 'berkeley-db)))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
90 (defun save-white ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
91 (close-database whitelist-db)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
92 (open-white))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
93
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
94 (defun open-ad ()
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
95 (setq adlist-db (open-database (concat my-mail-dir "/ad") 'berkeley-db)))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
96
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
97 (defun save-ad ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
98 (close-database adlist-db)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
99 (open-ad))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
100
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
101 (defun open-quaker ()
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
102 (setq quaker-db (open-database (concat my-mail-dir "/quaker") 'berkeley-db)))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
103 (defun save-quaker ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
104 (close-database quaker-db)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
105 (open-quaker))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
106
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
107 (defvar database-names '(whitelist-db adlist-db quaker-db) "sic")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
108
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
109 (defun db-status (&optional name)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
110 "Check on the whereabouts of a name"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
111 (interactive)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
112 (let ((addr
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
113 (or name
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
114 (progn
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
115 (gnus-summary-goto-article (gnus-summary-article-number))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
116 (get-canonical-from-addr (get-current-from-components)))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
117 res)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
118 (dolist (dbn database-names)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
119 (if (get-database addr (eval dbn))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
120 (setq res (cons dbn res))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
121 (if name
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
122 res
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
123 (message "%s" res))))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
124
63
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
125 (defun add-white (&optional dontAddToBBDB)
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
126 "While reading an article, add to whitelist"
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
127 (interactive "P")
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
128 (gnus-summary-goto-article (gnus-summary-article-number))
63
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
129 (do-add-white (gnus-fetch-original-field "From") dontAddToBBDB))
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
130
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
131 (defun do-add-white (addr &optional dontAddToBBDB)
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
132 (let* ((components (gnus-extract-address-components addr))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
133 (addr (get-canonical-from-addr components)))
63
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
134 (if (not dontAddToBBDB)
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
135 (let ((bbdb-no-duplicates-p t))
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
136 (condition-case nil
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
137 (bbdb-create-internal (car components) nil
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
138 (cadr components) nil nil nil)
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
139 (error
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
140 ;; OK, just means already present
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
141 ))))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
142 (if (new-white addr)
63
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
143 (save-white))))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
144
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
145 (defun add-ad ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
146 (interactive)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
147 (gnus-summary-goto-article (gnus-summary-article-number))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
148 (let ((addr (get-current-from-addr)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
149 (if (or (not (get-database addr whitelist-db))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
150 (yes-or-no-p "Already white, really convert to ad?"))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
151 (if (new-ad addr)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
152 (save-ad)))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
153
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
154 (defun add-quaker()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
155 (interactive)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
156 (let ((addr (get-addr-before-point)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
157 (when (new-quaker addr)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
158 (save-quaker))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
159 (quaker-sig-maybe)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
160
63
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
161 ; not needed anymore because of gnus-posting-styles (q.v. in mail-from-*)
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
162 (defun quaker-sig-if-to-quaker ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
163 (let ((message-options))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
164 (save-excursion (message-options-set-recipient))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
165 (let* ((recipStr (message-options-get 'message-recipients))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
166 (recips (split-string (downcase recipStr)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
167 ",[ \f\t\n\r\v]+" t)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
168 (while (and recips
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
169 (not (quaker-sig-if-quaker-1 (car recips))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
170 (setq recips (cdr recips))))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
171
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
172 (defun to-quaker-p ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
173 (let ((message-options))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
174 (save-excursion (message-options-set-recipient))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
175 (let* ((recipStr (message-options-get 'message-recipients))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
176 (recips (split-string (downcase recipStr)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
177 ",[ \f\t\n\r\v]+" t)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
178 (while (and recips
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
179 (not (get-database (car recips) quaker-db)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
180 (setq recips (cdr recips)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
181 (not (null recips)))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
182
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
183 (defun quaker-sig-if-quaker ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
184 (quaker-sig-if-quaker-1 (get-addr-before-point)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
185
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
186 (defun quaker-sig-if-quaker-1 (addr)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
187 (if (get-database addr quaker-db)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
188 (progn (quaker-sig-maybe)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
189 t)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
190
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
191 (defun kill-white ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
192 (interactive)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
193 (gnus-summary-goto-article (gnus-summary-article-number))
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
194 (let ((addr (downcase (get-current-from-addr))))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
195 (rem-white addr)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
196
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
197 (defun kill-ad ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
198 (interactive)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
199 (gnus-summary-goto-article (gnus-summary-article-number))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
200 (let ((addr (downcase (get-current-from-addr))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
201 (rem-ad addr)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
202
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
203 (defun get-from-gnus-addr ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
204 (get-from-addr (gnus-fetch-field "From")))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
205
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
206 (defun get-from-addr (addr)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
207 (get-canonical-from-addr (gnus-extract-address-components addr)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
208
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
209 (defun get-canonical-from-addr (components)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
210 (downcase (cadr components)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
211
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
212 (defun get-current-from-addr ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
213 (with-current-buffer gnus-article-buffer
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
214 (get-from-gnus-addr)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
215
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
216 (defun get-current-from-components ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
217 (with-current-buffer gnus-article-buffer
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
218 (gnus-extract-address-components (gnus-fetch-field "From"))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
219
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
220 (defun get-addr-before-point ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
221 (let ((cur (point)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
222 (save-excursion
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
223 (get-from-addr (buffer-substring (+ (search-backward " ") 1) cur)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
224 ))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
225
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
226 (defun blacken-and-delete (group)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
227 ;; mis-named now
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
228 ;; this is part of the expiry processing for xxxSPAM groups, and
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
229 ;; actually whitens the from addresses of #-marked articles
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
230 ;; The return value is crucial (and crucially outside of the scope of the if)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
231 (if (memq number
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
232 (with-current-buffer gnus-summary-buffer
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
233 gnus-newsgroup-processable))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
234 (let ((addr (get-from-gnus-addr)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
235 (new-white addr)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
236 'delete)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
237
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
238 (defun unwhiten-and-delete (group)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
239 ;; unused except in stale groups -- usable as an expiry
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
240 (if (memq number
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
241 (with-current-buffer gnus-summary-buffer
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
242 gnus-newsgroup-processable))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
243 (let ((addr (get-from-gnus-addr)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
244 (remove-database addr whitelist-db)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
245 'delete)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
246
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
247 (defun known-black (list)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
248 (if (get-database (get-from-gnus-addr) blacklist-db)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
249 list))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
250
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
251 (defun white-spam (list)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
252 (if (or (equal (get-database (get-from-gnus-addr) whitelist-db) "t")
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
253 (let ((case-fold-search t)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
254 (subj (gnus-fetch-field "Subject"))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
255 (from (get-from-gnus-addr)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
256 (or
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
257 (and subj (string-match white-subjects subj))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
258 (and from
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
259 (let ((fromDom (substring from (+ 1 (search "@" from)))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
260 (and fromDom (member fromDom white-domains)))))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
261 list))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
262
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
263 (defun ad-spam (list)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
264 (if (let ((from (get-from-gnus-addr)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
265 (or
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
266 (equal (get-database from adlist-db) "t")
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
267 (and from
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
268 (let ((fromDom (substring from (+ 1 (search "@" from)))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
269 (and fromDom (member fromDom ad-domains))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
270 ))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
271 list))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
272
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
273 (defun bogoNote (group)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
274 (if (memq number
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
275 (with-current-buffer gnus-summary-buffer
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
276 gnus-newsgroup-processable))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
277 (let ((addr (get-from-gnus-addr)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
278 (new-white addr)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
279 (shell-command-on-region (point-min) (point-max)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
280 "/afs/inf.ed.ac.uk/user/h/ht/share/bin/local/makeBogo")
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
281 'delete)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
282
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
283 (defun whiten-recip ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
284 ;;; a hook for outgoing mail
63
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
285 (let* ((to (message-fetch-field "To"))
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
286 (cc (message-fetch-field "cc"))
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
287 (msg-recipients (concat to (and to cc ", ") cc))
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
288 (recips (message-tokenize-header msg-recipients))
e7c2deb7de20 old changes ??,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 61
diff changeset
289 (res (mapcar (function do-add-white) recips)))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
290 (while (and res (not (car res)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
291 (setq res (cdr res)))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
292 (if res (save-white))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
293
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
294
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
295 (defun new-white (addr)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
296 (if (get-database addr whitelist-db)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
297 nil
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
298 (put-database addr "t" whitelist-db)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
299 t))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
300
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
301 (defun new-ad (addr)
67
a9b2a2335782 make setting advert whiten as well if needed,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 63
diff changeset
302 (new-white addr)
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
303 (if (get-database addr adlist-db)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
304 nil
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
305 (put-database addr "t" adlist-db)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
306 t))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
307
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
308 (defun rem-ad (addr)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
309 (remove-database addr adlist-db)
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
310 (save-ad))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
311
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
312 (defun new-quaker (addr)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
313 (if (get-database addr quaker-db)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
314 nil
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
315 (put-database addr "t" quaker-db)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
316 t))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
317
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
318 (defun rem-white (addr)
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
319 (remove-database (downcase addr) whitelist-db)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
320 (save-white))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
321
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
322 (defun bogoOK (group)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
323 (shell-command-on-region (point-min) (point-max)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
324 "/afs/inf.ed.ac.uk/user/h/ht/share/bin/local/makeNonBogo")
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
325 'delete)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
326
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
327 (defun del-dups ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
328 (interactive)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
329 (gnus-summary-sort-by-subject)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
330 (gnus-summary-clear-mark-forward 1)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
331 (goto-char (point-min))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
332 (let ((pos))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
333 (while (setq pos (search-forward "] " nil t))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
334 (end-of-line)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
335 (let ((subj (buffer-substring pos (point))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
336 (unless (equal subj "")
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
337 (let ((target (if (< (length subj) 26)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
338 (concat "] " subj "\n")
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
339 (concat "] " (substring subj 0 25))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
340 (done 0)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
341 (case-fold-search nil))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
342 (while (and (= done 0)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
343 (search-forward target nil t))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
344 (forward-char -3)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
345 (setq done (gnus-summary-mark-as-read-forward 1))))))))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
346 (gnus-summary-limit-to-unread)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
347 (gnus-summary-sort-by-original))
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
348
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
349 (defun mark-and-mark (n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
350 (interactive "p")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
351 (while (>= n 1)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
352 (gnus-summary-mark-as-read)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
353 (gnus-summary-mark-as-processable 1)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
354 (setq n (- n 1))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
355
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
356 (defun split-on-whole-field (field pat list)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
357 (goto-char (point-max))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
358 (let ((hit (assq pat wsp-cache))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
359 rpat)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
360 (if hit
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
361 (setq rpat (cdr hit))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
362 (setq rpat
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
363 (concat "^"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
364 field
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
365 ":\\s-*"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
366 (if (stringp pat)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
367 pat
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
368 (cdr (assq pat
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
369 nnmail-split-abbrev-alist)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
370 "$"))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
371 (setq wsp-cache (cons (cons pat rpat) wsp-cache)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
372 (if (re-search-backward rpat nil t)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
373 list)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
374
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
375 (defun ht-gnus-summary-delete-forward ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
376 "REAL delete for nnmail gnus"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
377 (interactive)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
378 (gnus-summary-delete-article)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
379 (gnus-summary-next-unread-article))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
380
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
381 ;; run the first time we make a summary window
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
382 (defun gnus-summary-mode-fun1 ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
383 "install ht's mods"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
384 (define-key gnus-summary-mode-map "D" 'ht-gnus-summary-delete-forward)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
385 (define-key gnus-summary-mode-map "~" 'mark-and-mark)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
386 (define-key gnus-summary-mode-map "\M-d" 'gnus-edit-and-move-to-diary)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
387 (define-key gnus-summary-mode-map "\M-e" 'gnus-extract-attachment)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
388 (define-key gnus-summary-mode-map "\M-w" 'add-white)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
389 (define-key gnus-summary-mode-map [(control meta w)] 'copy-region-to-kill)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
390 (define-key gnus-summary-mode-map "\M-h" 'showMPAhtml)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
391 ;(define-key gnus-summary-mode-map [(control meta w)] 'kill-white)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
392 (define-key gnus-summary-mode-map "\M-a" 'add-ad)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
393 (define-key gnus-summary-mode-map "\M-n" 'ht-next-unseen-maybe)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
394 (define-key gnus-summary-mode-map "\M-c" 'ht-catchup-and-next-unseen)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
395 (define-key gnus-summary-mime-map "O" 'ht-article-save-parts)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
396 (define-key gnus-summary-backend-map "M" 'ht-move-to-pers)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
397 (remove-hook 'gnus-summary-mode-hook 'gnus-summary-mode-fun1))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
398
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
399 (defun message-mode-fun1 ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
400 (define-key message-mode-map [(control meta q)] 'add-quaker)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
401 (remove-hook 'message-mode-hook 'message-mode-fun1))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
402
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
403 (defun ht-catchup-and-next-unseen ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
404 (interactive)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
405 (when (gnus-summary-catchup nil t nil 'fast)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
406 (gnus-summary-exit)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
407 (previous-line 1)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
408 (ht-next-with-unseen 1)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
409
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
410 (defun ht-next-unseen-maybe (n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
411 (interactive "p")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
412 (cond
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
413 ((eq (gnus-summary-next-unread-subject n) n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
414 (gnus-summary-exit)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
415 (previous-line 1)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
416 (if (ht-next-with-unseen n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
417 (ht-read-group-unseen-only)))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
418
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
419 (defun ht-gnus-pers-refresh (n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
420 (interactive "p")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
421 (let ((gn (concat "nnml+ht:pers-"
45
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
422 (format-time-string "%Y-%m" (current-time))))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
423 (jr ht-gnus-just-read))
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
424 (gnus-group-get-new-news)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
425 (let ((nn (gnus-number-of-unseen-articles-in-group gn)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
426 (gnus-group-goto-group gn)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
427 (cond
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
428 ((> nn 0)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
429 (gnus-group-read-group nn))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
430 ((> n 1)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
431 (let ((gnus-auto-select-subject
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
432 (lambda ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
433 (goto-char (point-max))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
434 (previous-line 1))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
435 (gnus-group-read-group nil t)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
436 (t (goto-char (point-min))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
437 (ht-next-with-unseen 1))))
45
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
438 (message "read: %s" ht-gnus-just-read)
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
439 ))
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
440
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
441 (defun no-select ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
442 (if (member gnus-newsgroup-name no-select-groups)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
443 (progn (make-variable-buffer-local 'gnus-auto-select-first)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
444 (setq gnus-auto-select-first nil))))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
445
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
446 (defun showMPAhtml ()
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
447 "Show the text/html parts of an multipart/alternative message using lynx"
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
448 (interactive)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
449 (gnus-summary-select-article)
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
450 (with-current-buffer gnus-original-article-buffer
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
451 (shell-command-on-region (point-min) (point-max)
43
eee08de75336 try to do better at where news/mail/init stuff is handled,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 34
diff changeset
452 ;(expand-file-name
55
95ba4cc6ffe4 better pattern for to-quaker-p
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 45
diff changeset
453 "/home/ht/bin/showMPA.sh"
43
eee08de75336 try to do better at where news/mail/init stuff is handled,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 34
diff changeset
454 ;)
eee08de75336 try to do better at where news/mail/init stuff is handled,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 34
diff changeset
455 ))
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
456 )
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
457
32
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
458
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
459 ;; run the first time we make a group window
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
460 (defun gnus-group-mode-fun1 ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
461 "install ht's mods"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
462 (require 'gnus-msg)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
463 (define-key gnus-group-mode-map "\M-\C-g" 'ht-gnus-pers-refresh)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
464 (define-key gnus-group-mode-map "\M-n" 'ht-next-with-unseen)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
465 (define-key gnus-group-mode-map "\M-p" 'ht-previous-with-unseen)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
466 (define-key gnus-group-mode-map "\M- " 'ht-read-group-unseen-only)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
467 (define-key gnus-send-bounce-map "R" 'resend-to-schemadev)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
468 (define-key gnus-send-bounce-map "x" 'flush-all-nogoods)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
469 (remove-hook 'gnus-group-mode-hook 'gnus-group-mode-fun1))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
470
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
471 (defun flush-all-nogoods ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
472 (interactive)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
473 (while (re-search-forward
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
474 "] \\(\\(Returned\\|\\([Uu]n\\|[Nn]on-?\\)deliver\\(able\\|ed\\)\\)\\( [Mm]ail\\|:?\\)\\|DELIVERY FAILURE\\|Delivery \\(Notification: Delivery has failed\\|Status Notification .\\(Failure\\|Delay\\).\\)\\|failure \\(notice\\|delivery\\)\\)"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
475 nil t)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
476 (gnus-summary-mark-as-read)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
477 (end-of-line)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
478
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
479 (defun gnus-user-format-function-t (header)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
480 "display the to field (for archive messages)"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
481 (let ((n (mail-header-number header)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
482 (with-current-buffer nntp-server-buffer
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
483 (save-excursion
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
484 (save-restriction
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
485 (let ((inhibit-point-motion-hooks t))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
486 (goto-char (point-min))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
487 (let ((beg (search-forward (format " %d Article retrieved." n)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
488 (end (search-forward "\n.\n")))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
489 (narrow-to-region beg end)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
490 (goto-char beg)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
491 (message-fetch-field "To"))))))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
492
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
493 (defun gnus-extract-attachment ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
494 "extract attachments from a multi-part mime message"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
495 (interactive)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
496 (let ((sm gnus-show-mime))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
497 (if sm
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
498 (progn (setq gnus-show-mime nil)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
499 (gnus-summary-select-article t 'force))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
500 )
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
501 (gnus-summary-show-all-headers)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
502 (with-current-buffer gnus-article-buffer
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
503 (save-excursion
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
504 (save-restriction
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
505 (mime/viewer-mode)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
506 (delete-other-windows)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
507 (let ((pt 0))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
508 (while (progn
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
509 (mime-viewer/next-content)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
510 (and
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
511 (equal "*Preview-*Article**" (buffer-name (current-buffer)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
512 (not (= pt (point)))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
513 (setq pt (point))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
514 (if (looking-at "^\\[[0-9]* \\([^ ]+ \\)+<")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
515 (mime-viewer/extract-content)))))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
516 (kill-buffer "*Preview-*Article**")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
517 (setq gnus-show-mime sm)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
518 ))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
519
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
520 ;;; Why???
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
521 (make-variable-buffer-local 'gnus-extra-headers)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
522 (make-variable-buffer-local 'nnmail-extra-headers)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
523
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
524
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
525 (defun resend-to-schemadev ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
526 (interactive)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
527 (message "forwarding to xmlschema-dev")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
528 (gnus-summary-resend-message "xmlschema-dev@w3.org" 1)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
529 (gnus-summary-next-unread-article))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
530
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
531 (defun brutal-resend ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
532 (interactive)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
533 (message "editing for resend. . .")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
534 (unless (eq (gnus-summary-article-number)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
535 gnus-current-article)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
536 (gnus-summary-select-article t))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
537 (gnus-summary-toggle-header 1)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
538 (with-current-buffer gnus-article-buffer
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
539 (toggle-read-only)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
540 (gnus-article-date-original)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
541 (goto-char (point-min))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
542 (replace-regexp "^\\(X-Diagnostic\\|X-Envelope-To\\|X-Original-To\\|Delivered-To\\):.*\n" "")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
543 (goto-char (point-min))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
544 (gnus-summary-edit-article-done
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
545 (or (mail-header-references gnus-current-headers) "")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
546 (gnus-group-read-only-p) gnus-summary-buffer nil))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
547 (call-interactively (function gnus-summary-resend-message))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
548 (gnus-summary-next-unread-article))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
549
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
550 ; (unless (fboundp 'builtin-coding-system-p)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
551 ; (fset 'builtin-coding-system-p (symbol-function 'coding-system-p))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
552 ; (defun coding-system-p (obj)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
553 ; (cond
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
554 ; ((builtin-coding-system-p obj) t)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
555 ; ((memq obj '(utf-8 gb2312 koi8-r iso-8859-1))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
556 ; (message (format "Coding system: %s" obj))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
557 ; t))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
558
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
559 ;;; dangerous hack to improve display of names and subjects in mail/news
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
560 (if nil (progn
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
561 (require 'mm-util)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
562 (defun mm-decode-coding-string (str cs)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
563 (if (and str (eq cs 'utf-8))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
564 (if (or (string-match "Â" str)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
565 (string-match "Ã" str))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
566 (let* ((r 0) ; read pointer
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
567 (w 0) ; write pointer
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
568 (l (length str)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
569 (while (< r l)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
570 (let* ((c (aref str r))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
571 (i (char-int c)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
572 (cond ((= i 194)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
573 (aset str w (aref str (+ r 1)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
574 (setq r (+ r 2)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
575 ((= i 195)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
576 (aset str w
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
577 (int-char
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
578 (+ 64
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
579 (char-int (aref str (+ r 1))))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
580 (setq r (+ r 2)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
581 (t
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
582 (aset str w c)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
583 (setq r (+ r 1)))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
584 (setq w (+ w 1)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
585 (substring str 0 w))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
586 str)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
587 str))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
588
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
589 (defun mm-sort-coding-systems-predicate (a b)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
590 ;; from mm-util, abort if no priorities
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
591 (or (not mm-coding-system-priorities)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
592 (let ((priorities
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
593 (mapcar (lambda (cs)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
594 ;; Note: invalid entries are dropped silently
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
595 (and (setq cs (mm-coding-system-p cs))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
596 (coding-system-base cs)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
597 mm-coding-system-priorities)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
598 (and (setq a (mm-coding-system-p a))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
599 (if (setq b (mm-coding-system-p b))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
600 (> (length (memq (coding-system-base a) priorities))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
601 (length (memq (coding-system-base b) priorities)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
602 t)))))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
603
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
604 (require 'browse-url)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
605
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
606 ;;; This version collects extra lines if you use right-button
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
607 ;;; to click on a URL
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
608 (defun browse-url (url &rest args)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
609 "Ask a WWW browser to load URL.
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
610 Prompts for a URL, defaulting to the URL at or before point. Variable
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
611 `browse-url-browser-function' says which browser to use."
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
612 (interactive (browse-url-interactive-arg "URL: "))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
613 (unless (interactive-p)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
614 (setq args (or args (list browse-url-new-window-flag))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
615 (if (and (boundp 'event)(= 3 (event-button event)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
616 (let ((thisLine url))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
617 (while (and (progn (forward-char (length thisLine))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
618 (eolp))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
619 (progn (forward-line 1)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
620 (beginning-of-line)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
621 (not (looking-at "\\s-"))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
622 (looking-at "\\S-*")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
623 (setq thisLine (buffer-substring (match-beginning 0)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
624 (match-end 0)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
625 (setq url (concat url thisLine)))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
626 (if (functionp browse-url-browser-function)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
627 (apply browse-url-browser-function url args)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
628 ;; The `function' can be an alist; look down it for first match
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
629 ;; and apply the function (which might be a lambda).
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
630 (catch 'done
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
631 (dolist (bf browse-url-browser-function)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
632 (when (string-match (car bf) url)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
633 (apply (cdr bf) url args)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
634 (throw 'done t)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
635 (error "No browse-url-browser-function matching URL %s"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
636 url))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
637
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
638 (defun gnus-user-format-function-H (dummy)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
639 (format "%c"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
640 (cond ((eq gnus-tmp-summary-live ?*)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
641 ?*)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
642 ((> (gnus-number-of-unseen-articles-in-group gnus-tmp-group) 0)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
643 ?.)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
644 (t ? ))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
645
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
646 (defun ht-next-with-unseen (n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
647 (interactive "p")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
648 (let* ((gvl (mapcar (function string-to-number)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
649 (split-string gnus-version-number "\\.")))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
650 (pattern (if (or (> (car gvl) 5)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
651 (and (eq (car gvl) 5)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
652 (or (> (cadr gvl) 10)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
653 (and (eq (cadr gvl) 10)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
654 (> (caddr gvl) 7)))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
655 "\\."
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
656 ":\\.")))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
657 (if (looking-at pattern)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
658 (if (< n 0)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
659 (backward-char 1)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
660 (forward-char 1)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
661 (let ((missing 0)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
662 (winning (looking-at pattern)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
663 (while (and (zerop missing)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
664 (not winning))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
665 (setq missing (gnus-group-next-unread-group n))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
666 (setq winning (looking-at pattern)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
667 winning)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
668
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
669 (defun ht-read-group-unseen-only ()
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
670 (interactive)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
671 (gnus-group-read-group
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
672 (gnus-number-of-unseen-articles-in-group (gnus-group-group-name))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
673
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
674 (defun ht-previous-with-unseen (n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
675 (interactive "p")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
676 (ht-next-with-unseen (- n)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
677
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
678 (defvar ht-stash-directory (concat my-mail-dir "/stash/"))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
679
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
680 (defun ht-save-part (handle n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
681 (let ((sup-type (mm-handle-media-supertype handle))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
682 (sub-type (mm-handle-media-subtype handle)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
683 (message (format "%s %s/%s" n sup-type sub-type))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
684 (cond ((and (equal sup-type "multipart")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
685 (or (equal sub-type "alternative")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
686 (equal sub-type "related")))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
687 (let ((alts (cddr handle))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
688 (j 0))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
689 (while alts
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
690 (let* ((alt (pop alts))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
691 (handle-type (mm-handle-type alt)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
692 (let* ((sub (mm-handle-media-subtype alt))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
693 (ext (cdr
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
694 (assoc sub '(("calendar" . "vcs")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
695 ("v-calendar" . "vcs"))))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
696 (setq j (+ j 1))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
697 (if (not (or (mail-content-type-get
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
698 (mm-handle-disposition alt) 'filename)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
699 (mail-content-type-get
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
700 handle-type 'name)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
701 (nconc
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
702 handle-type
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
703 (list (cons 'name (format "%s.%s.%s"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
704 n j (or ext sub))))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
705 (ht-save-part alt (format "%s.%s" n j)))))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
706 ((and (equal sup-type "text")(not
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
707 (member sub-type '("html"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
708 "v-calendar"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
709 "calendar"))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
710 (message "Skipping text part: %s" (mm-handle-disposition handle)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
711 (t
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
712 (mm-save-part handle)))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
713
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
714 (defun ht-move-to-pers (n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
715 (interactive "p")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
716 (gnus-summary-move-article n
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
717 (concat
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
718 "nnml+ht:pers-"
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
719 (format-time-string "%Y-%m" (current-time)))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
720
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
721 (defun ht-article-save-parts (n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
722 "Save non t/p MIME parts starting at N, which is the numerical prefix."
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
723 (interactive "p2")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
724 (let ((window (get-buffer-window gnus-article-buffer 'visible))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
725 frame)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
726 (when window
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
727 ;; It is necessary to select the article window so that
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
728 ;; `gnus-article-goto-part' may really move the point.
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
729 (setq frame (selected-frame))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
730 (gnus-select-frame-set-input-focus (window-frame window))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
731 (unwind-protect
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
732 (save-window-excursion
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
733 (select-window window)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
734 (let ((len (length gnus-article-mime-handle-alist)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
735 (setq mm-default-directory ht-stash-directory)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
736 (while (<= n len)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
737 (gnus-article-goto-part n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
738 (let ((handle (cdr (assq n gnus-article-mime-handle-alist))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
739 (ht-save-part handle n))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
740 (setq n (+ n 1))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
741 )))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
742 (gnus-select-frame-set-input-focus frame))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
743 )
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
744
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
745
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
746 (defun gnus-article-part-wrapper (n function)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
747 (let ((window (get-buffer-window gnus-article-buffer 'visible))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
748 frame)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
749 (when window
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
750 ;; It is necessary to select the article window so that
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
751 ;; `gnus-article-goto-part' may really move the point.
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
752 (setq frame (selected-frame))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
753 (gnus-select-frame-set-input-focus (window-frame window))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
754 (unwind-protect
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
755 (save-window-excursion
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
756 (select-window window)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
757 (when (> n (length gnus-article-mime-handle-alist))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
758 (error "No such part"))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
759 (gnus-article-goto-part n)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
760 (let ((handle (cdr (assq n gnus-article-mime-handle-alist))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
761 (funcall function handle)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
762 (gnus-select-frame-set-input-focus frame)))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
763
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
764 (defun mhstore-me (dir)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
765 (interactive (list (read-directory-name "Save parts to " "/tmp" "/tmp" t)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
766 (let ((art (gnus-summary-article-number)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
767 (let* ((grp-parts (split-string gnus-newsgroup-name ":"))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
768 (meth (car grp-parts))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
769 (grp (cadr grp-parts)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
770 (if (string= meth "nnml+ht")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
771 (let ((doit
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
772 (format (concat "cd %s && mhstore -f "
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
773 my-mail-dir "/Mail/%s/%s) -auto")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
774 dir grp art)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
775 (message doit)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
776 (shell-command doit))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
777 ))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
778
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
779 (defun my-message-send-and-exit (&optional arg)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
780 (interactive "P")
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
781 (let ((message-required-mail-headers
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
782 (if arg
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
783 (mapcar
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
784 (lambda(x)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
785 (if(and(consp x)(eq(cdr x)'In-Reply-To))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
786 (cons 'optional 'xyzzy)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
787 x))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
788 message-required-mail-headers)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
789 message-required-mail-headers)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
790 (orig-message-send-and-exit)))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
791
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
792 (require 'message)
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
793 (if (not (fboundp 'orig-message-send-and-exit))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
794 (progn
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
795 (fset 'orig-message-send-and-exit (symbol-function 'message-send-and-exit))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
796 (fset 'message-send-and-exit (symbol-function 'my-message-send-and-exit))))
cb9b76219c55 attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 24
diff changeset
797
45
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
798 ;; see message-citation-line-function in message.el
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
799 (defun safe-citation ()
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
800 (use-text-not-html)
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
801 (when message-reply-headers
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
802 (let ((from (mail-header-from message-reply-headers)))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
803 (cond ((string-match "^\"?\\([^\"]*\\)\"? <.*>$" from)
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
804 (insert (match-string 1 from) " writes:\n\n"))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
805 ((string-match "^\\([^<@]*\\)@" from)
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
806 (insert (match-string 1 from) " writes:\n\n"))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
807 (t
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
808 (insert "[anon] writes:\n\n"))))))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
809
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
810 (defun use-text-not-html (&optional clear)
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
811 (when (and (if clear (looking-at "<html")
67
a9b2a2335782 make setting advert whiten as well if needed,
Henry S Thompson <ht@inf.ed.ac.uk>
parents: 63
diff changeset
812 (looking-at "> <\\(html\\|div\\)"))
45
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
813 (bufferp (get-buffer "*Shell Command Output*")))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
814 ;; replace HTML only with result of my HTML filter
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
815 (delete-region (point)(mark t))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
816 (insert-buffer "*Shell Command Output*")
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
817 (when (looking-at "piping")
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
818 (kill-entire-line)
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
819 (indent-rigidly (point) (mark t) -3)
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
820 (if (not clear)
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
821 (submerge-region (point) (mark t)))))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
822 )
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
823
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
824 (setq message-citation-line-function (function safe-citation))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
825
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
826
61
963ac2f8e386 old local
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 55
diff changeset
827 (defvar safelink_pat "https://[a-z0-9.]*safelinks.protection.outlook.com/\\?url=\\(\\(ftp\\|https?\\)%3A%2F%2F[^&<>\"]*\\)[^\"<> \n]*")
45
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
828
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
829 (require 'url)
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
830
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
831 (defvar url-ok-chars (nconc
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
832 '(?/ ?& ?% ?+ ?? ?= ?: ?;
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
833 ?#
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
834 )
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
835 url-unreserved-chars))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
836
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
837 (defun unsafelink ()
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
838 ;; Thanks to Iain Murray for
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
839 ;; /public/homepages/imurray2/web/code/hacks/unsafelink
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
840 (let ((url-unreserved-chars url-ok-chars))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
841 (while (re-search-forward safelink_pat nil t)
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
842 (let ((res (match-string 1)))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
843 (replace-match "")
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
844 ;; unhexify uses regex, so trashes match-string :-(
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
845 (insert (url-hexify-string (url-unhex-string res)))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
846 ))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
847 ))
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
848
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
849 (add-hook 'gnus-article-prepare-hook 'unsafelink)
65ea96008fe0 hacked up some stuff to get rid of useless safelinks.outlook... link wrappers,
Henry S. Thompson <ht@inf.ed.ac.uk>
parents: 43
diff changeset
850
21
7b2c4ed36302 for new maritain
ht
parents: 7
diff changeset
851 (provide 'my-news)