* [PATCH 1/2] Allow org-clock-in-switch-to-state to be a function.
@ 2008-10-16 14:51 James TD Smith
2008-10-16 14:51 ` [PATCH 2/2] Make drawer skipping for note insertion more sensible James TD Smith
2008-10-16 17:16 ` [PATCH 1/2] Allow org-clock-in-switch-to-state to be a function Carsten Dominik
0 siblings, 2 replies; 4+ messages in thread
From: James TD Smith @ 2008-10-16 14:51 UTC (permalink / raw)
To: emacs-orgmode
Allow org-clock-in-switch-to-state to be a function. This lets you have
different clocked in states for different TODO keyword sets, for example
(defun ahkt-clock-state (state)
(cond ((string= state "TOREAD") "READING")
((string= state "TOWATCH") "WATCHING")
(t state)))
Also fix indentation on clock lines, and empty clock drawers when they are
inserted.
---
lisp/ChangeLog | 14 ++++++++++++--
lisp/org-clock.el | 35 ++++++++++++++++++++++-------------
2 files changed, 34 insertions(+), 15 deletions(-)
diff --git a/lisp/ChangeLog b/lisp/ChangeLog
index 05e734c..0bca2be 100755
--- a/lisp/ChangeLog
+++ b/lisp/ChangeLog
@@ -1,3 +1,13 @@
+2008-10-15 James TD Smith <ahktenzero@mohorovi.cc>
+
+ * org-clock.el (org-clock-in-switch-to-state): Allow this to be a
+ function
+ (org-clock-in): If `org-clock-in-switch-to-state' is a function,
+ call it with the current todo state to get the state to switch to
+ when clocking in.
+ (org-clock-in): Use org-indent-line-function to indent clock lines.
+ (org-clock-find-position): Fix indentation of empty clock drawers.
+
2008-10-14 Carsten Dominik <dominik@science.uva.nl>
* org-export-latex.el (org-export-latex-preprocess): Improve
@@ -66,7 +76,7 @@
* org-clock.el (org-clock-heading-for-remember): New variable.
(org-clock-in): Set `org-clock-heading-for-remember'.
-2008-10-01 James TD Smith <ahktenzero@mohorovi.cc>
+2008-10-01 James TD Smith <ahktenzero@mohorovi.cc>
* org-remember.el (org-remember-apply-template): Add new
expansions: %k, %K for currently clocked task and a link to the
@@ -175,7 +185,7 @@
* org-export-latex.el (org-export-latex-keywords-maybe): Bug fix.
-2008-09-22 James TA Smith <ahktenzero@mohorovi.cc>
+2008-09-22 James TD Smith <ahktenzero@mohorovi.cc>
* org-plot.el (org-plot/gnuplot): Make tables starting with a
hline work correctly.
diff --git a/lisp/org-clock.el b/lisp/org-clock.el
index 4a14100..56894cc 100644
--- a/lisp/org-clock.el
+++ b/lisp/org-clock.el
@@ -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.
--
1.6.0.2
^ permalink raw reply related [flat|nested] 4+ messages in thread
* [PATCH 2/2] Make drawer skipping for note insertion more sensible.
2008-10-16 14:51 [PATCH 1/2] Allow org-clock-in-switch-to-state to be a function James TD Smith
@ 2008-10-16 14:51 ` James TD Smith
2008-10-16 17:16 ` Carsten Dominik
2008-10-16 17:16 ` [PATCH 1/2] Allow org-clock-in-switch-to-state to be a function Carsten Dominik
1 sibling, 1 reply; 4+ messages in thread
From: James TD Smith @ 2008-10-16 14:51 UTC (permalink / raw)
To: emacs-orgmode
---
lisp/ChangeLog | 3 +++
lisp/org.el | 12 +++++++-----
2 files changed, 10 insertions(+), 5 deletions(-)
diff --git a/lisp/ChangeLog b/lisp/ChangeLog
index 42622b0..33eca1a 100755
--- a/lisp/ChangeLog
+++ b/lisp/ChangeLog
@@ -8,6 +8,9 @@
(org-clock-in): Use org-indent-line-function to indent clock lines.
(org-clock-find-position): Fix indentation of empty clock drawers.
+ * org.el (org-add-log-setup): Only skip drawers if the are
+ immediately after the scheduling keywords.
+
2008-10-16 Carsten Dominik <dominik@science.uva.nl>
* org.el (org-add-log-setup): Respect
diff --git a/lisp/org.el b/lisp/org.el
index 2eb70dd..413ac6c 100644
--- a/lisp/org.el
+++ b/lisp/org.el
@@ -8392,15 +8392,17 @@ EXTRA is additional text that will be inserted into the notes buffer."
(org-back-to-heading t)
(narrow-to-region (point) (save-excursion
(outline-next-heading) (point)))
- (when org-log-state-notes-insert-after-drawers
- (while (re-search-forward
- (concat "\\(" org-drawer-regexp
- "\\|" org-property-end-re "\\)")
- (point-max) t) (forward-line)))
(looking-at (concat outline-regexp "\\( *\\)[^\r\n]*"
"\\(\n[^\r\n]*?" org-keyword-time-not-clock-regexp
"[^\r\n]*\\)?"))
(goto-char (match-end 0))
+ (when (and org-log-state-notes-insert-after-drawers
+ (save-excursion (forward-line) (looking-at org-drawer-regexp)))
+ (progn (forward-line)
+ (while (looking-at org-drawer-regexp)
+ (goto-char (match-end 0))
+ (re-search-forward org-property-end-re (point-max) t)
+ (forward-line))))
(unless org-log-states-order-reversed
(and (= (char-after) ?\n) (forward-char 1))
(org-skip-over-state-notes)
--
1.6.0.2
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH 2/2] Make drawer skipping for note insertion more sensible.
2008-10-16 14:51 ` [PATCH 2/2] Make drawer skipping for note insertion more sensible James TD Smith
@ 2008-10-16 17:16 ` Carsten Dominik
0 siblings, 0 replies; 4+ messages in thread
From: Carsten Dominik @ 2008-10-16 17:16 UTC (permalink / raw)
To: James TD Smith; +Cc: emacs-orgmode
[-- Attachment #1.1: Type: text/plain, Size: 2101 bytes --]
Applied, thanks.
- Carsten
On Oct 16, 2008, at 4:51 PM, James TD Smith wrote:
> ---
> lisp/ChangeLog | 3 +++
> lisp/org.el | 12 +++++++-----
> 2 files changed, 10 insertions(+), 5 deletions(-)
>
> diff --git a/lisp/ChangeLog b/lisp/ChangeLog
> index 42622b0..33eca1a 100755
> --- a/lisp/ChangeLog
> +++ b/lisp/ChangeLog
> @@ -8,6 +8,9 @@
> (org-clock-in): Use org-indent-line-function to indent clock lines.
> (org-clock-find-position): Fix indentation of empty clock drawers.
>
> + * org.el (org-add-log-setup): Only skip drawers if the are
> + immediately after the scheduling keywords.
> +
> 2008-10-16 Carsten Dominik <dominik@science.uva.nl>
>
> * org.el (org-add-log-setup): Respect
> diff --git a/lisp/org.el b/lisp/org.el
> index 2eb70dd..413ac6c 100644
> --- a/lisp/org.el
> +++ b/lisp/org.el
> @@ -8392,15 +8392,17 @@ EXTRA is additional text that will be
> inserted into the notes buffer."
> (org-back-to-heading t)
> (narrow-to-region (point) (save-excursion
> (outline-next-heading) (point)))
> - (when org-log-state-notes-insert-after-drawers
> - (while (re-search-forward
> - (concat "\\(" org-drawer-regexp
> - "\\|" org-property-end-re "\\)")
> - (point-max) t) (forward-line)))
> (looking-at (concat outline-regexp "\\( *\\)[^\r\n]*"
> "\\(\n[^\r\n]*?" org-keyword-time-not-clock-regexp
> "[^\r\n]*\\)?"))
> (goto-char (match-end 0))
> + (when (and org-log-state-notes-insert-after-drawers
> + (save-excursion (forward-line) (looking-at org-drawer-regexp)))
> + (progn (forward-line)
> + (while (looking-at org-drawer-regexp)
> + (goto-char (match-end 0))
> + (re-search-forward org-property-end-re (point-max) t)
> + (forward-line))))
> (unless org-log-states-order-reversed
> (and (= (char-after) ?\n) (forward-char 1))
> (org-skip-over-state-notes)
> --
> 1.6.0.2
>
>
>
> _______________________________________________
> Emacs-orgmode mailing list
> Remember: use `Reply All' to send replies to the list.
> Emacs-orgmode@gnu.org
> http://lists.gnu.org/mailman/listinfo/emacs-orgmode
[-- Attachment #1.2: Type: text/html, Size: 5397 bytes --]
[-- Attachment #2: Type: text/plain, Size: 204 bytes --]
_______________________________________________
Emacs-orgmode mailing list
Remember: use `Reply All' to send replies to the list.
Emacs-orgmode@gnu.org
http://lists.gnu.org/mailman/listinfo/emacs-orgmode
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH 1/2] Allow org-clock-in-switch-to-state to be a function.
2008-10-16 14:51 [PATCH 1/2] Allow org-clock-in-switch-to-state to be a function James TD Smith
2008-10-16 14:51 ` [PATCH 2/2] Make drawer skipping for note insertion more sensible James TD Smith
@ 2008-10-16 17:16 ` Carsten Dominik
1 sibling, 0 replies; 4+ messages in thread
From: Carsten Dominik @ 2008-10-16 17:16 UTC (permalink / raw)
To: James TD Smith; +Cc: emacs-orgmode
[-- Attachment #1.1: Type: text/plain, Size: 5300 bytes --]
Applied, thanks.
- Carsten
On Oct 16, 2008, at 4:51 PM, James TD Smith wrote:
> Allow org-clock-in-switch-to-state to be a function. This lets you
> have
> different clocked in states for different TODO keyword sets, for
> example
>
> (defun ahkt-clock-state (state)
> (cond ((string= state "TOREAD") "READING")
> ((string= state "TOWATCH") "WATCHING")
> (t state)))
>
> Also fix indentation on clock lines, and empty clock drawers when
> they are
> inserted.
> ---
> lisp/ChangeLog | 14 ++++++++++++--
> lisp/org-clock.el | 35 ++++++++++++++++++++++-------------
> 2 files changed, 34 insertions(+), 15 deletions(-)
>
> diff --git a/lisp/ChangeLog b/lisp/ChangeLog
> index 05e734c..0bca2be 100755
> --- a/lisp/ChangeLog
> +++ b/lisp/ChangeLog
> @@ -1,3 +1,13 @@
> +2008-10-15 James TD Smith <ahktenzero@mohorovi.cc>
> +
> + * org-clock.el (org-clock-in-switch-to-state): Allow this to be a
> + function
> + (org-clock-in): If `org-clock-in-switch-to-state' is a function,
> + call it with the current todo state to get the state to switch to
> + when clocking in.
> + (org-clock-in): Use org-indent-line-function to indent clock lines.
> + (org-clock-find-position): Fix indentation of empty clock drawers.
> +
> 2008-10-14 Carsten Dominik <dominik@science.uva.nl>
>
> * org-export-latex.el (org-export-latex-preprocess): Improve
> @@ -66,7 +76,7 @@
> * org-clock.el (org-clock-heading-for-remember): New variable.
> (org-clock-in): Set `org-clock-heading-for-remember'.
>
> -2008-10-01 James TD Smith <ahktenzero@mohorovi.cc>
> +2008-10-01 James TD Smith <ahktenzero@mohorovi.cc>
>
> * org-remember.el (org-remember-apply-template): Add new
> expansions: %k, %K for currently clocked task and a link to the
> @@ -175,7 +185,7 @@
>
> * org-export-latex.el (org-export-latex-keywords-maybe): Bug fix.
>
> -2008-09-22 James TA Smith <ahktenzero@mohorovi.cc>
> +2008-09-22 James TD Smith <ahktenzero@mohorovi.cc>
>
> * org-plot.el (org-plot/gnuplot): Make tables starting with a
> hline work correctly.
> diff --git a/lisp/org-clock.el b/lisp/org-clock.el
> index 4a14100..56894cc 100644
> --- a/lisp/org-clock.el
> +++ b/lisp/org-clock.el
> @@ -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.
> --
> 1.6.0.2
>
>
>
> _______________________________________________
> Emacs-orgmode mailing list
> Remember: use `Reply All' to send replies to the list.
> Emacs-orgmode@gnu.org
> http://lists.gnu.org/mailman/listinfo/emacs-orgmode
[-- Attachment #1.2: Type: text/html, Size: 12046 bytes --]
[-- Attachment #2: Type: text/plain, Size: 204 bytes --]
_______________________________________________
Emacs-orgmode mailing list
Remember: use `Reply All' to send replies to the list.
Emacs-orgmode@gnu.org
http://lists.gnu.org/mailman/listinfo/emacs-orgmode
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2008-10-16 17:16 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-10-16 14:51 [PATCH 1/2] Allow org-clock-in-switch-to-state to be a function James TD Smith
2008-10-16 14:51 ` [PATCH 2/2] Make drawer skipping for note insertion more sensible James TD Smith
2008-10-16 17:16 ` Carsten Dominik
2008-10-16 17:16 ` [PATCH 1/2] Allow org-clock-in-switch-to-state to be a function Carsten Dominik
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.