diff options
| author | Paul Eggert | 2018-09-23 18:30:46 -0700 |
|---|---|---|
| committer | Paul Eggert | 2018-09-23 18:32:59 -0700 |
| commit | 662bee7d70ccd3903e123b08c7ec9108a1a2ce0b (patch) | |
| tree | 416de288b7f995a05f620c5a6e72cb5a30168551 /lisp/org | |
| parent | c2dee17e19e1cf80c2263f8de276cceb0252b76d (diff) | |
| download | emacs-662bee7d70ccd3903e123b08c7ec9108a1a2ce0b.tar.gz emacs-662bee7d70ccd3903e123b08c7ec9108a1a2ce0b.zip | |
file-attributes cleanup
Mostly, this replaces magic-number calls like (nth 4 A) with
more-informative calls like (file-attribute-access-time A).
It also fixes some documentation and minor timestamp coding
issues that I noticed while looking into this.
* doc/lispref/files.texi (File Attributes):
* lisp/files.el (file-attribute-size)
(file-attribute-inode-number, file-attribute-device-number):
* src/dired.c (Fdirectory_files_and_attributes)
(Ffile_attributes):
Mention which attributes must be integers, or nonnegative integers,
as opposed to merely being numbers. Remove no-longer-correct
talk about representing large integers as conses of integers.
* doc/lispref/files.texi (Magic File Names):
* doc/misc/gnus.texi (Low-level interface to the spam-stat dictionary):
* lisp/autorevert.el (auto-revert-find-file-function)
(auto-revert-tail-mode, auto-revert-handler):
* lisp/auth-source.el (auth-source-netrc-parse):
* lisp/cedet/ede/files.el (ede--inode-for-dir):
* lisp/cedet/semantic/db-file.el (object-write):
* lisp/cedet/semantic/db-mode.el (semanticdb-kill-hook):
* lisp/cedet/semantic/db.el (semanticdb-needs-refresh-p)
(semanticdb-synchronize):
* lisp/cedet/srecode/table.el (srecode-mode-table-new):
* lisp/desktop.el (desktop-save, desktop-read):
* lisp/dired-aux.el (dired-file-set-difference)
(dired-do-chxxx, dired-do-chmod, dired-copy-file-recursive)
(dired-create-files):
* lisp/dired.el (dired-directory-changed-p, dired-readin):
* lisp/dos-w32.el (w32-direct-print-region-helper):
* lisp/emacs-lisp/autoload.el (autoload-generate-file-autoloads)
(autoload-find-destination, update-directory-autoloads):
* lisp/emacs-lisp/shadow.el (load-path-shadows-same-file-or-nonexistent):
* lisp/epg.el (epg--start, epg-wait-for-completion):
* lisp/eshell/em-ls.el (eshell-ls-filetype-p)
(eshell-ls-applicable, eshell-ls-size-string)
(eshell-ls-file, eshell-ls-dir, eshell-ls-files)
(eshell-ls-entries):
* lisp/eshell/em-pred.el (eshell-predicate-alist)
(eshell-pred-file-type, eshell-pred-file-links)
(eshell-pred-file-size):
* lisp/eshell/em-unix.el (eshell-shuffle-files, eshell/cat)
(eshell-du-sum-directory, eshell/du):
* lisp/eshell/esh-util.el (eshell-read-passwd)
(eshell-read-hosts):
* lisp/files.el (remote-file-name-inhibit-cache)
(find-file-noselect, insert-file-1, dir-locals-find-file)
(dir-locals-read-from-dir, backup-buffer)
(file-ownership-preserved-p, copy-directory)
(read-file-modes):
* lisp/find-lisp.el (find-lisp-format):
* lisp/gnus/gnus-agent.el (gnus-agent-unfetch-articles)
(gnus-agent-read-agentview, gnus-agent-expire-group-1)
(gnus-agent-request-article, gnus-agent-regenerate-group)
(gnus-agent-update-files-total-fetched-for)
(gnus-agent-update-view-total-fetched-for):
* lisp/gnus/gnus-cache.el (gnus-cache-read-active)
(gnus-cache-update-file-total-fetched-for)
(gnus-cache-update-overview-total-fetched-for):
* lisp/gnus/gnus-cloud.el (gnus-cloud-file-new-p):
* lisp/gnus/gnus-score.el (gnus-score-score-files):
* lisp/gnus/gnus-start.el (gnus-save-newsrc-file)
(gnus-master-read-slave-newsrc):
* lisp/gnus/gnus-sum.el (gnus-summary-import-article):
* lisp/gnus/gnus-util.el (gnus-file-newer-than)
(gnus-cache-file-contents):
* lisp/gnus/mail-source.el (mail-source-delete-old-incoming)
(mail-source-callback, mail-source-movemail):
* lisp/gnus/nneething.el (nneething-create-mapping)
(nneething-make-head):
* lisp/gnus/nnfolder.el (nnfolder-read-folder):
* lisp/gnus/nnheader.el (nnheader-file-size)
(nnheader-insert-nov-file):
* lisp/gnus/nnmail.el (nnmail-activate):
* lisp/gnus/nnmaildir.el (nnmaildir--group-maxnum)
(nnmaildir--new-number, nnmaildir--update-nov)
(nnmaildir--scan, nnmaildir-request-scan)
(nnmaildir-request-update-info)
(nnmaildir-request-expire-articles):
* lisp/gnus/nnmh.el (nnmh-request-list-1)
(nnmh-request-expire-articles, nnmh-update-gnus-unreads):
* lisp/gnus/nnml.el (nnml-request-expire-articles):
* lisp/gnus/spam-stat.el (spam-stat-save, spam-stat-load)
(spam-stat-process-directory, spam-stat-test-directory):
* lisp/ido.el (ido-directory-too-big-p)
(ido-file-name-all-completions):
* lisp/image-dired.el (image-dired-get-thumbnail-image)
(image-dired-create-thumb-1):
* lisp/info.el (info-insert-file-contents):
* lisp/ls-lisp.el (ls-lisp-insert-directory)
(ls-lisp-handle-switches, ls-lisp-classify-file)
(ls-lisp-format):
* lisp/mail/blessmail.el:
* lisp/mail/feedmail.el (feedmail-default-date-generator)
(feedmail-default-message-id-generator):
* lisp/mail/mailabbrev.el (mail-abbrevs-sync-aliases)
(mail-abbrevs-setup):
* lisp/mail/mspools.el (mspools-size-folder):
* lisp/mail/rmail.el (rmail-insert-inbox-text):
* lisp/mail/sendmail.el (sendmail-sync-aliases):
* lisp/mh-e/mh-alias.el (mh-alias-tstamp):
* lisp/net/ange-ftp.el (ange-ftp-parse-netrc)
(ange-ftp-write-region, ange-ftp-file-newer-than-file-p)
(ange-ftp-cf1):
* lisp/net/eudcb-mab.el (eudc-mab-query-internal):
* lisp/net/eww.el (eww-read-bookmarks):
* lisp/net/netrc.el (netrc-parse):
* lisp/net/newst-backend.el (newsticker--image-get):
* lisp/nxml/rng-loc.el (rng-get-parsed-schema-locating-file):
* lisp/obsolete/fast-lock.el (fast-lock-save-cache):
* lisp/obsolete/vc-arch.el (vc-arch-state)
(vc-arch-diff3-rej-p):
* lisp/org/ob-eval.el (org-babel--shell-command-on-region):
* lisp/org/org-attach.el (org-attach-commit):
* lisp/org/org-macro.el (org-macro-initialize-templates):
* lisp/org/org.el (org-babel-load-file)
(org-file-newer-than-p):
* lisp/org/ox-html.el (org-html-format-spec):
* lisp/org/ox-publish.el (org-publish-find-date)
(org-publish-cache-ctime-of-src):
* lisp/pcmpl-gnu.el (pcomplete/tar):
* lisp/pcmpl-rpm.el (pcmpl-rpm-packages):
* lisp/play/cookie1.el (cookie-snarf):
* lisp/progmodes/cmacexp.el (c-macro-expansion):
* lisp/ps-bdf.el (bdf-file-mod-time):
* lisp/server.el (server-ensure-safe-dir):
* lisp/simple.el (shell-command-on-region):
* lisp/speedbar.el (speedbar-item-info-file-helper)
(speedbar-check-obj-this-line):
* lisp/thumbs.el (thumbs-cleanup-thumbsdir):
* lisp/time.el (display-time-mail-check-directory)
(display-time-file-nonempty-p):
* lisp/url/url-cache.el (url-is-cached):
* lisp/url/url-file.el (url-file-asynch-callback):
* lisp/vc/diff-mode.el (diff-delete-if-empty):
* lisp/vc/pcvs-info.el (cvs-fileinfo-from-entries):
* lisp/vc/vc-bzr.el (vc-bzr-state-heuristic):
* lisp/vc/vc-cvs.el (vc-cvs-checkout-model)
(vc-cvs-state-heuristic, vc-cvs-merge-news)
(vc-cvs-retrieve-tag, vc-cvs-parse-status, vc-cvs-parse-entry):
* lisp/vc/vc-hg.el (vc-hg--slurp-hgignore-1)
(vc-hg--ignore-patterns-valid-p)
(vc-hg--cached-dirstate-search, vc-hg-state-fast):
* lisp/vc/vc-hooks.el (vc-after-save):
* lisp/vc/vc-rcs.el (vc-rcs-workfile-is-newer):
* lisp/vc/vc-svn.el (vc-svn-merge-news, vc-svn-parse-status):
* lisp/vc/vc.el (vc-checkout, vc-checkin, vc-revert-file):
* lisp/xdg.el (xdg-mime-apps):
Prefer (file-attribute-size A) to (nth 7 A), and similarly
for other file attributes accessors.
* doc/lispref/files.texi (File Attributes):
* doc/lispref/intro.texi (Version Info):
* doc/lispref/os.texi (Idle Timers):
* lisp/erc/erc.el (erc-string-to-emacs-time):
* lisp/files.el (file-attribute-access-time)
(file-attribute-modification-time)
(file-attribute-status-change-time):
* lisp/net/tramp-compat.el:
(tramp-compat-file-attribute-modification-time)
(tramp-compat-file-attribute-size):
* src/buffer.c (syms_of_buffer):
* src/editfns.c (Fget_internal_run_time):
* src/fileio.c (Fvisited_file_modtime)
(Fset_visited_file_modtime):
* src/keyboard.c (Fcurrent_idle_time):
* src/process.c (Fprocess_attributes):
Defer implementation details about timestamp format to the
section that talks about timestamp format, to make it easier
to change the documentation later if timestamp formats are
extended.
* lisp/gnus/gnus-util.el (gnus-file-newer-than):
* lisp/speedbar.el (speedbar-check-obj-this-line):
* lisp/vc/vc-rcs.el (vc-rcs-workfile-is-newer):
Prefer time-less-p to doing it by hand.
* lisp/ls-lisp.el (ls-lisp-format): Inode numbers are no longer conses.
* lisp/vc/vc-bzr.el (vc-bzr-state-heuristic):
Use eql, not eq, to compare integers that might be bignums.
* lisp/org/ox-publish.el (org-publish-cache-ctime-of-src):
Prefer float-time to doing time arithmetic by hand.
Diffstat (limited to 'lisp/org')
| -rw-r--r-- | lisp/org/ob-eval.el | 2 | ||||
| -rw-r--r-- | lisp/org/org-attach.el | 2 | ||||
| -rw-r--r-- | lisp/org/org-macro.el | 3 | ||||
| -rw-r--r-- | lisp/org/org.el | 9 | ||||
| -rw-r--r-- | lisp/org/ox-html.el | 3 | ||||
| -rw-r--r-- | lisp/org/ox-publish.el | 9 |
6 files changed, 17 insertions, 11 deletions
diff --git a/lisp/org/ob-eval.el b/lisp/org/ob-eval.el index 2bfaa08a609..f8cb285dd3e 100644 --- a/lisp/org/ob-eval.el +++ b/lisp/org/ob-eval.el | |||
| @@ -120,7 +120,7 @@ function in various versions of Emacs. | |||
| 120 | (delete-file input-file)) | 120 | (delete-file input-file)) |
| 121 | 121 | ||
| 122 | (when (and error-file (file-exists-p error-file)) | 122 | (when (and error-file (file-exists-p error-file)) |
| 123 | (when (< 0 (nth 7 (file-attributes error-file))) | 123 | (when (< 0 (file-attribute-size (file-attributes error-file))) |
| 124 | (with-current-buffer (get-buffer-create error-buffer) | 124 | (with-current-buffer (get-buffer-create error-buffer) |
| 125 | (let ((pos-from-end (- (point-max) (point)))) | 125 | (let ((pos-from-end (- (point-max) (point)))) |
| 126 | (or (bobp) | 126 | (or (bobp) |
diff --git a/lisp/org/org-attach.el b/lisp/org/org-attach.el index 9774e3a7975..203e71e9549 100644 --- a/lisp/org/org-attach.el +++ b/lisp/org/org-attach.el | |||
| @@ -352,7 +352,7 @@ This checks for the existence of a \".git\" directory in that directory." | |||
| 352 | (shell-command-to-string | 352 | (shell-command-to-string |
| 353 | "git ls-files -zmo --exclude-standard") "\0" t)) | 353 | "git ls-files -zmo --exclude-standard") "\0" t)) |
| 354 | (if (and use-annex | 354 | (if (and use-annex |
| 355 | (>= (nth 7 (file-attributes new-or-modified)) | 355 | (>= (file-attribute-size (file-attributes new-or-modified)) |
| 356 | org-attach-git-annex-cutoff)) | 356 | org-attach-git-annex-cutoff)) |
| 357 | (call-process "git" nil nil nil "annex" "add" new-or-modified) | 357 | (call-process "git" nil nil nil "annex" "add" new-or-modified) |
| 358 | (call-process "git" nil nil nil "add" new-or-modified)) | 358 | (call-process "git" nil nil nil "add" new-or-modified)) |
diff --git a/lisp/org/org-macro.el b/lisp/org/org-macro.el index 1033db2af46..e50b2f99842 100644 --- a/lisp/org/org-macro.el +++ b/lisp/org/org-macro.el | |||
| @@ -159,7 +159,8 @@ function installs the following ones: \"property\", | |||
| 159 | (format "(eval (format-time-string \"$1\" (or (and (org-string-nw-p \"$2\") (org-macro--vc-modified-time %s)) '%s)))" | 159 | (format "(eval (format-time-string \"$1\" (or (and (org-string-nw-p \"$2\") (org-macro--vc-modified-time %s)) '%s)))" |
| 160 | (prin1-to-string visited-file) | 160 | (prin1-to-string visited-file) |
| 161 | (prin1-to-string | 161 | (prin1-to-string |
| 162 | (nth 5 (file-attributes visited-file))))))))) | 162 | (file-attribute-modification-time |
| 163 | (file-attributes visited-file))))))))) | ||
| 163 | ;; Initialize and install "n" macro. | 164 | ;; Initialize and install "n" macro. |
| 164 | (org-macro--counter-initialize) | 165 | (org-macro--counter-initialize) |
| 165 | (funcall update-templates | 166 | (funcall update-templates |
diff --git a/lisp/org/org.el b/lisp/org/org.el index 21d9cd8785d..873ae6b8209 100644 --- a/lisp/org/org.el +++ b/lisp/org/org.el | |||
| @@ -230,8 +230,9 @@ file to byte-code before it is loaded." | |||
| 230 | (let* ((age (lambda (file) | 230 | (let* ((age (lambda (file) |
| 231 | (float-time | 231 | (float-time |
| 232 | (time-subtract (current-time) | 232 | (time-subtract (current-time) |
| 233 | (nth 5 (or (file-attributes (file-truename file)) | 233 | (file-attribute-modification-time |
| 234 | (file-attributes file))))))) | 234 | (or (file-attributes (file-truename file)) |
| 235 | (file-attributes file))))))) | ||
| 235 | (base-name (file-name-sans-extension file)) | 236 | (base-name (file-name-sans-extension file)) |
| 236 | (exported-file (concat base-name ".el"))) | 237 | (exported-file (concat base-name ".el"))) |
| 237 | ;; tangle if the Org file is newer than the elisp file | 238 | ;; tangle if the Org file is newer than the elisp file |
| @@ -22381,7 +22382,9 @@ returned by, e.g., `current-time'." | |||
| 22381 | ;; (e.g. HFS+) do not retain any finer granularity. As | 22382 | ;; (e.g. HFS+) do not retain any finer granularity. As |
| 22382 | ;; a consequence, make sure we return non-nil when the two | 22383 | ;; a consequence, make sure we return non-nil when the two |
| 22383 | ;; times are equal. | 22384 | ;; times are equal. |
| 22384 | (not (time-less-p (cl-subseq (nth 5 (file-attributes file)) 0 2) | 22385 | (not (time-less-p (cl-subseq (file-attribute-modification-time |
| 22386 | (file-attributes file)) | ||
| 22387 | 0 2) | ||
| 22385 | (cl-subseq time 0 2))))) | 22388 | (cl-subseq time 0 2))))) |
| 22386 | 22389 | ||
| 22387 | (defun org-compile-file (source process ext &optional err-msg log-buf spec) | 22390 | (defun org-compile-file (source process ext &optional err-msg log-buf spec) |
diff --git a/lisp/org/ox-html.el b/lisp/org/ox-html.el index 39f7d83e14a..6166a4ad019 100644 --- a/lisp/org/ox-html.el +++ b/lisp/org/ox-html.el | |||
| @@ -1935,7 +1935,8 @@ INFO is a plist used as a communication channel." | |||
| 1935 | (?c . ,(plist-get info :creator)) | 1935 | (?c . ,(plist-get info :creator)) |
| 1936 | (?C . ,(let ((file (plist-get info :input-file))) | 1936 | (?C . ,(let ((file (plist-get info :input-file))) |
| 1937 | (format-time-string timestamp-format | 1937 | (format-time-string timestamp-format |
| 1938 | (and file (nth 5 (file-attributes file)))))) | 1938 | (and file (file-attribute-modification-time |
| 1939 | (file-attributes file)))))) | ||
| 1939 | (?v . ,(or (plist-get info :html-validation-link) ""))))) | 1940 | (?v . ,(or (plist-get info :html-validation-link) ""))))) |
| 1940 | 1941 | ||
| 1941 | (defun org-html--build-pre/postamble (type info) | 1942 | (defun org-html--build-pre/postamble (type info) |
diff --git a/lisp/org/ox-publish.el b/lisp/org/ox-publish.el index ba5a0232e42..80ef239b679 100644 --- a/lisp/org/ox-publish.el +++ b/lisp/org/ox-publish.el | |||
| @@ -879,7 +879,8 @@ If FILE is an Org file and provides a DATE keyword use it. In | |||
| 879 | any other case use the file system's modification time. Return | 879 | any other case use the file system's modification time. Return |
| 880 | time in `current-time' format." | 880 | time in `current-time' format." |
| 881 | (let ((file (org-publish--expand-file-name file project))) | 881 | (let ((file (org-publish--expand-file-name file project))) |
| 882 | (if (file-directory-p file) (nth 5 (file-attributes file)) | 882 | (if (file-directory-p file) (file-attribute-modification-time |
| 883 | (file-attributes file)) | ||
| 883 | (let ((date (org-publish-find-property file :date project))) | 884 | (let ((date (org-publish-find-property file :date project))) |
| 884 | ;; DATE is a secondary string. If it contains a time-stamp, | 885 | ;; DATE is a secondary string. If it contains a time-stamp, |
| 885 | ;; convert it to internal format. Otherwise, use FILE | 886 | ;; convert it to internal format. Otherwise, use FILE |
| @@ -889,7 +890,8 @@ time in `current-time' format." | |||
| 889 | (let ((value (org-element-interpret-data ts))) | 890 | (let ((value (org-element-interpret-data ts))) |
| 890 | (and (org-string-nw-p value) | 891 | (and (org-string-nw-p value) |
| 891 | (org-time-string-to-time value)))))) | 892 | (org-time-string-to-time value)))))) |
| 892 | ((file-exists-p file) (nth 5 (file-attributes file))) | 893 | ((file-exists-p file) (file-attribute-modification-time |
| 894 | (file-attributes file))) | ||
| 893 | (t (error "No such file: \"%s\"" file))))))) | 895 | (t (error "No such file: \"%s\"" file))))))) |
| 894 | 896 | ||
| 895 | (defun org-publish-sitemap-default-entry (entry style project) | 897 | (defun org-publish-sitemap-default-entry (entry style project) |
| @@ -1348,8 +1350,7 @@ does not exist." | |||
| 1348 | (expand-file-name (or (file-symlink-p file) file) | 1350 | (expand-file-name (or (file-symlink-p file) file) |
| 1349 | (file-name-directory file))))) | 1351 | (file-name-directory file))))) |
| 1350 | (if (not attr) (error "No such file: \"%s\"" file) | 1352 | (if (not attr) (error "No such file: \"%s\"" file) |
| 1351 | (+ (ash (car (nth 5 attr)) 16) | 1353 | (floor (float-time (file-attribute-modification-time attr)))))) |
| 1352 | (cadr (nth 5 attr)))))) | ||
| 1353 | 1354 | ||
| 1354 | 1355 | ||
| 1355 | (provide 'ox-publish) | 1356 | (provide 'ox-publish) |