Mercurial > hg > xemacs
annotate my-news.el @ 73:597af5ec2bbb
include cython mail with python
| author | Henry S. Thompson <ht@inf.ed.ac.uk> |
|---|---|
| date | Mon, 09 Jun 2025 13:35:35 +0100 |
| parents | e5b0b98e81a0 |
| children | 0508101db40f |
| 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) |
| 72 | 3 (setq ; see ~/.xemacs/gnus.el for local settings |
|
32
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
4 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
|
5 ) |
| 21 | 6 |
|
32
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
7 (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
|
8 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
|
9 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
|
10 '(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
|
11 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
|
12 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
|
13 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
|
14 gnus-simplify-subject-regexp "^\\(re[:;.]\\| \\|fwd:\\)*") |
| 21 | 15 |
|
32
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
16 (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
|
17 (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
|
18 (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
|
19 text)) |
| 21 | 20 |
|
32
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
21 (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
|
22 "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
|
23 ; (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
|
24 (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
|
25 (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
|
26 (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
|
27 (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
|
28 (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
|
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 h2))))))) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
31 ; (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
|
32 result))) |
| 21 | 33 |
| 34 | |
|
32
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
35 (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
|
36 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
|
37 gnus-secondary-select-methods |
| 21 | 38 '((nnml "ht" |
| 39 (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
|
40 (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
|
41 (gnus-article-sort-by-subject gnus-article-sort-by-date)) |
| 21 | 42 ))) |
| 43 ;;; fixup clarinews | |
| 44 ;(autoload 'gnus-clarinews-fun "clari-clean" "Clean ClariNews articles" t) | |
| 45 ;(add-hook 'gnus-article-prepare-hook 'gnus-clarinews-fun) | |
| 46 | |
| 47 | |
| 48 (defun gnus-Subject-sort-by-subject-and-date (reverse) | |
| 49 "Sort subject display buffer by subject alphabetically. `Re:'s are ignored. | |
| 50 If case-fold-search is non-nil, case of letters is ignored. Date is used | |
| 51 if subjects are equal | |
| 52 Argument REVERSE means reverse order." | |
| 53 (interactive "P") | |
| 54 (gnus-summary-sort-summary | |
| 55 (function | |
| 56 (lambda (a b) | |
| 57 (let ((s-a (gnus-trim-simplify-subject (nntp-header-subject a))) | |
| 58 (s-b (gnus-trim-simplify-subject (nntp-header-subject b))) | |
| 59 ) | |
| 60 (or (gnus-string-lessp s-a s-b) | |
| 61 (and (gnus-string-equal s-a s-b) | |
| 62 (gnus-date-lessp (nntp-header-date a) | |
| 63 (nntp-header-date b))))))) | |
| 64 reverse | |
| 65 )) | |
| 66 | |
| 67 ;(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
|
68 |
| 21 | 69 |
| 70 (defun gnus-string-equal (a b) | |
| 71 "Return T if first arg string is equal than second in lexicographic order. | |
| 72 If case-fold-search is non-nil, case of letters is ignored." | |
| 73 (if case-fold-search | |
| 74 (string-equal (downcase a) (downcase b)) (string-equal a b))) | |
| 75 | |
| 76 (defun gnus-Group-update-and-vanish () | |
| 77 "update newsrc and restore config pre-group selection" | |
| 78 (interactive) | |
| 79 (gnus-group-force-update) | |
| 80 (if gnus-pre-config | |
| 81 (set-window-configuration gnus-pre-config)) | |
| 82 ; (setq gnus-pre-config nil) | |
| 83 ) | |
| 84 | |
| 85 ;; Database stuff | |
| 86 (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
|
87 (setq whitelist-db (open-database (concat my-mail-dir "/white") 'berkeley-db))) |
| 21 | 88 (defun save-white () |
| 89 (close-database whitelist-db) | |
| 90 (open-white)) | |
| 91 | |
| 92 (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
|
93 (setq adlist-db (open-database (concat my-mail-dir "/ad") 'berkeley-db))) |
| 21 | 94 |
| 95 (defun save-ad () | |
| 96 (close-database adlist-db) | |
| 97 (open-ad)) | |
| 98 | |
| 99 (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
|
100 (setq quaker-db (open-database (concat my-mail-dir "/quaker") 'berkeley-db))) |
| 21 | 101 (defun save-quaker () |
| 102 (close-database quaker-db) | |
| 103 (open-quaker)) | |
| 104 | |
|
32
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
105 (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
|
106 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
107 (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
|
108 "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
|
109 (interactive) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
110 (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
|
111 (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
|
112 (progn |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
113 (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
|
114 (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
|
115 res) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
116 (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
|
117 (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
|
118 (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
|
119 (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
|
120 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 (message "%s" res)))) |
| 21 | 122 |
| 63 | 123 (defun add-white (&optional dontAddToBBDB) |
| 124 "While reading an article, add to whitelist" | |
| 21 | 125 (interactive "P") |
| 126 (gnus-summary-goto-article (gnus-summary-article-number)) | |
| 63 | 127 (do-add-white (gnus-fetch-original-field "From") dontAddToBBDB)) |
| 128 | |
| 129 (defun do-add-white (addr &optional dontAddToBBDB) | |
| 130 (let* ((components (gnus-extract-address-components addr)) | |
| 21 | 131 (addr (get-canonical-from-addr components))) |
| 63 | 132 (if (not dontAddToBBDB) |
| 133 (let ((bbdb-no-duplicates-p t)) | |
| 134 (condition-case nil | |
| 135 (bbdb-create-internal (car components) nil | |
| 136 (cadr components) nil nil nil) | |
| 137 (error | |
| 138 ;; OK, just means already present | |
| 139 )))) | |
| 21 | 140 (if (new-white addr) |
| 63 | 141 (save-white)))) |
| 21 | 142 |
| 143 (defun add-ad () | |
| 144 (interactive) | |
| 145 (gnus-summary-goto-article (gnus-summary-article-number)) | |
| 146 (let ((addr (get-current-from-addr))) | |
| 147 (if (or (not (get-database addr whitelist-db)) | |
| 148 (yes-or-no-p "Already white, really convert to ad?")) | |
| 149 (if (new-ad addr) | |
| 150 (save-ad))))) | |
| 151 | |
| 152 (defun add-quaker() | |
| 153 (interactive) | |
| 154 (let ((addr (get-addr-before-point))) | |
| 155 (when (new-quaker addr) | |
| 156 (save-quaker)) | |
| 157 (quaker-sig-maybe))) | |
| 158 | |
| 63 | 159 ; not needed anymore because of gnus-posting-styles (q.v. in mail-from-*) |
| 21 | 160 (defun quaker-sig-if-to-quaker () |
| 161 (let ((message-options)) | |
| 162 (save-excursion (message-options-set-recipient)) | |
| 163 (let* ((recipStr (message-options-get 'message-recipients)) | |
| 164 (recips (split-string (downcase recipStr) | |
| 165 ",[ \f\t\n\r\v]+" t))) | |
| 166 (while (and recips | |
| 167 (not (quaker-sig-if-quaker-1 (car recips)))) | |
| 168 (setq recips (cdr recips)))))) | |
| 169 | |
| 170 (defun to-quaker-p () | |
| 171 (let ((message-options)) | |
| 172 (save-excursion (message-options-set-recipient)) | |
| 173 (let* ((recipStr (message-options-get 'message-recipients)) | |
| 174 (recips (split-string (downcase recipStr) | |
| 175 ",[ \f\t\n\r\v]+" t))) | |
| 176 (while (and recips | |
| 177 (not (get-database (car recips) quaker-db))) | |
| 178 (setq recips (cdr recips))) | |
| 179 (not (null recips))))) | |
| 180 | |
| 181 (defun quaker-sig-if-quaker () | |
| 182 (quaker-sig-if-quaker-1 (get-addr-before-point))) | |
| 183 | |
| 184 (defun quaker-sig-if-quaker-1 (addr) | |
| 185 (if (get-database addr quaker-db) | |
| 186 (progn (quaker-sig-maybe) | |
| 187 t))) | |
| 188 | |
| 189 (defun kill-white () | |
| 190 (interactive) | |
| 191 (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
|
192 (let ((addr (downcase (get-current-from-addr)))) |
| 21 | 193 (rem-white addr))) |
| 194 | |
|
32
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
195 (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
|
196 (interactive) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
197 (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
|
198 (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
|
199 (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
|
200 |
| 21 | 201 (defun get-from-gnus-addr () |
| 202 (get-from-addr (gnus-fetch-field "From"))) | |
| 203 | |
| 204 (defun get-from-addr (addr) | |
| 205 (get-canonical-from-addr (gnus-extract-address-components addr))) | |
| 206 | |
| 207 (defun get-canonical-from-addr (components) | |
| 208 (downcase (cadr components))) | |
| 209 | |
| 210 (defun get-current-from-addr () | |
| 211 (with-current-buffer gnus-article-buffer | |
| 212 (get-from-gnus-addr))) | |
| 213 | |
| 214 (defun get-current-from-components () | |
| 215 (with-current-buffer gnus-article-buffer | |
| 216 (gnus-extract-address-components (gnus-fetch-field "From")))) | |
| 217 | |
| 218 (defun get-addr-before-point () | |
| 219 (let ((cur (point))) | |
| 220 (save-excursion | |
| 221 (get-from-addr (buffer-substring (+ (search-backward " ") 1) cur))) | |
| 222 )) | |
| 223 | |
| 224 (defun blacken-and-delete (group) | |
| 225 ;; mis-named now | |
| 226 ;; this is part of the expiry processing for xxxSPAM groups, and | |
| 227 ;; actually whitens the from addresses of #-marked articles | |
| 228 ;; The return value is crucial (and crucially outside of the scope of the if) | |
| 229 (if (memq number | |
| 230 (with-current-buffer gnus-summary-buffer | |
| 231 gnus-newsgroup-processable)) | |
| 232 (let ((addr (get-from-gnus-addr))) | |
| 233 (new-white addr))) | |
| 234 'delete) | |
| 235 | |
| 236 (defun unwhiten-and-delete (group) | |
| 237 ;; unused except in stale groups -- usable as an expiry | |
| 238 (if (memq number | |
| 239 (with-current-buffer gnus-summary-buffer | |
| 240 gnus-newsgroup-processable)) | |
| 241 (let ((addr (get-from-gnus-addr))) | |
| 242 (remove-database addr whitelist-db))) | |
| 243 'delete) | |
| 244 | |
| 245 (defun known-black (list) | |
| 246 (if (get-database (get-from-gnus-addr) blacklist-db) | |
| 247 list)) | |
| 248 | |
| 249 (defun white-spam (list) | |
| 250 (if (or (equal (get-database (get-from-gnus-addr) whitelist-db) "t") | |
| 251 (let ((case-fold-search t) | |
| 252 (subj (gnus-fetch-field "Subject")) | |
| 253 (from (get-from-gnus-addr))) | |
| 254 (or | |
| 255 (and subj (string-match white-subjects subj)) | |
| 256 (and from | |
| 257 (let ((fromDom (substring from (+ 1 (search "@" from))))) | |
| 258 (and fromDom (member fromDom white-domains))))))) | |
| 259 list)) | |
| 260 | |
| 261 (defun ad-spam (list) | |
| 262 (if (let ((from (get-from-gnus-addr))) | |
| 263 (or | |
| 264 (equal (get-database from adlist-db) "t") | |
| 265 (and from | |
| 266 (let ((fromDom (substring from (+ 1 (search "@" from))))) | |
| 267 (and fromDom (member fromDom ad-domains)))) | |
| 268 )) | |
| 269 list)) | |
| 270 | |
| 271 (defun bogoNote (group) | |
| 272 (if (memq number | |
| 273 (with-current-buffer gnus-summary-buffer | |
| 274 gnus-newsgroup-processable)) | |
| 275 (let ((addr (get-from-gnus-addr))) | |
| 276 (new-white addr))) | |
| 277 (shell-command-on-region (point-min) (point-max) | |
| 278 "/afs/inf.ed.ac.uk/user/h/ht/share/bin/local/makeBogo") | |
| 279 'delete) | |
| 280 | |
| 281 (defun whiten-recip () | |
| 282 ;;; a hook for outgoing mail | |
| 63 | 283 (let* ((to (message-fetch-field "To")) |
| 284 (cc (message-fetch-field "cc")) | |
| 285 (msg-recipients (concat to (and to cc ", ") cc)) | |
| 286 (recips (message-tokenize-header msg-recipients)) | |
| 287 (res (mapcar (function do-add-white) recips))) | |
| 21 | 288 (while (and res (not (car res))) |
| 289 (setq res (cdr res))) | |
| 290 (if res (save-white)))) | |
| 291 | |
| 292 | |
| 293 (defun new-white (addr) | |
| 294 (if (get-database addr whitelist-db) | |
| 295 nil | |
| 296 (put-database addr "t" whitelist-db) | |
| 297 t)) | |
| 298 | |
| 299 (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
|
300 (new-white addr) |
| 21 | 301 (if (get-database addr adlist-db) |
| 302 nil | |
| 303 (put-database addr "t" adlist-db) | |
| 304 t)) | |
| 305 | |
|
32
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
306 (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
|
307 (remove-database addr adlist-db) |
| 21 | 308 (save-ad)) |
| 309 | |
| 310 (defun new-quaker (addr) | |
| 311 (if (get-database addr quaker-db) | |
| 312 nil | |
| 313 (put-database addr "t" quaker-db) | |
| 314 t)) | |
| 315 | |
| 316 (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
|
317 (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
|
318 (save-white)) |
| 21 | 319 |
| 320 (defun bogoOK (group) | |
| 321 (shell-command-on-region (point-min) (point-max) | |
| 322 "/afs/inf.ed.ac.uk/user/h/ht/share/bin/local/makeNonBogo") | |
| 323 'delete) | |
| 324 | |
| 325 (defun del-dups () | |
| 326 (interactive) | |
| 327 (gnus-summary-sort-by-subject) | |
| 328 (gnus-summary-clear-mark-forward 1) | |
| 329 (goto-char (point-min)) | |
| 330 (let ((pos)) | |
| 331 (while (setq pos (search-forward "] " nil t)) | |
| 332 (end-of-line) | |
| 333 (let ((subj (buffer-substring pos (point)))) | |
| 334 (unless (equal subj "") | |
| 335 (let ((target (if (< (length subj) 26) | |
| 336 (concat "] " subj "\n") | |
| 337 (concat "] " (substring subj 0 25)))) | |
| 338 (done 0) | |
| 339 (case-fold-search nil)) | |
| 340 (while (and (= done 0) | |
| 341 (search-forward target nil t)) | |
| 342 (forward-char -3) | |
| 343 (setq done (gnus-summary-mark-as-read-forward 1)))))))) | |
| 344 (gnus-summary-limit-to-unread) | |
| 345 (gnus-summary-sort-by-original)) | |
| 346 | |
|
32
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
347 (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
|
348 (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
|
349 (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
|
350 (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
|
351 (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
|
352 (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
|
353 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
354 (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
|
355 (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
|
356 (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
|
357 rpat) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
358 (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
|
359 (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
|
360 (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
|
361 (concat "^" |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
362 field |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
363 ":\\s-*" |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
364 (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
|
365 pat |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
366 (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
|
367 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
|
368 "$")) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
369 (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
|
370 (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
|
371 list))) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
372 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
373 (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
|
374 "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
|
375 (interactive) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
376 (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
|
377 (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
|
378 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
379 ;; 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
|
380 (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
|
381 "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
|
382 (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
|
383 (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
|
384 (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
|
385 (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
|
386 (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
|
387 (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
|
388 (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
|
389 ;(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
|
390 (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
|
391 (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
|
392 (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
|
393 (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
|
394 (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
|
395 (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
|
396 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
397 (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
|
398 (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
|
399 (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
|
400 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
401 (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
|
402 (interactive) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
403 (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
|
404 (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
|
405 (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
|
406 (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
|
407 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
408 (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
|
409 (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
|
410 (cond |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
411 ((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
|
412 (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
|
413 (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
|
414 (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
|
415 (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
|
416 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
417 (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
|
418 (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
|
419 (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
|
420 (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
|
421 (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
|
422 (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
|
423 (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
|
424 (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
|
425 (cond |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
426 ((> 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
|
427 (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
|
428 ((> 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
|
429 (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
|
430 (lambda () |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
431 (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
|
432 (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
|
433 (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
|
434 (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
|
435 (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
|
436 (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
|
437 )) |
|
32
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
438 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
439 (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
|
440 (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
|
441 (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
|
442 (setq gnus-auto-select-first nil)))) |
| 21 | 443 |
| 444 (defun showMPAhtml () | |
| 445 "Show the text/html parts of an multipart/alternative message using lynx" | |
| 446 (interactive) | |
| 447 (gnus-summary-select-article) | |
| 448 (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
|
449 (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
|
450 ;(expand-file-name |
|
55
95ba4cc6ffe4
better pattern for to-quaker-p
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
45
diff
changeset
|
451 "/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
|
452 ;) |
|
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
|
453 )) |
| 21 | 454 ) |
| 455 | |
|
32
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
456 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
457 ;; 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
|
458 (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
|
459 "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
|
460 (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
|
461 (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
|
462 (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
|
463 (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
|
464 (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
|
465 (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
|
466 (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
|
467 (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
|
468 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
469 (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
|
470 (interactive) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
471 (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
|
472 "] \\(\\(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
|
473 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
|
474 (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
|
475 (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
|
476 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
477 (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
|
478 "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
|
479 (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
|
480 (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
|
481 (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
|
482 (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
|
483 (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
|
484 (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
|
485 (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
|
486 (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
|
487 (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
|
488 (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
|
489 (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
|
490 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
491 (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
|
492 "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
|
493 (interactive) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
494 (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
|
495 (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
|
496 (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
|
497 (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
|
498 ) |
|
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-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
|
500 (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
|
501 (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
|
502 (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
|
503 (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
|
504 (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
|
505 (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
|
506 (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
|
507 (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
|
508 (and |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
509 (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
|
510 (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
|
511 (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
|
512 (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
|
513 (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
|
514 (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
|
515 (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
|
516 )) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
517 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
518 ;;; Why??? |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
519 (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
|
520 (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
|
521 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
522 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
523 (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
|
524 (interactive) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
525 (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
|
526 (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
|
527 (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
|
528 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
529 (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
|
530 (interactive) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
531 (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
|
532 (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
|
533 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
|
534 (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
|
535 (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
|
536 (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
|
537 (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
|
538 (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
|
539 (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
|
540 (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
|
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 (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
|
543 (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
|
544 (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
|
545 (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
|
546 (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
|
547 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
548 ; (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
|
549 ; (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
|
550 ; (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
|
551 ; (cond |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
552 ; ((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
|
553 ; ((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
|
554 ; (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
|
555 ; t)))) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
556 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
557 ;;; 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
|
558 (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
|
559 (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
|
560 (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
|
561 (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
|
562 (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
|
563 (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
|
564 (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
|
565 (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
|
566 (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
|
567 (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
|
568 (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
|
569 (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
|
570 (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
|
571 (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
|
572 (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
|
573 ((= 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
|
574 (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
|
575 (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
|
576 (+ 64 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
577 (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
|
578 (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
|
579 (t |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
580 (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
|
581 (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
|
582 (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
|
583 (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
|
584 str) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
585 str)) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
586 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
587 (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
|
588 ;; 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
|
589 (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
|
590 (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
|
591 (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
|
592 ;; 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
|
593 (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
|
594 (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
|
595 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
|
596 (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
|
597 (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
|
598 (> (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
|
599 (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
|
600 t))))))) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
601 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
602 (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
|
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 ;;; 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
|
605 ;;; 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
|
606 (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
|
607 "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
|
608 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
|
609 `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
|
610 (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
|
611 (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
|
612 (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
|
613 (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
|
614 (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
|
615 (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
|
616 (eolp)) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
617 (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
|
618 (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
|
619 (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
|
620 (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
|
621 (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
|
622 (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
|
623 (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
|
624 (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
|
625 (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
|
626 ;; 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
|
627 ;; 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
|
628 (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
|
629 (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
|
630 (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
|
631 (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
|
632 (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
|
633 (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
|
634 url)))) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
635 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
636 (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
|
637 (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
|
638 (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
|
639 ?*) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
640 ((> (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
|
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 (t ? )))) |
|
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 (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
|
645 (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
|
646 (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
|
647 (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
|
648 (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
|
649 (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
|
650 (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
|
651 (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
|
652 (> (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
|
653 "\\." |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
654 ":\\."))) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
655 (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
|
656 (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
|
657 (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
|
658 (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
|
659 (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
|
660 (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
|
661 (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
|
662 (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
|
663 (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
|
664 (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
|
665 winning))) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
666 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
667 (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
|
668 (interactive) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
669 (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
|
670 (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
|
671 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
672 (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
|
673 (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
|
674 (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
|
675 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
676 (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
|
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 (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
|
679 (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
|
680 (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
|
681 (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
|
682 (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
|
683 (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
|
684 (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
|
685 (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
|
686 (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
|
687 (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
|
688 (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
|
689 (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
|
690 (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
|
691 (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
|
692 (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
|
693 ("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
|
694 (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
|
695 (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
|
696 (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
|
697 (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 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
|
699 (nconc |
|
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 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
701 (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
|
702 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
|
703 (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
|
704 ((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
|
705 (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
|
706 "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
|
707 "calendar")))) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
708 (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
|
709 (t |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
710 (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
|
711 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
712 (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
|
713 (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
|
714 (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
|
715 (concat |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
716 "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
|
717 (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
|
718 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
719 (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
|
720 "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
|
721 (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
|
722 (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
|
723 frame) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
724 (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
|
725 ;; 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
|
726 ;; `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
|
727 (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
|
728 (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
|
729 (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
|
730 (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
|
731 (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
|
732 (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
|
733 (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
|
734 (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
|
735 (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
|
736 (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
|
737 (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
|
738 (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
|
739 ))) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
740 (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
|
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 |
|
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 (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
|
745 (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
|
746 frame) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
747 (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
|
748 ;; 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
|
749 ;; `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
|
750 (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
|
751 (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
|
752 (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
|
753 (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
|
754 (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
|
755 (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
|
756 (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
|
757 (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
|
758 (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
|
759 (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
|
760 (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
|
761 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
762 (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
|
763 (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
|
764 (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
|
765 (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
|
766 (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
|
767 (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
|
768 (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
|
769 (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
|
770 (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
|
771 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
|
772 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
|
773 (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
|
774 (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
|
775 )))) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
776 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
777 (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
|
778 (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
|
779 (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
|
780 (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
|
781 (mapcar |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
782 (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
|
783 (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
|
784 (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
|
785 x)) |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
786 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
|
787 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
|
788 (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
|
789 |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
790 (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
|
791 (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
|
792 (progn |
|
cb9b76219c55
attempt to merge mail read and send from all over
Henry S Thompson <ht@inf.ed.ac.uk>
parents:
24
diff
changeset
|
793 (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
|
794 (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
|
795 |
|
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
|
796 ;; 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
|
797 (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
|
798 (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
|
799 (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
|
800 (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
|
801 (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
|
802 (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
|
803 ((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 (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
|
806 (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
|
807 |
|
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 (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
|
809 (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
|
810 (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
|
811 (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
|
812 ;; 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
|
813 (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
|
814 (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
|
815 (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
|
816 (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
|
817 (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
|
818 (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
|
819 (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
|
820 ) |
|
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 |
|
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 (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
|
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 |
| 61 | 825 (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
|
826 |
|
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
|
827 (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
|
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 (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
|
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 ?# |
|
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 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
|
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 (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
|
836 ;; 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
|
837 ;; /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
|
838 (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
|
839 (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
|
840 (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
|
841 (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
|
842 ;; 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
|
843 (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
|
844 )) |
|
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 )) |
|
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 (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
|
848 |
| 21 | 849 (provide 'my-news) |
