Mercurial > emacs
comparison lisp/org/org-bbdb.el @ 94414:d86cb59eea9f
2008-04-27 Carsten Dominik <dominik@science.uva.nl>
* org/org.el (org-html-level-start): Always have id's in HTML
(org-export-as-html): Use `org-link-protocols' to
retrieve the export form of the link.
(org-add-link-type): Final parameter renamed from PUBLISH. Better
documentation of how it is to be used. Avoid double entries for
the same link type.
(org-add-link-props): New function.
(org-modules-loaded): New variable.
(org-load-modules-maybe, org-set-modules): New function.
(org-modules): New option.
(org-mode, org-cycle, orgstruct-mode, org-run-like-in-org-mode)
(orgtbl-mode, org-store-link, org-insert-link-global)
(org-open-at-point): Call `org-load-modules-maybe'.
(org-search-view): Add more text properties.
(org-agenda-schedule, org-agenda-deadline): Allow also in
search-type agendas.
(org-search-view): Order of arguments has been changed.
Interpret prefix-arg as TODO-ONLY.
(org-agenda, org-run-agenda-series, org-agenda-manipulate-query):
Take new argument order of `org-search-view' into account.
(org-todo-only): New variable.
(org-search-syntax-table): New variable and function.
(org-search-view): Do the search with the special syntax table.
(define-obsolete-function-alias): Make work with XEmacs.
(org-add-planning-info): Use old date as default when modifying an
existing deadline or scheduled item.
(org-agenda-compute-time-span): Make argument N optional.
(org-agenda-format-date-aligned): Require `cal-iso'.
(org-agenda-list): Include week into into agenda heading, don't
list it at each date (only on Mondays).
(org-read-date-analyze): Define local variable `iso-date'.
(org-agenda-format-date-aligned): Remove dependency on
`calendar-time-from-absolute'.
(org-remember-apply-template, org-go-to-remember-target):
Interpret filenames relative to `org-directory'.
(org-complete): Silently fail when trying to complete
keywords that don't have a default value.
(org-get-current-options): Added a #+DATE: option.
(org-additional-option-like-keywords): Removed "DATE:" from the
list of additional keywords.
(org-export-as-html): Removed (current-time) as unnecessary second
argument of `format-time-string'.
(org-clock-find-position): Handle special case at end of
buffer.
(org-agenda-day-view): New argument DAY-OF-YEAR, pass it on to
`org-agenda-change-time-span'.
(org-agenda-week-view): New argument ISO-WEEK, pass it on to
`org-agenda-change-time-span'.
(org-agenda-month-view): New argument MONTH, pass it on to
`org-agenda-change-time-span'.
(org-agenda-year-view): New argument YEAR, pass it on to
`org-agenda-change-time-span'.
(org-agenda-change-time-span): New optional argument N, pass it on
to `org-agenda-compute-time-span'.
(org-agenda-compute-time-span): New argument N, interpret it by
changing the starting day.
(org-small-year-to-year): New function.
(org-scheduled-past-days): Respect
`org-scheduled-past-days'.
(org-auto-repeat-maybe): Make sure that repeating
dates are pushed into the future, and that the shift is at least
one interval, never 0.
(org-update-checkbox-count): Fix bug with checkbox
counting.
(org-add-note): New command.
(org-add-log-setup): Renamed from `org-add-log-maybe'.
(org-log-note-headings): New entry for plain notes (i.e. notes not
related to state changes or clocking).
(org-get-org-file): Check for availability of
`remember-data-file'.
(org-cached-entry-get): Allow a regexp value for
`org-use-property-inheritance'.
(org-use-property-inheritance): Allow regexp value. Fix bug in
customization type.
(org-use-tag-inheritance): Allow a list and a regexp value for
this variable.
(org-scan-tags, org-get-tags-at): Implement selective tag
inheritance.
(org-entry-get): Respect value `selective' for the INHERIT
argument.
(org-tag-inherit-p, org-property-inherit-p): New functions.
(org-agenda-format-date-aligned): Allow 10 characters for
weekday, to acomodate German locale.
(org-add-archive-files): New function.
(org-agenda-files): New argument `ext', to
get archive files as well.
(org-tbl-menu): Protect the use of variables that
are only available when org-table.el gets loaded.
(org-read-agenda-file-list): Error if `org-agenda-files' is a
single directory.
(org-open-file): Allow a batch process to trigger
waiting after executing a system command.
(org-store-link): Link to headline when there is not
target and no region in an org-mode buffer when creating a link.
(org-link-types-re): New variable.
(org-make-link-regexps): Compute `org-link-types-re'.
(org-make-link-description-function): New option.
(org-agenda-date, org-agenda-date-weekend): New faces.
(org-archive-sibling-heading): New option.
(org-archive-to-archive-sibling): New function.
(org-iswitchb): New command.
(org-buffer-list): New function.
(org-agenda-columns): Also try the #+COLUMNS line in
the buffer associated with the entry at point (or with the first
entry in the agenda view).
(org-modules): Add entry for org-bibtex.el.
(org-completion-fallback-command): Moved into `org-completion'
group.
(org-clock-heading-function): Moved to `org-progress' group.
(org-auto-repeat-maybe): Make sure that a note can
be enforces if `org-log-repeat' is `note'.
(org-modules): Allow additional symbols for external
packages.
(org-ctrl-c-ctrl-c): Allow for `org-clock-overlays' to be
undefined.
(org-clock-goto): Hide drawers after showing an
entry with `org-clock-goto.'
(org-shiftup, org-shiftdown, org-shiftright, org-shiftleft): Try
also a clocktable block shift.
(org-clocktable-try-shift): New function.
(org-columns-hscoll-title): New function.
(org-columns-previous-hscroll): New variable.
(org-columns-full-header-line-format): New variable.
(org-columns-display-here-title, org-columns-remove-overlays):
Install `org-columns-hscoll-title' in post-command-hook.
* org/org.el: Split into many small files.
* org/org-agenda.el: New file, split off from org.el.
* org/org-archive.el: New file, split off from org.el.
* org/org-bbdb.el: New file.
* org/org-bibtex.el: New file, split off from org.el.
* org/org-clock.el: New file, split off from org.el.
* org/org-colview.el: New file, split off from org.el.
* org/org-compat.el: New file, split off from org.el.
* org/org-exp.el: New file, split off from org.el.
* org/org-faces.el: New file, split off from org.el.
* org/org-gnus.el: New file, split off from org.el.
* org/org-info.el: New file, split off from org.el.
* org/org-infojs.el: New file.
* org/org-irc.el: New file.
* org/org-macs.el: New file, split off from org.el.
* org/org-mew.el: New file.
* org/org-mhe.el: New file, split off from org.el.
* org/org-publish.el: New file, split off from org.el.
* org/org-remember.el: New file, split off from org.el.
* org/org-rmail.el: New file, split off from org.el.
* org/org-table.el: New file, split off from org.el.
* org/org-vm.el: New file, split off from org.el.
* org/org-wl.el: New file, split off from org.el.
2008-04-27 Jason Riedy <jason@acm.org>
* lisp/org-table.el (orgtbl-to-generic): Add a :remove-nil-lines
parameter that supresses lines that evaluate to NIL.
(orgtbl-get-fmt): New inline function for
picking apart formats that may be lists.
(orgtbl-apply-fmt): New inline function for applying formats that
may be functions.
(orgtbl-eval-str): New inline function for strings that may be
functions.
(orgtbl-format-line, orgtbl-to-generic): Use and document.
(orgtbl-to-latex, orgtbl-to-texinfo): Document.
(*orgtbl-llfmt*, *orgtbl-llstart*)
(*orgtbl-llend*): Dynamic variables for last-line formatting.
(orgtbl-format-section): Shift formatting to support detecting the
last line and formatting it specially.
(orgtbl-to-generic): Document :ll* formats. Set to the non-ll
formats unless overridden.
(orgtbl-to-latex): Suggest using :llend to suppress the final \\.
(*orgtbl-table*, *orgtbl-rtn*): Dynamically
bound variables to hold the input collection of lines and output
formatted text.
(*orgtbl-hline*, *orgtbl-sep*, *orgtbl-fmt*, *orgtbl-efmt*,
(*orgtbl-lfmt*, *orgtbl-lstart*, *orgtbl-lend*): Dynamically bound
format parameters.
(orgtbl-format-line): New function encapsulating formatting for a
single line.
(orgtbl-format-section): Similar for each section. Rebinding the
dynamic vars customizes the formatting for each section.
(orgtbl-to-generic): Use orgtbl-format-line and
orgtbl-format-section.
(org-get-param): Now unused, so delete.
(orgtbl-gather-send-defs): New function to
gather all the SEND definitions before a table.
(orgtbl-send-replace-tbl): New function to find the RECEIVE
corresponding to the current name.
(orgtbl-send-table): Use the previous two functions and implement
multiple destinations for each table.
* doc/org.texi (A LaTeX example): Note that fmt may be a
one-argument function, and efmt may be a two-argument function.
(Radio tables): Document multiple destinations.
2008-04-27 Carsten Dominik <dominik@science.uva.nl>
* org/org-agenda.el (org-add-to-diary-list): New function.
(org-prefix-has-effort): New variable.
(org-sort-agenda-noeffort-is-high): New option.
(org-agenda-columns-show-summaries)
(org-agenda-columns-compute-summary-properties): New options.
(org-format-agenda-item): Compute the duration of the item.
(org-agenda-weekend-days): New variable.
(org-agenda-list, org-timeline): Use the proper faces for dates in
the agenda and timeline buffers.
(org-agenda-archive-to-archive-sibling): New command.
(org-agenda-start-with-clockreport-mode): New option.
(org-agenda-clockreport-parameter-plist): New option.
(org-agenda-clocktable-mode): New variable.
(org-agenda-deadline-leaders): Allow a function value for the
deadline leader.
(org-agenda-get-deadlines): Deal with new function value.
* lisp/org-clock.el (org-clock): New customization group.
(org-clock-into-drawer, org-clock-out-when-done)
(org-clock-in-switch-to-state, org-clock-heading-function): Moved
into the new group.
(org-clock-out-remove-zero-time-clocks): New option.
(org-clock-out): Use `org-clock-out-remove-zero-time-clocks'.
(org-dblock-write:clocktable): Allow a Lisp form for the scope
parameter.
(org-dblock-write:clocktable): Fixed bug with total time
calculation.
(org-dblock-write:clocktable): Request the unrestricted list of
files.
(org-get-clocktable): New function.
(org-dblock-write:clocktable): Make sure :tstart and :tend can not
only be strings but also integers (an absolute day number) and
lists (m d y).
* org/org-colview.el (org-columns-next-allowed-value)
(org-columns-edit-value): Limit the effort for updatig in the
agenda to recomputing a single file.
(org-columns-compute): Only write property value if it has
changed. This avoids raising the buffer-change-flag
unnecessarily.
(org-agenda-colview-summarize)
(org-agenda-colview-compute): New functions.
(org-agenda-columns): Call `org-agenda-colview-summarize'.
* org/org-exp.el (org-export-run-in-background): New option.
(org-export-icalendar): Allow a batch process to trigger waiting
after executing a system command.
(org-export-preprocess-string): Renamed-from
`org-cleaned-string-for-export'.
(org-export-html-style): Made target class look like normal text.
(org-export-as-html): Make use of the better proprocessing in
`org-cleaned-string-for-export'.
(org-cleaned-string-for-export): Better treatment of heuristic
targets, many more internal links will now work in HTML export.
(org-get-current-options): Incorporate LINK_UP, LINK_HOME, and
INFOJS.
(org-export-inbuffer-options-extra): New variable.
(org-export-options-filters): New hook.
(org-infile-export-plist): Find also the settings keywords in
`org-export-inbuffer-options-extra'.
(org-infile-export-plist): Allow multiple #+OPTIONS lines and
multiple #+INFOJS_OPT lines.
(org-export-html-handle-js-options): New function.
(org-export-html-infojs-setup): New option.
(org-export-as-html): Call `org-export-html-handle-js-options'.
Add autoload to all entry points.
(org-skip-comments): Function removed.
* org/org-table.el (org-table-make-reference): Extra parenthesis
around single fields, to make sure that algebraic formulas get
correctly interpreted by calc.
(org-table-current-column): No longer interactive.
* org/org-export-latex.el (org-export-latex-preprocess): Renamed
from `org-export-latex-cleaned-string'.
2008-04-27 Bastien Guerry <bzg@altern.org>
* org/org-publish.el (org-publish-get-base-files-1): New function.
(org-publish-get-base-files): Use it.
(org-publish-temp-files): New variable.
Don't require 'dired-aux anymore.
(org-publish-initial-buffer): New variable.
(org-publish-org-to, org-publish): Use it.
(org-publish-get-base-files-1): Bug fix: get
the proper list of files when recursing thru a directory.
(org-publish-get-base-files): Use the :exclude property to skip
both files and directories.
author | Carsten Dominik <dominik@science.uva.nl> |
---|---|
date | Sun, 27 Apr 2008 18:33:39 +0000 |
parents | |
children | da5141d2e8fc |
comparison
equal
deleted
inserted
replaced
94413:90289baecd6a | 94414:d86cb59eea9f |
---|---|
1 ;;; org-bbdb.el --- Support for links to BBDB entries from within Org-mode | |
2 | |
3 ;; Copyright (C) 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. | |
4 | |
5 ;; Author: Carsten Dominik <carsten at orgmode dot org>, | |
6 ;; Thomas Baumann <thomas dot baumann at ch dot tum dot de> | |
7 ;; Keywords: outlines, hypermedia, calendar, wp | |
8 ;; Homepage: http://orgmode.org | |
9 ;; Version: 6.02b | |
10 ;; | |
11 ;; This file is part of GNU Emacs. | |
12 ;; | |
13 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
14 ;; it under the terms of the GNU General Public License as published by | |
15 ;; the Free Software Foundation; either version 3, or (at your option) | |
16 ;; any later version. | |
17 | |
18 ;; GNU Emacs is distributed in the hope that it will be useful, | |
19 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
20 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
21 ;; GNU General Public License for more details. | |
22 | |
23 ;; You should have received a copy of the GNU General Public License | |
24 ;; along with GNU Emacs; see the file COPYING. If not, write to the | |
25 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, | |
26 ;; Boston, MA 02110-1301, USA. | |
27 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | |
28 ;; | |
29 ;;; Commentary: | |
30 | |
31 ;; This file implements links to BBDB database entries from within Org-mode. | |
32 ;; Org-mode loads this module by default - if this is not what you want, | |
33 ;; configure the variable `org-modules'. | |
34 | |
35 | |
36 ;; It also implements an interface (based on Ivar Rummelhoff's | |
37 ;; bbdb-anniv.el) for those org-mode users, who do not use the diary | |
38 ;; but who do want to include the anniversaries stored in the BBDB | |
39 ;; into the org-agenda. If you already include the `diary' into the | |
40 ;; agenda, you might want to prefer to include the anniversaries in | |
41 ;; the diary using bbdb-anniv.el. | |
42 ;; | |
43 ;; Put the following in /somewhere/at/home/diary.org and make sure | |
44 ;; that this file is in `org-agenda-files` | |
45 ;; | |
46 ;; %%(org-bbdb-anniversaries) | |
47 ;; | |
48 ;; For example my diary.org looks like: | |
49 ;; * Anniversaries | |
50 ;; #+CATEGORY: Anniv | |
51 ;; %%(org-bbdb-anniversaries) | |
52 ;; | |
53 ;; | |
54 ;; The anniversaries are stored in BBDB in the field `anniversary' | |
55 ;; in the format | |
56 ;; | |
57 ;; YYYY-MM-DD{ CLASS-OR-FORMAT-STRING}* | |
58 ;; {\nYYYY-MM-DD CLASS-OR-FORMAT-STRING}* | |
59 ;; | |
60 ;; CLASS-OR-FORMAT-STRING is one of two things: | |
61 ;; | |
62 ;; * an identifier for a class of anniversaries (eg. birthday or | |
63 ;; wedding) from `org-bbdb-anniversary-format-alist'. | |
64 ;; * the (format) string displayed in the diary. | |
65 ;; | |
66 ;; It defaults to the value of `org-bbdb-default-anniversary-format' | |
67 ;; ("birthday" by default). | |
68 ;; | |
69 ;; The substitutions in the format string are (in order): | |
70 ;; * the name of the record containing this anniversary | |
71 ;; * the number of years | |
72 ;; * an ordinal suffix (st, nd, rd, th) for the year | |
73 ;; | |
74 ;; See the documentation of `org-bbdb-anniversary-format-alist' for | |
75 ;; further options. | |
76 ;; | |
77 ;; Example | |
78 ;; | |
79 ;; 1973-06-22 | |
80 ;; 20??-??-?? wedding | |
81 ;; 1998-03-12 %s created bbdb-anniv.el %d years ago | |
82 | |
83 ;;; Code: | |
84 | |
85 (require 'org) | |
86 (eval-when-compile | |
87 (require 'cl)) | |
88 | |
89 ;; Declare external functions and variables | |
90 | |
91 (declare-function bbdb "ext:bbdb-com" (string elidep)) | |
92 (declare-function bbdb-company "ext:bbdb-com" (string elidep)) | |
93 (declare-function bbdb-current-record "ext:bbdb-com" | |
94 (&optional planning-on-modifying)) | |
95 (declare-function bbdb-name "ext:bbdb-com" (string elidep)) | |
96 (declare-function bbdb-record-getprop "ext:bbdb" (record property)) | |
97 (declare-function bbdb-record-name "ext:bbdb" (record)) | |
98 (declare-function bbdb-records "ext:bbdb" | |
99 (&optional dont-check-disk already-in-db-buffer)) | |
100 (declare-function bbdb-split "ext:bbdb" (string separators)) | |
101 (declare-function bbdb-string-trim "ext:bbdb" (string)) | |
102 (declare-function calendar-leap-year-p "calendar" (year)) | |
103 (declare-function diary-ordinal-suffix "diary-lib" (n)) | |
104 | |
105 (defvar date) | |
106 | |
107 ;; Customization | |
108 | |
109 (defgroup org-bbdb-anniversaries nil | |
110 "Customizations for including anniversaries from BBDB into Agenda." | |
111 :group 'org-bbdb) | |
112 | |
113 (defcustom org-bbdb-default-anniversary-format "birthday" | |
114 "Default anniversary class." | |
115 :type 'string | |
116 :group 'org-bbdb-anniversaries | |
117 :require 'bbdb) | |
118 | |
119 (defcustom org-bbdb-anniversary-format-alist | |
120 '( ("birthday" . "Birthday: %s (%d%s)") | |
121 ("wedding" . "%s's %d%s wedding anniversary") ) | |
122 "How different types of anniversaries should be formatted. | |
123 An alist of elements (STRING . FORMAT) where STRING is the name of an | |
124 anniversary class and format is either: | |
125 1) A format string with the following substitutions (in order): | |
126 * the name of the record containing this anniversary | |
127 * the number of years | |
128 * an ordinal suffix (st, nd, rd, th) for the year | |
129 | |
130 2) A function to be called with three arguments: NAME YEARS SUFFIX | |
131 (string int string) returning a string for the diary or nil. | |
132 | |
133 3) An Emacs Lisp form that should evaluate to a string (or nil) in the | |
134 scope of variables NAME, YEARS and SUFFIX (among others)." | |
135 :type 'sexp | |
136 :group 'org-bbdb-anniversaries | |
137 :require 'bbdb) | |
138 | |
139 (defcustom org-bbdb-anniversary-field 'anniversary | |
140 "The BBDB field which contains anniversaries. | |
141 The anniversaries are stored in the following format | |
142 | |
143 YYYY-MM-DD Class-or-Format-String | |
144 | |
145 where class is one of the customized classes for anniversaries; | |
146 birthday and wedding are predefined. Format-String can take three | |
147 substitutions 1) the name of the record containing this | |
148 anniversary, 2) the number of years, and 3) an ordinal suffix for | |
149 the year. | |
150 | |
151 Multiple anniversaries can be separated by \\n" | |
152 :type 'symbol | |
153 :group 'org-bbdb-anniversaries | |
154 :require 'bbdb) | |
155 | |
156 (defcustom org-bbdb-extract-date-fun 'org-bbdb-anniv-extract-date | |
157 "How to retrieve `month date year' from the anniversary field. | |
158 | |
159 Customize if you have already filled your bbdb with dates | |
160 different from YYYY-MM-DD. The function must return a list (month | |
161 date year)" | |
162 :type 'function | |
163 :group 'org-bbdb-anniversaries | |
164 :require 'bbdb) | |
165 | |
166 | |
167 ;; Install the link type | |
168 (org-add-link-type "bbdb" 'org-bbdb-open 'org-bbdb-export) | |
169 (add-hook 'org-store-link-functions 'org-bbdb-store-link) | |
170 | |
171 ;; Implementation | |
172 (defun org-bbdb-store-link () | |
173 "Store a link to a BBDB database entry." | |
174 (when (eq major-mode 'bbdb-mode) | |
175 ;; This is BBDB, we make this link! | |
176 (let* ((name (bbdb-record-name (bbdb-current-record))) | |
177 (company (bbdb-record-getprop (bbdb-current-record) 'company)) | |
178 (link (org-make-link "bbdb:" name))) | |
179 (org-store-link-props :type "bbdb" :name name :company company | |
180 :link link :description name) | |
181 link))) | |
182 | |
183 (defun org-bbdb-export (path desc format) | |
184 "Create the export version of a BBDB link specified by PATH or DESC. | |
185 If exporting to either HTML or LaTeX FORMAT the link will be | |
186 italicised, in all other cases it is left unchanged." | |
187 "Create the exprt verison of a bbdb link." | |
188 (cond | |
189 ((eq format 'html) (format "<i>%s</i>" (or desc path))) | |
190 ((eq format 'latex) (format "\\textit{%s}" (or desc path))) | |
191 (t (or desc path)))) | |
192 | |
193 (defun org-bbdb-open (name) | |
194 "Follow a BBDB link to NAME." | |
195 (require 'bbdb) | |
196 (let ((inhibit-redisplay (not debug-on-error)) | |
197 (bbdb-electric-p nil)) | |
198 (catch 'exit | |
199 ;; Exact match on name | |
200 (bbdb-name (concat "\\`" name "\\'") nil) | |
201 (if (< 0 (buffer-size (get-buffer "*BBDB*"))) (throw 'exit nil)) | |
202 ;; Exact match on name | |
203 (bbdb-company (concat "\\`" name "\\'") nil) | |
204 (if (< 0 (buffer-size (get-buffer "*BBDB*"))) (throw 'exit nil)) | |
205 ;; Partial match on name | |
206 (bbdb-name name nil) | |
207 (if (< 0 (buffer-size (get-buffer "*BBDB*"))) (throw 'exit nil)) | |
208 ;; Partial match on company | |
209 (bbdb-company name nil) | |
210 (if (< 0 (buffer-size (get-buffer "*BBDB*"))) (throw 'exit nil)) | |
211 ;; General match including network address and notes | |
212 (bbdb name nil) | |
213 (when (= 0 (buffer-size (get-buffer "*BBDB*"))) | |
214 (delete-window (get-buffer-window "*BBDB*")) | |
215 (error "No matching BBDB record"))))) | |
216 | |
217 (defun org-bbdb-anniv-extract-date (time-str) | |
218 "Convert YYYY-MM-DD to (month date year). | |
219 Argument TIME-STR is the value retrieved from BBDB." | |
220 (multiple-value-bind (y m d) (bbdb-split time-str "-") | |
221 (list (string-to-number m) | |
222 (string-to-number d) | |
223 (string-to-number y)))) | |
224 | |
225 (defun org-bbdb-anniv-split (str) | |
226 "Split mutliple entries in the BBDB anniversary field. | |
227 Argument STR is the anniversary field in BBDB." | |
228 (let ((pos (string-match "[ \t]" str))) | |
229 (if pos (list (substring str 0 pos) | |
230 (bbdb-string-trim (substring str pos))) | |
231 (list str nil)))) | |
232 | |
233 | |
234 ;;;###autoload | |
235 (defun org-bbdb-anniversaries () | |
236 "Extract anniversaries from BBDB for display in the agenda." | |
237 (require 'diary-lib) | |
238 (let ((dates (list (cons (cons (car date) ; month | |
239 (nth 1 date)) ; day | |
240 (nth 2 date)))) ; year | |
241 (text ()) | |
242 annivs date years | |
243 split class form) | |
244 (dolist (rec (bbdb-records)) | |
245 (when (setq annivs (bbdb-record-getprop | |
246 rec org-bbdb-anniversary-field)) | |
247 (setq annivs (bbdb-split annivs "\n")) | |
248 (while annivs | |
249 (setq split (org-bbdb-anniv-split (pop annivs))) | |
250 (multiple-value-bind (m d y) | |
251 (funcall org-bbdb-extract-date-fun (car split)) | |
252 | |
253 (when (and (or (setq date (assoc (cons m d) dates)) | |
254 (and (= d 29) | |
255 (= m 2) | |
256 (setq date (assoc '(3 . 1) dates)) | |
257 (not (calendar-leap-year-p (cdr date))))) | |
258 (< 0 (setq years (- (cdr date) y)))) | |
259 (let* ((class (or (cadr split) | |
260 org-bbdb-default-anniversary-format)) | |
261 (form (or (cdr (assoc class | |
262 org-bbdb-anniversary-format-alist)) | |
263 class)) ; (as format string) | |
264 (name (bbdb-record-name rec)) | |
265 (suffix (diary-ordinal-suffix years)) | |
266 (tmp (cond | |
267 ((functionp form) | |
268 (funcall form name years suffix)) | |
269 ((listp form) (eval form)) | |
270 (t (format form name years suffix))))) | |
271 (if text | |
272 (setq text (append text (list tmp))) | |
273 (setq text (list tmp)))) | |
274 ))))) | |
275 (when text | |
276 (mapconcat 'identity text "; ")))) | |
277 | |
278 (provide 'org-bbdb) | |
279 | |
280 ;;; org-bbdb.el ends here |