changeset 14638:46556543f4e6

(display-time-update): New subroutine broken out from display-time-event-handler. (display-time): Add hook to rmail-get-new-mail-hook.
author Karl Heuer <kwzh@gnu.org>
date Wed, 21 Feb 1996 21:33:35 +0000
parents 89952d6af6c2
children 4c778d943271
files lisp/time.el
diffstat 1 files changed, 13 insertions(+), 4 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/time.el	Wed Feb 21 21:33:12 1996 +0000
+++ b/lisp/time.el	Wed Feb 21 21:33:35 1996 +0000
@@ -74,7 +74,9 @@
 	    (append global-mode-string '(display-time-string))))
   (timer-set-time display-time-timer (current-time) display-time-interval)
   (timer-set-function display-time-timer 'display-time-event-handler)
-  (timer-activate display-time-timer))
+  (timer-activate display-time-timer)
+  ;; When you get new mail, clear "Mail" from the mode line.
+  (add-hook 'rmail-get-new-mail-hook 'display-time-event-handler))
 
 (defvar display-time-string-forms
   '((if display-time-day-and-date
@@ -102,6 +104,15 @@
 would give mode line times like `94/12/30 21:07:48 (UTC)'.")
 
 (defun display-time-event-handler ()
+  (display-time-update)
+  ;; Do redisplay right now, if no input pending.
+  (sit-for 0))
+
+;; Update the display-time info for the mode line
+;; but don't redisplay right now.  This is used for
+;; things like Rmail `g' that want to force an update
+;; which can wait for the next redisplay.
+(defun display-time-update ()
   (let* ((now (current-time))
 	 (time (current-time-string now))
          (load (condition-case ()
@@ -152,9 +163,7 @@
     ;; This is inside the let binding, but we are not going to document
     ;; what variables are available.
     (run-hooks 'display-time-hook))
-  (force-mode-line-update)
-  ;; Do redisplay right now, if no input pending.
-  (sit-for 0))
+  (force-mode-line-update))
 
 (defun display-time-file-nonempty-p (file)
   (and (file-exists-p file)