]> git.eshelyaron.com Git - emacs.git/commitdiff
Handle chrooted environments in Tramp
authorMichael Albinus <michael.albinus@gmx.de>
Thu, 19 Apr 2018 09:04:01 +0000 (11:04 +0200)
committerMichael Albinus <michael.albinus@gmx.de>
Thu, 19 Apr 2018 09:04:01 +0000 (11:04 +0200)
* doc/misc/tramp.texi (Frequently Asked Questions): New item, chrooted
environments.

* lisp/net/tramp.el (tramp-local-host-regexp): Make it a defcustom.
Allow nil.
(tramp-local-host-p):
* lisp/net/tramp-sh.el (tramp-compute-multi-hops): Handle this.

doc/misc/tramp.texi
lisp/net/tramp-sh.el
lisp/net/tramp.el

index f0ea073ed091977d2285782f8a09e087e1a3ad41..7ae7150930a7792238094e157bb871e478fdf9e2 100644 (file)
@@ -3294,6 +3294,7 @@ Keep the file @option{tramp-persistency-file-name}, which is where
 @value{tramp} caches remote information about hosts and files.  Caching
 is enabled by default.  Don't disable it.
 
+@vindex remote-file-name-inhibit-cache
 Set @code{remote-file-name-inhibit-cache} to @code{nil} if remote
 files are not independently updated outside @value{tramp}'s control.
 That cache cleanup will be necessary if the remote directories or
@@ -3427,6 +3428,16 @@ first saving to a temporary file.
 @end itemize
 
 
+@item
+@value{tramp} fails in a chrooted environment
+
+@vindex tramp-local-host-regexp
+When connecting to a local host, @value{tramp} uses some internal
+optimizations.  They fail, when there is a chrooted environment.  In
+order to disable those optimizations, set user option
+@option{tramp-local-host-regexp} to @code{nil}.
+
+
 @item
 @value{tramp} does not recognize if a @command{ssh} session hangs
 
index 3ba3d956efca031e255885eec73e64b2c5369069..2fb5566a3bf9b279fa058e80a6135213df658e26 100644 (file)
@@ -4634,7 +4634,7 @@ Goes through the list `tramp-inline-compress-commands'."
     ;; host name in their command template.  In this case, the remote
     ;; file name must use either a local host name (first hop), or a
     ;; host name matching the previous hop.
-    (let ((previous-host tramp-local-host-regexp))
+    (let ((previous-host (or tramp-local-host-regexp "")))
       (setq choices target-alist)
       (while (setq item (pop choices))
        (let ((host (tramp-file-name-host item)))
index 52ff021c5007161ce75490a587c63aa4a01665f8..5c785b16d89104f9de7e8bdcc7bf515f1270192e 100644 (file)
@@ -428,13 +428,19 @@ host runs a registered shell, it shall be added to this list, too."
   :require 'tramp)
 
 ;;;###tramp-autoload
-(defconst tramp-local-host-regexp
+(defcustom tramp-local-host-regexp
   (concat
    "\\`"
    (regexp-opt
     (list "localhost" "localhost6" (system-name) "127.0.0.1" "::1") t)
    "\\'")
-  "Host names which are regarded as local host.")
+  "Host names which are regarded as local host.
+If the local host runs a chrooted environment, set this to nil."
+  :version "27.1"
+  :group 'tramp
+  :type '(choice (const :tag "Chrooted environment" nil)
+                (regexp :tag "Host regexp"))
+  :require 'tramp)
 
 (defvar tramp-completion-function-alist nil
   "Alist of methods for remote files.
@@ -4239,11 +4245,12 @@ be granted."
 
 ;;;###tramp-autoload
 (defun tramp-local-host-p (vec)
-  "Return t if this points to the local host, nil otherwise."
+  "Return t if this points to the local host, nil otherwise.
+This handles also chrooted environments, which are not regarded as local."
   (let ((host (tramp-file-name-host vec))
        (port (tramp-file-name-port vec)))
     (and
-     (stringp host)
+     (stringp tramp-local-host-regexp) (stringp host)
      (string-match tramp-local-host-regexp host)
      ;; A port is an indication for an ssh tunnel or alike.
      (null port)