emacs-orgmode
[Top][All Lists]
Advanced

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

[O] Setting a parametric org-agenda-skip-function?


From: Alan Schmitt
Subject: [O] Setting a parametric org-agenda-skip-function?
Date: Fri, 21 Jun 2013 18:42:28 +0200
User-agent: mu4e 0.9.9.5; emacs 24.3.1

Hello,

I'm trying to have a custom agenda where I say I want to skip some
tags. I wrote a function that does what I want (it takes two arguments:
the list of tags to keep, and a boolean that says whether entries with
no tags should be kept). The function works well, but for some reason it
is not called. Here is how I try to call it:

 ("w" "Work Agenda"
  ((agenda ""
           ((org-agenda-skip-function 
             '(org-agenda-skip-entry-unless-tags 
               my-work-tags
               t))))

I make org-agenda-skip-entry-unless-tags as debugged, and when I call
this agenda view, I don't go in the debugger, so I guess it is not
called.

I tried adding a "lambda ()" at the beginning, or getting rid of the
quote, but it does not work.

Any suggestion as to what I'm doing wrong?

Thanks,

Alan

PS: here are the functions this depends on

(defun as/has-tag (tags-to-test taglist &optional trueifempty)
  "return true if a tag in TAGS-TO-TEST is in TAGLIST. If
  TRUEIFEMPTY is non-nil, then returns true if TAGS-TO-TEST is
  empty."
  (or
   (and trueifempty (not tags-to-test))
   (catch 'match
     (mapc (lambda (tag)
             (when (member tag taglist)
               (throw 'match t)))
           tags-to-test)
     nil))
  )

(defun org-agenda-skip-entry-unless-tags (tags &optional keepempty)
  "Skip entries that do not contain specified tags.
TAGS is a list specifying which tags should be displayed.
Inherited tags will be considered. If keepempty is non-nil,
entries with no tags will be kept."
  (let ((next-headline (save-excursion (or (outline-next-heading) (point-max))))
        (current-headline (or (and (org-at-heading-p)
                                   (point))
                              (save-excursion (org-back-to-heading)))))
    (let ((atags (org-get-tags-at current-headline)))
      (if (as/has-tag atags tags keepempty)
          nil
        next-headline))))
 



reply via email to

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