Mercurial > emacs
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)