aboutsummaryrefslogtreecommitdiffstats
path: root/lisp/org
diff options
context:
space:
mode:
authorPaul Eggert2018-09-23 18:30:46 -0700
committerPaul Eggert2018-09-23 18:32:59 -0700
commit662bee7d70ccd3903e123b08c7ec9108a1a2ce0b (patch)
tree416de288b7f995a05f620c5a6e72cb5a30168551 /lisp/org
parentc2dee17e19e1cf80c2263f8de276cceb0252b76d (diff)
downloademacs-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.el2
-rw-r--r--lisp/org/org-attach.el2
-rw-r--r--lisp/org/org-macro.el3
-rw-r--r--lisp/org/org.el9
-rw-r--r--lisp/org/ox-html.el3
-rw-r--r--lisp/org/ox-publish.el9
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
879any other case use the file system's modification time. Return 879any other case use the file system's modification time. Return
880time in `current-time' format." 880time 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)