emacs-orgmode
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Orgmode] [PATCH] fast tag selection interface


From: Christopher Suckling
Subject: [Orgmode] [PATCH] fast tag selection interface
Date: Mon, 16 Feb 2009 00:15:33 +0000

As a result of the 40 variables thread and assorted worg tutorials, I'm getting a little carried away with customising my workflow. Consequently, my tag list have grown to the extent that the fast tags selection interface is looking rather messy.

The small patch below adds the capability to create arbitrary new lines, either by adding "\n" (backslash n, not a newline!) to your # +TAGS: or by adding "(:newline . nil)" to org-tag-alist.

So I can have something like:

-----
[a] @assorted [g] @gtd [c] @contexts

[o] other [r] relevant [t] tags

[m] more [f] for [d] different [p] projects
-----

The patch is a very hacky cut and paste job with little understanding of the surrounding code, but I don't seem to have broken anything in my setup yet...

Best wishes,

Christopher

-----

        Modified lisp/org.el
diff --git a/lisp/org.el b/lisp/org.el
index c4cfacd..484df30 100644
--- a/lisp/org.el
+++ b/lisp/org.el
@@ -2066,7 +2066,8 @@ See the manual for details."
           (cons   (string    :tag "Tag name")
                   (character :tag "Access char"))
           (const :tag "Start radio group" (:startgroup))
-          (const :tag "End radio group" (:endgroup)))))
+          (const :tag "End radio group" (:endgroup))
+          (const :tag "New line" (:newline)))))

 (defvar org-file-tags nil
   "List of tags that can be inherited by all entries in the file.
@@ -3398,6 +3399,7 @@ means to push this value onto the list in the variable.")
            (cond
             ((equal e "{") (push '(:startgroup) tgs))
             ((equal e "}") (push '(:endgroup) tgs))
+            ((equal e "\\n") (push '(:newline) tgs))
             ((string-match (org-re "^\\([[:alnum:address@hidden)(\\(.\\))$") e)
              (push (cons (match-string 1 e)
                          (string-to-char (match-string 2 e)))
@@ -3534,6 +3536,7 @@ Respect keys that are already there."
       (cond
        ((equal e '(:startgroup)) (push e new))
        ((equal e '(:endgroup)) (push e new))
+       ((equal e '(:newline)) (push e new))
        (t
        (setq k (car e) c2 nil)
        (if (cdr e)
@@ -8866,6 +8869,8 @@ Returns the new TODO keyword, or nil if no state change should occur."
           ((equal e '(:endgroup))
            (setq ingroup nil cnt 0)
            (insert "}\n"))
+          ((equal e '(:newline))
+           (insert "\n  "))
           (t
            (setq tg (car e) c (cdr e))
            (if ingroup (push tg (car groups)))
@@ -10316,6 +10321,8 @@ Returns the new tags string, or nil to not change the current settings."
         ((equal e '(:endgroup))
          (setq ingroup nil cnt 0)
          (insert "}\n"))
+        ((equal e '(:newline))
+         (insert "\n  "))
         (t
          (setq tg (car e) c2 nil)
          (if (cdr e)








reply via email to

[Prev in Thread] Current Thread [Next in Thread]