From: Eli Zaretskii Date: Wed, 29 Apr 2020 15:58:42 +0000 (+0300) Subject: Fix project.el commands in "transient" projects X-Git-Tag: emacs-27.1-rc1~169 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=7a12ab5ea2257f8e9d3f4ba03918cf9709a728e1;p=emacs.git Fix project.el commands in "transient" projects * lisp/progmodes/project.el (project--files-in-directory): Run local DIR directory names through 'expand-file-name', so that "~/" is expanded, in case the shell doesn't or the shell's notion of the home directory is different from that of Emacs. (Bug#40940) --- diff --git a/lisp/progmodes/project.el b/lisp/progmodes/project.el index 1f4cbe96ad8..dbc967b8851 100644 --- a/lisp/progmodes/project.el +++ b/lisp/progmodes/project.el @@ -185,23 +185,27 @@ to find the list of ignores for each directory." (require 'find-dired) (require 'xref) (defvar find-name-arg) - (let ((default-directory dir) - (command (format "%s %s %s -type f %s -print0" - find-program - (file-local-name dir) - (xref--find-ignores-arguments - ignores - (expand-file-name dir)) - (if files - (concat (shell-quote-argument "(") - " " find-name-arg " " - (mapconcat - #'shell-quote-argument - (split-string files) - (concat " -o " find-name-arg " ")) - " " - (shell-quote-argument ")"))"") - ))) + (let* ((default-directory dir) + (dirname (file-remote-p dir 'localname)) + (dirname (or dirname + ;; Make sure ~/ etc. in local directory name is + ;; expanded and not left for the shell command + ;; to interpret. + (expand-file-name dir))) + (command (format "%s %s %s -type f %s -print0" + find-program + dirname + (xref--find-ignores-arguments ignores dirname) + (if files + (concat (shell-quote-argument "(") + " " find-name-arg " " + (mapconcat + #'shell-quote-argument + (split-string files) + (concat " -o " find-name-arg " ")) + " " + (shell-quote-argument ")"))"") + ))) (project--remote-file-names (sort (split-string (shell-command-to-string command) "\0" t) #'string<))))