emacs-orgmode@gnu.org archives
 help / color / mirror / code / Atom feed
From: Carsten Dominik <dominik@science.uva.nl>
To: James TD Smith <ahktenzero@mohorovi.cc>
Cc: emacs-orgmode@gnu.org
Subject: Re: [PATCH 1/2] Allow org-clock-in-switch-to-state to be a function.
Date: Thu, 16 Oct 2008 19:16:20 +0200	[thread overview]
Message-ID: <C038CCDA-263B-45E7-8172-7B520F7C5E41@uva.nl> (raw)
In-Reply-To: <1224168679-56353-1-git-send-email-ahktenzero@mohorovi.cc>


[-- 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

      parent reply	other threads:[~2008-10-16 17:16 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
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 ` Carsten Dominik [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.orgmode.org/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=C038CCDA-263B-45E7-8172-7B520F7C5E41@uva.nl \
    --to=dominik@science.uva.nl \
    --cc=ahktenzero@mohorovi.cc \
    --cc=emacs-orgmode@gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).