]> git.eshelyaron.com Git - emacs.git/commitdiff
Allow using `mm-inline-message' from other mail clients than Gnus
authorLars Ingebrigtsen <larsi@gnus.org>
Tue, 6 Jul 2021 14:33:25 +0000 (16:33 +0200)
committerLars Ingebrigtsen <larsi@gnus.org>
Tue, 6 Jul 2021 14:34:24 +0000 (16:34 +0200)
* lisp/gnus/mm-view.el (mm-inline-message-prepare-function): New
variable (bug#49380).
(mm-inline-message): Use it to separate out the Gnus-specific code.
* lisp/gnus/gnus-art.el (gnus-mime-display-single): ... which has
been moved here.

lisp/gnus/gnus-art.el
lisp/gnus/mm-view.el

index f2ec9462c5e2d5c39cde5a225d6f78229e2d10f1..b989446792bd4df5f78bbff392f6f4ea5d4e3f44 100644 (file)
@@ -6039,7 +6039,28 @@ If nil, don't show those extra buttons."
        (ignored gnus-ignored-mime-types)
        (mm-inline-font-lock (gnus-visual-p 'article-highlight 'highlight))
        (not-attachment t)
-       display text)
+        ;; Arrange a callback from `mm-inline-message' if we're
+        ;; displaying a message/rfc822 part.
+        (mm-inline-message-prepare-function
+         (lambda (charset)
+           (let ((handles
+                  (let (gnus-article-mime-handles
+                       ;; disable prepare hook
+                       gnus-article-prepare-hook
+                       (gnus-newsgroup-charset
+                         ;; mm-uu might set it.
+                        (unless (eq charset 'gnus-decoded)
+                          (or charset gnus-newsgroup-charset))))
+                   (let ((gnus-original-article-buffer
+                           (mm-handle-buffer handle)))
+                     (run-hooks 'gnus-article-decode-hook))
+                   (gnus-article-prepare-display)
+                    gnus-article-mime-handles)))
+            (when handles
+              (setq gnus-article-mime-handles
+                    (mm-merge-handles gnus-article-mime-handles handles))))))
+       display text
+        gnus-displaying-mime)
     (catch 'ignored
       (progn
        (while ignored
index 3e36d6724ea3d08a20bf6d15b329abe1cf26d2bd..2ec75a0bc59cb6deae9b1b3afcacb2f76cf8b02d 100644 (file)
@@ -418,16 +418,18 @@ This is only used if `mm-inline-large-images' is set to
   (fundamental-mode)
   (goto-char (point-min)))
 
-(defvar gnus-original-article-buffer)
-(defvar gnus-article-prepare-hook)
-(defvar gnus-displaying-mime)
+(defvar mm-inline-message-prepare-function nil
+  "Function called by `mm-inline-message' to do client specific setup.
+It is called with one parameter -- the charset.")
 
 (defun mm-inline-message (handle)
+  "Insert HANDLE (a message/rfc822 part) into the current buffer.
+This function will call `mm-inline-message-prepare-function'
+after inserting the part."
   (let ((b (point))
        (bolp (bolp))
        (charset (mail-content-type-get
-                 (mm-handle-type handle) 'charset))
-       gnus-displaying-mime handles)
+                 (mm-handle-type handle) 'charset)))
     (when (and charset
               (stringp charset))
       (setq charset (intern (downcase charset)))
@@ -437,16 +439,8 @@ This is only used if `mm-inline-large-images' is set to
       (save-restriction
        (narrow-to-region b b)
        (mm-insert-part handle)
-       (let (gnus-article-mime-handles
-             ;; disable prepare hook
-             gnus-article-prepare-hook
-             (gnus-newsgroup-charset
-              (unless (eq charset 'gnus-decoded) ;; mm-uu might set it.
-                (or charset gnus-newsgroup-charset))))
-         (let ((gnus-original-article-buffer (mm-handle-buffer handle)))
-           (run-hooks 'gnus-article-decode-hook))
-         (gnus-article-prepare-display)
-         (setq handles gnus-article-mime-handles))
+        (when mm-inline-message-prepare-function
+         (funcall mm-inline-message-prepare-function charset))
        (goto-char (point-min))
        (unless bolp
          (insert "\n"))
@@ -454,9 +448,6 @@ This is only used if `mm-inline-large-images' is set to
        (unless (bolp)
          (insert "\n"))
        (insert "----------\n\n")
-       (when handles
-         (setq gnus-article-mime-handles
-               (mm-merge-handles gnus-article-mime-handles handles)))
        (mm-handle-set-undisplayer
         handle
         (let ((beg (point-min-marker))