]> git.eshelyaron.com Git - emacs.git/commitdiff
`decoded-time-set-defaults' refactored out from iso8601 code
authorLars Ingebrigtsen <larsi@gnus.org>
Tue, 30 Jul 2019 14:46:10 +0000 (16:46 +0200)
committerLars Ingebrigtsen <larsi@gnus.org>
Wed, 31 Jul 2019 19:47:29 +0000 (21:47 +0200)
* lisp/calendar/iso8601.el (iso8601--encode-time):
* lisp/calendar/time-date.el (decoded-time-set-defaults):
Refactor out from `iso8601--encode-time', because it's helpful
in other contexts.

etc/NEWS
lisp/calendar/iso8601.el
lisp/calendar/time-date.el

index 7dfb08256f26531efd2c11e706642a4b753ea2ae..486e677539db0f50cf6868c96bf9e692f62eb905 100644 (file)
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -2102,13 +2102,13 @@ with POSIX.1-2017.
 'decoded-time-weekday', 'decoded-time-dst' and 'decoded-time-zone'
 accessors can be used.
 
-+++
 *** The new functions 'date-days-in-month' (which will say how many
 days there are in a month in a specific year), 'date-ordinal-to-time'
 (that computes the date of an ordinal day), 'decoded-time-add' for
-doing computations on a decoded time structure), and
-'make-decoded-time' (for making a decoded time structure with only the
-given keywords filled out) have been added.
+doing computations on a decoded time structure), 'make-decoded-time'
+(for making a decoded time structure with only the given keywords
+filled out), and 'encoded-time-set-defaults' (which fills in nil
+elements as if it's midnight January 1st, 1970) have been added.
 
 ** 'define-minor-mode' automatically documents the meaning of ARG.
 
index ab0077ac58da651c668fff0c1a57f58480d2d71f..c69156cbeb68e5febb085fa91adec84af0e06552 100644 (file)
@@ -349,21 +349,7 @@ Return the number of minutes."
 
 (defun iso8601--encode-time (time)
   "Like `encode-time', but fill in nil values in TIME."
-  (setq time (copy-sequence time))
-  (unless (decoded-time-second time)
-    (setf (decoded-time-second time) 0))
-  (unless (decoded-time-minute time)
-    (setf (decoded-time-minute time) 0))
-  (unless (decoded-time-hour time)
-    (setf (decoded-time-hour time) 0))
-
-  (unless (decoded-time-day time)
-    (setf (decoded-time-day time) 1))
-  (unless (decoded-time-month time)
-    (setf (decoded-time-month time) 1))
-  (unless (decoded-time-year time)
-    (setf (decoded-time-year time) 0))
-  (encode-time time))
+  (encode-time (decoded-time-set-defaults (copy-sequence time))))
 
 (provide 'iso8601)
 
index e195f71c58af4f015429a4e02ff50c4611ff805f..f14478e67cc5a888db72c34e133cb7289de7b27e 100644 (file)
@@ -498,6 +498,26 @@ changes in daylight saving time are not taken into account."
   "Return a `decoded-time' structure with only the keywords given filled out."
   (list second minute hour day month year nil dst zone))
 
+(defun decoded-time-set-defaults (time)
+  "Set any nil values in `decoded-time' TIME to default values.
+The default value is based on January 1st, 1970 at midnight.
+
+TIME is modified and returned."
+  (unless (decoded-time-second time)
+    (setf (decoded-time-second time) 0))
+  (unless (decoded-time-minute time)
+    (setf (decoded-time-minute time) 0))
+  (unless (decoded-time-hour time)
+    (setf (decoded-time-hour time) 0))
+
+  (unless (decoded-time-day time)
+    (setf (decoded-time-day time) 1))
+  (unless (decoded-time-month time)
+    (setf (decoded-time-month time) 1))
+  (unless (decoded-time-year time)
+    (setf (decoded-time-year time) 0))
+  time)
+
 (provide 'time-date)
 
 ;;; time-date.el ends here