]> git.eshelyaron.com Git - emacs.git/commitdiff
Enable showing local time and lapsed time in Gnus
authorAdam Sjøgren <asjo@koldfront.dk>
Sat, 20 Jul 2019 13:02:22 +0000 (15:02 +0200)
committerLars Ingebrigtsen <larsi@gnus.org>
Sat, 20 Jul 2019 13:02:22 +0000 (15:02 +0200)
* lisp/gnus/gnus-art.el (article-make-date-combine-with-lapsed) factor
code out into new function, used for providing both combined-lapsed
and combined-local-lapsed.

doc/misc/gnus.texi
etc/NEWS
lisp/gnus/gnus-art.el

index 7c5bc3eee855f4701891e1de3addb3c2ec5ca2ed..f688e84e7e89df6bd2b759bccf6c73f68cce901d 100644 (file)
@@ -12040,6 +12040,10 @@ The time elapsed since the message was posted.
 @item combined-lapsed
 Both the original date header and a (shortened) elapsed time.
 
+@item combined-local-lapsed
+Both the time in the user's local time zone a (shortened) elapsed
+time.
+
 @item original
 The original date header.
 
index 9b7cfd7bb7e8f2fffb4ad4769c290229f529347e..d0a9c031e94b7fe6f00ad183e0a245573fa6c5a6 100644 (file)
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -923,6 +923,10 @@ Of course it will still find it if you have it in '~/.ecompleterc'.
 
 ** Gnus
 
+*** There's a new value for `gnus-article-date-headers',
+`combined-local-lapsed', which will show both the time (in the local
+timezone) and the lapsed time.
+
 ---
 *** Gnus now maps imaps to 993 only on old MS-Windows versions.
 The nnimap backend used to do this unconditionally to work around
index 42e1a821b90acdcb5545c8db60feb076ec987a81..65e1c8106d5ea16217d510f2ef07c6a33fd755d6 100644 (file)
@@ -999,6 +999,7 @@ on parts -- for instance, adding Vcard info to a database."
 Valid formats are `ut' (Universal Time), `local' (local time
 zone), `english' (readable English), `lapsed' (elapsed time),
 `combined-lapsed' (both the original date and the elapsed time),
+`combined-local-lapsed' (both the local time and the elapsed time),
 `original' (the original date header), `iso8601' (ISO8601
 format), and `user-defined' (a user-defined format defined by the
 `gnus-article-time-format' variable).
@@ -1014,6 +1015,7 @@ Some of these headers are updated automatically.  See
          (const :tag "Readable English" english)
          (const :tag "Elapsed time" lapsed)
          (const :tag "Original and elapsed time" combined-lapsed)
+         (const :tag "Local and elapsed time" combined-local-lapsed)
          (const :tag "Original date header" original)
          (const :tag "ISO8601 format" iso8601)
          (const :tag "User-defined" user-defined)))
@@ -3528,10 +3530,28 @@ possible values."
            (put-text-property (match-beginning 1) (match-end 1)
                               'face eface)))))))
 
+(defun article-make-date-combine-with-lapsed (date time type)
+  "Return type of date with lapsed time added."
+  (let ((date-string (article-make-date-line date type))
+       (segments 3)
+       lapsed-string)
+    (while (and
+            time
+           (setq lapsed-string
+                 (concat " (" (article-lapsed-string time segments) ")"))
+           (> (+ (length date-string)
+                 (length lapsed-string))
+              (+ fill-column 6))
+           (> segments 0))
+      (setq segments (1- segments)))
+    (if (> segments 0)
+       (concat date-string lapsed-string)
+      date-string)))
+
 (defun article-make-date-line (date type)
   "Return a DATE line of TYPE."
   (unless (memq type '(local ut original user-defined iso8601 lapsed english
-                            combined-lapsed))
+                            combined-lapsed combined-local-lapsed))
     (error "Unknown conversion type: %s" type))
   (condition-case ()
       (let ((time (ignore-errors (date-to-time date))))
@@ -3569,21 +3589,10 @@ possible values."
          (concat "Date: " (article-lapsed-string time)))
         ;; A combined date/lapsed format.
         ((eq type 'combined-lapsed)
-         (let ((date-string (article-make-date-line date 'original))
-               (segments 3)
-               lapsed-string)
-           (while (and
-                    time
-                   (setq lapsed-string
-                         (concat " (" (article-lapsed-string time segments) ")"))
-                   (> (+ (length date-string)
-                         (length lapsed-string))
-                      (+ fill-column 6))
-                   (> segments 0))
-             (setq segments (1- segments)))
-           (if (> segments 0)
-               (concat date-string lapsed-string)
-             date-string)))
+          (article-make-date-combine-with-lapsed date time 'original))
+         ;; A combined local/lapsed format.
+         ((eq type 'combined-local-lapsed)
+          (article-make-date-combine-with-lapsed date time 'local))
         ;; Display the date in proper English
         ((eq type 'english)
          (let ((dtime (decode-time time)))