From 3d220232ff64e1ec1dcc9ec2c0cfefe37cdde431 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 | 15 ++++++++++++++- test/lisp/eshell/esh-proc-tests.el | 15 +++++++++++++++ 2 files changed, 29 insertions(+), 1 deletion(-) diff --git a/lisp/eshell/esh-proc.el b/lisp/eshell/esh-proc.el index fcd59ab9f37..fcb0b7d7fd3 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,9 @@ 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")) + (tramp-remote-path (bound-and-true-p tramp-remote-path)) + (delete-exited-processes (if eshell-current-subjob-p eshell-delete-exited-processes delete-exited-processes)) @@ -280,6 +284,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