X-Git-Url: http://git.chise.org/gitweb/?a=blobdiff_plain;f=semi-setup.el;h=620b8fe9842e1489bd61610883cc464763072d8f;hb=b98bb33cbde02a8db223077a99b522476fc5a42a;hp=48d0df6443fb63fc81597734ff527a803a944316;hpb=e30fde45e61499d5c2dbbe86576d4cd6e8b8b6a3;p=elisp%2Fsemi.git diff --git a/semi-setup.el b/semi-setup.el index 48d0df6..620b8fe 100644 --- a/semi-setup.el +++ b/semi-setup.el @@ -1,12 +1,11 @@ ;;; semi-setup.el --- setup file for MIME-View. -;; Copyright (C) 1994,1995,1996,1997 Free Software Foundation, Inc. +;; Copyright (C) 1994,95,96,97,98,99,2000 Free Software Foundation, Inc. -;; Author: MORIOKA Tomohiko -;; Version: $Id: semi-setup.el,v 0.11 1997-03-10 13:42:02 morioka Exp $ +;; Author: MORIOKA Tomohiko ;; Keywords: mail, news, MIME, multimedia, multilingual, encoded-word -;; This file is part of SEMI (SEMI is Emacs MIME Interfaces). +;; This file is part of SEMI (Setting for Emacs MIME Interfaces). ;; This program is free software; you can redistribute it and/or ;; modify it under the terms of the GNU General Public License as @@ -25,76 +24,177 @@ ;;; Code: -(require 'mime-def) +(require 'semi-def) +;; for image/* +(defvar mime-setup-enable-inline-image + (if (featurep 'xemacs) + (console-on-window-system-p) + window-system) + "*If it is non-nil, semi-setup sets up to use mime-image.") -;;; @ for mime-view -;;; - -(call-after-loaded - 'mime-view - (function - (lambda () - ;; for message/partial - (require 'mime-partial) - ))) - +(eval-after-load "mime-view" + '(if mime-setup-enable-inline-image + (require 'mime-image))) + +;; for text/html +(defvar mime-setup-enable-inline-html + (locate-library "w3") + "*If it is non-nil, semi-setup sets up to use mime-w3.") + +(eval-after-load "mime-view" + '(when mime-setup-enable-inline-html + (autoload 'mime-preview-text/html "mime-w3") + (ctree-set-calist-strictly + 'mime-preview-condition + '((type . text)(subtype . html) + (body . visible) + (body-presentation-method . mime-preview-text/html))) + + (set-alist 'mime-view-type-subtype-score-alist + '(text . html) 3))) + +;; for text/x-vcard +(defvar mime-setup-enable-vcard + (locate-library "vcard") + "*If it is non-nil, semi-setup sets uf to use mime-vcard.") + +(eval-after-load "mime-view" + '(when mime-setup-enable-vcard + (autoload 'mime-display-text/x-vcard "mime-vcard") + + (mime-add-condition + 'preview + '((type . text)(subtype . x-vcard) + (body . visible) + (body-presentation-method . mime-display-text/x-vcard)) + 'strict) + + (set-alist 'mime-view-type-subtype-score-alist + '(text . x-vcard) 3))) -(defvar running-xemacs (string-match "XEmacs" emacs-version)) +;; for PGP +(defvar mime-setup-enable-pgp t + "*If it is non-nil, semi-setup sets uf to use mime-pgp.") -;; for image/* and X-Face -(defvar mime-setup-enable-inline-image - (and window-system - (or running-xemacs - (and (featurep 'mule)(module-installed-p 'bitmap)) - )) - "*If it is non-nil, semi-setup sets up to use mime-image.") +(eval-after-load "mime-view" + '(when mime-setup-enable-pgp + (mime-add-condition + 'preview '((type . application)(subtype . pgp) + (message-button . visible))) + (mime-add-condition + 'action '((type . application)(subtype . pgp) + (method . mime-view-application/pgp)) + 'strict "mime-pgp") + (mime-add-condition + 'action '((type . text)(subtype . x-pgp) + (method . mime-view-application/pgp))) + + (mime-add-condition + 'action '((type . multipart)(subtype . signed) + (method . mime-verify-multipart/signed)) + 'strict "mime-pgp") + + (mime-add-condition + 'action + '((type . application)(subtype . pgp-signature) + (method . mime-verify-application/pgp-signature)) + 'strict "mime-pgp") + + (mime-add-condition + 'action + '((type . application)(subtype . pgp-encrypted) + (method . mime-decrypt-application/pgp-encrypted)) + 'strict "mime-pgp") + + (mime-add-condition + 'action + '((type . application)(subtype . pgp-keys) + (method . mime-add-application/pgp-keys)) + 'strict "mime-pgp") + + (mime-add-condition + 'action + '((type . application)(subtype . pkcs7-signature) + (method . mime-verify-application/pkcs7-signature)) + 'strict "mime-pgp") + + (mime-add-condition + 'action + '((type . application)(subtype . x-pkcs7-signature) + (method . mime-verify-application/pkcs7-signature)) + 'strict "mime-pgp") + + (mime-add-condition + 'action + '((type . application)(subtype . pkcs7-mime) + (method . mime-view-application/pkcs7-mime)) + 'strict "mime-pgp") + + (mime-add-condition + 'action + '((type . application)(subtype . x-pkcs7-mime) + (method . mime-view-application/pkcs7-mime)) + 'strict "mime-pgp"))) + + +;;; @ for mime-edit +;;; -(if mime-setup-enable-inline-image - (call-after-loaded 'mime-view - (function - (lambda () - (require 'mime-image) - ))) - ) +;; (defun mime-setup-decode-message-header () +;; (save-excursion +;; (save-restriction +;; (goto-char (point-min)) +;; (narrow-to-region +;; (point-min) +;; (if (re-search-forward +;; (concat "^" (regexp-quote mail-header-separator) "$") +;; nil t) +;; (match-beginning 0) +;; (point-max) +;; )) +;; (mime-decode-header-in-buffer) +;; (set-buffer-modified-p nil) +;; ))) + +;; (add-hook 'mime-edit-mode-hook 'mime-setup-decode-message-header) + + +;;; @@ variables +;;; +(defvar mime-setup-use-signature t + "If it is not nil, mime-setup sets up to use signature.el.") -(defvar mime-setup-enable-pgp - (module-installed-p 'mailcrypt) - "*If it is non-nil, semi-setup sets uf to use mime-pgp.") +(defvar mime-setup-default-signature-key "\C-c\C-s" + "*Key to insert signature.") -;; for PGP -(if mime-setup-enable-pgp - (call-after-loaded 'mime-view - (function - (lambda () - (require 'mime-pgp) - ))) - ) +(defvar mime-setup-signature-key-alist '((mail-mode . "\C-c\C-w")) + "Alist of major-mode vs. key to insert signature.") -;;; @ for mh-e +;;; @@ for signature ;;; -(defun semi-setup-load-emh () - (require 'emh) +(defun mime-setup-set-signature-key () + (let ((keymap (current-local-map))) + (if keymap + (let ((key + (or (cdr (assq major-mode mime-setup-signature-key-alist)) + mime-setup-default-signature-key))) + (define-key keymap key (function insert-signature)))))) + +(when mime-setup-use-signature + (autoload 'insert-signature "signature" "Insert signature" t) + (add-hook 'mime-edit-mode-hook 'mime-setup-set-signature-key) + ;; (setq message-signature nil) ) -(call-after-loaded 'mh-e 'semi-setup-load-emh 'mh-folder-mode-hook) -(or (featurep 'mh-e) - (add-hook 'mh-letter-mode-hook 'semi-setup-load-emh) - ) - -;;; @ for Gnus +;;; @ for mu-cite ;;; - -(defun semi-setup-load-gnus () - (let (gnus-load-hook) - (require 'gnus-mime) - )) -(add-hook 'gnus-load-hook 'semi-setup-load-gnus) +;; (add-hook 'mu-cite/pre-cite-hook 'eword-decode-header) ;;; @ end