tm 5.12
[elisp/tm.git] / tm-gnus.el
1 ;;;
2 ;;;   A MIME extension for GNUS
3 ;;;
4 ;;; by Morioka Tomohiko, 1993/11/20
5 ;;;
6
7 (provide 'tm-gnus)
8
9
10 ;;; @ require modules
11 ;;;
12 (require 'tm-misc)
13 (require 'tl-str)
14 (require 'gnus)
15
16
17 ;;; @ version
18 ;;;
19 (defconst tm-gnus/RCS-ID
20   "$Id: tm-gnus.el,v 5.0 1994/10/17 07:18:44 morioka Exp $")
21
22 (defconst tm-gnus/version (get-version-string tm-gnus/RCS-ID))
23
24
25 ;;; @ variables
26 ;;;
27 (defvar tm-gnus/startup-hook nil)
28
29
30 ;;; @ to decode subject in mode-line
31 ;;;
32 ;; This function imported from gnus.el.
33 ;;
34 ;; New implementation in gnus 3.14.3
35 ;;
36 (defun tm-gnus/article-set-mode-line ()
37   "Set Article mode line string.
38 If you don't like it, define your own gnus-article-set-mode-line."
39   (let ((maxlen 15)                     ;Maximum subject length
40         (subject
41          (if gnus-current-headers
42              (mime/decode-string (nntp-header-subject gnus-current-headers))
43            "")
44          ))
45     ;; The value must be a string to escape %-constructs because of subject.
46     (setq mode-line-buffer-identification
47           (format "GNUS: %s%s %s%s%s"
48                   gnus-newsgroup-name
49                   (if gnus-current-article
50                       (format "/%d" gnus-current-article) "")
51                   (rightful-boundary-short-string subject
52                                                   (min (string-width subject)
53                                                        maxlen))
54                   (if (> (string-width subject) maxlen) "..." "")
55                   (make-string (max 0 (- 17 (string-width subject))) ? )
56                   )))
57   (set-buffer-modified-p t))
58
59
60 ;;; @ change MIME header decoding mode, decoding or non decoding.
61 ;;;
62
63 (defun tm-gnus/set-mime-header-decoding-mode (arg)
64   "Set MIME header processing.
65 With arg, turn MIME processing on iff arg is positive."
66   (setq mime/header-decoding-mode arg)
67   (setq gnus-have-all-headers (not gnus-have-all-headers))
68   (gnus-summary-select-article (not gnus-have-all-headers) t)
69   )
70
71 (defun tm-gnus/toggle-mime-header-decoding-mode ()
72   "Toggle MIME header processing.
73 With arg, turn MIME processing on iff arg is positive."
74   (interactive)
75   (tm-gnus/set-mime-header-decoding-mode (not mime/header-decoding-mode))
76   )
77
78 ;;; @ set up
79 ;;;
80 (if (string-match "^GNUS [0-3]" gnus-version)
81     (require 'tm-gnus3)
82   (require 'tm-gnus4)
83   )
84     
85 (run-hooks 'tm-gnus/startup-hook)