From a433028e00e5dbe851fcb2df5cce35a8a91e8cc5 Mon Sep 17 00:00:00 2001 From: Jim Porter Date: Sun, 27 Aug 2023 12:53:40 -0700 Subject: [PATCH] Fix remote path setting in Eshell This ensures that we supply Tramp with the local PATH so that it can do its job of starting the local "ssh", or whatever the method uses (bug#65551). * lisp/eshell/esh-proc.el (eshell-gather-process-output): Add special handling for remote processes. * test/lisp/eshell/esh-proc-tests.el (esh-var-test/remote/remote-path): New test. --- lisp/eshell/esh-proc.el | 14 +++++++++++++- test/lisp/eshell/esh-proc-tests.el | 15 +++++++++++++++ 2 files changed, 28 insertions(+), 1 deletion(-) diff --git a/lisp/eshell/esh-proc.el b/lisp/eshell/esh-proc.el index fcd59ab9f37..5bd8446eeec 100644 --- a/lisp/eshell/esh-proc.el +++ b/lisp/eshell/esh-proc.el @@ -265,6 +265,8 @@ eshell-last-sync-output-start "A marker that tracks the beginning of output of the last subprocess. Used only on systems which do not support async subprocesses.") +(defvar tramp-remote-path) + (defun eshell-gather-process-output (command args) "Gather the output from COMMAND + ARGS." (require 'esh-var) @@ -272,7 +274,8 @@ eshell-gather-process-output (unless (and (file-executable-p command) (file-regular-p (file-truename command))) (error "%s: not an executable file" command)) - (let* ((delete-exited-processes + (let* ((real-path (getenv "PATH")) + (delete-exited-processes (if eshell-current-subjob-p eshell-delete-exited-processes delete-exited-processes)) @@ -280,6 +283,15 @@ eshell-gather-process-output (coding-system-for-read coding-system-for-read) (coding-system-for-write coding-system-for-write) proc stderr-proc decoding encoding changed) + ;; HACK: We want to supply our subprocess with the all the + ;; environment variables we've set in Eshell. However, supplying + ;; a remote PATH this way can break Tramp, which needs the *local* + ;; PATH for calling "ssh", etc. Instead, set the local path in + ;; our `process-environment' and pass the remote PATH via + ;; `tramp-remote-path'. + (when (file-remote-p default-directory) + (push (concat "PATH=" real-path) process-environment) + (setq tramp-remote-path (eshell-get-path))) ;; MS-Windows needs special setting of encoding/decoding, because ;; (a) non-ASCII text in command-line arguments needs to be ;; encoded in the system's codepage; and (b) because many Windows diff --git a/test/lisp/eshell/esh-proc-tests.el b/test/lisp/eshell/esh-proc-tests.el index 8e02fbb5497..7d0432dbe68 100644 --- a/test/lisp/eshell/esh-proc-tests.el +++ b/test/lisp/eshell/esh-proc-tests.el @@ -259,4 +259,19 @@ esh-proc-test/kill-pipeline-head output-start (eshell-end-of-output)) ""))))) + +;; Remote processes + +(ert-deftest esh-var-test/remote/remote-path () + "Ensure that setting the remote PATH in Eshell doesn't interfere with Tramp. +See bug#65551." + (skip-unless (and (eshell-tests-remote-accessible-p) + (executable-find "echo"))) + (let ((default-directory ert-remote-temporary-file-directory)) + (with-temp-eshell + (eshell-insert-command "set PATH ''") + (eshell-match-command-output + (format "%s hello" (executable-find "echo" t)) + "\\`hello\n")))) + ;;; esh-proc-tests.el ends here -- 2.25.1