|
@@ -67,12 +67,16 @@ A nil value means, clock will keep running until stopped explicitly with
|
|
|
|
|
|
(defcustom org-clock-in-switch-to-state nil
|
|
|
"Set task to a special todo state while clocking it.
|
|
|
-The value should be the state to which the entry should be switched."
|
|
|
+The value should be the state to which the entry should be
|
|
|
+switched. If the value is a function, it must take one
|
|
|
+parameter (the current TODO state of the item) and return the
|
|
|
+state to switch it to."
|
|
|
:group 'org-clock
|
|
|
:group 'org-todo
|
|
|
:type '(choice
|
|
|
(const :tag "Don't force a state" nil)
|
|
|
- (string :tag "State")))
|
|
|
+ (string :tag "State")
|
|
|
+ (symbol :tag "Function")))
|
|
|
|
|
|
(defcustom org-clock-history-length 5
|
|
|
"Number of clock tasks to remember in history."
|
|
@@ -265,12 +269,16 @@ the clocking selection, associated with the letter `d'."
|
|
|
(org-back-to-heading t)
|
|
|
(or interrupting (move-marker org-clock-interrupted-task nil))
|
|
|
(org-clock-history-push)
|
|
|
- (when (and org-clock-in-switch-to-state
|
|
|
- (not (looking-at (concat outline-regexp "[ \t]*"
|
|
|
- org-clock-in-switch-to-state
|
|
|
- "\\>"))))
|
|
|
- (org-todo org-clock-in-switch-to-state))
|
|
|
- (setq org-clock-heading-for-remember
|
|
|
+ (cond ((functionp org-clock-in-switch-to-state)
|
|
|
+ (looking-at org-complex-heading-regexp)
|
|
|
+ (let ((newstate (funcall org-clock-in-switch-to-state (match-string 2))))
|
|
|
+ (if newstate (org-todo newstate))))
|
|
|
+ ((and org-clock-in-switch-to-state
|
|
|
+ (not (looking-at (concat outline-regexp "[ \t]*"
|
|
|
+ org-clock-in-switch-to-state
|
|
|
+ "\\>"))))
|
|
|
+ (org-todo org-clock-in-switch-to-state)))
|
|
|
+ (setq org-clock-heading-for-remember
|
|
|
(and (looking-at org-complex-heading-regexp)
|
|
|
(match-end 4)
|
|
|
(org-trim (buffer-substring (match-end 1) (match-end 4)))))
|
|
@@ -283,9 +291,9 @@ the clocking selection, associated with the letter `d'."
|
|
|
(t "???")))
|
|
|
(setq org-clock-heading (org-propertize org-clock-heading 'face nil))
|
|
|
(org-clock-find-position)
|
|
|
-
|
|
|
+
|
|
|
(insert "\n") (backward-char 1)
|
|
|
- (indent-relative)
|
|
|
+ (org-indent-line-function)
|
|
|
(insert org-clock-string " ")
|
|
|
(setq org-clock-start-time (current-time))
|
|
|
(setq ts (org-insert-time-stamp (current-time) 'with-hm 'inactive))
|
|
@@ -348,11 +356,12 @@ the clocking selection, associated with the letter `d'."
|
|
|
(or (bolp) (newline)))
|
|
|
(when (eq t org-clock-into-drawer)
|
|
|
(insert ":CLOCK:\n:END:\n")
|
|
|
- (beginning-of-line -1)
|
|
|
+ (beginning-of-line 0)
|
|
|
(org-indent-line-function)
|
|
|
+ (beginning-of-line 0)
|
|
|
(org-flag-drawer t)
|
|
|
- (beginning-of-line 2)
|
|
|
- (org-indent-line-function)))))
|
|
|
+ (org-indent-line-function)
|
|
|
+ (beginning-of-line 2)))))
|
|
|
|
|
|
(defun org-clock-out (&optional fail-quietly)
|
|
|
"Stop the currently running clock.
|