(defun files--splice-dirname-file (dirname file)
"Splice DIRNAME to FILE like the operating system would.
-If FILENAME is relative, return DIRNAME concatenated to FILE.
+If FILE is relative, return DIRNAME concatenated to FILE.
Otherwise return FILE, quoted as needed if DIRNAME and FILE have
different handlers; although this quoting is dubious if DIRNAME
is magic, it is not clear what would be better. This function
differs from `expand-file-name' in that DIRNAME must be a
directory name and leading `~' and `/:' are not special in FILE."
- (if (files--name-absolute-system-p file)
- (if (eq (find-file-name-handler dirname 'file-symlink-p)
- (find-file-name-handler file 'file-symlink-p))
- file
- ;; If `file' is remote, we want to quote it at the beginning.
- (let (file-name-handler-alist) (file-name-quote file)))
- (concat dirname file)))
+ (let ((unquoted (if (files--name-absolute-system-p file)
+ file
+ (concat dirname file))))
+ (if (eq (find-file-name-handler dirname 'file-symlink-p)
+ (find-file-name-handler unquoted 'file-symlink-p))
+ unquoted
+ (let (file-name-handler-alist) (file-name-quote unquoted)))))
(defun file-truename (filename &optional counter prev-dirs)
"Return the truename of FILENAME.