From 893895d31069c9d708e1c95436f2609f035629a2 Mon Sep 17 00:00:00 2001 From: Michael Albinus Date: Sat, 6 Oct 2007 15:25:50 +0000 Subject: [PATCH] * net/tramp.el (tramp-completion-mode): Extend doc-string. (tramp-completion-mode-p): Revert change from 2007-09-24. Checking for `return' etc as last character is not sufficient, for example in dired-mode when entering (revert-buffer) or (dired-sort). --- lisp/ChangeLog | 8 ++++++++ lisp/net/tramp.el | 39 +++++++++++++++++++++++++++------------ 2 files changed, 35 insertions(+), 12 deletions(-) diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 80d5f3f7e43..a30381b784c 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,11 @@ +2007-10-06 Michael Albinus + + * net/tramp.el (tramp-completion-mode): Extend doc-string. + (tramp-completion-mode-p): Revert change from 2007-09-24. + Checking for `return' etc as last character is not sufficient, for + example in dired-mode when entering (revert-buffer) or + (dired-sort). + 2007-10-06 Martin Rudalics * window.el (mouse-autoselect-window-cancel): Don't cancel for diff --git a/lisp/net/tramp.el b/lisp/net/tramp.el index 7d2e5161ac9..4bff0f8ee3f 100644 --- a/lisp/net/tramp.el +++ b/lisp/net/tramp.el @@ -4554,7 +4554,12 @@ Falls back to normal file name handler if no tramp file name handler exists." ;;; File name handler functions for completion mode (defvar tramp-completion-mode nil - "If non-nil, we are in file name completion mode.") + "If non-nil, external packages signal that they are in file name completion. + +This is necessary, because Tramp uses a heuristic depending on last +input event. This fails when external packages use other characters +but , or ?\\? for file name completion. This variable +should never be set globally, the intention is to let-bind it.") ;; Necessary because `tramp-file-name-regexp-unified' and ;; `tramp-completion-file-name-regexp-unified' aren't different. @@ -4579,23 +4584,33 @@ Falls back to normal file name handler if no tramp file name handler exists." file) (member (match-string 1 file) (mapcar 'car tramp-methods))) ((or - ;; Emacs - (not (memq last-input-event '(return newline))) + ;; Emacs. + (equal last-input-event 'tab) (and (natnump last-input-event) - (not (char-equal last-input-event ?\n)) - (not (char-equal last-input-event ?\r))) - ;; XEmacs + (or + ;; ?\t has event-modifier 'control + (char-equal last-input-event ?\t) + (and (not (event-modifiers last-input-event)) + (or (char-equal last-input-event ?\?) + (char-equal last-input-event ?\ ))))) + ;; XEmacs. (and (featurep 'xemacs) ;; `last-input-event' might be nil. (not (null last-input-event)) ;; `last-input-event' may have no character approximation. (funcall (symbol-function 'event-to-character) last-input-event) - (not (char-equal - (funcall (symbol-function 'event-to-character) - last-input-event) ?\n)) - (not (char-equal - (funcall (symbol-function 'event-to-character) - last-input-event) ?\r)))) + (or + ;; ?\t has event-modifier 'control + (char-equal + (funcall (symbol-function 'event-to-character) + last-input-event) ?\t) + (and (not (event-modifiers last-input-event)) + (or (char-equal + (funcall (symbol-function 'event-to-character) + last-input-event) ?\?) + (char-equal + (funcall (symbol-function 'event-to-character) + last-input-event) ?\ )))))) t))) ;; Method, host name and user name completion. -- 2.39.2