ambrevar/file: Return NIL for files that cannot be stat'ed.

For instance, Emacs unsaved buffer locks.
master
Pierre Neidhardt 2021-01-15 13:54:00 +01:00
parent 42335e2759
commit 31a4fffa30
1 changed files with 21 additions and 19 deletions

View File

@ -83,25 +83,27 @@ This returns the directory name for directories."
(uiop:parse-native-namestring path)))))
(assert (or (uiop:file-exists-p native-path)
(uiop:directory-exists-p native-path)))
(let ((stat (osicat-posix:stat native-path)))
;; From Osicat's `file-permissions':
(flet ((stat-permissions (stat)
(let ((mode (osicat-posix:stat-mode stat)))
(loop for (name . value) in osicat::+permissions+
when (plusp (logand mode value))
collect name))))
(make-instance 'file
:path (uiop:unix-namestring native-path)
:inode (osicat-posix:stat-ino stat)
:link-count (osicat-posix:stat-nlink stat)
:kind (osicat:file-kind native-path) ; TODO: Don't recall `stat'.
:size (osicat-posix:stat-size stat)
:user-id (osicat-posix:stat-uid stat)
:group-id (osicat-posix:stat-gid stat)
:creation-date (local-time:unix-to-timestamp (osicat-posix:stat-ctime stat))
:modification-date (local-time:unix-to-timestamp (osicat-posix:stat-mtime stat))
:access-date (local-time:unix-to-timestamp (osicat-posix:stat-atime stat))
:permissions (stat-permissions stat))))))
;; TODO: What do we do with non-existent files (e.g. unsaved emacs buffers)? Just return nil?
(let ((stat (ignore-errors (osicat-posix:stat native-path))))
(when stat
;; From Osicat's `file-permissions':
(flet ((stat-permissions (stat)
(let ((mode (osicat-posix:stat-mode stat)))
(loop for (name . value) in osicat::+permissions+
when (plusp (logand mode value))
collect name))))
(make-instance 'file
:path (uiop:unix-namestring native-path)
:inode (osicat-posix:stat-ino stat)
:link-count (osicat-posix:stat-nlink stat)
:kind (osicat:file-kind native-path) ; TODO: Don't recall `stat'.
:size (osicat-posix:stat-size stat)
:user-id (osicat-posix:stat-uid stat)
:group-id (osicat-posix:stat-gid stat)
:creation-date (local-time:unix-to-timestamp (osicat-posix:stat-ctime stat))
:modification-date (local-time:unix-to-timestamp (osicat-posix:stat-mtime stat))
:access-date (local-time:unix-to-timestamp (osicat-posix:stat-atime stat))
:permissions (stat-permissions stat)))))))
(export-always '*finder-include-directories*)
(defvar *finder-include-directories* t