emacs-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Emacs-diffs] master 92045f4: Add file name handler support for file-sys


From: Michael Albinus
Subject: [Emacs-diffs] master 92045f4: Add file name handler support for file-system-info
Date: Tue, 3 Oct 2017 10:15:22 -0400 (EDT)

branch: master
commit 92045f4546b9708dc9f69954799d211c1f56ff1e
Author: Michael Albinus <address@hidden>
Commit: Michael Albinus <address@hidden>

    Add file name handler support for file-system-info
    
    * doc/lispref/files.texi (Magic File Names): Add file-system-info.
    
    * etc/NEWS: Mention get-free-disk-space working on remote systems.
    
    * lisp/files.el (get-free-disk-space): Do not block on remote systems.
    
    * src/w32fns.c (Ffile_system_info):
    * src/fileio.c (Ffile_system_info): Call file name handler if exists.
    (syms_of_fileio): Add Qfile_system_info.
---
 doc/lispref/files.texi |  6 ++++--
 etc/NEWS               |  8 +++++++-
 lisp/files.el          | 10 ++++------
 src/fileio.c           | 13 +++++++++++++
 src/w32fns.c           | 11 +++++++++++
 5 files changed, 39 insertions(+), 9 deletions(-)

diff --git a/doc/lispref/files.texi b/doc/lispref/files.texi
index 0a37eeb..0f0ce15 100644
--- a/doc/lispref/files.texi
+++ b/doc/lispref/files.texi
@@ -3135,7 +3135,8 @@ first, before handlers for jobs such as remote file 
access.
 @code{file-ownership-preserved-p},
 @code{file-readable-p}, @code{file-regular-p},
 @code{file-remote-p}, @code{file-selinux-context},
address@hidden, @code{file-truename}, @code{file-writable-p},
address@hidden, @code{file-system-info},
address@hidden, @code{file-writable-p},
 @code{find-backup-file-name},@*
 @code{get-file-buffer},
 @code{insert-directory},
@@ -3191,7 +3192,8 @@ first, before handlers for jobs such as remote file 
access.
 @address@hidden,
 @code{file-readable-p}, @code{file-regular-p},
 @code{file-remote-p}, @code{file-selinux-context},
address@hidden, @code{file-truename}, @code{file-writable-p},
address@hidden, @code{file-system-info},
address@hidden, @code{file-writable-p},
 @code{find-backup-file-name},
 @code{get-file-buffer},
 @code{insert-directory},
diff --git a/etc/NEWS b/etc/NEWS
index 28789a9..1566180 100644
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -70,13 +70,19 @@ Programs that called it with multiple arguments before 
should pass
 them through 'format' first.  Even that is discouraged: for ElDoc
 support, you should set 'eldoc-documentation-function' instead of
 calling 'eldoc-message' directly.
+
 
 * Lisp Changes in Emacs 27.1
 
+---
 ** The 'file-system-info' function is now available on all platforms.
-instead of just Microsoft platforms.  This fixes a get-free-disk-space
+instead of just Microsoft platforms.  This fixes a 'get-free-disk-space'
 bug on OS X 10.8 and later (Bug#28639).
 
+---
+** The function 'get-free-disk-space' returns now a non-nil value for
+remote systems, which support this check.
+
 
 * Changes in Emacs 27.1 on Non-Free Operating Systems
 
diff --git a/lisp/files.el b/lisp/files.el
index 194c87a..666654d 100644
--- a/lisp/files.el
+++ b/lisp/files.el
@@ -6407,12 +6407,10 @@ This variable is obsolete; Emacs no longer uses it."
 The return value is a string describing the amount of free
 space (normally, the number of free 1KB blocks).
 
-If DIR's free space cannot be obtained, or if DIR is a remote
-directory, this function returns nil."
-  (unless (file-remote-p (expand-file-name dir))
-    (let ((avail (nth 2 (file-system-info dir))))
-      (if avail
-         (format "%.0f" (/ avail 1024))))))
+If DIR's free space cannot be obtained, this function returns nil."
+  (let ((avail (nth 2 (file-system-info dir))))
+    (if avail
+       (format "%.0f" (/ avail 1024)))))
 
 ;; The following expression replaces `dired-move-to-filename-regexp'.
 (defvar directory-listing-before-filename-regexp
diff --git a/src/fileio.c b/src/fileio.c
index 1137027..d460f12 100644
--- a/src/fileio.c
+++ b/src/fileio.c
@@ -5789,6 +5789,18 @@ If the underlying system call fails, value is nil.  */)
   (Lisp_Object filename)
 {
   Lisp_Object encoded = ENCODE_FILE (Fexpand_file_name (filename, Qnil));
+
+  /* If the file name has special constructs in it,
+     call the corresponding file handler.  */
+  Lisp_Object handler = Ffind_file_name_handler (encoded, Qfile_system_info);
+  if (!NILP (handler))
+    {
+      Lisp_Object result = call2 (handler, Qfile_system_info, encoded);
+      if (CONSP (result) || NILP (result))
+       return result;
+      error ("Invalid handler in `file-name-handler-alist'");
+    }
+
   struct fs_usage u;
   if (get_fs_usage (SSDATA (encoded), NULL, &u) != 0)
     return Qnil;
@@ -5870,6 +5882,7 @@ syms_of_fileio (void)
   DEFSYM (Qwrite_region, "write-region");
   DEFSYM (Qverify_visited_file_modtime, "verify-visited-file-modtime");
   DEFSYM (Qset_visited_file_modtime, "set-visited-file-modtime");
+  DEFSYM (Qfile_system_info, "file-system-info");
 
   /* The symbol bound to coding-system-for-read when
      insert-file-contents is called for recovering a file.  This is not
diff --git a/src/w32fns.c b/src/w32fns.c
index efbd81b..e3de22d 100644
--- a/src/w32fns.c
+++ b/src/w32fns.c
@@ -9336,6 +9336,17 @@ If the underlying system call fails, value is nil.  */)
   filename = Fexpand_file_name (filename, Qnil);
   encoded = ENCODE_FILE (filename);
 
+  /* If the file name has special constructs in it,
+     call the corresponding file handler.  */
+  Lisp_Object handler = Ffind_file_name_handler (encoded, Qfile_system_info);
+  if (!NILP (handler))
+    {
+      value = call2 (handler, Qfile_system_info, encoded);
+      if (CONSP (value) || NILP (value))
+       return value;
+      error ("Invalid handler in `file-name-handler-alist'");
+    }
+
   value = Qnil;
 
   /* Determining the required information on Windows turns out, sadly,



reply via email to

[Prev in Thread] Current Thread [Next in Thread]