forked from trebb/bbdb-vcard
-
Notifications
You must be signed in to change notification settings - Fork 10
/
bbdb-vcard.texi
186 lines (138 loc) · 5.98 KB
/
bbdb-vcard.texi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
\input texinfo.tex @c -*-texinfo-*-
@c %**start of header
@setfilename bbdb-vcard.info
@settitle vCard import/export for BBDB
@documentencoding utf-8
@c %**end of header
@dircategory Emacs
@direntry
* BBDB vCard: (bbdb-vcard). vCard import/export for BBDB.
@end direntry
@copying
Copyright @copyright{} 2010 Bert Burgemeister
Copyright @copyright{} 2013 Toke Høiland-Jørgensen, Kevin Brubeck Unhammer, Steve Purcell, Vincent Geddes
@quotation
Permission is granted to copy, distribute and/or modify this document
under the terms of the GNU Free Documentation License, Version 1.2 or
any later version published by the Free Software Foundation; with no
Invariant Sections, with no Front-Cover Texts, and with no Back-Cover
Texts. A copy of the license is included in the section entitled
``GNU Free Documentation License''.
@end quotation
@end copying
@node Top
@top BBDB vCard Documentation
Import and export of vCards as defined in RFC 2425 and RFC 2426
to/from The Insidious Big Brother Database (BBDB).
@menu
* Setup::
* Import Contacts::
* Export Contacts::
* Implementation::
@end menu
@node Setup
@chapter Setup
Put this file and file vcard.el into your @code{load-path} and add the
following line to your Emacs initialization file:
@lisp
(require 'bbdb-vcard)
(bbdb-vcard-default-keybindings) ; optional, binds v/V keys in bbdb
@end lisp
@noindent If you use @code{use-package} for deferred loading, you may prefer:
@lisp
(use-package bbdb-vcard
:ensure t ; get it from Melpa
:after bbdb ; defer until bbdb loaded
:config ; bind v/V keys
(bbdb-vcard-default-keybindings))
@end lisp
@node Import Contacts
@chapter Import Contacts
On a file, a buffer or a region containing one or more vCards, use
@code{bbdb-vcard-import-file}, @code{bbdb-vcard-import-buffer}, or
@code{bbdb-vcard-import-region} respectively to import them into BBDB.
Preferred input format is vCard version 3.0. Version 2.1 vCards
are converted to version 3.0 on import.
@node Export Contacts
@chapter Export Contacts
In buffer *BBDB*, press v to export the record under point. Press
@kbd{* v} to export all records in buffer into one vCard file. Press @kbd{* C-u v}
to export them into one file each. To put one or all vCard(s) into the kill ring, press @kbd{V} or @kbd{* V}
respectively.
Exported vCards are always version 3.0. They can be re-imported
without data loss with one exception: North American phone numbers
lose their structure and are stored as flat strings.
There are a few customization variables grouped under `bbdb-vcard'.
@node Implementation
@chapter Implementation
@menu
* vCard Import::
* vCard Export::
@end menu
@node vCard Import
@section vCard Import
Noah Friedman's vcard.el (included) is used to convert v2.1 vCards to the v3.0 form.
An existing BBDB record is extended by new information from a vCard
(a) if name and organization and an email address match
(b) or if name and organization match
(c) or if name and an email address match
(d) or if name and birthday match
(e) or if name and a phone number match.
Otherwise, a fresh BBDB record is created.
When @code{bbdb-vcard-try-merge} is set to nil, there is always a fresh
record created.
In cases (c), (d), and (e), if the vCard has ORG defined, this ORG
would overwrite an existing Organization in BBDB.
Phone numbers are always imported as strings.
For vCard types that have more or less direct counterparts in BBDB,
labels and parameters are translated and structured values
(lastname; firstname; additional names; prefixes etc.) are
converted appropriately with the risk of some (hopefully
unessential) information loss. For labels of the vCard types ADR
and TEL, parameter translation is defined in
@code{bbdb-vcard-import-translation-table}.
If there is a REV element, it is stored in BBDB's creation-date in
newly created BBDB records, or discarded for existing ones. Time
and time zone information from REV are stored there as well if
there are any, but are ignored by BBDB (v2.36).
VCard type prefixes (A.ADR:..., B.ADR:... etc.) are stripped off
and discarded from the following types: N, FN, NICKNAME, ORG (first
occurrence), ADR, TEL, EMAIL, URL, BDAY (first occurrence), NOTE.
VCard types that are prefixed `X-BBDB-' are stored in BBDB without
the prefix.
VCard type X-BBDB-ANNIVERSARY may contain (previously exported)
newline-separated non-birthday anniversaries that are meant to be
read by org-mode.
All remaining vCard types that don't match the regexp in
@code{bbdb-vcard-skip-on-import} and that have a non-empty value are
stored unaltered in the BBDB Notes alist where, for instance,
`TZ;VALUE=text:-05:00' is stored as `(tz\;value=text . "-05:00")'.
From the BBDB data fields AKA, Phones, Addresses, Net Addresses,
and Notes, duplicates are removed, respectively.
VCards found inside other vCards (as values of type AGENT) are
imported as well.
Handling of the individual types defined in RFC2426 during import
(assuming default label translation and no vCard type exclusion):
@node vCard Export
@section vCard Export
VCard types N (only fields lastname, firstname) and FN both come
from BBDB's Name.
Members of BBDB field AKA are stored comma-separated under the
vCard type NICKNAME.
Labels of Addresses and Phones are translated as defined in
@code{bbdb-vcard-export-translation-table} into type parameters of
vCard types ADR and TEL, respectively.
In vCard type ADR, fields postbox and extended address are always
empty. Newlines which subdivide BBDB Address fields are converted
into commas subdividing vCard ADR fields.
The value of 'anniversary in Notes is supposed to be subdivided by
newlines. The birthday part (either just a date or a date followed
by \"birthday\") is stored under vCard type BDAY. The rest is
stored newline-separated in the non-standard vCard type
X-BBDB-ANNIVERSARY.
Field names listed in @code{bbdb-vcard-x-bbdb-candidates} are in the
exported vCard prepended by `X-BBDB-'.
The creation-date of the BBDB record is stored as vCard type REV.
Remaining members of BBDB Notes are exported to the vCard without
change.
@bye