annotate lisp/net/eudcb-bbdb.el @ 87264:864814308855

*** empty log message ***
author Glenn Morris <rgm@gnu.org>
date Tue, 11 Dec 2007 08:28:49 +0000
parents d63d925838d5
children 107ccd98fa12 53108e6cea98
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
1 ;;; eudcb-bbdb.el --- Emacs Unified Directory Client - BBDB Backend
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
2
74509
f7702c5f335d Update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 68648
diff changeset
3 ;; Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004,
75347
e3694f1cb928 Add 2007 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 74509
diff changeset
4 ;; 2005, 2006, 2007 Free Software Foundation, Inc.
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
5
42778
6d743d659035 New maintainer. Change author's address.
Pavel Janík <Pavel@Janik.cz>
parents: 42574
diff changeset
6 ;; Author: Oscar Figueiredo <oscar@cpe.fr>
6d743d659035 New maintainer. Change author's address.
Pavel Janík <Pavel@Janik.cz>
parents: 42574
diff changeset
7 ;; Maintainer: Pavel Janík <Pavel@Janik.cz>
42574
fcac9cd201ad Fix Keywords: header.
Pavel Janík <Pavel@Janik.cz>
parents: 42570
diff changeset
8 ;; Keywords: comm
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
9
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
10 ;; This file is part of GNU Emacs.
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
11
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
12 ;; GNU Emacs is free software; you can redistribute it and/or modify
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
13 ;; it under the terms of the GNU General Public License as published by
78230
84cf1e2214c5 Switch license to GPLv3 or later.
Glenn Morris <rgm@gnu.org>
parents: 75347
diff changeset
14 ;; the Free Software Foundation; either version 3, or (at your option)
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
15 ;; any later version.
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
16
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
17 ;; GNU Emacs is distributed in the hope that it will be useful,
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
20 ;; GNU General Public License for more details.
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
21
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
22 ;; You should have received a copy of the GNU General Public License
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
23 ;; along with GNU Emacs; see the file COPYING. If not, write to the
64085
18a818a2ee7c Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 52401
diff changeset
24 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18a818a2ee7c Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 52401
diff changeset
25 ;; Boston, MA 02110-1301, USA.
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
26
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
27 ;;; Commentary:
42570
78a4068d960a Remove unnecessary whitespaces.
Pavel Janík <Pavel@Janik.cz>
parents: 27313
diff changeset
28 ;; This library provides an interface to use BBDB as a backend of
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
29 ;; the Emacs Unified Directory Client.
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
30
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
31 ;;; Code:
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
32
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
33 (require 'eudc)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
34 (if (not (featurep 'bbdb))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
35 (load-library "bbdb"))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
36 (if (not (featurep 'bbdb-com))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
37 (load-library "bbdb-com"))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
38
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
39 ;;{{{ Internal cooking
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
40
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
41 ;; I don't like this but mapcar does not accept a parameter to the function and
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
42 ;; I don't want to use mapcar*
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
43 (defvar eudc-bbdb-current-query nil)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
44 (defvar eudc-bbdb-current-return-attributes nil)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
45
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
46 (defvar eudc-bbdb-attributes-translation-alist
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
47 '((name . lastname)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
48 (email . net)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
49 (phone . phones))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
50 "Alist mapping EUDC attribute names to BBDB names.")
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
51
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
52 (eudc-protocol-set 'eudc-query-function 'eudc-bbdb-query-internal 'bbdb)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
53 (eudc-protocol-set 'eudc-list-attributes-function nil 'bbdb)
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
54 (eudc-protocol-set 'eudc-protocol-attributes-translation-alist
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
55 'eudc-bbdb-attributes-translation-alist 'bbdb)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
56 (eudc-protocol-set 'eudc-bbdb-conversion-alist nil 'bbdb)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
57 (eudc-protocol-set 'eudc-protocol-has-default-query-attributes nil 'bbdb)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
58
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
59 (defun eudc-bbdb-format-query (query)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
60 "Format a EUDC query alist into a list suitable to `bbdb-search'."
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
61 (let* ((firstname (cdr (assq 'firstname query)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
62 (lastname (cdr (assq 'lastname query)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
63 (name (or (and firstname lastname
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
64 (concat firstname " " lastname))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
65 firstname
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
66 lastname))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
67 (company (cdr (assq 'company query)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
68 (net (cdr (assq 'net query)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
69 (notes (cdr (assq 'notes query)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
70 (phone (cdr (assq 'phone query))))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
71 (list name company net notes phone)))
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
72
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
73
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
74 (defun eudc-bbdb-filter-non-matching-record (record)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
75 "Return RECORD if it matches `eudc-bbdb-current-query', nil otherwise."
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
76 (catch 'unmatch
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
77 (progn
85228
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
78 (mapc
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
79 (function
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
80 (lambda (condition)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
81 (let ((attr (car condition))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
82 (val (cdr condition))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
83 (case-fold-search t)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
84 bbdb-val)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
85 (or (and (memq attr '(firstname lastname aka company phones addresses net))
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
86 (progn
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
87 (setq bbdb-val
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
88 (eval (list (intern (concat "bbdb-record-"
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
89 (symbol-name attr)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
90 'record)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
91 (if (listp bbdb-val)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
92 (if eudc-bbdb-enable-substring-matches
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
93 (eval `(or ,@(mapcar '(lambda (subval)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
94 (string-match val
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
95 subval))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
96 bbdb-val)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
97 (member (downcase val)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
98 (mapcar 'downcase bbdb-val)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
99 (if eudc-bbdb-enable-substring-matches
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
100 (string-match val bbdb-val)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
101 (string-equal (downcase val) (downcase bbdb-val))))))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
102 (throw 'unmatch nil)))))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
103 eudc-bbdb-current-query)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
104 record)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
105
86816
4a5a63e12e5a (bbdb-phone-location, bbdb-phone-string)
Glenn Morris <rgm@gnu.org>
parents: 85228
diff changeset
106 ;; External.
86843
9e7d6c65162b (bbdb-phone-location, bbdb-record-phones)
Glenn Morris <rgm@gnu.org>
parents: 86816
diff changeset
107 (declare-function bbdb-phone-location "ext:bbdb" t) ; via bbdb-defstruct
86816
4a5a63e12e5a (bbdb-phone-location, bbdb-phone-string)
Glenn Morris <rgm@gnu.org>
parents: 85228
diff changeset
108 (declare-function bbdb-phone-string "ext:bbdb" (phone))
86843
9e7d6c65162b (bbdb-phone-location, bbdb-record-phones)
Glenn Morris <rgm@gnu.org>
parents: 86816
diff changeset
109 (declare-function bbdb-record-phones "ext:bbdb" t) ; via bbdb-defstruct
87024
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
110 (declare-function bbdb-address-streets "ext:bbdb" t) ; via bbdb-defstruct
86843
9e7d6c65162b (bbdb-phone-location, bbdb-record-phones)
Glenn Morris <rgm@gnu.org>
parents: 86816
diff changeset
111 (declare-function bbdb-address-city "ext:bbdb" t) ; via bbdb-defstruct
9e7d6c65162b (bbdb-phone-location, bbdb-record-phones)
Glenn Morris <rgm@gnu.org>
parents: 86816
diff changeset
112 (declare-function bbdb-address-state "ext:bbdb" t) ; via bbdb-defstruct
9e7d6c65162b (bbdb-phone-location, bbdb-record-phones)
Glenn Morris <rgm@gnu.org>
parents: 86816
diff changeset
113 (declare-function bbdb-address-zip "ext:bbdb" t) ; via bbdb-defstruct
9e7d6c65162b (bbdb-phone-location, bbdb-record-phones)
Glenn Morris <rgm@gnu.org>
parents: 86816
diff changeset
114 (declare-function bbdb-address-location "ext:bbdb" t) ; via bbdb-defstruct
9e7d6c65162b (bbdb-phone-location, bbdb-record-phones)
Glenn Morris <rgm@gnu.org>
parents: 86816
diff changeset
115 (declare-function bbdb-record-addresses "ext:bbdb" t) ; via bbdb-defstruct
86816
4a5a63e12e5a (bbdb-phone-location, bbdb-phone-string)
Glenn Morris <rgm@gnu.org>
parents: 85228
diff changeset
116 (declare-function bbdb-records "ext:bbdb"
4a5a63e12e5a (bbdb-phone-location, bbdb-phone-string)
Glenn Morris <rgm@gnu.org>
parents: 85228
diff changeset
117 (&optional dont-check-disk already-in-db-buffer))
4a5a63e12e5a (bbdb-phone-location, bbdb-phone-string)
Glenn Morris <rgm@gnu.org>
parents: 85228
diff changeset
118
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
119 (defun eudc-bbdb-extract-phones (record)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
120 (mapcar (function
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
121 (lambda (phone)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
122 (if eudc-bbdb-use-locations-as-attribute-names
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
123 (cons (intern (bbdb-phone-location phone))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
124 (bbdb-phone-string phone))
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
125 (cons 'phones (format "%s: %s"
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
126 (bbdb-phone-location phone)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
127 (bbdb-phone-string phone))))))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
128 (bbdb-record-phones record)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
129
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
130 (defun eudc-bbdb-extract-addresses (record)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
131 (let (s c val)
87024
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
132 (mapcar (lambda (address)
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
133 (setq c (bbdb-address-streets address))
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
134 (dotimes (n 3)
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
135 (unless (zerop (length (setq s (nth n c))))
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
136 (setq val (concat val s "\n"))))
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
137 (setq c (bbdb-address-city address)
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
138 s (bbdb-address-state address))
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
139 (setq val (concat val
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
140 (if (and (> (length c) 0) (> (length s) 0))
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
141 (concat c ", " s)
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
142 c)
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
143 " "
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
144 (bbdb-address-zip address)))
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
145 (if eudc-bbdb-use-locations-as-attribute-names
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
146 (cons (intern (bbdb-address-location address)) val)
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
147 (cons 'addresses (concat (bbdb-address-location address)
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
148 "\n" val))))
d63d925838d5 (bbdb-address-streets): Declare as a function.
Glenn Morris <rgm@gnu.org>
parents: 86843
diff changeset
149 (bbdb-record-addresses record))))
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
150
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
151 (defun eudc-bbdb-format-record-as-result (record)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
152 "Format the BBDB RECORD as a EUDC query result record.
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
153 The record is filtered according to `eudc-bbdb-current-return-attributes'"
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
154 (let ((attrs (or eudc-bbdb-current-return-attributes
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
155 '(firstname lastname aka company phones addresses net notes)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
156 attr
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
157 eudc-rec
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
158 val)
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
159 (while (prog1
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
160 (setq attr (car attrs))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
161 (setq attrs (cdr attrs)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
162 (cond
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
163 ((eq attr 'phones)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
164 (setq val (eudc-bbdb-extract-phones record)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
165 ((eq attr 'addresses)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
166 (setq val (eudc-bbdb-extract-addresses record)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
167 ((memq attr '(firstname lastname aka company net notes))
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
168 (setq val (eval
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
169 (list (intern
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
170 (concat "bbdb-record-"
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
171 (symbol-name attr)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
172 'record))))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
173 (t
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
174 (setq val "Unknown BBDB attribute")))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
175 (if val
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
176 (cond
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
177 ((memq attr '(phones addresses))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
178 (setq eudc-rec (append val eudc-rec)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
179 ((and (listp val)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
180 (= 1 (length val)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
181 (setq eudc-rec (cons (cons attr (car val)) eudc-rec)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
182 ((> (length val) 0)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
183 (setq eudc-rec (cons (cons attr val) eudc-rec)))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
184 (t
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
185 (error "Unexpected attribute value")))))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
186 (nreverse eudc-rec)))
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
187
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
188
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
189
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
190 (defun eudc-bbdb-query-internal (query &optional return-attrs)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
191 "Query BBDB with QUERY.
49598
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
192 QUERY is a list of cons cells (ATTR . VALUE) where ATTRs should be valid
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
193 BBDB attribute names.
0d8b17d428b5 Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 42778
diff changeset
194 RETURN-ATTRS is a list of attributes to return, defaulting to
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
195 `eudc-default-return-attributes'."
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
196
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
197 (let ((eudc-bbdb-current-query query)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
198 (eudc-bbdb-current-return-attributes return-attrs)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
199 (query-attrs (eudc-bbdb-format-query query))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
200 bbdb-attrs
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
201 (records (bbdb-records))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
202 result
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
203 filtered)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
204 ;; BBDB ORs its query attributes while EUDC ANDs them, hence we need to
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
205 ;; call bbdb-search iteratively on the returned records for each of the
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
206 ;; requested attributes
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
207 (while (and records (> (length query-attrs) 0))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
208 (setq bbdb-attrs (append bbdb-attrs (list (car query-attrs))))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
209 (if (car query-attrs)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
210 (setq records (eval `(bbdb-search ,(quote records) ,@bbdb-attrs))))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
211 (setq query-attrs (cdr query-attrs)))
85228
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
212 (mapc (function
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
213 (lambda (record)
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
214 (setq filtered (eudc-filter-duplicate-attributes record))
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
215 ;; If there were duplicate attributes reverse the order of the
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
216 ;; record so the unique attributes appear first
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
217 (if (> (length filtered) 1)
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
218 (setq filtered (mapcar (function
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
219 (lambda (rec)
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
220 (reverse rec)))
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
221 filtered)))
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
222 (setq result (append result filtered))))
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
223 (delq nil
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
224 (mapcar 'eudc-bbdb-format-record-as-result
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
225 (delq nil
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
226 (mapcar 'eudc-bbdb-filter-non-matching-record
631c2c083474 (eudc-bbdb-filter-non-matching-record)
Glenn Morris <rgm@gnu.org>
parents: 78230
diff changeset
227 records)))))
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
228 result))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
229
42570
78a4068d960a Remove unnecessary whitespaces.
Pavel Janík <Pavel@Janik.cz>
parents: 27313
diff changeset
230 ;;}}}
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
231
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
232 ;;{{{ High-level interfaces (interactive functions)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
233
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
234 (defun eudc-bbdb-set-server (dummy)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
235 "Set the EUDC server to BBDB."
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
236 (interactive)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
237 (eudc-set-server dummy 'bbdb)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
238 (message "BBDB server selected"))
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
239
42570
78a4068d960a Remove unnecessary whitespaces.
Pavel Janík <Pavel@Janik.cz>
parents: 27313
diff changeset
240 ;;}}}
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
241
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
242
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
243 (eudc-register-protocol 'bbdb)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
244
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
245 (provide 'eudcb-bbdb)
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
246
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 49598
diff changeset
247 ;;; arch-tag: 38276208-75de-4dbc-ba6f-8db684c32e0a
27313
babfd92e24bf *** empty log message ***
Gerd Moellmann <gerd@gnu.org>
parents:
diff changeset
248 ;;; eudcb-bbdb.el ends here