diff options
author | Stefan Monnier <monnier@iro.umontreal.ca> | 2023-08-30 23:10:04 -0400 |
---|---|---|
committer | marty hiatt <martianhiatus [a t] riseup [d o t] net> | 2023-09-21 11:29:32 +0200 |
commit | 52ef7089a73c0408e74eb8fd384af3e275e4aff6 (patch) | |
tree | 3c1befb1f95ec4978c8a80664d596b4cd6fb18cb /lisp | |
parent | 40aa02fb06692fab20f75e7314eecdf0ef638a63 (diff) |
(mastodon-tl--relative-time-details): Use `mastodon-tl--human-duration`
* lisp/mastodon-tl.el (mastodon-tl--human-duration): Cap the
finest resolution and return a pair to include the resolution used.
(mastodon-tl--format-poll-expiry): Adjust accordingly.
(mastodon-tl--relative-time-details): Rewrite using
`mastodon-tl--human-duration`.
Diffstat (limited to 'lisp')
-rw-r--r-- | lisp/mastodon-tl.el | 92 |
1 files changed, 38 insertions, 54 deletions
diff --git a/lisp/mastodon-tl.el b/lisp/mastodon-tl.el index c921ba9..715884b 100644 --- a/lisp/mastodon-tl.el +++ b/lisp/mastodon-tl.el @@ -702,57 +702,18 @@ this just means displaying toot client." ;;; TIMESTAMPS (defun mastodon-tl--relative-time-details (timestamp &optional current-time) - "Return cons of (descriptive string . next change) for the TIMESTAMP. + "Return cons of (DESCRIPTIVE STRING . NEXT-CHANGE) for the TIMESTAMP. Use the optional CURRENT-TIME as the current time (only used for reliable testing). The descriptive string is a human readable version relative to the current time while the next change timestamp give the first time that this description will change in the future. TIMESTAMP is assumed to be in the past." - ;; FIXME: Use `mastodon-tl--human-duration'! - (let* ((now (or current-time (current-time))) - (time-difference (time-subtract now timestamp)) + (let* ((time-difference (time-subtract current-time timestamp)) (seconds-difference (float-time time-difference)) - (regular-response - (lambda (seconds-difference multiplier unit-name) - (let ((n (floor (+ 0.5 (/ seconds-difference multiplier))))) - (cons (format "%d %ss ago" n unit-name) - (* (+ 0.5 n) multiplier))))) - (relative-result - (cond - ((< seconds-difference 60) - (cons "just now" - 60)) - ((< seconds-difference (* 1.5 60)) - (cons "1 minute ago" - 90)) ;; at 90 secs - ((< seconds-difference (* 60 59.5)) - (funcall regular-response seconds-difference 60 "minute")) - ((< seconds-difference (* 1.5 60 60)) - (cons "1 hour ago" - (* 60 90))) ;; at 90 minutes - ((< seconds-difference (* 60 60 23.5)) - (funcall regular-response seconds-difference (* 60 60) "hour")) - ((< seconds-difference (* 1.5 60 60 24)) - (cons "1 day ago" - (* 1.5 60 60 24))) ;; at a day and a half - ((< seconds-difference (* 60 60 24 6.5)) - (funcall regular-response seconds-difference (* 60 60 24) "day")) - ((< seconds-difference (* 1.5 60 60 24 7)) - (cons "1 week ago" - (* 1.5 60 60 24 7))) ;; a week and a half - ((< seconds-difference (* 60 60 24 7 52)) - (if (= 52 (floor (+ 0.5 (/ seconds-difference 60 60 24 7)))) - (cons "52 weeks ago" - (* 60 60 24 7 52)) - (funcall regular-response seconds-difference (* 60 60 24 7) "week"))) - ((< seconds-difference (* 1.5 60 60 24 365)) - (cons "1 year ago" - (* 60 60 24 365 1.5))) ;; a year and a half - (t - (funcall regular-response seconds-difference (* 60 60 24 365.25) "year"))))) - (cons (car relative-result) - (time-add timestamp (seconds-to-time (cdr relative-result)))))) + (tmp (mastodon-tl--human-duration (max 0 seconds-difference)))) + (cons (concat (car tmp) " ago") + (time-add current-time (cdr tmp))))) (defun mastodon-tl--relative-time-description (timestamp &optional current-time) "Return a string with a human readable TIMESTAMP relative to the current time. @@ -1159,27 +1120,50 @@ LONGEST-OPTION is the option whose length determines the formatting." ;; FIXME: Could we document the format of TIMESTAMP here? (let* ((ts (encode-time (parse-time-string timestamp))) (seconds (time-to-seconds (time-subtract ts nil)))) - (concat (mastodon-tl--human-duration (max 0 seconds)) " left"))) - -(defun mastodon-tl--human-duration (seconds) - "Return a string describing SECONDS in a more human-friendly way." + ;; FIXME: Use the `cdr' to update poll expiry times? + (concat (car (mastodon-tl--human-duration (max 0 seconds))) " left"))) + +(defun mastodon-tl--human-duration (seconds &optional resolution) + "Return a string describing SECONDS in a more human-friendly way. +The return format is (STRING . RES) where RES is the resolution of +this string, in seconds. +RESOLUTION is the finest resolution, in seconds, to use for the +second part of the output (defaults to 60, so that seconds are only +displayed when the duration is smaller than a minute)." (cl-assert (>= seconds 0)) + (unless resolution (setq resolution 60)) (let* ((units mastodon-tl--time-units) - (n1 seconds) (unit1 (pop units)) n2 unit2 + (n1 seconds) (unit1 (pop units)) (res1 1) + n2 unit2 res2 next) (while (and units (> (truncate (setq next (/ n1 (car units)))) 0)) (setq unit2 unit1) + (setq res2 res1) (setq n2 (- n1 (* (car units) (truncate n1 (car units))))) (setq n1 next) + (setq res1 (truncate (* res1 (car units)))) (pop units) (setq unit1 (pop units))) (setq n1 (truncate n1)) (if n2 (setq n2 (truncate n2))) - (if (memq n2 '(nil 0)) - (format "%d %s%s" n1 unit1 (if (> n1 1) "s" "")) - (format "%d %s%s, %d %s%s" - n1 unit1 (if (> n1 1) "s" "") - n2 unit2 (if (> n2 1) "s" ""))))) + (cond + ((null n2) + (cons (format "%d %s%s" n1 unit1 (if (> n1 1) "s" "")) + (max resolution res1))) + ((< (* res2 n2) resolution) + (cons (format "%d %s%s" n1 unit1 (if (> n1 1) "s" "")) + (max resolution res2))) + ((< res2 resolution) + (let ((n2 (/ (* resolution (/ (* n2 res2) resolution)) res2))) + (cons (format "%d %s%s, %d %s%s" + n1 unit1 (if (> n1 1) "s" "") + n2 unit2 (if (> n2 1) "s" "")) + resolution))) + (t + (cons (format "%d %s%s, %d %s%s" + n1 unit1 (if (> n1 1) "s" "") + n2 unit2 (if (> n2 1) "s" "")) + (max res2 resolution)))))) (defun mastodon-tl--read-poll-option () "Read a poll option to vote on a poll." |