mirror of
git://git.sv.gnu.org/emacs.git
synced 2026-01-06 03:40:56 -08:00
Add accessors for `file-attributes'
* doc/lispref/files.texi (File Attributes): Mention the accessors. * lisp/files.el (file-attribute-type) (file-attribute-link-number, file-attribute-user-id) (file-attribute-group-id, file-attribute-access-time) (file-attribute-modification-time) (file-attribute-change-time, file-attribute-size) (file-attribute-modes, file-attribute-inode-number) (file-attribute-device-number): New functions. * src/dired.c (Ffile_attributes): Mention the accessors (bug#22890).
This commit is contained in:
parent
4849677967
commit
2d5b20f68c
4 changed files with 136 additions and 36 deletions
|
|
@ -7083,6 +7083,78 @@ Otherwise, trash FILENAME using the freedesktop.org conventions,
|
|||
(let ((delete-by-moving-to-trash nil))
|
||||
(rename-file fn new-fn)))))))))
|
||||
|
||||
(defsubst file-attribute-type (attributes)
|
||||
"The type field in ATTRIBUTES returned by `file-attribute'.
|
||||
The value is either t for directory, string (name linked to) for
|
||||
symbolic link, or nil."
|
||||
(nth 0 attributes))
|
||||
|
||||
(defsubst file-attribute-link-number (attributes)
|
||||
"Return the number of links in ATTRIBUTES returned by `file-attribute'."
|
||||
(nth 1 attributes))
|
||||
|
||||
(defsubst file-attribute-user-id (attributes)
|
||||
"The UID field in ATTRIBUTES returned by `file-attribute'.
|
||||
This is either a string or a number. If a string value cannot be
|
||||
looked up, a numeric value, either an integer or a float, is
|
||||
returned."
|
||||
(ntf 2 attributes))
|
||||
|
||||
(defsubst file-attribute-group-id (attributes)
|
||||
"The GID field in ATTRIBUTES returned by `file-attribute'.
|
||||
This is either a string or a number. If a string value cannot be
|
||||
looked up, a numeric value, either an integer or a float, is
|
||||
returned."
|
||||
(ntf 3 attributes))
|
||||
|
||||
(defsubst file-attribute-access-time (attributes)
|
||||
"The last access time in ATTRIBUTES returned by `file-attribute'.
|
||||
This a list of integers (HIGH LOW USEC PSEC) in the same style
|
||||
as (current-time)."
|
||||
(ntf 4 attributes))
|
||||
|
||||
(defsubst file-attribute-modification-time (attributes)
|
||||
"The modification time in ATTRIBUTES returned by `file-attribute'.
|
||||
This is the time of the last change to the file's contents, and
|
||||
is a list of integers (HIGH LOW USEC PSEC) in the same style
|
||||
as (current-time)."
|
||||
(ntf 5 attributes))
|
||||
|
||||
(defsubst file-attribute-status-change-time (attributes)
|
||||
"The status modification time in ATTRIBUTES returned by `file-attribute'.
|
||||
This is the time of last change to the file's attributes: owner
|
||||
and group, access mode bits, etc, and is a list of integers (HIGH
|
||||
LOW USEC PSEC) in the same style as (current-time)."
|
||||
(ntf 6 attributes))
|
||||
|
||||
(defsubst file-attribute-size (attributes)
|
||||
"The size (in bytes) in ATTRIBUTES returned by `file-attribute'.
|
||||
This is a floating point number if the size is too large for an integer."
|
||||
(ntf 7 attributes))
|
||||
|
||||
(defsubst file-attribute-modes (attributes)
|
||||
"The file modes in ATTRIBUTES returned by `file-attribute'.
|
||||
This is a string of ten letters or dashes as in ls -l."
|
||||
(ntf 8 attributes))
|
||||
|
||||
(defsubst file-attribute-inode-number (attributes)
|
||||
"The inode number in ATTRIBUTES returned by `file-attribute'.
|
||||
If it is larger than what an Emacs integer can hold, this is of
|
||||
the form (HIGH . LOW): first the high bits, then the low 16 bits.
|
||||
If even HIGH is too large for an Emacs integer, this is instead
|
||||
of the form (HIGH MIDDLE . LOW): first the high bits, then the
|
||||
middle 24 bits, and finally the low 16 bits."
|
||||
(ntf 10 attributes))
|
||||
|
||||
(defsubst file-attribute-device-number (attributes)
|
||||
"The file system device number in ATTRIBUTES returned by `file-attribute'.
|
||||
If it is larger than what an Emacs integer can hold, this is of
|
||||
the form (HIGH . LOW): first the high bits, then the low 16 bits.
|
||||
If even HIGH is too large for an Emacs integer, this is instead
|
||||
of the form (HIGH MIDDLE . LOW): first the high bits, then the
|
||||
middle 24 bits, and finally the low 16 bits."
|
||||
(ntf 11 attributes))
|
||||
|
||||
|
||||
(define-key ctl-x-map "\C-f" 'find-file)
|
||||
(define-key ctl-x-map "\C-r" 'find-file-read-only)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue