1 ;;; semi-setup.el --- setup file for MIME-View.
3 ;; Copyright (C) 1994,95,96,97,98,99,2000 Free Software Foundation, Inc.
5 ;; Author: MORIOKA Tomohiko <tomo@m17n.org>
6 ;; Keywords: mail, news, MIME, multimedia, multilingual, encoded-word
8 ;; This file is part of SEMI (Setting for Emacs MIME Interfaces).
10 ;; This program is free software; you can redistribute it and/or
11 ;; modify it under the terms of the GNU General Public License as
12 ;; published by the Free Software Foundation; either version 2, or (at
13 ;; your option) any later version.
15 ;; This program is distributed in the hope that it will be useful, but
16 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 ;; General Public License for more details.
20 ;; You should have received a copy of the GNU General Public License
21 ;; along with GNU Emacs; see the file COPYING. If not, write to the
22 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
23 ;; Boston, MA 02110-1301, USA.
30 (defun call-after-loaded (module func &optional hook-name)
31 "If MODULE is provided, then FUNC is called.
32 Otherwise func is set to MODULE-load-hook.
33 If optional argument HOOK-NAME is specified,
34 it is used as hook to set."
38 (setq hook-name (intern (concat (symbol-name module) "-load-hook")))
40 (add-hook hook-name func)
45 (defvar mime-setup-enable-inline-image
47 (or (featurep 'xemacs)(featurep 'mule)))
48 "*If it is non-nil, semi-setup sets up to use mime-image.")
50 (if mime-setup-enable-inline-image
51 (eval-after-load "mime-view"
52 '(require 'mime-image)))
55 (defvar mime-setup-enable-inline-html
56 (module-installed-p 'w3)
57 "*If it is non-nil, semi-setup sets up to use mime-w3.")
59 (if mime-setup-enable-inline-html
60 (eval-after-load "mime-view"
62 (autoload 'mime-preview-text/html "mime-w3")
64 (ctree-set-calist-strictly
65 'mime-preview-condition
66 '((type . text)(subtype . html)
68 (body-presentation-method . mime-preview-text/html)))
70 (set-alist 'mime-view-type-subtype-score-alist
76 (defvar mime-setup-enable-pgp t
77 "*If it is non-nil, semi-setup sets uf to use mime-pgp.")
79 (if mime-setup-enable-pgp
80 (eval-after-load "mime-view"
85 'preview '((type . application)(subtype . pgp)
86 (message-button . visible)))
88 'action '((type . application)(subtype . pgp)
89 (method . mime-view-application/pgp))
92 'action '((type . text)(subtype . x-pgp)
93 (method . mime-view-application/pgp)))
96 'action '((type . multipart)(subtype . signed)
97 (method . mime-verify-multipart/signed))
102 '((type . application)(subtype . pgp-signature)
103 (method . mime-verify-application/pgp-signature))
108 '((type . application)(subtype . pgp-encrypted)
109 (method . mime-decrypt-application/pgp-encrypted))
114 '((type . application)(subtype . pgp-keys)
115 (method . mime-add-application/pgp-keys))
120 '((type . application)(subtype . pkcs7-signature)
121 (method . mime-verify-application/pkcs7-signature))
126 '((type . application)(subtype . x-pkcs7-signature)
127 (method . mime-verify-application/pkcs7-signature))
132 '((type . application)(subtype . pkcs7-mime)
133 (method . mime-view-application/pkcs7-mime))
138 '((type . application)(subtype . x-pkcs7-mime)
139 (method . mime-view-application/pkcs7-mime))
142 (ctree-set-calist-strictly
143 'mime-preview-condition
144 '((type . multipart) (subtype . encrypted) ("protocol" . "application/pgp-encrypted")
146 (body-presentation-method . mime-display-multipart/pgp-encrypted)))
154 ;; (defun mime-setup-decode-message-header ()
157 ;; (goto-char (point-min))
160 ;; (if (re-search-forward
161 ;; (concat "^" (regexp-quote mail-header-separator) "$")
163 ;; (match-beginning 0)
166 ;; (mime-decode-header-in-buffer)
167 ;; (set-buffer-modified-p nil)
170 ;; (add-hook 'mime-edit-mode-hook 'mime-setup-decode-message-header)
176 (defvar mime-setup-use-signature t
177 "If it is not nil, mime-setup sets up to use signature.el.")
179 (defvar mime-setup-default-signature-key "\C-c\C-s"
180 "*Key to insert signature.")
182 (defvar mime-setup-signature-key-alist '((mail-mode . "\C-c\C-w"))
183 "Alist of major-mode vs. key to insert signature.")
189 (defun mime-setup-set-signature-key ()
190 (let ((keymap (current-local-map)))
193 (or (cdr (assq major-mode mime-setup-signature-key-alist))
194 mime-setup-default-signature-key)))
195 (define-key keymap key (function insert-signature))
198 (when mime-setup-use-signature
199 (autoload 'insert-signature "signature" "Insert signature" t)
200 (add-hook 'mime-edit-mode-hook 'mime-setup-set-signature-key)
201 ;; (setq message-signature nil)
208 ;; (add-hook 'mu-cite/pre-cite-hook 'eword-decode-header)
214 (when (eq system-type 'darwin)
215 (eval-after-load "mime-view"
219 '((type . application)
220 (method . mime-mac-save-and-play-with-open))
229 (provide 'semi-setup)
231 ;;; semi-setup.el ends here