Mercurial > emacs
changeset 102968:3f05108a52f1
* net/tramp.el (tramp-handle-dired-recursive-delete-directory):
Fix an error in flushing cache data.
(tramp-handle-process-file): Flush all file cache values for the
connection, because the remote process could have changed them.
Suggested by Stefan Monnier <monnier@iro.umontreal.ca>.
Handle QUIT.
author | Michael Albinus <michael.albinus@gmx.de> |
---|---|
date | Tue, 14 Apr 2009 14:36:38 +0000 |
parents | ed58adc8f9aa |
children | a8c41d72ae8a |
files | lisp/net/tramp.el |
diffstat | 1 files changed, 14 insertions(+), 5 deletions(-) [+] |
line wrap: on
line diff
--- a/lisp/net/tramp.el Tue Apr 14 13:58:35 2009 +0000 +++ b/lisp/net/tramp.el Tue Apr 14 14:36:38 2009 +0000 @@ -3468,9 +3468,9 @@ "Recursively delete the directory given. This is like `dired-recursive-delete-directory' for Tramp files." (with-parsed-tramp-file-name filename nil - (tramp-flush-directory-property v filename) + (tramp-flush-directory-property v localname) ;; Run a shell command 'rm -r <localname>' - ;; Code shamelessly stolen for the dired implementation and, um, hacked :) + ;; Code shamelessly stolen from the dired implementation and, um, hacked :) (unless (file-exists-p filename) (tramp-error v 'file-error "No such directory: %s" filename)) ;; Which is better, -r or -R? (-r works for me <daniel@danann.net>) @@ -3896,7 +3896,12 @@ (with-current-buffer outbuf (insert output-string))) (when display (display-buffer outbuf)))) - ;; When the user did interrupt, we should do it also. + ;; When the user did interrupt, we should do it also. We use + ;; return code -1 as marker. + (quit + (kill-buffer (tramp-get-connection-buffer v)) + (setq ret -1)) + ;; Handle errors. (error (kill-buffer (tramp-get-connection-buffer v)) (setq ret 1))) @@ -3905,10 +3910,14 @@ (unless ret (setq ret (tramp-send-command-and-check v nil))) ;; Provide error file. (when tmpstderr (rename-file tmpstderr (cadr destination) t)) - ;; Cleanup. + ;; Cleanup. We remove all file cache values for the connection, + ;; because the remote process could have changed them. (when tmpinput (delete-file tmpinput)) + (tramp-flush-directory-property v "") ;; Return exit status. - ret))) + (if (equal ret -1) + (keyboard-quit) + ret)))) (defun tramp-local-call-process (program &optional infile destination display &rest args)