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