فهرست منبع

Option for clock and timer to be displayed in frame-title

* org-clock.el: New option `org-clock-clocked-in-display' to control
whether the current clock is displayed in the mode line and/or frame
title.

* org-timer.el: New option `org-timer-display' to control whether
the current timer is displayed in the mode line and/or frame title.

This allows the clock and timer to be displayed in the frame title instead of,
or as well as, the mode line.  This is useful for people with limited space in
the mode line but with ample space in the frame title.
George Kettleborough 13 سال پیش
والد
کامیت
37fafb7b9e
2فایلهای تغییر یافته به همراه86 افزوده شده و 16 حذف شده
  1. 44 8
      lisp/org-clock.el
  2. 42 8
      lisp/org-timer.el

+ 44 - 8
lisp/org-clock.el

@@ -330,6 +330,22 @@ play with them."
   :version "24.1"
   :version "24.1"
   :type 'boolean)
   :type 'boolean)
 
 
+(defcustom org-clock-clocked-in-display 'mode-line
+  "When clocked in for a task, org-mode can display the current
+task and accumulated time in the mode line and/or frame title.
+Allowed values are:
+
+both         displays in both mode line and frame title
+mode-line    displays only in mode line (default)
+frame-title  displays only in frame title
+nil          current clock is not displayed"
+  :group 'org-clock
+  :type '(choice
+	  (const :tag "Mode line" mode-line)
+	  (const :tag "Frame title" frame-title)
+	  (const :tag "Both" both)
+	  (const :tag "None" nil)))
+
 (defvar org-clock-in-prepare-hook nil
 (defvar org-clock-in-prepare-hook nil
   "Hook run when preparing the clock.
   "Hook run when preparing the clock.
 This hook is run before anything happens to the task that
 This hook is run before anything happens to the task that
@@ -352,6 +368,8 @@ to add an effort property.")
 (defvar org-mode-line-string "")
 (defvar org-mode-line-string "")
 (put 'org-mode-line-string 'risky-local-variable t)
 (put 'org-mode-line-string 'risky-local-variable t)
 
 
+(defvar org-frame-title-string '(" " org-mode-line-string))
+
 (defvar org-clock-mode-line-timer nil)
 (defvar org-clock-mode-line-timer nil)
 (defvar org-clock-idle-timer nil)
 (defvar org-clock-idle-timer nil)
 (defvar org-clock-heading) ; defined in org.el
 (defvar org-clock-heading) ; defined in org.el
@@ -1176,18 +1194,28 @@ the clocking selection, associated with the letter `d'."
 			 (save-excursion (org-back-to-heading t) (point))
 			 (save-excursion (org-back-to-heading t) (point))
 			 (buffer-base-buffer))
 			 (buffer-base-buffer))
 	    (setq org-clock-has-been-used t)
 	    (setq org-clock-has-been-used t)
-	    (or global-mode-string (setq global-mode-string '("")))
-	    (or (memq 'org-mode-line-string global-mode-string)
-		(setq global-mode-string
-		      (append global-mode-string '(org-mode-line-string))))
+	    ;; add to mode line
+	    (when (or (eq org-clock-clocked-in-display 'mode-line)
+		      (eq org-clock-clocked-in-display 'both))
+	      (or global-mode-string (setq global-mode-string '("")))
+	      (or (memq 'org-mode-line-string global-mode-string)
+		  (setq global-mode-string
+			(append global-mode-string '(org-mode-line-string)))))
+	    ;; add to frame title
+	    (when (or (eq org-clock-clocked-in-display 'frame-title)
+		      (eq org-clock-clocked-in-display 'both))
+	      (or (memq 'org-frame-title-string frame-title-format)
+		  (setq frame-title-format
+			(append frame-title-format '(org-frame-title-string)))))
 	    (org-clock-update-mode-line)
 	    (org-clock-update-mode-line)
 	    (when org-clock-mode-line-timer
 	    (when org-clock-mode-line-timer
 	      (cancel-timer org-clock-mode-line-timer)
 	      (cancel-timer org-clock-mode-line-timer)
 	      (setq org-clock-mode-line-timer nil))
 	      (setq org-clock-mode-line-timer nil))
-	    (setq org-clock-mode-line-timer
-		  (run-with-timer org-clock-update-period
-				  org-clock-update-period
-				  'org-clock-update-mode-line))
+	    (when org-clock-clocked-in-display
+	      (setq org-clock-mode-line-timer
+		    (run-with-timer org-clock-update-period
+				    org-clock-update-period
+				    'org-clock-update-mode-line)))
 	    (when org-clock-idle-timer
 	    (when org-clock-idle-timer
 	      (cancel-timer org-clock-idle-timer)
 	      (cancel-timer org-clock-idle-timer)
 	      (setq org-clock-idle-timer nil))
 	      (setq org-clock-idle-timer nil))
@@ -1335,6 +1363,8 @@ If there is no running clock, throw an error, unless FAIL-QUIETLY is set."
     (when (not (org-clocking-p))
     (when (not (org-clocking-p))
       (setq global-mode-string
       (setq global-mode-string
 	    (delq 'org-mode-line-string global-mode-string))
 	    (delq 'org-mode-line-string global-mode-string))
+      (setq frame-title-format
+	    (delq 'org-frame-title-string frame-title-format))
       (force-mode-line-update)
       (force-mode-line-update)
       (if fail-quietly (throw 'exit t) (error "No active clock")))
       (if fail-quietly (throw 'exit t) (error "No active clock")))
     (let (ts te s h m remove)
     (let (ts te s h m remove)
@@ -1379,6 +1409,8 @@ If there is no running clock, throw an error, unless FAIL-QUIETLY is set."
 	    (setq org-clock-idle-timer nil))
 	    (setq org-clock-idle-timer nil))
 	  (setq global-mode-string
 	  (setq global-mode-string
 		(delq 'org-mode-line-string global-mode-string))
 		(delq 'org-mode-line-string global-mode-string))
+	  (setq frame-title-format
+		(delq 'org-frame-title-string frame-title-format))
 	  (when org-clock-out-switch-to-state
 	  (when org-clock-out-switch-to-state
 	    (save-excursion
 	    (save-excursion
 	      (org-back-to-heading t)
 	      (org-back-to-heading t)
@@ -1478,6 +1510,8 @@ UPDOWN tells whether to change 'up or 'down."
   (when (not (org-clocking-p))
   (when (not (org-clocking-p))
     (setq global-mode-string
     (setq global-mode-string
          (delq 'org-mode-line-string global-mode-string))
          (delq 'org-mode-line-string global-mode-string))
+    (setq frame-title-format
+	  (delq 'org-frame-title-string frame-title-format))
     (force-mode-line-update)
     (force-mode-line-update)
     (error "No active clock"))
     (error "No active clock"))
   (save-excursion ; Do not replace this with `with-current-buffer'.
   (save-excursion ; Do not replace this with `with-current-buffer'.
@@ -1490,6 +1524,8 @@ UPDOWN tells whether to change 'up or 'down."
   (move-marker org-clock-hd-marker nil)
   (move-marker org-clock-hd-marker nil)
   (setq global-mode-string
   (setq global-mode-string
 	(delq 'org-mode-line-string global-mode-string))
 	(delq 'org-mode-line-string global-mode-string))
+  (setq frame-title-format
+	(delq 'org-frame-title-string frame-title-format))
   (force-mode-line-update)
   (force-mode-line-update)
   (message "Clock canceled")
   (message "Clock canceled")
   (run-hooks 'org-clock-cancel-hook))
   (run-hooks 'org-clock-cancel-hook))

+ 42 - 8
lisp/org-timer.el

@@ -56,6 +56,22 @@ When 0, the user is prompted for a value."
   :version "24.1"
   :version "24.1"
   :type 'number)
   :type 'number)
 
 
+(defcustom org-timer-display 'mode-line
+  "When a timer is running, org-mode can display it in the mode
+line and/or frame title.
+Allowed values are:
+
+both         displays in both mode line and frame title
+mode-line    displays only in mode line (default)
+frame-title  displays only in frame title
+nil          current timer is not displayed"
+  :group 'org-time
+  :type '(choice
+	  (const :tag "Mode line" mode-line)
+	  (const :tag "Frame title" frame-title)
+	  (const :tag "Both" both)
+	  (const :tag "None" nil)))
+
 (defvar org-timer-start-hook nil
 (defvar org-timer-start-hook nil
   "Hook run after relative timer is started.")
   "Hook run after relative timer is started.")
 
 
@@ -270,10 +286,17 @@ If the integer is negative, the string will start with \"-\"."
 (defun org-timer-set-mode-line (value)
 (defun org-timer-set-mode-line (value)
   "Set the mode-line display of the relative timer.
   "Set the mode-line display of the relative timer.
 VALUE can be `on', `off', or `pause'."
 VALUE can be `on', `off', or `pause'."
-  (or global-mode-string (setq global-mode-string '("")))
-  (or (memq 'org-timer-mode-line-string global-mode-string)
-      (setq global-mode-string
-	    (append global-mode-string '(org-timer-mode-line-string))))
+  (when (or (eq org-timer-display 'mode-line)
+	    (eq org-timer-display 'both))
+    (or global-mode-string (setq global-mode-string '("")))
+    (or (memq 'org-timer-mode-line-string global-mode-string)
+	(setq global-mode-string
+	      (append global-mode-string '(org-timer-mode-line-string)))))
+  (when (or (eq org-timer-display 'frame-title)
+	     (eq org-timer-display 'both))
+    (or (memq 'org-timer-mode-line-string frame-title-format)
+	(setq frame-title-format
+	      (append frame-title-format '(org-timer-mode-line-string)))))
   (cond
   (cond
    ((equal value 'off)
    ((equal value 'off)
     (when org-timer-mode-line-timer
     (when org-timer-mode-line-timer
@@ -281,21 +304,32 @@ VALUE can be `on', `off', or `pause'."
       (setq org-timer-mode-line-timer nil))
       (setq org-timer-mode-line-timer nil))
     (setq global-mode-string
     (setq global-mode-string
 	  (delq 'org-timer-mode-line-string global-mode-string))
 	  (delq 'org-timer-mode-line-string global-mode-string))
+    (setq frame-title-format
+	  (delq 'org-timer-mode-line-string frame-title-format))
     (force-mode-line-update))
     (force-mode-line-update))
    ((equal value 'pause)
    ((equal value 'pause)
     (when org-timer-mode-line-timer
     (when org-timer-mode-line-timer
       (cancel-timer org-timer-mode-line-timer)
       (cancel-timer org-timer-mode-line-timer)
       (setq org-timer-mode-line-timer nil)))
       (setq org-timer-mode-line-timer nil)))
    ((equal value 'on)
    ((equal value 'on)
+  (when (or (eq org-timer-display 'mode-line)
+	    (eq org-timer-display 'both))
     (or global-mode-string (setq global-mode-string '("")))
     (or global-mode-string (setq global-mode-string '("")))
     (or (memq 'org-timer-mode-line-string global-mode-string)
     (or (memq 'org-timer-mode-line-string global-mode-string)
 	(setq global-mode-string
 	(setq global-mode-string
-	      (append global-mode-string '(org-timer-mode-line-string))))
+	      (append global-mode-string '(org-timer-mode-line-string)))))
+  (when (or (eq org-timer-display 'frame-title)
+	    (eq org-timer-display 'both))
+    (or (memq 'org-timer-mode-line-string frame-title-format)
+	(setq frame-title-format
+	      (append frame-title-format '(org-timer-mode-line-string)))))
     (org-timer-update-mode-line)
     (org-timer-update-mode-line)
     (when org-timer-mode-line-timer
     (when org-timer-mode-line-timer
-      (cancel-timer org-timer-mode-line-timer))
-    (setq org-timer-mode-line-timer
-	  (run-with-timer 1 1 'org-timer-update-mode-line)))))
+      (cancel-timer org-timer-mode-line-timer)
+      (setq org-timer-mode-line-timer nil))
+    (when org-timer-display
+      (setq org-timer-mode-line-timer
+	    (run-with-timer 1 1 'org-timer-update-mode-line))))))
 
 
 (defun org-timer-update-mode-line ()
 (defun org-timer-update-mode-line ()
   "Update the timer time in the mode line."
   "Update the timer time in the mode line."