]> git.eshelyaron.com Git - emacs.git/commitdiff
* net/tramp.el (tramp-let-maybe): Removed.
authorMichael Albinus <michael.albinus@gmx.de>
Wed, 19 Mar 2008 21:06:37 +0000 (21:06 +0000)
committerMichael Albinus <michael.albinus@gmx.de>
Wed, 19 Mar 2008 21:06:37 +0000 (21:06 +0000)
(tramp-drop-volume-letter): Don't use `replace-regexp-in-string'.
It does not exist under XEmacs.
(tramp-handle-file-truename, tramp-handle-expand-file-name)
(tramp-completion-file-name-handler): Let-bind
`directory-sep-char'.

lisp/ChangeLog
lisp/net/tramp.el

index e5f9e969815ae7cab19b8d10a53e1f51076b1f3a..ed6f30769b0ac5bdfa2ff1ad9c444acccb7e3916 100644 (file)
@@ -1,3 +1,15 @@
+2008-03-19  Michael Albinus  <michael.albinus@gmx.de>
+
+       * net/tramp.el (tramp-let-maybe): Removed.
+       (tramp-drop-volume-letter): Don't use `replace-regexp-in-string'.
+       It does not exist under XEmacs.
+       (tramp-handle-file-truename, tramp-handle-expand-file-name)
+       (tramp-completion-file-name-handler): Let-bind
+       `directory-sep-char'.
+
+       * net/tramp-fish.el (tramp-fish-handle-expand-file-name): Let-bind
+       `directory-sep-char'.
+
 2008-03-19  Stefan Monnier  <monnier@iro.umontreal.ca>
 
        * help-fns.el (describe-function-1): Don't signal "missing arglist"
index d530da37e2291da2315ffde685c35a14c33d5ae2..fa5cdafca561016a051eedbd141f078c6ebaf476 100644 (file)
@@ -5,7 +5,7 @@
 
 ;; (copyright statements below in code to be updated with the above notice)
 
-;; Author: Kai Großjohann <kai.grossjohann@gmx.net>
+;; Author: Kai Großjohann <kai.grossjohann@gmx.net>
 ;;         Michael Albinus <michael.albinus@gmx.de>
 ;; Keywords: comm, processes
 
@@ -1957,18 +1957,6 @@ FILE must be a local file name on a connection identified via VEC."
 (put 'with-connection-property 'edebug-form-spec t)
 (font-lock-add-keywords 'emacs-lisp-mode '("\\<with-connection-property\\>"))
 
-;;;###autoload
-(defmacro tramp-let-maybe (variable value &rest body)
-  "Let-bind VARIABLE to VALUE in BODY, but only if VARIABLE is not obsolete.
-BODY is executed whether or not the variable is obsolete.
-The intent is to protect against `obsolete variable' warnings."
-  `(if (get ',variable 'byte-obsolete-variable)
-       (progn ,@body)
-     (let ((,variable ,value))
-       ,@body)))
-(put 'tramp-let-maybe 'lisp-indent-function 2)
-(put 'tramp-let-maybe 'edebug-form-spec t)
-
 (defsubst tramp-make-tramp-temp-file (vec)
   "Create a temporary file on the remote host identified by VEC.
 Return the local name of the temporary file."
@@ -2201,9 +2189,9 @@ target of the symlink differ."
   "Like `file-truename' for Tramp files."
   (with-parsed-tramp-file-name (expand-file-name filename) nil
     (with-file-property v localname "file-truename"
-      (let* ((steps        (tramp-split-string localname "/"))
-            (localnamedir (tramp-let-maybe directory-sep-char ?/ ;for XEmacs
-                            (file-name-as-directory localname)))
+      (let* ((directory-sep-char ?/) ; for XEmacs
+            (steps (tramp-split-string localname "/"))
+            (localnamedir (file-name-as-directory localname))
             (is-dir (string= localname localnamedir))
             (thisstep nil)
             (numchase 0)
@@ -3505,7 +3493,10 @@ The function `tramp-handle-expand-file-name' calls `expand-file-name'
 locally on a remote file name.  When the local system is a W32 system
 but the remote system is Unix, this introduces a superfluous drive
 letter into the file name.  This function removes it."
-       (save-match-data (replace-regexp-in-string tramp-root-regexp "/" name)))
+       (save-match-data
+         (if (string-match tramp-root-regexp name)
+             (replace-match "/" nil t name)
+           name)))
 
     (defalias 'tramp-drop-volume-letter 'identity)))
 
@@ -3558,13 +3549,13 @@ the result will be a local, non-Tramp, filename."
       ;; would otherwise use backslash.  `default-directory' is
       ;; bound, because on Windows there would be problems with UNC
       ;; shares or Cygwin mounts.
-      (tramp-let-maybe directory-sep-char ?/
-       (let ((default-directory (tramp-compat-temporary-file-directory)))
-         (tramp-make-tramp-file-name
-          method user host
-          (tramp-drop-volume-letter
-           (tramp-run-real-handler 'expand-file-name
-                                   (list localname)))))))))
+      (let ((directory-sep-char ?/)
+           (default-directory (tramp-compat-temporary-file-directory)))
+       (tramp-make-tramp-file-name
+        method user host
+        (tramp-drop-volume-letter
+         (tramp-run-real-handler 'expand-file-name
+                                 (list localname))))))))
 
 (defun tramp-handle-substitute-in-file-name (filename)
   "Like `substitute-in-file-name' for Tramp files.
@@ -4500,11 +4491,11 @@ Fall back to normal file name handler if no Tramp handler exists."
 Falls back to normal file name handler if no Tramp file name handler exists."
   ;; We bind `directory-sep-char' here for XEmacs on Windows, which
   ;; would otherwise use backslash.
-  (tramp-let-maybe directory-sep-char ?/
-    (let ((fn (assoc operation tramp-completion-file-name-handler-alist)))
-      (if fn
-         (save-match-data (apply (cdr fn) args))
-       (tramp-completion-run-real-handler operation args))))))
+  (let ((directory-sep-char ?/)
+       (fn (assoc operation tramp-completion-file-name-handler-alist)))
+    (if fn
+       (save-match-data (apply (cdr fn) args))
+      (tramp-completion-run-real-handler operation args)))))
 
 ;;;###autoload
 (defsubst tramp-register-file-name-handler ()
@@ -7371,7 +7362,7 @@ Only works for Bourne-like shells."
 ;;   transfer method to use.  (Greg Stark)
 ;; * Remove unneeded parameters from methods.
 ;; * Invoke rsync once for copying a whole directory hierarchy.
-;;   (Francesco Potortì)
+;;   (Francesco Potortì)
 ;; * Make it work for different encodings, and for different file name
 ;;   encodings, too.  (Daniel Pittman)
 ;; * Progress reports while copying files.  (Michael Kifer)