emacs-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

master 6aeaf12 2/3: Allow mm-external-terminal-program to be a list of s


From: Lars Ingebrigtsen
Subject: master 6aeaf12 2/3: Allow mm-external-terminal-program to be a list of strings
Date: Mon, 15 Nov 2021 01:38:29 -0500 (EST)

branch: master
commit 6aeaf12551bc63c92cd85cd936c40b2f6a99e944
Author: Lars Ingebrigtsen <larsi@gnus.org>
Commit: Lars Ingebrigtsen <larsi@gnus.org>

    Allow mm-external-terminal-program to be a list of strings
    
    * doc/misc/emacs-mime.texi (Display Customization): Document it.
    
    * lisp/gnus/mm-decode.el (mm-external-terminal-program): Allow
    being a list.
---
 doc/misc/emacs-mime.texi |  3 ++-
 lisp/gnus/mm-decode.el   | 23 +++++++++++++++--------
 2 files changed, 17 insertions(+), 9 deletions(-)

diff --git a/doc/misc/emacs-mime.texi b/doc/misc/emacs-mime.texi
index 7cd3e5f..96a4ad5 100644
--- a/doc/misc/emacs-mime.texi
+++ b/doc/misc/emacs-mime.texi
@@ -454,7 +454,8 @@ setting this option to non-@code{nil}.  The default value 
is @code{t}.
 
 @item mm-external-terminal-program
 @vindex mm-external-terminal-program
-The program used to start an external terminal.
+This should be a list of strings; typically something like
+@samp{("xterm" "-e")} or @samp{("gnome-terminal" "--")}.
 
 @item mm-enable-external
 @vindex mm-enable-external
diff --git a/lisp/gnus/mm-decode.el b/lisp/gnus/mm-decode.el
index aca4bf2..d781407 100644
--- a/lisp/gnus/mm-decode.el
+++ b/lisp/gnus/mm-decode.el
@@ -446,10 +446,11 @@ If not set, `default-directory' will be used."
   :type 'integer
   :group 'mime-display)
 
-(defcustom mm-external-terminal-program "xterm"
-  "The program to start an external terminal."
-  :version "22.1"
-  :type 'string
+(defcustom mm-external-terminal-program '("xterm" "-e")
+  "The program to start an external terminal.
+This should be a list of strings."
+  :version "29.1"
+  :type '(choice string (repeat string))
   :group 'mime-display)
 
 ;;; Internal variables.
@@ -957,10 +958,16 @@ external if displayed external."
              (unwind-protect
                  (if window-system
                      (set-process-sentinel
-                      (start-process "*display*" nil
-                                     mm-external-terminal-program
-                                     "-e" shell-file-name
-                                     shell-command-switch command)
+                      (apply #'start-process "*display*" nil
+                              (append
+                               (if (listp mm-external-terminal-program)
+                                   mm-external-terminal-program
+                                 ;; Be backwards-compatible.
+                                 (list mm-external-terminal-program
+                                       "-e"))
+                               (list shell-file-name
+                                    shell-command-switch
+                                     command)))
                       (lambda (process _state)
                         (if (eq 'exit (process-status process))
                             (run-at-time



reply via email to

[Prev in Thread] Current Thread [Next in Thread]