0
|
1 ;;; VM user and internal variable initialization
|
98
|
2 ;;; Copyright (C) 1989-1997 Kyle E. Jones
|
0
|
3 ;;;
|
|
4 ;;; This program is free software; you can redistribute it and/or modify
|
|
5 ;;; it under the terms of the GNU General Public License as published by
|
|
6 ;;; the Free Software Foundation; either version 1, or (at your option)
|
|
7 ;;; any later version.
|
|
8 ;;;
|
|
9 ;;; This program is distributed in the hope that it will be useful,
|
|
10 ;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
11 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
12 ;;; GNU General Public License for more details.
|
|
13 ;;;
|
|
14 ;;; You should have received a copy of the GNU General Public License
|
|
15 ;;; along with this program; if not, write to the Free Software
|
|
16 ;;; Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
17
|
|
18 (provide 'vm-vars)
|
|
19
|
|
20 (defvar vm-init-file "~/.vm"
|
|
21 "*Startup file for VM that is loaded the first time you run VM
|
|
22 in an Emacs session.")
|
|
23
|
98
|
24 (defvar vm-preferences-file "~/.vm.preferences"
|
0
|
25 "*Secondary startup file for VM, loaded after vm-init-file.
|
|
26 This file is written and overwritten by VM and is not meant for
|
98
|
27 users to edit directly.")
|
0
|
28
|
|
29 (defvar vm-primary-inbox "~/INBOX"
|
|
30 "*Mail is moved from the system mailbox to this file for reading.")
|
|
31
|
|
32 (defvar vm-crash-box "~/INBOX.CRASH"
|
|
33 "*File in which to store mail temporarily while it is transferred from
|
|
34 the system mailbox to the primary inbox. If a crash occurs
|
|
35 during this mail transfer, any missing mail will be found in this
|
|
36 file. VM will do crash recovery from this file automatically at
|
|
37 startup, as necessary.")
|
|
38
|
|
39 (defvar vm-keep-crash-boxes nil
|
|
40 "*Non-nil value should be a string specifying a directory where
|
|
41 your crash boxes should be moved after VM has copied new mail
|
|
42 out of them. This is a safety measure. In at least one case a
|
|
43 pointer corruption bug inside Emacs has caused VM to believe that
|
|
44 it had copied information out of the crash box when it in fact
|
|
45 had not. VM then deleted the crash box, losing the batch of
|
|
46 incoming mail. This is an exceedingly rare problem, but if you
|
|
47 want to avoid losing mail if it happens, set vm-keep-crash-boxes
|
|
48 to point to a directory in the same filesystem as all your
|
|
49 crash boxes. Each saved crash box will have a unique name based
|
|
50 on the current date and time the box was saved. You will need to
|
|
51 clean out this directory from time to time; VM does not do so.
|
|
52
|
|
53 A nil value means VM should just delete crash boxes after it
|
|
54 has copied out the mail.")
|
|
55
|
|
56 ;; use this function to access vm-spool-files on the fly. this
|
|
57 ;; allows us to use environmental variables without setting
|
|
58 ;; vm-spool-files at load time and thereby making it hard to dump an
|
|
59 ;; Emacs containing a preloaded VM.
|
|
60 (defun vm-spool-files ()
|
|
61 (or vm-spool-files
|
|
62 (and (setq vm-spool-files (getenv "MAILPATH"))
|
|
63 (setq vm-spool-files
|
|
64 (vm-parse vm-spool-files
|
|
65 "\\([^:%?]+\\)\\([%?][^:]*\\)?\\(:\\|$\\)")))
|
|
66 (and (setq vm-spool-files (getenv "MAIL"))
|
|
67 (setq vm-spool-files (list vm-spool-files)))))
|
|
68
|
|
69 (defvar vm-spool-files nil
|
|
70 "*If non-nil this variable's value should be a list of strings
|
|
71 or a list of lists.
|
|
72
|
|
73 If the value is a list of strings, the strings should name files
|
|
74 that VM will check for incoming mail instead of the default place
|
|
75 VM thinks your system mailbox is. Mail will be moved from these
|
|
76 mailboxes to your primary inbox as specified by vm-primary-inbox,
|
|
77 using vm-crash-box as a waystation.
|
|
78
|
|
79 If the value is a list of lists, each sublist should be of the form
|
|
80
|
|
81 (INBOX SPOOLNAME CRASHBOX)
|
|
82
|
|
83 INBOX, SPOOLNAME and CRASHBOX are all strings.
|
|
84
|
|
85 INBOX is the folder where you want your new mail to be moved when
|
|
86 you type 'g' (running vm-get-new-mail) in VM. It is where you
|
|
87 will read the mail.
|
|
88
|
|
89 SPOOLNAME is where the mail system leaves your incoming mail,
|
|
90 e.g. /var/spool/mail/kyle. It can also be a POP maildrop,
|
|
91 provided it can be matched by the value of vm-recognize-pop-maildrops.
|
|
92
|
|
93 A POP maildrop specification has the following format:
|
|
94
|
|
95 \"HOST:PORT:AUTH:USER:PASSWORD\"
|
|
96
|
|
97 HOST is the host name of the POP server
|
|
98 PORT is the TCP port number to connect to (should normally be 110).
|
|
99 USER is the user name sent to the server.
|
|
100 PASSWORD is the secret shared by you and the server for
|
|
101 authentication purposes. How is it used depends on the value of
|
|
102 the AUTH parameter. If the PASSWORD is \"*\", VM will prompt
|
|
103 you for the password the first time you try to retrieve mail from
|
|
104 maildrop. If the password is valid, VM will not ask you for the
|
|
105 password again during this Emacs session.
|
|
106
|
|
107 AUTH is the authentication method used to convince the server you
|
|
108 should have access to the maildrop. Acceptable values are
|
|
109 \"pass\", \"rpop\" and \"apop\". For \"pass\", the PASSWORD is sent to
|
|
110 the server with the POP PASS command. For \"rpop\", the PASSWORD
|
|
111 should be the string to be sent to the server via the RPOP
|
|
112 command. In this case the string is not really a secret;
|
|
113 authentication is done by other means. For \"apop\", an MD5 digest
|
|
114 of the PASSWORD appended to the server timestamp will be sent to
|
|
115 the server with the APOP command. In order to use \"apop\" you
|
|
116 will have to set the value of vm-pop-md5-program appropriately to
|
|
117 point at the program that will generate the MD5 digest that VM
|
|
118 needs.
|
|
119
|
|
120 CRASHBOX is the temporary file that VM uses to store mail in
|
|
121 between the SPOOLNAME and the INBOX. If the system crashes or
|
|
122 Emacs dies while mail is being moved, and the new mail is not in
|
|
123 the SPOOLNAME or the INBOX, then it will be in the CRASHBOX.
|
|
124
|
|
125 There can be multiple entries with the same INBOX value, but a
|
|
126 particular SPOOLNAME should appear only once. CRASHBOXes should
|
|
127 not be shared among different INBOXes, but you can use the same
|
|
128 CRASHBOX/INBOX pair with a different SPOOLNAME.
|
|
129
|
|
130 NOTE: The values of vm-primary-inbox and vm-crash-box are ignored
|
|
131 when getting new mail if vm-spool-files is a list of lists.
|
|
132
|
|
133 vm-spool-files will default to the value of the shell
|
|
134 environmental variables MAILPATH or MAIL if either of these
|
|
135 variables are defined and no particular value for vm-spool-files
|
|
136 has been specified.")
|
|
137
|
98
|
138 (defvar vm-spool-file-suffixes nil
|
|
139 "*List of suffixes to be used to create possible spool file names
|
|
140 for folders. Example:
|
|
141
|
|
142 (setq vm-spool-file-suffixes '(\".spool\" \"-\"))
|
|
143
|
|
144 If you visit a folder ~/mail/beekeeping, when VM attempts to
|
|
145 retrieve new mail for that folder it will look for mail in
|
|
146 ~/mail/beekeeping.spool and ~/mail/beekeeping- in addition to
|
|
147 scanning vm-spool-files for matches.
|
|
148
|
|
149 The value of vm-spool-files-suffixes will not be used unless
|
|
150 vm-crash-box-suffix is also defined, since a crash box is
|
|
151 required for all mail retrieval from spool files.")
|
|
152
|
|
153 (defvar vm-crash-box-suffix nil
|
|
154 "*String suffix used to create possible crash box file names for folders.
|
|
155 When VM uses vm-spool-file-suffixes to create a spool file name,
|
|
156 it will append the value of vm-crash-box-suffix to the folder's
|
|
157 file name to create a crash box name.")
|
|
158
|
|
159 (defvar vm-make-spool-file-name nil
|
|
160 "*Non-nil value should be a function that returns a spool file name
|
|
161 for a folder. The function will be called with one argument, the
|
|
162 folder's file name. If the folder does not have a file name,
|
|
163 the function will not be called.")
|
|
164
|
|
165 (defvar vm-make-crash-box-name nil
|
|
166 "*Non-nil value should be a function that returns a crash box file name
|
|
167 for a folder. The function will be called with one argument, the
|
|
168 folder's file name. If the folder does not have a file name,
|
|
169 the function will not be called.")
|
|
170
|
0
|
171 (defvar vm-pop-md5-program "md5"
|
|
172 "*Program that reads a message on its standard input and writes an
|
|
173 MD5 digest on its output.")
|
|
174
|
100
|
175 (defvar vm-pop-max-message-size nil
|
|
176 "*If VM is about to retrieve via POP a message larger than this size
|
|
177 (in bytes) it will ask the you whether it should retrieve the message.
|
|
178
|
|
179 If VM is retrieving mail automatically because vm-auto-get-new-mail is
|
|
180 set to a numeric value then you will not be prompted about large messages.
|
|
181 This is to avoid prompting you while you're typing in another buffer.
|
|
182 In this case the large message will be skipped with a warning
|
|
183 message.
|
|
184
|
|
185 A nil value for vm-pop-max-message-size means no size limit.")
|
|
186
|
|
187 (defvar vm-pop-messages-per-session nil
|
|
188 "*Non-nil value should be a integer specifying how many messages to
|
|
189 retrieve per POP session. When you type 'g' to get new mail, VM
|
|
190 will only retrieve that many messages from any particular POP maildrop.
|
|
191 To retrieve more messages, type 'g' again.
|
|
192
|
|
193 A nil value means there's no limit.")
|
|
194
|
|
195 (defvar vm-pop-bytes-per-session nil
|
|
196 "*Non-nil value should be a integer specifying how many bytes to
|
|
197 retrieve per POP session. When you type 'g' to get new mail, VM
|
|
198 will only retrieve messages until the byte limit is reached on
|
|
199 any particular POP maildrop. To retrieve more messages, type 'g'
|
|
200 again.
|
|
201
|
|
202 A nil value means there's no limit.")
|
|
203
|
0
|
204 (defvar vm-recognize-pop-maildrops "^[^:]+:[^:]+:[^:]+:[^:]+:[^:]+"
|
|
205 "*Value if non-nil should be a regular expression that matches
|
|
206 spool names found in vm-spool-files that should be considered POP
|
|
207 maildrops. A nil value tells VM that all the spool names are to
|
|
208 be considered files.")
|
|
209
|
|
210 (defvar vm-auto-get-new-mail t
|
|
211 "*Non-nil value causes VM to automatically move mail from spool files
|
|
212 to a mail folder when the folder is first visited. Nil means
|
|
213 you must always use vm-get-new-mail to pull in newly arrived messages.
|
|
214
|
|
215 If the value is a number, then it specifies how often (in
|
|
216 seconds) VM should check for new mail and try to retrieve it.
|
|
217 This is done asynchronously and may occur while you are editing
|
|
218 other files. It should not disturb your editing, except perhaps
|
98
|
219 for a pause while the check is being done.")
|
24
|
220
|
100
|
221 (defvar vm-mail-check-interval 300
|
|
222 "*Numeric value specifies the number of seconds between checks
|
|
223 for new mail. The maildrops for all visited folders are checked.
|
|
224 The buffer local variable vm-spooled-mail-waiting is set non-nil
|
|
225 in the buffers of those folders that have mail waiting.")
|
|
226
|
|
227 (defvar vm-spooled-mail-waiting nil
|
|
228 "Value is non-nil if there is mail waiting for the current folder.
|
|
229 This variable's value is local in all buffers.
|
|
230 VM maintains this variable, you should not set it.")
|
|
231 (make-variable-buffer-local 'vm-spooled-mail-waiting)
|
|
232
|
0
|
233 (defvar vm-default-folder-type
|
|
234 (cond ((not (boundp 'system-configuration))
|
|
235 'From_)
|
|
236 ((or (string-match "-solaris" system-configuration)
|
|
237 (string-match "usg-unix-v" system-configuration)
|
|
238 (string-match "-ibm-aix" system-configuration))
|
|
239 'From_-with-Content-Length)
|
|
240 ((string-match "-sco" system-configuration)
|
|
241 'mmdf)
|
|
242 (t 'From_))
|
|
243 "*Default folder type for empty folders.
|
|
244 If VM has to add messages that have no specific folder type to an
|
|
245 empty folder, the folder will become this default type.
|
|
246 Allowed types are:
|
|
247
|
|
248 From_
|
|
249 From_-with-Content-Length
|
|
250 mmdf
|
|
251 babyl
|
|
252
|
|
253 Value must be a symbol, not a string. i.e. write
|
|
254
|
|
255 (setq vm-default-folder-type 'From_)
|
|
256
|
|
257 in your .emacs or .vm file.
|
|
258
|
|
259 If you set this variable's value to From_-with-Content-Length you
|
|
260 must set vm-trust-From_-with-Content-Length non-nil.")
|
|
261
|
|
262 (defvar vm-check-folder-types t
|
|
263 "*Non-nil value causes VM to check folder and message types for
|
|
264 compatibility before it performs certain operations.
|
|
265
|
|
266 Before saving a message to a folder, VM will check that the destination folder
|
|
267 is of the same type as the message to be saved.
|
|
268
|
|
269 Before incorporating message into a visited folder, VM will check that the
|
|
270 messages are of the same type as that folder.
|
|
271
|
|
272 A nil value means don't do the checks.
|
|
273
|
70
|
274 Depending on the value of vm-convert-folder-types VM will either
|
|
275 convert the messages to the appropriate type before saving or
|
|
276 incorporating them, or it will signal an error.")
|
0
|
277
|
|
278 (defvar vm-convert-folder-types t
|
|
279 "*Non-nil value means that when VM checks folder types and finds
|
|
280 a mismatch (see vm-check-folder-types), it will convert the
|
|
281 source messages to the type of the destination folder, if it can.
|
|
282
|
|
283 If vm-check-folder-types is nil, then this variable isn't
|
|
284 consulted.")
|
|
285
|
|
286 (defvar vm-trust-From_-with-Content-Length
|
|
287 (eq vm-default-folder-type 'From_-with-Content-Length)
|
|
288 "*Non-nil value means that if the first message in a folder contains
|
|
289 a Content-Length header and begins with \"From \" VM can safely
|
|
290 assume that all messages in the folder have Content-Length headers
|
|
291 that specify the length of the text section of each message. VM
|
|
292 will then use these headers to determine message boundaries
|
|
293 instead of the usual way of searching for two newlines followed by a
|
|
294 line that begins with \"From \".
|
|
295
|
|
296 If you set vm-default-folder-type to From_-with-Content-Length you
|
|
297 must set this variable non-nil.")
|
|
298
|
|
299 (defvar vm-visible-headers
|
|
300 '("Resent-"
|
|
301 "From:" "Sender:"
|
|
302 "To:" "Apparently-To:" "Cc:"
|
|
303 "Subject:"
|
|
304 "Date:")
|
|
305 "*List of headers that should be visible when VM first displays a message.
|
|
306 These should be listed in the order you wish them presented.
|
|
307 Regular expressions are allowed. There's no need to anchor
|
|
308 patterns with \"^\", as searches always start at the beginning of
|
|
309 a line. Put a colon at the end of patterns to get exact matches.
|
|
310 For example, \"Date\" matches \"Date\" and \"Date-Sent\". Header names
|
|
311 are always matched case insensitively.
|
|
312
|
|
313 If the value of vm-invisible-header-regexp is nil, only the
|
|
314 headers matched by vm-visible-headers will be displayed.
|
|
315 Otherwise all headers are displayed except those matched by
|
|
316 vm-invisible-header-regexp. In this case vm-visible-headers
|
|
317 specifies the order in which headers are displayed. Headers not
|
|
318 matching vm-visible-headers are display last.")
|
|
319
|
|
320 (defvar vm-invisible-header-regexp nil
|
|
321 "*Non-nil value should be a regular expression that tells what headers
|
|
322 VM should NOT normally display when presenting a message. All other
|
|
323 headers will be displayed. The variable vm-visible-headers specifies
|
|
324 the presentation order of headers; headers not matched by
|
|
325 vm-visible-headers are displayed last.
|
|
326
|
|
327 Nil value causes VM to display ONLY those headers specified in
|
|
328 vm-visible-headers.")
|
|
329
|
|
330 (defvar vm-highlighted-header-regexp nil
|
|
331 "*Value specifies which headers to highlight.
|
|
332 This is a regular expression that matches the names of headers that should
|
|
333 be highlighted when a message is first presented. For example setting
|
|
334 this variable to \"From:\\\\|Subject:\" causes the From and Subject
|
|
335 headers to be highlighted.
|
|
336
|
|
337 This does not work under version 18 Emacs.
|
|
338
|
|
339 If you're using XEmacs, you might want to use the builtin
|
|
340 `highlight-headers' package instead. If so, then you should set
|
|
341 the variable vm-use-lucid-highlighting non-nil. You'll need to
|
|
342 set the various variables used by the highlight-headers package
|
|
343 to customize highlighting. vm-highlighted-header-regexp is
|
|
344 ignored in this case.")
|
|
345
|
|
346 (defvar vm-use-lucid-highlighting
|
|
347 ;; (not (not ...)) to avoid the confusing value of 6.
|
|
348 (not (not (string-match "XEmacs" emacs-version)))
|
|
349 "*Non-nil means to use the `highlight-headers' package in XEmacs.
|
|
350 Nil means just use VM's builtin header highlighting code.
|
|
351
|
|
352 FSF Emacs always uses VM's builtin highlighting code.")
|
|
353
|
|
354 (defvar vm-highlighted-header-face 'bold
|
|
355 "*Face to be used to highlight headers.
|
98
|
356 The header to highlight are sepcified by the vm-highlighted-header-regexp
|
|
357 variable.
|
|
358
|
|
359 This variable is ignored under XEmacs if vm-use-lucid-highlighting is
|
|
360 nil. XEmacs' highlight-headers package is used instead. See the
|
|
361 documentation for the function `highlight-headers' to find out how to
|
|
362 customize header highlighting using this package.")
|
0
|
363
|
|
364 (defvar vm-preview-lines 0
|
|
365 "*Non-nil value N causes VM to display the visible headers + N lines of text
|
|
366 of a message when it is first presented. The message is not actually
|
|
367 flagged as read until it is exposed in its entirety.
|
|
368
|
|
369 A value of t causes VM to display as much of the message as will
|
|
370 fit in the window associated with the folder buffer.
|
|
371
|
|
372 A nil value causes VM not to preview messages; no text lines are hidden and
|
|
373 messages are immediately flagged as read.")
|
|
374
|
|
375 (defvar vm-preview-read-messages nil
|
|
376 "*Non-nil value means to preview messages even if they've already been read.
|
|
377 A nil value causes VM to preview messages only if new or unread.")
|
|
378
|
98
|
379 (defvar vm-display-using-mime t
|
|
380 "*Non-nil value means VM should display messages using MIME.
|
|
381 MIME (Multipurpose Internet Mail Extensions) is a set of
|
|
382 extensions to the standard Internet message format that allows
|
|
383 reliable tranmission and reception of arbitrary data including
|
|
384 images, audio and video as well as traditional text.
|
|
385
|
|
386 A non-nil value for this variable means that VM will recognize
|
|
387 MIME encoded messages and display them as specified by the
|
|
388 various MIME standards specifications.
|
|
389
|
|
390 A nil value means VM will not display MIME messages any
|
|
391 differently than any other message.")
|
|
392
|
|
393 ;; try to avoid bad interaction with TM
|
|
394 (defvar vm-send-using-mime (not (featurep 'mime-setup))
|
|
395 "*Non-nil value means VM should support sending messages using MIME.
|
|
396 MIME (Multipurpose Internet Mail Extensions) is a set of
|
|
397 extensions to the standard Internet message format that allows
|
|
398 reliable tranmission and reception of arbitrary data including
|
|
399 images, audio and video as well as traditional text.
|
|
400
|
|
401 A non-nil value for this variable means that VM will
|
|
402
|
|
403 - allow you to attach files and messages to your outbound message.
|
|
404 - analyze the composition buffer when you send off a message and
|
|
405 encode it as needed.
|
|
406
|
|
407 A nil value means VM will not offer any support for composing
|
|
408 MIME messages.")
|
|
409
|
|
410 (defvar vm-honor-mime-content-disposition nil
|
|
411 "*Non-nil value means use information from the Content-Disposition header
|
|
412 to display MIME messages. The Content-Disposition header
|
|
413 specifies whether a MIME object should be displayed inline or
|
|
414 treated as an attachment. For VM, ``inline'' display means
|
|
415 displaying the object in the Emacs buffer, if possible.
|
|
416 Attachments will be displayed as a button that you can use
|
|
417 mouse-2 to activate or mouse-3 to pull up a menu of options.")
|
|
418
|
|
419 (defvar vm-auto-decode-mime-messages nil
|
|
420 "*Non-nil value causes MIME decoding to occur automatically
|
|
421 when a message containing MIME objects is exposed. A nil value
|
|
422 means that you will have to run the `vm-decode-mime-message'
|
|
423 command (normally bound to `D') manually to decode and display
|
|
424 MIME objects.")
|
|
425
|
|
426 (defvar vm-auto-displayed-mime-content-types '("text" "multipart")
|
|
427 "*List of MIME content types that should be displayed immediately
|
|
428 after decoding. Other types will be displayed as a button that
|
|
429 the user must activate to display the object.
|
|
430
|
|
431 A value of t means that all types should be displayed immediately.
|
|
432 A nil value means never display MIME objects immediately; only use buttons.
|
|
433
|
|
434 If the value is a list, it should be a list of strings, which
|
|
435 should all be types or type/subtype pairs. Example:
|
|
436
|
|
437 (setq vm-auto-displayed-mime-content-types '(\"text\" \"image/jpeg\"))
|
|
438
|
|
439 If a top-level type is listed without a subtype, all subtypes of
|
|
440 that type are assumed to be included.
|
|
441
|
|
442 Note that some types are processed specially, and this variable does not
|
|
443 apply to them.
|
|
444
|
|
445 Multipart/Digest and Message/RFC822 messages are always
|
|
446 displayed as a button to avoid visiting a new folder while the
|
|
447 user is moving around in the current folder.
|
|
448
|
|
449 Message/Partial messages are always displayed as a button,
|
|
450 because there always needs to be a way to trigger the assembly
|
|
451 of the parts into a full message.
|
|
452
|
|
453 Any type that cannot be displayed internally or externally will
|
|
454 be displayed as a button that allows you to save the body to a
|
|
455 file.")
|
|
456
|
|
457 (defvar vm-mime-internal-content-types t
|
|
458 "*List of MIME content types that should be displayed internally
|
|
459 if Emacs is capable of doing so. A value of t means that VM
|
|
460 should always display an object internally if possible. A nil
|
|
461 value means never display MIME objects internally, which means VM
|
|
462 have to run an external viewer to display MIME objects.
|
|
463
|
|
464 If the value is a list, it should be a list of strings. Example:
|
|
465
|
|
466 (setq vm-mime-internal-content-types '(\"text\" \"image/jpeg\"))
|
|
467
|
|
468 If a top-level type is listed without a subtype, all subtypes of
|
|
469 that type are assumed to be included.
|
|
470
|
|
471 Note that all multipart types are always handled internally.
|
|
472 There is no need to list them here.")
|
|
473
|
|
474 (defvar vm-mime-external-content-types-alist nil
|
|
475 "*Alist of MIME content types and the external programs used to display them.
|
|
476 If VM cannot display a type internally or has been instructed not
|
|
477 to (see the documentation for the vm-mime-internal-content-types
|
|
478 variable) it will try to launch an external program to display that
|
|
479 type.
|
|
480
|
|
481 The alist format is
|
|
482
|
|
483 ( (TYPE PROGRAM ARG ARG ... ) ... )
|
|
484
|
|
485 TYPE is a string specifying a MIME type or type/subtype pair.
|
|
486 Example \"text\" or \"image/jpeg\". If a top-level type is
|
|
487 listed without a subtype, all subtypes of that type are assumed
|
|
488 to be included.
|
|
489
|
|
490 PROGRAM is a string naming a program to run to display an object.
|
|
491 Any ARGS will be passed to the program as arguments. The octets
|
|
492 that compose the object will be written into a file and the name
|
|
493 of the file will be passed to the program as its last argument.
|
|
494
|
|
495 Example:
|
|
496
|
|
497 (setq vm-mime-external-content-types-alist
|
|
498 '(
|
|
499 (\"text/html\" \"netscape\")
|
|
500 (\"image/gif\" \"xv\")
|
|
501 (\"image/jpeg\" \"xv\")
|
|
502 (\"video/mpeg\" \"mpeg_play\")
|
|
503 (\"video\" \"xanim\")
|
|
504 )
|
|
505 )
|
|
506
|
|
507 The first matching list element will be used.
|
|
508
|
|
509 No multipart message will ever be sent to an external viewer.")
|
|
510
|
|
511 (defvar vm-mime-type-converter-alist nil
|
|
512 "*Alist of MIME types and programs that can convert between them.
|
|
513 If VM cannot display a content type, it will scan this list to
|
|
514 see if the type can be converted into a type that it can display.
|
|
515
|
|
516 The alist format is
|
|
517
|
|
518 ( (START-TYPE END-TYPE COMMAND-LINE ) ... )
|
|
519
|
|
520 START-TYPE is a string specifying a MIME type or type/subtype pair.
|
|
521 Example \"text\" or \"image/jpeg\". If a top-level type is
|
|
522 listed without a subtype, all subtypes of that type are assumed
|
|
523 to be included.
|
|
524
|
|
525 END-TYPE must be an exact type/subtype pair. This is the type
|
|
526 to which START-TYPE will be converted.
|
|
527
|
|
528 COMMAND-LINE is a string giving a command line to be passed to
|
|
529 the shell. The octets that compose the object will be written to
|
|
530 the standard input of the shell command.
|
|
531
|
|
532 Example:
|
|
533
|
|
534 (setq vm-mime-type-converter-alist
|
|
535 '(
|
|
536 (\"image/jpeg\" \"image/gif\" \"jpeg2gif\")
|
|
537 (\"text/html\" \"text/plain\" \"striptags\")
|
|
538 )
|
|
539 )
|
|
540
|
|
541 The first matching list element will be used.")
|
|
542
|
|
543 (defvar vm-mime-alternative-select-method 'best-internal
|
|
544 "*Value tells how to choose which multipart/alternative part to display.
|
|
545 A MIME message of type multipart/alternative has multiple message
|
|
546 parts containing the same information, but each part may be
|
|
547 formatted differently. VM will display only one of the parts.
|
|
548 This variable tells VM how to choose which part to display.
|
|
549
|
|
550 A value of 'best means choose the part that is the most faithful to
|
|
551 the sender's original content that can be displayed.
|
|
552
|
|
553 A value of 'best-internal means choose the best part that can be
|
|
554 displayed internally, i.e. with the built-in capabilities of Emacs.
|
|
555 If none of the parts can be displayed internally, behavior reverts to
|
|
556 that of 'best.")
|
|
557
|
100
|
558 (defvar vm-mime-default-face-charsets '("us-ascii" "iso-8859-1")
|
|
559 "*List of character sets that can use the `default' face.
|
|
560 For other characters sets VM will have to create a new face and assign
|
|
561 a font to it that can be used to display that character set.")
|
|
562
|
|
563 (defvar vm-mime-charset-font-alist nil
|
|
564 "*Assoc list of character sets and fonts that can be used to display them.
|
|
565 The format of the list is:
|
|
566
|
|
567 ( (CHARSET . FONT) ...)
|
|
568
|
|
569 CHARSET is a string naming a MIME registered character set such
|
|
570 as \"iso-8859-5\". Character set names should be specified in
|
|
571 lower case.
|
|
572
|
|
573 FONT is a string naming a font that can be used to display CHARSET.
|
|
574
|
|
575 An example setup might be:
|
|
576
|
|
577 (setq vm-mime-charset-font-alist
|
|
578 '(
|
|
579 (\"iso-8859-7\" . \"-*-*-medium-r-normal--16-160-72-72-c-80-iso8859-7\")
|
|
580 )
|
|
581 )
|
|
582
|
|
583 This variable is only useful for character sets whose characters
|
|
584 can all be encoded in single 8-bit bytes. Also multiple fonts
|
|
585 can only be displayed if you're running under a window system
|
|
586 e.g. X windows. So this variable will have no effect if you're
|
|
587 running Emacs on a tty.
|
|
588
|
|
589 Note that under FSF Emacs any fonts you use must be the same size
|
|
590 as your default font. XEmacs does not have this limitation.")
|
|
591
|
98
|
592 (defvar vm-mime-button-face
|
|
593 (cond ((fboundp 'find-face)
|
|
594 (or (and (not (eq (device-type) 'tty)) (find-face 'gui-button-face)
|
|
595 'gui-button-face)
|
|
596 (and (find-face 'bold-italic) 'bold-italic)))
|
|
597 ((fboundp 'facep)
|
|
598 (or (and (facep 'gui-button-face) 'gui-button-face)
|
|
599 (and (facep 'bold-italic) 'bold-italic))))
|
|
600 "*Face used for text in buttons that trigger the display of MIME objects.")
|
|
601
|
|
602 (defvar vm-mime-8bit-composition-charset "iso-8859-1"
|
|
603 "*Character set that VM should assume if it finds non-US-ASCII characters
|
|
604 in a composition buffer. Composition buffers are assumed to use
|
|
605 US-ASCII unless the buffer contains a byte with the high bit set.
|
|
606 This variable specifies what character set VM should assume if
|
100
|
607 such a character is found.
|
|
608
|
|
609 This variable is unused in XEmacs/MULE. Since multiple character
|
|
610 sets can be displayed in a single buffer under MULE, VM will map
|
|
611 the file coding system of the buffer to a single MIME character
|
|
612 that can display all the buffer's characters.")
|
98
|
613
|
|
614 (defvar vm-mime-8bit-text-transfer-encoding 'quoted-printable
|
|
615 "*Symbol specifying what kind of transfer encoding to use on 8bit
|
|
616 text. Characters with the high bit set cannot safely pass
|
|
617 through all mail gateways and mail transport software. MIME has
|
|
618 two transfer encodings that convert 8-bit data to 7-bit for same
|
|
619 transport. Quoted-printable leaves the text mostly readable even
|
100
|
620 if the recipient does not have a MIME-capable mail reader. BASE64
|
|
621 is unreadable without a MIME-capable mail reader, unless your name
|
98
|
622 is U3BvY2s=.
|
|
623
|
|
624 A value of 'quoted-printable, means to use quoted-printable encoding.
|
|
625 A value of 'base64 means to use BASE64 encoding.
|
|
626 A value of '8bit means to send the message as is.
|
|
627
|
|
628 Note that this only applies to textual MIME content types. Images, audio,
|
|
629 video, etc. will always use BASE64 encoding.
|
|
630
|
|
631 Note that lines of 1000 characters or longer will automatically
|
|
632 trigger BASE64 encoding. Carriage returns (ascii code 13) in the
|
|
633 text will also trigger BASE64 encoding.")
|
|
634
|
|
635 (defvar vm-mime-attachment-auto-type-alist
|
|
636 '(
|
|
637 ("\\.jpe?g" . "image/jpeg")
|
|
638 ("\\.gif" . "image/gif")
|
|
639 ("\\.png" . "image/png")
|
100
|
640 ("\\.tiff?" . "image/tiff")
|
|
641 ("\\.html?" . "text/html")
|
98
|
642 ("\\.au" . "audio/basic")
|
|
643 ("\\.mpe?g" . "video/mpeg")
|
|
644 ("\\.ps" . "application/postscript")
|
|
645 )
|
|
646 "*Alist used to guess a MIME content type based on a file name.
|
|
647 The list format is
|
|
648
|
|
649 ((REGEXP . TYPE) ...)
|
|
650
|
|
651 REGEXP is a string that specifies a regular expression.
|
|
652 TYPE is a string specifying a MIME content type.
|
|
653
|
|
654 When a non-MIME file is attached to a MIME composition buffer,
|
|
655 this list will be scanned until a REGEXP matches the file's name.
|
|
656 The corresponding TYPE will be offered as a default when you are
|
|
657 prompted for the file's type.")
|
|
658
|
|
659 (defvar vm-mime-max-message-size nil
|
|
660 "*Largest MIME message that VM should send without fragmentation.
|
|
661 The value should be a integer which specifies the size in bytes.
|
|
662 A message larger than this value will be split into multiple parts
|
|
663 for transmission using the MIME message/partial type.")
|
|
664
|
|
665 (defvar vm-mime-attachment-save-directory nil
|
|
666 "*Non-nil value is a default directory for saving MIME attachments.
|
|
667 When VM prompts you for a target file name when saving a MIME body,
|
|
668 any relative pathnames will be relative to this directory.")
|
|
669
|
|
670 (defvar vm-mime-avoid-folding-content-type nil
|
|
671 "*Non-nil means don't send folded Content-Type headers in MIME messages.
|
|
672 `Folded' headers are headers broken into multiple lines as specified
|
|
673 in RFC822 for readability and to avoid excessive line lengths. At
|
|
674 least one major UNIX vendor ships a version of sendmail that believes
|
|
675 a folded Content-Type header is a syntax error, and returns any such
|
|
676 message to sender. A typical error message from such a sendmail
|
|
677 version is,
|
|
678
|
|
679 553 header syntax error, line \" charset=us-ascii\"
|
|
680
|
|
681 If you see one of these, setting vm-mime-avoid-folding-content-type
|
|
682 non-nil may let your mail get through.")
|
|
683
|
|
684 (defvar vm-mime-base64-decoder-program nil
|
|
685 "*Non-nil value should be a string that names a MIME base64 decoder.
|
|
686 The program should expect to read base64 data on its standard
|
|
687 input and write the converted data to its standard output.")
|
|
688
|
|
689 (defvar vm-mime-base64-decoder-switches nil
|
|
690 "*List of command line flags passed to the command named by
|
|
691 vm-mime-base64-decoder-program.")
|
|
692
|
|
693 (defvar vm-mime-base64-encoder-program nil
|
|
694 "*Non-nil value should be a string that names a MIME base64 encoder.
|
|
695 The program should expect arbitrary data on its standard
|
|
696 input and write base64 data to its standard output.")
|
|
697
|
|
698 (defvar vm-mime-base64-encoder-switches nil
|
|
699 "*List of command line flags passed to the command named by
|
|
700 vm-mime-base64-encoder-program.")
|
|
701
|
0
|
702 (defvar vm-auto-next-message t
|
|
703 "*Non-nil value causes VM to use vm-next-message to advance to the next
|
|
704 message in the folder if the user attempts to scroll past the end of the
|
|
705 current messages. A nil value disables this behavior.")
|
|
706
|
|
707 (defvar vm-honor-page-delimiters nil
|
|
708 "*Non-nil value causes VM to honor page delimiters (as specified by the
|
|
709 Emacs page-delimiter variable) when scrolling through a message.")
|
|
710
|
|
711 (defvar vm-default-window-configuration
|
|
712 ;; startup = full screan summary
|
|
713 ;; quitting = full screen folder
|
|
714 ;; reading-message = folder on bottom, summary on top
|
|
715 ;; composing-message = full screen composition
|
|
716 ;; editing-message = full screen edit
|
|
717 ;; vm-summarize = folder on bottom, summary on top
|
|
718 '(
|
|
719 (startup
|
|
720 ((((top . 70) (left . 70)))
|
|
721 (((- (0 0 80 10) (0 10 80 40))
|
|
722 ((nil summary) (nil message))
|
|
723 ((nil nil nil t) (nil nil nil nil))))))
|
|
724 (quitting
|
|
725 ((((top . 70) (left . 70)))
|
|
726 (((0 0 80 40)
|
|
727 ((nil message))
|
|
728 ((nil nil nil t))))))
|
|
729 (reading-message
|
|
730 ((((top . 70) (left . 70)))
|
|
731 (((- (0 0 80 10) (0 10 80 40))
|
|
732 ((nil summary) (nil message))
|
|
733 ((nil nil nil t) (nil nil nil nil))))))
|
|
734 (composing-message
|
|
735 ((((top . 70) (left . 70)))
|
|
736 (((0 0 80 40)
|
|
737 ((nil composition))
|
|
738 ((nil nil nil t))))))
|
|
739 (editing-message
|
|
740 ((((top . 70) (left . 70)))
|
|
741 (((0 0 80 40)
|
|
742 ((nil edit))
|
|
743 ((nil nil nil t))))))
|
|
744 (vm-summarize
|
|
745 ((((top . 70) (left . 70)))
|
|
746 (((- (0 0 80 10) (0 10 80 40))
|
|
747 ((nil summary) (nil message))
|
|
748 ((nil nil nil t) (nil nil nil nil))))))
|
|
749 )
|
|
750 "Default window configuration for VM if the user does not specify one.
|
|
751 If you want to completely turn off VM's window configuration
|
|
752 feature, set this variable and vm-window-configuration-file to
|
|
753 nil in your .vm file.
|
|
754
|
|
755 If you want to have a different window configuration setup than
|
|
756 this, you should not set this variable directly. Rather you
|
|
757 should set the variable vm-window-configuration-file to point at
|
|
758 a file, and use the command vm-save-window-configuration
|
|
759 (normally bound to `WS') to modify part of this configuration to
|
|
760 your liking.
|
|
761
|
|
762 WARNING: Don't point vm-window-configuration-file at your .vm or
|
|
763 .emacs file. Your window configuration file should start out as
|
|
764 an empty or nonexistent file. VM will repeatedly overwrite this
|
|
765 file as you update your window configuration settings, so
|
|
766 anything else you put into this file will go away.")
|
|
767
|
|
768 (defvar vm-window-configuration-file "~/.vm.windows"
|
|
769 "*Non-nil value should be a string that tells VM where to load
|
|
770 and save your window configuration settings. Your window
|
|
771 configuration settings are loaded automatically the first time
|
|
772 you run VM in an Emacs session, and tells VM how to set up
|
|
773 windows depending on what you are doing inside VM.
|
|
774
|
|
775 The commands vm-save-window-configuration (normally bound to `WS') and
|
|
776 vm-delete-window-configuration (bound to `WD') let you update this
|
|
777 information; see their documentation for more information.
|
|
778
|
|
779 You cannot change your window configuration setup without giving
|
|
780 vm-window-configuration-file a non-nil value. A nil value causes
|
|
781 VM to use the default window setup specified by the value of
|
|
782 vm-default-window-configuration.
|
|
783
|
|
784 WARNING: Don't point vm-window-configuration-file at your .vm or
|
|
785 .emacs file. Your window configuration file should start out as
|
|
786 an empty or nonexistent file. VM will repeatedly overwrite this
|
|
787 file as you update your window configuration settings, so
|
|
788 anything else you put into this file will go away.")
|
|
789
|
|
790 (defvar vm-confirm-quit 0
|
|
791 "*Value of t causes VM to always ask for confirmation before quitting
|
|
792 a VM visit of a folder. A nil value means VM will ask only when messages
|
|
793 will be lost unwittingly by quitting, i.e. not removed by intentional
|
|
794 delete and expunge. A value that is not nil and not t causes VM to ask
|
|
795 only when there are unsaved changes to message attributes, or when messages
|
|
796 will be unwittingly lost.")
|
|
797
|
|
798 (defvar vm-folder-directory nil
|
|
799 "*Directory where folders of mail are kept.")
|
|
800
|
|
801 (defvar vm-confirm-new-folders nil
|
|
802 "*Non-nil value causes interactive calls to vm-save-message
|
|
803 to ask for confirmation before creating a new folder.")
|
|
804
|
|
805 (defvar vm-delete-empty-folders t
|
|
806 "*Non-nil value means remove empty (zero length) folders after saving
|
|
807 A value of t means always remove the folders.
|
|
808 A value of nil means never remove empty folders.
|
|
809 A value that's not t or nil means ask before removing empty folders.")
|
|
810
|
100
|
811 (defvar vm-flush-interval 90
|
0
|
812 "*Non-nil value specifies how often VM flushes its cached internal
|
|
813 data. A numeric value gives the number of seconds between
|
|
814 flushes. A value of t means flush every time there is a change.
|
|
815 Nil means don't do flushing until a message or folder is saved.
|
|
816
|
|
817 Normally when a message attribute is changed. VM keeps the record
|
|
818 of the change in its internal memory and doesn't insert the
|
|
819 changed data into the folder buffer until a particular message or
|
|
820 the whole folder is saved to disk. This makes normal Emacs
|
|
821 auto-saving useless for VM folder buffers because the information
|
98
|
822 you'd want to auto-save, i.e. the attribute changes are not in
|
0
|
823 the buffer when it is auto-saved.
|
|
824
|
|
825 Setting vm-flush-interval to a numeric value will cause the VM's
|
|
826 internal memory caches to be periodically flushed to the folder
|
|
827 buffer. This is done non-obtrusively, so that if you type
|
|
828 something while flushing is occurring, the flush will abort
|
|
829 cleanly and Emacs will respond to your keystrokes as usual.")
|
|
830
|
|
831 (defvar vm-visit-when-saving 0
|
|
832 "*Value determines whether VM will visit folders when saving messages.
|
|
833 `Visiting' means that VM will read the folder into Emacs and append the
|
|
834 message to the buffer instead of appending to the folder file directly.
|
|
835 This behavior is ideal when folders are encrypted or compressed since
|
|
836 appending plaintext directly to such folders is a ghastly mistake.
|
|
837
|
|
838 A value of t means VM will always visit folders when saving.
|
|
839
|
|
840 A nil value means VM will never visit folders before saving to them, and
|
|
841 VM will generate an error if you attempt to save messages to a folder
|
|
842 that is being visited. The latter restriction is necessary to insure
|
|
843 that the buffer and disk copies of the folder being visited remain
|
|
844 consistent.
|
|
845
|
|
846 A value that is not nil and not t means VM will save to a folder's
|
|
847 buffer if that folder is being visited, otherwise VM saves to the folder
|
|
848 file itself.")
|
|
849
|
|
850 (defvar vm-auto-folder-alist nil
|
|
851 "*Non-nil value should be an alist that VM will use to choose a default
|
|
852 folder name when messages are saved. The alist should be of the form
|
|
853 \((HEADER-NAME-REGEXP
|
|
854 (REGEXP . FOLDER-NAME) ...
|
|
855 ...))
|
|
856 where HEADER-NAME-REGEXP and REGEXP are strings, and FOLDER-NAME
|
|
857 is a string or an s-expression that evaluates to a string.
|
|
858
|
|
859 If any part of the contents of the message header whose name is
|
|
860 matched by HEADER-NAME-REGEXP is matched by the regular
|
|
861 expression REGEXP, VM will evaluate the corresponding FOLDER-NAME
|
|
862 and use the result as the default when prompting for a folder to
|
|
863 save the message in. If the resulting folder name is a relative
|
|
864 pathname, then it will be rooted in the directory named by
|
|
865 vm-folder-directory, or the default-directory of the currently
|
|
866 visited folder if vm-folder-directory is nil.
|
|
867
|
|
868 When FOLDER-NAME is evaluated, the current buffer will contain
|
|
869 only the contents of the header matched by HEADER-NAME-REGEXP.
|
|
870 It is safe to modify this buffer. You can use the match data
|
|
871 from any \\( ... \\) grouping constructs in REGEXP along with the
|
|
872 function buffer-substring to build a folder name based on the
|
|
873 header information. If the result of evaluating FOLDER-NAME is a
|
|
874 list, then the list will be treated as another auto-folder-alist
|
|
875 and will be descended recursively.
|
|
876
|
|
877 Whether REGEXP is matched case sensitively depends on the value
|
|
878 of the variable vm-auto-folder-case-fold-search. Header names
|
|
879 are always matched case insensitively.")
|
|
880
|
|
881 (defvar vm-auto-folder-case-fold-search nil
|
|
882 "*Non-nil value means VM will ignore case when matching header
|
|
883 contents while doing automatic folder selection via the variable
|
|
884 vm-auto-folder-alist.")
|
|
885
|
|
886 (defvar vm-virtual-folder-alist nil
|
|
887 "*Non-nil value should be a list of virtual folder definitions.
|
|
888
|
|
889 A virtual folder is a mapping of messages from one or more real folders
|
|
890 into what appears to be a single folder. A virtual folder definition
|
|
891 specifies which real folders should be searched for prospective messages
|
|
892 and what the inclusion criteria are.
|
|
893
|
|
894 Each virtual folder definition should have the following form:
|
|
895
|
|
896 (VIRTUAL-FOLDER-NAME
|
|
897 ( (FOLDER-NAME ...)
|
|
898 (SELECTOR [ARG ...]) ... )
|
|
899 ... )
|
|
900
|
|
901 VIRTUAL-FOLDER-NAME is the name of the virtual folder being defined.
|
|
902 This is the name by which you and VM will refer to this folder.
|
|
903
|
|
904 FOLDER-NAME should be the name of a real folder. There may be more than
|
|
905 one FOLDER-NAME listed, the SELECTORs within that sublist will apply to
|
|
906 them all. If FOLDER-NAME is a directory, VM will assume this to mean that
|
|
907 all the folders in that directory should be searched.
|
|
908
|
|
909 The SELECTOR is a Lisp symbol that tells VM how to decide whether a message
|
|
910 from one of the folders specified by the FOLDER-NAMEs should be included
|
|
911 in the virtual folder. Some SELECTORs require an argument ARG; unless
|
|
912 otherwise noted ARG may be omitted.
|
|
913
|
|
914 The recognized SELECTORs are:
|
|
915
|
|
916 author - matches message if ARG matches the author; ARG should be a
|
|
917 regular expression.
|
|
918 and - matches the message if all its argument
|
|
919 selectors match the message. Example:
|
|
920 (and (author \"Derek McGinty\") (new))
|
|
921 matches all new messages from Derek McGinty.
|
|
922 `and' takes any number of arguments.
|
|
923 any - matches any message.
|
|
924 deleted - matches message if it is flagged for deletion.
|
|
925 edited - matches message if it has been edited.
|
|
926 filed - matched message if it has been saved with its headers.
|
|
927 forwarded - matches message if it has been forwarded.
|
|
928 header - matches message if ARG matches any part of the header
|
|
929 portion of the message; ARG should be a
|
|
930 regular expression.
|
|
931 label - matches message if message has a label named ARG.
|
|
932 less-chars-than - matches message if message has less than ARG
|
|
933 characters. ARG should be a number.
|
|
934 less-lines-than - matches message if message has less than ARG
|
|
935 lines. ARG should be a number.
|
|
936 more-chars-than - matches message if message has more than ARG
|
|
937 characters. ARG should be a number.
|
|
938 more-lines-than - matches message if message has more than ARG
|
|
939 lines. ARG should be a number.
|
|
940 marked - matches message if it is marked, as with vm-mark-message.
|
|
941 new - matches message if it is new.
|
|
942 not - matches message only if its selector argument
|
|
943 does NOT match the message. Example:
|
|
944 (not (deleted))
|
|
945 matches messages that are not deleted.
|
|
946 or - matches the message if any of its argument
|
|
947 selectors match the message. Example:
|
|
948 (or (author \"Dave Weckl\") (subject \"drum\"))
|
|
949 matches messages from Dave Weckl or messages
|
|
950 with the word \"drum\" in their Subject header.
|
|
951 `or' takes any number of arguments.
|
|
952 read - matches message if it is neither new nor unread.
|
|
953 recipient - matches message if ARG matches any part of the recipient
|
|
954 list of the message. ARG should be a regular expression.
|
|
955 replied - matches message if it has been replied to.
|
|
956 sent-after - matches message if it was sent after the date ARG.
|
|
957 A fully specified date looks like this:
|
|
958 \"31 Dec 1999 23:59:59 GMT\"
|
|
959 although the parts can appear in any order.
|
|
960 You can leave out any part and it will
|
|
961 default to the current date's value for that
|
|
962 part, with the exception of the hh:mm:ss
|
|
963 part which defaults to midnight.
|
|
964 sent-before - matches message if it was sent before the date ARG.
|
|
965 A fully specified date looks like this:
|
|
966 \"31 Dec 1999 23:59:59 GMT\"
|
|
967 although the parts can appear in any order.
|
|
968 You can leave out any part and it will
|
|
969 default to the current date's value for that
|
|
970 part, with the exception of the hh:mm:ss
|
|
971 part which defaults to midnight.
|
|
972 subject - matches message if ARG matches any part of the message's
|
|
973 subject; ARG should be a regular expression.
|
|
974 text - matches message if ARG matches any part of the text
|
|
975 portion of the message; ARG should be a
|
|
976 regular expression.
|
|
977 unread - matches message if it is old but unread.
|
|
978 written - matches message if it has been saved without its headers.
|
|
979 ")
|
|
980
|
|
981 (defvar vm-virtual-mirror t
|
|
982 "*Non-nil value causes the attributes of messages in virtual folders
|
|
983 to mirror the changes in the attributes of the underlying real messages.
|
|
984 Similarly, changes in the attributes of virtual messages will change the
|
|
985 attributes of the underlying real messages. A nil value causes virtual
|
|
986 messages to have their own distinct set of attributes, apart from the
|
|
987 underlying real message.
|
|
988
|
|
989 This variable automatically becomes buffer-local when set in any
|
|
990 fashion. You should set this variable only in your .vm or .emacs
|
|
991 file. Use setq-default. Once VM has been started, you should not
|
|
992 set this variable directly, rather you should use the command
|
|
993 vm-toggle-virtual-mirror, normally bound to `V M'.")
|
|
994 (make-variable-buffer-local 'vm-virtual-mirror)
|
|
995
|
|
996 (defvar vm-folder-read-only nil
|
|
997 "*Non-nil value causes a folder to be considered unmodifiable by VM.
|
|
998 Commands that modify message attributes or messages themselves are disallowed.
|
|
999 Commands that add or delete messages from the folder are disallowed.
|
|
1000 Commands that scan or allow the reading of messages are allowed but the
|
|
1001 `new' and `unread' message flags are not changed by them.
|
|
1002
|
|
1003 This variable automatically becomes buffer-local when set in any
|
|
1004 fashion. You should set this variable only in your .vm or .emacs
|
|
1005 file. Use setq-default. Once VM has been started, you should not
|
|
1006 set this variable directly, rather you should use the command
|
|
1007 vm-toggle-read-only, normally bound to C-x C-q.")
|
|
1008 (make-variable-buffer-local 'vm-folder-read-only)
|
|
1009
|
|
1010 (defvar vm-included-text-prefix " > "
|
|
1011 "*String used to prefix included text in replies.")
|
|
1012
|
|
1013 (defvar vm-keep-sent-messages 1
|
|
1014 "*Non-nil value N causes VM to keep the last N messages sent from within VM.
|
|
1015 `Keep' means that VM will not kill the VM mail buffer after you send a message
|
|
1016 with C-c C-c (vm-mail-send-and-exit). A value of 0 or nil causes VM never
|
|
1017 to keep such buffers. A value of t causes VM never to kill such buffers.
|
|
1018
|
|
1019 Note that these buffers will vanish once you exit Emacs. To keep a permanent
|
|
1020 record of your outgoing mail, use the mail-archive-file-name variable.")
|
|
1021
|
|
1022 (defvar vm-confirm-mail-send nil
|
|
1023 "*Non-nil means ask before sending a mail message.
|
|
1024 This affects vm-mail-send and vm-mail-send-and-exit in Mail mode.")
|
|
1025
|
|
1026 (defvar vm-mail-header-from nil
|
|
1027 "*Non-nil value should be a string that will be appear as the body
|
|
1028 of the From header in outbound mail messages. A nil value means don't
|
|
1029 insert a From header. This variable also controls the inclusion and
|
|
1030 format of the Resent-From header, when resending a message with
|
|
1031 vm-resend-message.")
|
|
1032
|
|
1033 (defvar vm-reply-subject-prefix nil
|
|
1034 "*Non-nil value should be a string that VM should add to the beginning
|
|
1035 of the Subject header in replies, if the string is not already present.
|
|
1036 Nil means don't prefix the Subject header.")
|
|
1037
|
|
1038 (defvar vm-reply-ignored-addresses nil
|
|
1039 "*Non-nil value should be a list of regular expressions that match
|
|
1040 addresses that VM should automatically remove from the recipient
|
|
1041 headers of replies. These addresses are removed from the headers
|
|
1042 before you are placed in the message composition buffer. So if
|
|
1043 you see an address in the header you don't want you should remove
|
|
1044 it yourself.
|
|
1045
|
|
1046 Case is ignored when matching the addresses.")
|
|
1047
|
|
1048 (defvar vm-reply-ignored-reply-tos nil
|
|
1049 "*Non-nil value should be a list of regular expressions that match
|
|
1050 addresses that, if VM finds in a message's Reply-To header, VM
|
|
1051 should ignore the Reply-To header and not use it for replies. VM
|
|
1052 will use the From header instead.
|
|
1053
|
|
1054 Case is ignored when matching the addresses.
|
|
1055
|
|
1056 This variable exists solely to provide a escape chute from
|
|
1057 mailing lists that add a Reply-To: mailing list header, thereby
|
|
1058 leaving no way to reply to just the author of a message.")
|
|
1059
|
|
1060 (defvar vm-in-reply-to-format "%i"
|
|
1061 "*String which specifies the format of the contents of the In-Reply-To
|
|
1062 header that is generated for replies. See the documentation for the
|
|
1063 variable vm-summary-format for information on what this string may
|
|
1064 contain. The format should *not* end with a newline.
|
|
1065 Nil means don't put an In-Reply-To header in replies.")
|
|
1066
|
|
1067 (defvar vm-included-text-attribution-format "%F writes:\n"
|
|
1068 "*String which specifies the format of the attribution that precedes the
|
|
1069 included text from a message in a reply. See the documentation for the
|
|
1070 variable vm-summary-format for information on what this string may contain.
|
|
1071 Nil means don't attribute included text in replies.")
|
|
1072
|
|
1073 (defvar vm-included-text-headers nil
|
|
1074 "*List of headers that should be retained in a message included in
|
|
1075 a reply. These should be listed in the order you wish them to
|
|
1076 appear in the included text. Regular expressions are allowed.
|
|
1077 There's no need to anchor patterns with \"^\", as searches always
|
|
1078 start at the beginning of a line. Put a colon at the end of
|
|
1079 patterns to get exact matches. (E.g. \"Date\" matches \"Date\"
|
|
1080 and \"Date-Sent\".) Header names are always matched case
|
|
1081 insensitively.
|
|
1082
|
|
1083 If the value of vm-included-text-discard-header-regexp is nil,
|
|
1084 the headers matched by vm-included-text-headers are the only
|
|
1085 headers that will be retained.
|
|
1086
|
|
1087 If vm-included-text-discard-header-regexp is non-nil, then only
|
|
1088 headers matched by that variable will be omitted; all others will
|
|
1089 be included. vm-included-text-headers determines the header
|
|
1090 order in that case, with headers not matching any in the
|
|
1091 vm-included-text-headers list appearing last in the header
|
|
1092 section of the included text.")
|
|
1093
|
|
1094 (defvar vm-included-text-discard-header-regexp nil
|
|
1095 "*Non-nil value should be a regular expression header that tells
|
|
1096 what headers should not be retained in a message included in a
|
|
1097 reply. This variable along with vm-included-text-headers determines
|
|
1098 which headers are retained.
|
|
1099
|
|
1100 If the value of vm-included-text-discard-header-regexp is nil,
|
|
1101 the headers matched by vm-included-text-headers are the only headers
|
|
1102 that will be retained.
|
|
1103
|
|
1104 If vm-included-text-discard-header-regexp is non-nil, then only
|
|
1105 headers matched by this variable will not be retained; all
|
|
1106 others will be included. vm-included-text-headers determines the
|
|
1107 header order in that case, with headers not matching any in
|
|
1108 the vm-included-text-headers list appearing last in the header
|
|
1109 section of the included text.")
|
|
1110
|
|
1111 (defvar vm-forwarding-subject-format "forwarded message from %F"
|
|
1112 "*String which specifies the format of the contents of the Subject
|
|
1113 header that is generated for a forwarded message. See the documentation
|
|
1114 for the variable vm-summary-format for information on what this string
|
|
1115 may contain. The format should *not* end with nor contain a newline.
|
|
1116 Nil means leave the Subject header empty when forwarding.")
|
|
1117
|
|
1118 (defvar vm-forwarded-headers nil
|
|
1119 "*List of headers that should be forwarded by vm-forward-message.
|
|
1120 These should be listed in the order you wish them to appear in
|
|
1121 the forwarded message. Regular expressions are allowed.
|
|
1122 There's no need to anchor patterns with \"^\", as searches always
|
|
1123 start at the beginning of a line. Put a colon at the end of
|
|
1124 patterns to get exact matches. (E.g. \"Date\" matches \"Date\"
|
|
1125 and \"Date-Sent\".) Header names are always matched case
|
|
1126 insensitively.
|
|
1127
|
|
1128 If the value of vm-unforwarded-header-regexp is nil, the headers
|
|
1129 matched by vm-forwarded-headers are the only headers that will be
|
|
1130 forwarded.
|
|
1131
|
|
1132 If vm-unforwarded-header-regexp is non-nil, then only headers
|
|
1133 matched by that variable will be omitted; all others will be
|
|
1134 forwarded. vm-forwarded-headers determines the forwarding order
|
|
1135 in that case, with headers not matching any in the
|
|
1136 vm-forwarded-headers list appearing last in the header section of
|
|
1137 the forwarded message.")
|
|
1138
|
|
1139 (defvar vm-unforwarded-header-regexp "only-drop-this-header"
|
|
1140 "*Non-nil value should be a regular expression header that tells
|
|
1141 what headers should not be forwarded by vm-forward-message. This
|
|
1142 variable along with vm-forwarded-headers determines which headers
|
|
1143 are forwarded.
|
|
1144
|
|
1145 If the value of vm-unforwarded-header-regexp is nil, the headers
|
|
1146 matched by vm-forwarded-headers are the only headers that will be
|
|
1147 forwarded.
|
|
1148
|
|
1149 If vm-unforwarded-header-regexp is non-nil, then only headers
|
|
1150 matched by this variable will not be forwarded; all others will
|
|
1151 be forwarded. vm-forwarded-headers determines the forwarding
|
|
1152 order in that case, with headers not matching any in the
|
|
1153 vm-forwarded-headers list appearing last in the header section of
|
|
1154 the forwarded message.")
|
|
1155
|
98
|
1156 (defvar vm-forwarding-digest-type "mime"
|
0
|
1157 "*Non-nil value should be a string that specifies the type of
|
|
1158 message encapsulation format to use when forwarding a message.
|
|
1159 Legal values of this variable are:
|
|
1160
|
|
1161 \"rfc934\"
|
|
1162 \"rfc1153\"
|
98
|
1163 \"mime\"
|
0
|
1164 nil
|
|
1165
|
|
1166 A nil value means don't use a digest, just mark the beginning and
|
|
1167 end of the forwarded message.")
|
|
1168
|
98
|
1169 (defvar vm-burst-digest-messages-inherit-labels t
|
|
1170 "*Non-nil values means messages from a digest inherit the digest's labels.
|
|
1171 Labels are added to messages with vm-add-message-labels, normally
|
|
1172 bound to `l a'.")
|
|
1173
|
0
|
1174 (defvar vm-digest-preamble-format "\"%s\" (%F)"
|
|
1175 "*String which specifies the format of the preamble lines generated by
|
|
1176 vm-send-digest when it is invoked with a prefix argument. One
|
|
1177 line will be generated for each message put into the digest. See the
|
|
1178 documentation for the variable vm-summary-format for information
|
|
1179 on what this string may contain. The format should *not* end
|
|
1180 with nor contain a newline.")
|
|
1181
|
|
1182 (defvar vm-digest-center-preamble t
|
|
1183 "*Non-nil value means VM will center the preamble lines that precede
|
|
1184 the start of a digest. How the lines will be centered depends on the
|
|
1185 ambient value of fill-column. A nil value suppresses centering.")
|
|
1186
|
|
1187 (defvar vm-digest-identifier-header-format "X-Digest: %s\n"
|
|
1188 "*Header to insert into messages burst from a digest.
|
70
|
1189 Value should be a format string of the same type as vm-summary-format that describes a header to be inserted into each message burst from a digest. The format string must end with a newline.")
|
0
|
1190
|
98
|
1191 (defvar vm-digest-burst-type "guess"
|
0
|
1192 "*Value specifies the default digest type offered by vm-burst-digest
|
|
1193 when it asks you what type of digest you want to unpack. Allowed
|
|
1194 values of this variable are:
|
|
1195
|
|
1196 \"rfc934\"
|
|
1197 \"rfc1153\"
|
98
|
1198 \"mime\"
|
0
|
1199 \"guess\"
|
|
1200
|
98
|
1201 rfc1153 digests have a preamble, followed by a line of exactly 70
|
|
1202 dashes, with digested messages separated by lines of exactly 30 dashes.
|
|
1203
|
|
1204 rfc934 digests separate messages on any line that begins with a few
|
|
1205 dashes, but doesn't require lines with only dashes or lines with a
|
|
1206 specific number of dashes. In the text of the message, any line
|
|
1207 beginning with dashes is textually modified to be preceeded by a dash
|
|
1208 and a space to prevent confusion with message separators.
|
|
1209
|
|
1210 MIME digests use whatever boundary that is specified by the
|
|
1211 boundary parameter in the Content-Type header of the digest.
|
|
1212
|
0
|
1213 If the value is \"guess\", and you take the default
|
|
1214 response when vm-burst-digest queries you, VM will try to guess
|
|
1215 the digest type.")
|
|
1216
|
98
|
1217 (defvar vm-digest-send-type "mime"
|
0
|
1218 "*String that specifies the type of digest vm-send-digest will use.
|
|
1219 Legal values of this variable are:
|
|
1220
|
|
1221 \"rfc934\"
|
|
1222 \"rfc1153\"
|
98
|
1223 \"mime\"
|
0
|
1224
|
|
1225 ")
|
|
1226
|
|
1227 (defvar vm-rfc934-digest-headers
|
|
1228 '("Resent-"
|
|
1229 "From:" "Sender:"
|
|
1230 "To:" "Cc:"
|
|
1231 "Subject:"
|
|
1232 "Date:"
|
|
1233 "Message-ID:"
|
|
1234 "Keywords:")
|
|
1235 "*List of headers that should be appear in RFC 934 digests
|
|
1236 created by VM. These should be listed in the order you wish them
|
|
1237 to appear in the digest. Regular expressions are allowed.
|
|
1238 There's no need to anchor patterns with \"^\", as searches always
|
|
1239 start at the beginning of a line. Put a colon at the end of
|
|
1240 patterns to get exact matches. (E.g. \"Date\" matches \"Date\"
|
|
1241 and \"Date-Sent\".) Header names are always matched case
|
|
1242 insensitively.
|
|
1243
|
|
1244 If the value of vm-rfc934-digest-discard-header-regexp is nil, the headers
|
|
1245 matched by vm-rfc934-digest-headers are the only headers that will be
|
|
1246 kept.
|
|
1247
|
|
1248 If vm-rfc934-digest-discard-header-regexp is non-nil, then only
|
|
1249 headers matched by that variable will be discarded; all others
|
|
1250 will be kept. vm-rfc934-digest-headers determines the order of
|
|
1251 appearance in that case, with headers not matching any in the
|
|
1252 vm-rfc934-digest-headers list appearing last in the headers
|
|
1253 of the digestified messages.")
|
|
1254
|
|
1255 (defvar vm-rfc934-digest-discard-header-regexp nil
|
|
1256 "*Non-nil value should be a regular expression header that tells
|
|
1257 what headers should not appear in RFC 934 digests created by VM. This
|
|
1258 variable along with vm-rfc934-digest-headers determines which headers
|
|
1259 are kept and which are discarded.
|
|
1260
|
|
1261 If the value of vm-rfc934-digest-discard-header-regexp is nil, the headers
|
|
1262 matched by vm-rfc934-digest-headers are the only headers that will be
|
|
1263 kept.
|
|
1264
|
|
1265 If vm-rfc934-digest-discard-header-regexp is non-nil, then only
|
|
1266 headers matched by this variable will be discarded; all others
|
|
1267 will be kept. vm-rfc934-digest-headers determines the order of
|
|
1268 appearance in that case, with headers not matching any in the
|
|
1269 vm-rfc934-digest-headers list appearing last in the headers
|
|
1270 of the digestified messages.")
|
|
1271
|
|
1272 (defvar vm-rfc1153-digest-headers
|
|
1273 '("Resent-"
|
|
1274 "Date:"
|
|
1275 "From:" "Sender:"
|
|
1276 "To:" "Cc:"
|
|
1277 "Subject:"
|
|
1278 "Message-ID:"
|
|
1279 "Keywords:")
|
|
1280 "*List of headers that should be appear in RFC 1153 digests
|
|
1281 created by VM. These should be listed in the order you wish them
|
|
1282 to appear in the digest. Regular expressions are allowed.
|
|
1283 There is no need to anchor patterns with \"^\", as searches always
|
|
1284 start at the beginning of a line. Put a colon at the end of
|
|
1285 patterns to get exact matches. (E.g. \"Date\" matches \"Date\"
|
|
1286 and \"Date-Sent\".) Header names are always matched case
|
|
1287 insensitively.
|
|
1288
|
|
1289 If the value of vm-rfc1153-digest-discard-header-regexp is nil, the headers
|
|
1290 matched by vm-rfc1153-digest-headers are the only headers that will be
|
|
1291 kept.
|
|
1292
|
|
1293 If vm-rfc1153-digest-discard-header-regexp is non-nil, then only
|
|
1294 headers matched by that variable will be discarded; all others
|
|
1295 will be kept. vm-rfc1153-digest-headers determines the order of
|
|
1296 appearance in that case, with headers not matching any in the
|
|
1297 vm-rfc1153-digest-headers list appearing last in the headers of
|
|
1298 the digestified messages.")
|
|
1299
|
|
1300 (defvar vm-rfc1153-digest-discard-header-regexp "\\(X400-\\)?Received:"
|
|
1301 "*Non-nil value should be a regular expression header that tells
|
|
1302 what headers should not appear in RFC 1153 digests created by VM. This
|
|
1303 variable along with vm-rfc1153-digest-headers determines which headers
|
|
1304 are kept and which headers are discarded.
|
|
1305
|
|
1306 If the value of vm-rfc1153-digest-discard-header-regexp is nil, the headers
|
|
1307 matched by vm-rfc1153-digest-headers are the only headers that will be
|
|
1308 kept.
|
|
1309
|
|
1310 If vm-rfc1153-digest-discard-header-regexp is non-nil, then only
|
|
1311 headers matched by this variable will be discarded; all others
|
|
1312 will be kept. vm-rfc1153-digest-headers determines the order of
|
|
1313 appearance in that case, with headers not matching any in the
|
|
1314 vm-rfc1153-digest-headers list appearing last in the headers of
|
|
1315 the digestified messages.")
|
|
1316
|
98
|
1317 (defvar vm-mime-digest-headers
|
|
1318 '("Resent-"
|
|
1319 "From:" "Sender:"
|
|
1320 "To:" "Cc:"
|
|
1321 "Subject:"
|
|
1322 "Date:"
|
|
1323 "Message-ID:"
|
|
1324 "Keywords:"
|
|
1325 "MIME-Version:"
|
|
1326 "Content-")
|
|
1327 "*List of headers that should be appear in MIME digests
|
|
1328 created by VM. These should be listed in the order you wish them
|
|
1329 to appear in the messages in the digest. Regular expressions are
|
|
1330 allowed. There's no need to anchor patterns with \"^\", as
|
|
1331 searches always start at the beginning of a line. Put a colon at
|
|
1332 the end of patterns to get exact matches. (E.g. \"Date\" matches
|
|
1333 \"Date\" and \"Date-Sent\".) Header names are always matched
|
|
1334 case insensitively.
|
|
1335
|
|
1336 If the value of vm-mime-digest-discard-header-regexp is nil, the headers
|
|
1337 matched by vm-mime-digest-headers are the only headers that will be
|
|
1338 kept.
|
|
1339
|
|
1340 If vm-mime-digest-discard-header-regexp is non-nil, then only
|
|
1341 headers matched by that variable will be discarded; all others
|
|
1342 will be kept. vm-mime-digest-headers determines the order of
|
|
1343 appearance in that case, with headers not matching any in the
|
|
1344 vm-mime-digest-headers list appearing last in the headers
|
|
1345 of the digestified messages.")
|
|
1346
|
|
1347 (defvar vm-mime-digest-discard-header-regexp nil
|
|
1348 "*Non-nil value should be a regular expression header that tells
|
|
1349 which headers should not appear in MIME digests created
|
|
1350 by VM. This variable along with vm-mime-digest-headers
|
|
1351 determines which headers are kept and which are discarded.
|
|
1352
|
|
1353 If the value of vm-mime-digest-discard-header-regexp is nil, the headers
|
|
1354 matched by vm-mime-digest-headers are the only headers that will be
|
|
1355 kept.
|
|
1356
|
|
1357 If vm-mime-digest-discard-header-regexp is non-nil, then only
|
|
1358 headers matched by this variable will be discarded; all others
|
|
1359 will be kept. vm-mime-digest-headers determines the order of
|
|
1360 appearance in that case, with headers not matching any in the
|
|
1361 vm-mime-digest-headers list appearing last in the headers
|
|
1362 of the digestified messages.")
|
|
1363
|
0
|
1364 (defvar vm-resend-bounced-headers
|
98
|
1365 '("MIME-Version:" "Content-"
|
0
|
1366 "From:" "Sender:" "Reply-To:"
|
|
1367 "To:" "Cc:"
|
|
1368 "Subject:"
|
|
1369 "Newsgroups:"
|
|
1370 "In-Reply-To:" "References:"
|
|
1371 "Keywords:"
|
|
1372 "X-")
|
|
1373 "*List of headers that should be appear in messages resent with
|
|
1374 vm-resend-bounced-message. These should be listed in the order you wish them
|
|
1375 to appear in the message. Regular expressions are allowed.
|
|
1376 There is no need to anchor patterns with \"^\", as searches always
|
|
1377 start at the beginning of a line. Put a colon at the end of
|
|
1378 patterns to get exact matches. (E.g. \"Date\" matches \"Date\"
|
|
1379 and \"Date-Sent\".) Header names are always matched case
|
|
1380 insensitively.
|
|
1381
|
|
1382 If the value of vm-resend-bounced-discard-header-regexp is nil, the headers
|
|
1383 matched by vm-resend-bounced-headers are the only headers that will be
|
|
1384 kept.
|
|
1385
|
|
1386 If vm-resend-bounced-discard-header-regexp is non-nil, then only
|
|
1387 headers matched by that variable will be discarded; all others
|
|
1388 will be kept. vm-resend-bounced-headers determines the order of
|
|
1389 appearance in that case, with headers not matching any in the
|
|
1390 vm-resend-bounced-headers list appearing last in the headers of
|
|
1391 the message.")
|
|
1392
|
|
1393 (defvar vm-resend-bounced-discard-header-regexp nil
|
|
1394 "*Non-nil value should be a regular expression that tells
|
|
1395 what headers should not appear in a resent bounced message. This
|
|
1396 variable along with vm-resend-bounced-headers determines which headers
|
|
1397 are kept and which headers are discarded.
|
|
1398
|
|
1399 If the value of vm-resend-bounced-discard-header-regexp is nil,
|
|
1400 the headers matched by vm-resend-bounced-headers are the only
|
|
1401 headers that will be kept.
|
|
1402
|
|
1403 If vm-resend-bounced-discard-header-regexp is non-nil, then only
|
|
1404 headers matched by this variable will be discarded; all others
|
|
1405 will be kept. vm-resend-bounced-headers determines the order of
|
|
1406 appearance in that case, with headers not matching any in the
|
|
1407 vm-resend-bounced-headers list appearing last in the headers of
|
|
1408 the message.")
|
|
1409
|
|
1410 (defvar vm-resend-headers nil
|
|
1411 "*List of headers that should be appear in messages resent with
|
|
1412 vm-resend-message. These should be listed in the order you wish them
|
|
1413 to appear in the message. Regular expressions are allowed.
|
|
1414 There is no need to anchor patterns with \"^\", as searches always
|
|
1415 start at the beginning of a line. Put a colon at the end of
|
|
1416 patterns to get exact matches. (E.g. \"Date\" matches \"Date\"
|
|
1417 and \"Date-Sent\".) Header names are always matched case
|
|
1418 insensitively.
|
|
1419
|
|
1420 If the value of vm-resend-discard-header-regexp is nil, the headers
|
|
1421 matched by vm-resend-headers are the only headers that will be
|
|
1422 kept.
|
|
1423
|
|
1424 If vm-resend-discard-header-regexp is non-nil, then only
|
|
1425 headers matched by that variable will be discarded; all others
|
|
1426 will be kept. vm-resend-headers determines the order of
|
|
1427 appearance in that case, with headers not matching any in the
|
|
1428 vm-resend-headers list appearing last in the headers of
|
|
1429 the message.")
|
|
1430
|
|
1431 (defvar vm-resend-discard-header-regexp "\\(\\(X400-\\)?Received:\\|Resent-\\)"
|
|
1432 "*Non-nil value should be a regular expression that tells
|
|
1433 what headers should not appear in a resent message. This
|
98
|
1434 variable along with vm-resend-headers determines which
|
0
|
1435 headers are kept and which headers are discarded.
|
|
1436
|
|
1437 If the value of vm-resend-discard-header-regexp is nil,
|
|
1438 the headers matched by vm-resend-headers are the only
|
|
1439 headers that will be kept.
|
|
1440
|
|
1441 If vm-resend-discard-header-regexp is non-nil, then only
|
|
1442 headers matched by this variable will be discarded; all others
|
|
1443 will be kept. vm-resend-headers determines the order of
|
|
1444 appearance in that case, with headers not matching any in the
|
|
1445 vm-resend-headers list appearing last in the headers of
|
|
1446 the message.")
|
|
1447
|
|
1448 (defvar vm-summary-format "%n %*%a %-17.17F %-3.3m %2d %4l/%-5c %I\"%s\"\n"
|
|
1449 "*String which specifies the message summary line format.
|
|
1450 The string may contain the printf-like `%' conversion specifiers which
|
|
1451 substitute information about the message into the final summary line.
|
|
1452
|
|
1453 Recognized specifiers are:
|
|
1454 a - attribute indicators (always four characters wide)
|
|
1455 The first char is `D', `N', `U' or ` ' for deleted, new, unread
|
|
1456 and read messages respectively.
|
|
1457 The second char is `F', `W' or ` ' for filed (saved) or written
|
|
1458 messages.
|
|
1459 The third char is `R', `Z' or ` ' for messages replied to,
|
|
1460 and forwarded messages.
|
|
1461 The fourth char is `E' if the message has been edited, ` ' otherwise.
|
|
1462 A - longer version of attributes indicators (seven characters wide)
|
|
1463 The first char is `D', `N', `U' or ` ' for deleted, new, unread
|
|
1464 and read messages respectively.
|
|
1465 The second is `r' or ` ', for message replied to.
|
|
1466 The third is `z' or ` ', for messages forwarded.
|
|
1467 The fourth is `b' or ` ', for messages redistributed.
|
|
1468 The fifth is `f' or ` ', for messages filed.
|
|
1469 The sixth is `w' or ` ', for messages written.
|
|
1470 The seventh is `e' or ` ', for messages that have been edited.
|
|
1471 c - number of characters in message (ignoring headers)
|
|
1472 d - numeric day of month message sent
|
|
1473 f - author's address
|
|
1474 F - author's full name (same as f if full name not found)
|
|
1475 h - hour:min:sec message sent
|
|
1476 H - hour:min message sent
|
|
1477 i - message ID
|
|
1478 I - thread indentation
|
|
1479 l - number of lines in message (ignoring headers)
|
|
1480 L - labels (as a comma list)
|
|
1481 m - month message sent
|
|
1482 M - numeric month message sent (January = 1)
|
|
1483 n - message number
|
|
1484 s - message subject
|
|
1485 t - addresses of the recipients of the message, in a comma-separated list
|
|
1486 T - full names of the recipients of the message, in a comma-separated list
|
|
1487 If a full name cannot be found, the corresponding address is used
|
|
1488 instead.
|
|
1489 U - user defined specifier. The next character in the format
|
|
1490 string should be a letter. VM will call the function
|
|
1491 vm-summary-function-<letter> (e.g. vm-summary-function-A for
|
|
1492 \"%UA\") in the folder buffer with the message being summarized
|
|
1493 bracketed by (point-min) and (point-max). The function
|
|
1494 will be passed a message struct as an argument.
|
|
1495 The function should return a string, which VM will insert into
|
|
1496 the summary as it would for information from any other summary
|
|
1497 specifier.
|
|
1498 w - day of the week message sent
|
|
1499 y - year message sent
|
|
1500 z - timezone of date when the message was sent
|
|
1501 * - `*' if the message is marked, ` ' otherwise
|
|
1502
|
|
1503 Use %% to get a single %.
|
|
1504
|
|
1505 A numeric field width may be given between the `%' and the specifier;
|
|
1506 this causes right justification of the substituted string. A negative field
|
|
1507 width causes left justification.
|
|
1508
|
|
1509 The field width may be followed by a `.' and a number specifying
|
|
1510 the maximum allowed length of the substituted string. If the
|
|
1511 string is longer than this value the right end of the string is
|
|
1512 truncated. If the value is negative, the string is truncated on
|
98
|
1513 the left instead of the right.
|
0
|
1514
|
|
1515 The summary format need not be one line per message but it must end with
|
|
1516 a newline, otherwise the message pointer will not be displayed correctly
|
|
1517 in the summary window.")
|
|
1518
|
|
1519 (defvar vm-summary-arrow "->"
|
|
1520 "*String that is displayed to the left of the summary of the
|
|
1521 message VM consider to be the current message. The value takes
|
|
1522 effect when the summary buffer is created. Changing this
|
|
1523 variable's value has no effect on existing summary buffers.")
|
|
1524
|
|
1525 (defvar vm-summary-highlight-face 'bold
|
|
1526 "*Face to use to highlight the summary entry for the current message.
|
|
1527 Nil means don't highlight the current message's summary entry.")
|
|
1528
|
98
|
1529 (defvar vm-mouse-track-summary t
|
|
1530 "*Non-nil value means highlight summary lines as the mouse passes
|
|
1531 over them.")
|
|
1532
|
0
|
1533 (defvar vm-summary-show-threads nil
|
|
1534 "*Non-nil value means VM should display and maintain
|
|
1535 message thread trees in the summary buffer. This means that
|
|
1536 messages with a common ancestor will be displayed contiguously in
|
|
1537 the summary. (If you have vm-move-messages-physically set
|
|
1538 non-nil the folder itself will be reordered to match the thread
|
|
1539 ordering.) If you use the `%I' summary format specifier in your
|
|
1540 vm-summary-format, indentation will be provided as described in the
|
|
1541 documentation for vm-summary-thread-indent-level (which see).
|
|
1542
|
|
1543 A nil value means don't display thread information. The `%I'
|
|
1544 specifier does nothing in the summary format.
|
|
1545
|
|
1546 This variable automatically becomes buffer-local when set in any
|
|
1547 fashion. You should set this variable only in your .vm or .emacs
|
|
1548 file. Use setq-default. Once VM has been started, you should not
|
|
1549 set this variable directly, rather you should use the command
|
|
1550 vm-toggle-threads-display, normally bound to C-t.")
|
|
1551 (make-variable-buffer-local 'vm-summary-show-threads)
|
|
1552
|
|
1553 (defvar vm-summary-thread-indent-level 2
|
|
1554 "*Value should be a number that specifies how much
|
|
1555 indentation the '%I' summary format specifier should provide per
|
|
1556 thread level. A message's `thread level' refers to the number of
|
|
1557 direct ancestors from the message to the oldest ancestor the
|
|
1558 message has that is in the current folder. For example, the
|
|
1559 first message of a thread is generally a message about a new
|
|
1560 topic, e.g. a message that is not a reply to some other message.
|
|
1561 Therefore it has no ancestor and would cause %I to generate no
|
|
1562 indentation. A reply to this message will be indented by the value
|
|
1563 of vm-summary-thread-indent-level. A reply to that reply will be
|
|
1564 indented twice the value of vm-summary-thread-indent-level.")
|
|
1565
|
|
1566 (defvar vm-thread-using-subject t
|
|
1567 "*Non-nil value causes VM to use the Subject header to thread messages.
|
|
1568 Messages with the same subject will be grouped together.
|
|
1569
|
|
1570 A nil value means VM will disregard the Subject header when
|
|
1571 threading messages.")
|
|
1572
|
|
1573 (defvar vm-summary-uninteresting-senders nil
|
|
1574 "*Non-nil value should be a regular expression that matches
|
|
1575 addresses that you don't consider interesting enough to
|
|
1576 appear in the summary. When such senders would be displayed by
|
|
1577 the %F or %f summary format specifiers VM will substitute the
|
|
1578 value of vm-summary-uninteresting-senders-arrow (default \"To:
|
|
1579 \") followed by what would be shown by the %T and %t specifiers
|
|
1580 respectively.")
|
|
1581
|
|
1582 (defvar vm-summary-uninteresting-senders-arrow "To: "
|
|
1583 "*String to display before the string that is displayed instead of an
|
|
1584 \"uninteresting\" sender. See vm-summary-uninteresting-senders.")
|
|
1585
|
|
1586 (defvar vm-auto-center-summary nil
|
|
1587 "*Value controls whether VM will keep the summary arrow vertically
|
|
1588 centered within the summary window. A value of t causes VM to always
|
|
1589 keep arrow centered. A value of nil means VM will never bother centering
|
|
1590 the arrow. A value that is not nil and not t causes VM to center the
|
|
1591 arrow only if the summary window is not the only existing window.")
|
|
1592
|
|
1593 (defvar vm-subject-ignored-prefix "^\\(re: *\\)+"
|
|
1594 "*Non-nil value should be a regular expression that matches
|
|
1595 strings at the beginning of the Subject header that you want VM to ignore
|
|
1596 when threading, sorting, marking, and killing messages by subject.
|
|
1597
|
|
1598 Matches are done case-insensitively.")
|
|
1599
|
|
1600 (defvar vm-subject-ignored-suffix "\\( (fwd)\\| \\)+$"
|
|
1601 "*Non-nil value should be a regular expression that matches
|
|
1602 strings at the end of the Subject header that you want VM to ignore
|
|
1603 when threading, sorting, marking and killing messages by subject.
|
|
1604
|
|
1605 Matches are done case-insensitively.")
|
|
1606
|
|
1607 (defvar vm-mutable-windows pop-up-windows
|
|
1608 "*This variable's value controls VM's window usage.
|
|
1609
|
|
1610 A non-nil value gives VM free run of the Emacs display; it will commandeer
|
|
1611 the entire screen for its purposes.
|
|
1612
|
|
1613 A value of nil restricts VM's window usage to the window from which
|
|
1614 it was invoked. VM will not create, delete, or use any other windows,
|
|
1615 nor will it resize its own window.")
|
|
1616
|
70
|
1617 (defvar vm-mutable-frames nil
|
0
|
1618 "*Non-nil value means VM is allowed to create and destroy frames
|
70
|
1619 to display and undisplay buffers.
|
0
|
1620
|
|
1621 VM can create a frame to display a buffer, and delete frame to
|
|
1622 undisplay a buffer. A nil value means VM should not create or
|
|
1623 delete frames.
|
|
1624
|
70
|
1625 This variable is _not_ an analogue of vm-mutable-windows. VM
|
|
1626 still might create frames if this variable is nil. If you set
|
|
1627 the vm-frame-per-* variables VM will still create frames. Using
|
|
1628 the vm-frame-per-* variables you have more control over when it
|
|
1629 happens.
|
|
1630
|
|
1631 Users should consider setting vm-frame-per-folder and
|
|
1632 vm-frame-per-composition and/or using the -other-frame commands
|
|
1633 instead of setting this variable. If vm-mutable-frames is set to t,
|
|
1634 then vm-mutable-windows should probably be set to nil so that you
|
|
1635 avoid splitting frames.
|
0
|
1636
|
|
1637 This variable does not apply to the VM commands whose
|
70
|
1638 names end in -other-frame, which always create a new frame.
|
0
|
1639
|
70
|
1640 This variable has no meaning if you're not running Emacs native
|
|
1641 under X Windows or some other window system that allows multiple
|
|
1642 Emacs frames.")
|
20
|
1643
|
98
|
1644 (defvar vm-raise-frame-at-startup t
|
|
1645 "*Specifies whether VM should raise its frame at startup.
|
|
1646 A value of nil means never raise the frame.
|
|
1647 A value of t means always raise the frame.
|
|
1648 Other values are reserved for future use.")
|
|
1649
|
0
|
1650 (defvar vm-frame-per-folder t
|
|
1651 "*Non-nil value causes the folder visiting commands to visit in a new frame.
|
|
1652 Nil means the commands will use the current frame. This variable
|
|
1653 does not apply to the VM commands whose names end in
|
|
1654 -other-frame, which always create a new frame.
|
|
1655
|
70
|
1656 This variable has no meaning if you're not running Emacs native
|
|
1657 under X Windows or some other window system that allows multiple
|
|
1658 Emacs frames.")
|
0
|
1659
|
|
1660 (defvar vm-frame-per-summary nil
|
|
1661 "*Non-nil value causes VM to display the folder summary in its own frame.
|
|
1662 Nil means the vm-summarize command will use the current frame.
|
|
1663 This variable does not apply to vm-summarize-other-frame, which
|
|
1664 always create a new frame.
|
|
1665
|
70
|
1666 This variable has no meaning if you're not running Emacs native
|
|
1667 under X Windows or some other window system that allows multiple
|
|
1668 Emacs frames.")
|
0
|
1669
|
|
1670 (defvar vm-frame-per-composition t
|
|
1671 "*Non-nil value causes the mail composition commands to open a new frame.
|
|
1672 Nil means the commands will use the current frame. This variable
|
|
1673 does not apply to the VM commands whose names end in
|
|
1674 -other-frame, which always create a new frame.
|
|
1675
|
70
|
1676 This variable has no meaning if you're not running Emacs native
|
|
1677 under X Windows or some other window system that allows multiple
|
|
1678 Emacs frames.")
|
0
|
1679
|
|
1680 (defvar vm-frame-per-edit t
|
|
1681 "*Non-nil value causes vm-edit-message to open a new frame.
|
|
1682 Nil means the vm-edit-message will use the current frame. This
|
|
1683 variable does not apply to vm-edit-message-other-frame, which
|
|
1684 always create a new frame.
|
|
1685
|
20
|
1686 This variable has no meaning if you're not running Emacs native
|
|
1687 under X Windows or some other window system that allows multiple
|
70
|
1688 Emacs frames.")
|
20
|
1689
|
98
|
1690 (defvar vm-frame-per-completion t
|
|
1691 "*Non-nil value causes VM to open a new frame on mouse
|
|
1692 initiated completing reads. A mouse initiated completing read
|
|
1693 occurs when you invoke a VM command using the mouse, either with a
|
|
1694 menu or a toolbar button. That command must then prompt you for
|
|
1695 information, and there must be a limited set of proper responses.
|
|
1696
|
|
1697 If these conditions are met and vm-frame-per-completion's value
|
|
1698 is non-nil, VM will create a new frame containing a list of
|
|
1699 responses that you can select with the mouse.
|
|
1700
|
|
1701 A nil value means the current frame will be used to display the
|
|
1702 list of choices.
|
|
1703
|
|
1704 This variable has no meaning if you're not running Emacs native
|
|
1705 under X Windows or some other window system that allows multiple
|
|
1706 Emacs frames.")
|
|
1707
|
76
|
1708 (defvar vm-frame-parameter-alist nil
|
0
|
1709 "*Non-nil value is an alist of types and lists of frame parameters.
|
|
1710 This list tells VM what frame parameters to associate with each
|
|
1711 new frame it creates of a specific type.
|
|
1712
|
|
1713 The alist should be of this form
|
|
1714
|
98
|
1715 ((SYMBOL PARAMLIST) (SYMBOL2 PARAMLIST2) ...)
|
|
1716
|
|
1717 SYMBOL must be one of `completion', `composition', `edit',
|
|
1718 `folder', `primary-folder' or `summary'. It specifies the type
|
|
1719 of frame that the following PARAMLIST applies to.
|
|
1720
|
|
1721 `completion' specifies parameters for frames that display list of
|
|
1722 choices generated by a mouse-initiated completing read.
|
|
1723 (See vm-frame-per-completion.)
|
0
|
1724 `composition' specifies parameters for mail composition frames.
|
|
1725 `edit' specifies parameters for message edit frames
|
|
1726 (e.g. created by vm-edit-message-other-frame)
|
|
1727 `folder' specifies parameters for frames created by `vm' and the
|
|
1728 `vm-visit-' commands.
|
|
1729 `primary-folder' specifies parameters for the frame created by running
|
|
1730 `vm' without any arguments.
|
98
|
1731 `summary' specifies parameters for frames that display a summary buffer
|
0
|
1732 (e.g. created by vm-summarize-other-frame)
|
|
1733
|
|
1734 PARAMLIST is a list of pairs as described in the documentation for
|
70
|
1735 the function `make-frame'.
|
|
1736
|
|
1737 This variable has no effect on frames created as a result of
|
|
1738 having vm-mutable-frames set to non-nil.")
|
0
|
1739
|
|
1740 (defvar vm-search-other-frames t
|
|
1741 "*Non-nil means VM should search frames other than the selected frame
|
|
1742 when looking for a window that is already displaying a buffer that
|
|
1743 VM wants to display or undisplay.")
|
|
1744
|
100
|
1745 (defvar vm-image-directory
|
|
1746 (expand-file-name (concat data-directory "vm/"))
|
|
1747 "*Value specifies the directory VM should find its artwork.")
|
|
1748
|
0
|
1749 (defvar vm-use-toolbar
|
|
1750 '(next previous delete/undelete autofile file
|
|
1751 reply compose print visit quit nil help)
|
|
1752 "*Non-nil value causes VM to provide a toolbar interface.
|
|
1753 Value should be a list of symbols that will determine which
|
100
|
1754 toolbar buttons will appear and in what order. Valid symbol
|
0
|
1755 value within the list are:
|
|
1756
|
98
|
1757 autofile
|
|
1758 compose
|
|
1759 delete/undelete
|
|
1760 file
|
100
|
1761 getmail
|
98
|
1762 help
|
|
1763 mime
|
|
1764 next
|
|
1765 previous
|
|
1766 print
|
|
1767 quit
|
|
1768 reply
|
|
1769 visit
|
|
1770 nil
|
0
|
1771
|
|
1772 If nil appears in the list, it should appear exactly once. All
|
|
1773 buttons after nil in the list will be displayed flushright in
|
100
|
1774 top/bottom toolbars and flushbottom in left/right toolbars.
|
0
|
1775
|
|
1776 This variable only has meaning under XEmacs 19.12 and beyond.
|
|
1777 See also vm-toolbar-orientation to control where the toolbar is placed.")
|
|
1778
|
|
1779 (defvar vm-toolbar-orientation 'left
|
|
1780 "*Value is a symbol that specifies where the VM toolbar is located.
|
|
1781 Legal values are `left', `right' `top' and `bottom'. Any other
|
|
1782 value will be interpreted as `top'.
|
|
1783
|
|
1784 This variable only has meaning under XEmacs 19.12 and beyond.")
|
|
1785
|
100
|
1786 (defvar vm-toolbar-pixmap-directory vm-image-directory
|
0
|
1787 "*Value specifies the directory VM should find its toolbar pixmaps.")
|
|
1788
|
76
|
1789 (defvar vm-toolbar nil
|
|
1790 "*Non-nil value should be a list of toolbar button descriptors.
|
|
1791 See the documentation for the variable default-toolbar for a
|
|
1792 definition of what a toolbar button descriptor is.
|
|
1793
|
|
1794 If vm-toolbar is set non-nil VM will use its value as a toolbar
|
|
1795 instantiator instead of the usual beavior of building a button
|
|
1796 list based on the value of vm-use-toolbar. vm-use-toolbar still
|
|
1797 must be set non-nil for a toolbar to appear, however.
|
|
1798
|
|
1799 Consider this variable experimental; it may not be supported forever.")
|
|
1800
|
98
|
1801 (defvar vm-use-menus
|
|
1802 (nconc (list 'folder 'motion 'send 'mark 'label 'sort 'virtual)
|
|
1803 (cond ((string-match ".*-.*-\\(win95\\|nt\\)" system-configuration)
|
|
1804 nil)
|
|
1805 (t (list 'undo)))
|
|
1806 (list 'dispose)
|
|
1807 (cond ((string-match ".*-.*-\\(win95\\|nt\\)" system-configuration)
|
|
1808 nil)
|
|
1809 (t (list 'emacs)))
|
|
1810 (list nil 'help))
|
0
|
1811 "*Non-nil value causes VM to provide a menu interface.
|
|
1812 A value that is a list causes VM to install its own menubar.
|
|
1813 A value of 1 causes VM to install a \"VM\" item in the Emacs menubar.
|
|
1814
|
|
1815 If the value of vm-use-menus is a list, it should be a list of
|
|
1816 symbols. The symbols and the order that they are listed
|
|
1817 determine what menus will be in the menubar and how they are
|
|
1818 ordered. Valid symbols values are:
|
|
1819
|
|
1820 dispose
|
|
1821 emacs
|
|
1822 folder
|
|
1823 help
|
|
1824 label
|
|
1825 mark
|
|
1826 motion
|
|
1827 send
|
|
1828 sort
|
|
1829 undo
|
|
1830 virtual
|
|
1831 nil
|
|
1832
|
|
1833 If nil appears in the list, it should appear exactly once. All
|
|
1834 menus after nil in the list will be displayed flushright in
|
|
1835 menubar.
|
|
1836
|
|
1837 This variable only has meaning in Emacs environments where menus
|
|
1838 are provided, which usually means Emacs has to be running under a
|
|
1839 window system.")
|
|
1840
|
98
|
1841 (defvar vm-popup-menu-on-mouse-3 t
|
|
1842 "*Non-nil value means VM should provide context-sensitive menus on mouse-3.
|
|
1843 A nil value means VM should not change the binding of mouse-3.")
|
|
1844
|
0
|
1845 (defvar vm-warp-mouse-to-new-frame nil
|
|
1846 "*Non-nil value causes VM to move the mouse cursor into newly created frames.
|
|
1847 This is useful to give the new frame the focus under some window managers
|
|
1848 that randomly place newly created frames.
|
|
1849
|
|
1850 Nil means don't move the mouse cursor.")
|
|
1851
|
98
|
1852 (defvar vm-url-browser
|
|
1853 (cond ((fboundp 'w3-fetch-other-frame)
|
|
1854 'w3-fetch-other-frame)
|
|
1855 ((fboundp 'w3-fetch)
|
|
1856 'w3-fetch)
|
|
1857 (t 'vm-mouse-send-url-to-netscape))
|
|
1858 "*Non-nil value means VM should enable URL passing.
|
|
1859 This means that VM will search for URLs (Uniform Resource
|
0
|
1860 Locators) in messages and make it possible for you to pass them
|
|
1861 to a World Wide Web browser.
|
|
1862
|
|
1863 Clicking mouse-2 on the URL will send it to the browser.
|
|
1864
|
98
|
1865 By default clicking mouse-3 on the URL will pop up a menu of
|
|
1866 browsers and you can pick which one you want to use. If
|
|
1867 vm-popup-menu-on-mouse-3 is set to nil, you will not see the menu.
|
0
|
1868
|
|
1869 Moving point to a character within the URL and pressing RETURN
|
98
|
1870 will send the URL to the browser.
|
0
|
1871
|
|
1872 If the value of vm-url-browser is a string, it should specify
|
|
1873 name of an external browser to run. The URL will be passed to
|
|
1874 the program as its first argument.
|
|
1875
|
98
|
1876 If the value of vm-url-browser is a symbol, it should specify a
|
0
|
1877 Lisp function to call. The URL will be passed to the program as
|
|
1878 its first and only argument. Use
|
|
1879
|
|
1880 (setq vm-url-browser 'vm-mouse-send-url-to-netscape)
|
|
1881
|
|
1882 for Netscape, and
|
|
1883
|
|
1884 (setq vm-url-browser 'vm-mouse-send-url-to-mosaic)
|
|
1885
|
|
1886 for Mosaic. The advantage of using them is that they will display
|
|
1887 an URL using on existing Mosaic or Netscape process, if possible.
|
|
1888
|
98
|
1889 A nil value means VM should not enable URL passing to browsers.")
|
0
|
1890
|
|
1891 (defvar vm-highlight-url-face 'bold-italic
|
|
1892 "*Non-nil value should be a face to use display URLs found in messages.
|
|
1893 Nil means don't highlight URLs.")
|
|
1894
|
|
1895 (defvar vm-url-search-limit 12000
|
|
1896 "*Non-nil numeric value tells VM how hard to search for URLs.
|
|
1897 The number specifies the maximum message size in characters that
|
|
1898 VM will search for URLs. For message larger than this value, VM
|
|
1899 will search from the beginning of the mssage to a point
|
|
1900 vm-url-search-limit / 2 characters into the message. Then VM will
|
|
1901 search from a point vm-url-search-limit / 2 characters from the
|
|
1902 end of the message to the end of message.")
|
|
1903
|
|
1904 (defvar vm-display-xfaces nil
|
|
1905 "*Non-nil means display images as specifies in X-Face headers.
|
|
1906 This requires at least XEmacs 19.12 with native xface support compiled in.")
|
|
1907
|
|
1908 (defvar vm-startup-with-summary t
|
|
1909 "*Value tells VM whether to generate a summary when a folder is visited.
|
|
1910 Nil means don't automatically generate a summary.
|
|
1911
|
|
1912 A value of t means always generate a summary.
|
|
1913
|
|
1914 A positive numeric value N means only generate a summary if there
|
|
1915 are N or more messages.
|
|
1916
|
|
1917 A negative numeric value -N means only generate a summary if
|
|
1918 there are N or less messages.")
|
|
1919
|
|
1920 (defvar vm-follow-summary-cursor t
|
|
1921 "*Non-nil value causes VM to select the message under the cursor in the
|
|
1922 summary window before executing commands that operate on the current message.
|
|
1923 This occurs only when the summary buffer window is the selected window.")
|
|
1924
|
|
1925 (defvar vm-jump-to-new-messages t
|
|
1926 "*Non-nil value causes VM to jump to the first new message
|
|
1927 whenever such messages arrive in a folder or the first time a
|
|
1928 folder is visited.
|
|
1929
|
|
1930 See also vm-jump-to-unread-messages.")
|
|
1931
|
|
1932 (defvar vm-jump-to-unread-messages t
|
|
1933 "*Non-nil value causes VM to jump to the first unread message
|
|
1934 whenever such messages arrive in a folder or the first time a
|
|
1935 folder is visited. New messages are considered unread in this
|
|
1936 context so new messages will be jumped to as well.
|
|
1937
|
|
1938 The value of vm-jump-to-new-messages takes precedence over the
|
|
1939 setting of this variable. So if there are unread messages and
|
|
1940 new messages VM will jump to the first new message, even if an
|
|
1941 unread message appears before it in the folder, provided
|
|
1942 vm-jump-to-new-messages is non-nil.")
|
|
1943
|
|
1944 (defvar vm-skip-deleted-messages t
|
|
1945 "*Non-nil value causes VM's `n' and 'p' commands to skip over
|
|
1946 deleted messages. A value of t causes deleted messages to always be skipped.
|
|
1947 A value that is not nil and not t causes deleted messages to be skipped only
|
|
1948 if there are other messages that are not flagged for deletion in the desired
|
|
1949 direction of motion.")
|
|
1950
|
|
1951 (defvar vm-skip-read-messages nil
|
|
1952 "*Non-nil value causes VM's `n' and `p' commands to skip over
|
|
1953 messages that have already been read, in favor of new or unread messages.
|
|
1954 A value of t causes read messages to always be skipped. A value that is
|
|
1955 not nil and not t causes read messages to be skipped only if there are
|
|
1956 unread messages in the desired direction of motion.")
|
|
1957
|
|
1958 (defvar vm-move-after-deleting nil
|
|
1959 "*Non-nil value causes VM's `d' command to automatically invoke
|
|
1960 vm-next-message or vm-previous-message after deleting, to move
|
|
1961 past the deleted messages. A value of t means motion should
|
|
1962 honor the value of vm-circular-folders. A value that is not t
|
|
1963 and not nil means that motion should be done as if
|
|
1964 vm-circular-folders is set to nil.")
|
|
1965
|
|
1966 (defvar vm-move-after-undeleting nil
|
|
1967 "*Non-nil value causes VM's `u' command to automatically invoke
|
|
1968 vm-next-message or vm-previous-message after undeleting, to move
|
|
1969 past the undeleted messages. A value of t means motion should
|
|
1970 honor the value of vm-circular-folders. A value that is not t
|
|
1971 and not nil means that motion should be done as if
|
|
1972 vm-circular-folders is set to nil.")
|
|
1973
|
98
|
1974 (defvar vm-move-after-killing nil
|
|
1975 "*Non-nil value causes VM's `k' command to automatically invoke
|
|
1976 vm-next-message or vm-previous-message after killing messages, to try
|
|
1977 to move past the deleted messages. A value of t means motion
|
|
1978 should honor the value of vm-circular-folders. A value that is
|
|
1979 not t and not nil means that motion should be done as if
|
|
1980 vm-circular-folders is set to nil.")
|
|
1981
|
0
|
1982 (defvar vm-delete-after-saving nil
|
|
1983 "*Non-nil value causes VM automatically to mark messages for deletion
|
|
1984 after successfully saving them to a folder.")
|
|
1985
|
|
1986 (defvar vm-delete-after-archiving nil
|
|
1987 "*Non-nil value causes VM automatically to mark messages for deletion
|
|
1988 after successfully auto-archiving them with the vm-auto-archive-messages
|
|
1989 command.")
|
|
1990
|
|
1991 (defvar vm-delete-after-bursting nil
|
|
1992 "*Non-nil value causes VM automatically to mark a message for deletion
|
|
1993 after it has been successfully burst by the vm-burst-digest command.")
|
|
1994
|
|
1995 (defvar vm-circular-folders 0
|
|
1996 "*Value determines whether VM folders will be considered circular by
|
|
1997 various commands. `Circular' means VM will wrap from the end of the folder
|
|
1998 to the start and vice versa when moving the message pointer, or deleting,
|
|
1999 undeleting or saving messages before or after the current message.
|
|
2000
|
|
2001 A value of t causes all VM commands to consider folders circular.
|
|
2002
|
|
2003 A value of nil causes all of VM commands to signal an error if the start
|
|
2004 or end of the folder would have to be passed to complete the command.
|
|
2005 For movement commands, this occurs after the message pointer has been
|
|
2006 moved as far as possible in the specified direction. For other commands,
|
|
2007 the error occurs before any part of the command has been executed, i.e.
|
|
2008 no deletions, saves, etc. will be done unless they can be done in their
|
|
2009 entirety.
|
|
2010
|
|
2011 A value that is not nil and not t causes only VM's movement commands to
|
|
2012 consider folders circular. Saves, deletes and undelete commands will
|
|
2013 behave the same as if the value is nil.")
|
|
2014
|
|
2015 (defvar vm-search-using-regexps nil
|
|
2016 "*Non-nil value causes VM's search command to interpret user input as a
|
|
2017 regular expression instead of as a literal string.")
|
|
2018
|
|
2019 (defvar vm-move-messages-physically nil
|
|
2020 "*Non-nil value causes VM's commands that change the message order
|
|
2021 of a folder to always move the physical messages involved and not
|
|
2022 just change the presentation order. Nil means that commands just
|
|
2023 change the order in which VM displays messages and leave the
|
|
2024 folder itself undisturbed.")
|
|
2025
|
|
2026 (defvar vm-edit-message-mode 'text-mode
|
|
2027 "*Major mode to use when editing messages in VM.")
|
|
2028
|
|
2029 (defvar vm-print-command lpr-command
|
|
2030 "*Command VM uses to print messages.")
|
|
2031
|
|
2032 (defvar vm-print-command-switches lpr-switches
|
98
|
2033 "*List of command line flags passed to the command named by vm-print-command.
|
0
|
2034 VM uses vm-print-command to print messages.")
|
|
2035
|
|
2036 (defvar vm-berkeley-mail-compatibility
|
|
2037 (memq system-type '(berkeley-unix netbsd))
|
|
2038 "*Non-nil means to read and write BSD Mail(1) style Status: headers.
|
|
2039 This makes sense if you plan to use VM to read mail archives created by
|
|
2040 Mail.")
|
|
2041
|
|
2042 (defvar vm-strip-reply-headers nil
|
|
2043 "*Non-nil value causes VM to strip away all comments and extraneous text
|
|
2044 from the headers generated in reply messages. If you use the \"fakemail\"
|
98
|
2045 program as distributed with Emacs, you probably want to set this variable
|
0
|
2046 to t, because as of Emacs v18.52 \"fakemail\" could not handle unstripped
|
|
2047 headers.")
|
|
2048
|
|
2049 (defvar vm-select-new-message-hook nil
|
|
2050 "*List of hook functions called every time a message with the 'new'
|
|
2051 attribute is made to be the current message. When the hooks are run the
|
|
2052 current buffer will be the folder containing the message and the
|
|
2053 start and end of the message will be bracketed by (point-min) and
|
|
2054 (point-max).")
|
|
2055
|
|
2056 (defvar vm-select-unread-message-hook nil
|
|
2057 "*List of hook functions called every time a message with the 'unread'
|
|
2058 attribute is made to be the current message. When the hooks are run the
|
|
2059 current buffer will be the folder containing the message and the
|
|
2060 start and end of the message will be bracketed by (point-min) and
|
|
2061 (point-max).")
|
|
2062
|
|
2063 (defvar vm-select-message-hook nil
|
|
2064 "*List of hook functions called every time a message
|
|
2065 is made to be the current message. When the hooks are run the
|
|
2066 current buffer will be the folder containing the message and the
|
|
2067 start and end of the message will be bracketed by (point-min) and
|
|
2068 (point-max).")
|
|
2069
|
|
2070 (defvar vm-arrived-message-hook nil
|
|
2071 "*List of hook functions called once for each message gathered from
|
|
2072 the system mail spool, or from another folder with
|
|
2073 vm-get-new-mail, or from a digest with vm-burst-digest. When the
|
|
2074 hooks are run the current buffer will be the folder containing
|
|
2075 the message and the start and end of the message will be
|
|
2076 bracketed by (point-min) and (point-max).")
|
|
2077
|
|
2078 (defvar vm-arrived-messages-hook nil
|
|
2079 "*List of hook functions called after VM has gathered a group of
|
|
2080 messages from the system mail spool, or from another folder with
|
|
2081 vm-get-new-mail, or from a digest with vm-burst-digest. When the
|
|
2082 hooks are run, the new messages will have already been added to
|
|
2083 the message list but may not yet appear in the summary. When the
|
|
2084 hooks are run the current buffer will be the folder containing
|
|
2085 the messages.")
|
|
2086
|
|
2087 (defvar vm-reply-hook nil
|
|
2088 "*List of hook functions to be run after a Mail mode
|
|
2089 composition buffer has been created for a reply. VM runs this
|
|
2090 hook and then runs vm-mail-mode-hook before leaving the user in
|
|
2091 the Mail mode buffer.")
|
|
2092
|
|
2093 (defvar vm-forward-message-hook nil
|
|
2094 "*List of hook functions to be run after a Mail mode
|
|
2095 composition buffer has been created to forward a message. VM
|
|
2096 runs this hook and then runs vm-mail-mode-hook before leaving the
|
|
2097 user in the Mail mode buffer.")
|
|
2098
|
|
2099 (defvar vm-resend-bounced-message-hook nil
|
|
2100 "*List of hook functions to be run after a Mail mode
|
|
2101 composition buffer has been created to resend a bounced message.
|
|
2102 VM runs this hook and then runs vm-mail-mode-hook before leaving
|
|
2103 the user in the Mail mode buffer.")
|
|
2104
|
|
2105 (defvar vm-resend-message-hook nil
|
|
2106 "*List of hook functions to be run after a Mail mode
|
|
2107 composition buffer has been created to resend a message.
|
|
2108 VM runs this hook and then runs vm-mail-mode-hook before leaving
|
|
2109 the user in the Mail mode buffer.")
|
|
2110
|
|
2111 (defvar vm-send-digest-hook nil
|
|
2112 "*List of hook functions to be run after a Mail mode
|
|
2113 composition buffer has been created to send a digest.
|
|
2114 VM runs this hook and then runs vm-mail-mode-hook before leaving
|
|
2115 the user in the Mail mode buffer.")
|
|
2116
|
|
2117 (defvar vm-mail-hook nil
|
|
2118 "*List of hook functions to be run after a Mail mode
|
|
2119 composition buffer has been created to send a non specialized
|
|
2120 message, i.e. a message that is not a reply, forward, digest,
|
|
2121 etc. VM runs this hook and then runs vm-mail-mode-hook before
|
|
2122 leaving the user in the Mail mode buffer.")
|
|
2123
|
|
2124 (defvar vm-summary-update-hook nil
|
|
2125 "*List of hook functions called just after VM updates an existing
|
|
2126 entry a folder summary.")
|
|
2127
|
|
2128 (defvar vm-summary-redo-hook nil
|
|
2129 "*List of hook functions called just after VM adds or deletes
|
|
2130 entries from a folder summary.")
|
|
2131
|
|
2132 (defvar vm-visit-folder-hook nil
|
|
2133 "*List of hook functions called just after VM visits a folder.
|
|
2134 It doesn't matter if the folder buffer already exists, this hook
|
|
2135 is run each time vm or vm-visit-folder is called interactively.
|
|
2136 It is NOT run after vm-mode is called.")
|
|
2137
|
|
2138 (defvar vm-retrieved-spooled-mail-hook nil
|
|
2139 "*List of hook functions called just after VM has retrieved
|
|
2140 a group of messages from your system mailbox(es). When these
|
|
2141 hooks are run, the messages have been added to the folder buffer
|
|
2142 but not the message list or summary. When the hooks are run, the
|
|
2143 current buffer will be the folder where the messages were
|
|
2144 incorporated.")
|
|
2145
|
|
2146 (defvar vm-edit-message-hook nil
|
|
2147 "*List of hook functions to be run just before a message is edited.
|
|
2148 This is the last thing vm-edit-message does before leaving the user
|
|
2149 in the edit buffer.")
|
|
2150
|
|
2151 (defvar vm-mail-mode-hook nil
|
|
2152 "*List of hook functions to be run after a Mail mode
|
|
2153 composition buffer has been created. This is the last thing VM
|
|
2154 does before leaving the user in the Mail mode buffer.")
|
|
2155
|
|
2156 (defvar vm-mode-hook nil
|
|
2157 "*List of hook functions to run when a buffer enters vm-mode.
|
|
2158 These hook functions should generally be used to set key bindings
|
|
2159 and local variables.")
|
|
2160
|
|
2161 (defvar vm-mode-hooks nil
|
|
2162 "*Old name for vm-mode-hook.
|
|
2163 Supported for backward compatibility.
|
|
2164 You should use the new name.")
|
|
2165
|
|
2166 (defvar vm-summary-mode-hook nil
|
|
2167 "*List of hook functions to run when a VM summary buffer is created.
|
|
2168 The current buffer will be that buffer when the hooks are run.")
|
|
2169
|
|
2170 (defvar vm-summary-mode-hooks nil
|
|
2171 "*Old name for vm-summary-mode-hook.
|
|
2172 Supported for backward compatibility.
|
|
2173 You should use the new name.")
|
|
2174
|
|
2175 (defvar vm-virtual-mode-hook nil
|
|
2176 "*List of hook functions to run when a VM virtual folder buffer is created.
|
|
2177 The current buffer will be that buffer when the hooks are run.")
|
|
2178
|
|
2179 (defvar vm-quit-hook nil
|
|
2180 "*List of hook functions to run when you quit VM.
|
|
2181 This applies to any VM quit command.")
|
|
2182
|
|
2183 (defvar vm-summary-pointer-update-hook nil
|
|
2184 "*List of hook functions to run when VM summary pointer is updated.
|
|
2185 When the hooks are run, the current buffer will be the summary buffer.")
|
|
2186
|
|
2187 (defvar vm-display-buffer-hook nil
|
|
2188 "*List of hook functions that are run every time VM wants to
|
|
2189 display a buffer. When the hooks are run the current buffer will
|
|
2190 be the buffer that VM wants to display. The hooks are expected
|
|
2191 to select a window and VM will display the buffer in that
|
|
2192 window.
|
|
2193
|
|
2194 If you use display hooks, you should not use VM's builtin window
|
|
2195 configuration system as the result is likely to be confusing.")
|
|
2196
|
|
2197 (defvar vm-undisplay-buffer-hook nil
|
|
2198 "*List of hook functions that are run every time VM wants to
|
|
2199 remove a buffer from the display. When the hooks are run the
|
|
2200 current buffer will be the buffer that VM wants to disappear.
|
|
2201 The hooks are expected to do the work of removing the buffer from
|
|
2202 the display. The hook functions should not kill the buffer.
|
|
2203
|
|
2204 If you use undisplay hooks, you should not use VM's builtin
|
|
2205 window configuration system as the result is likely to be
|
|
2206 confusing.")
|
|
2207
|
|
2208 (defvar vm-iconify-frame-hook nil
|
|
2209 "*List of hook functions that are run whenever VM iconifies a frame.")
|
|
2210
|
|
2211 (defvar vm-menu-setup-hook nil
|
76
|
2212 "*List of hook functions that are run just after all menus are initialized.")
|
20
|
2213
|
98
|
2214 (defvar vm-mime-display-function nil
|
|
2215 "*If non-nil, this should name a function to be called inside
|
|
2216 vm-decode-mime-message to do the MIME display the current
|
|
2217 message. The function is called with no arguments, and at the
|
|
2218 time of the call the current buffer will be the `presentation'
|
|
2219 buffer for the folder, which is a temporary buffer that VM uses
|
|
2220 for the display of MIME messages. A copy of the current message
|
|
2221 will be in the presentation buffer at that time. The normal work
|
|
2222 that vm-decode-mime-message would do is not done, because this
|
|
2223 function is expected to subsume all of it.")
|
|
2224
|
0
|
2225 (defvar mail-yank-hooks nil
|
|
2226 "Hooks called after a message is yanked into a mail composition.
|
|
2227
|
|
2228 (This hook is deprecated, you should use mail-citation-hook instead.)
|
|
2229
|
|
2230 Value is a list of functions to be run.
|
|
2231 Each hook function can find the newly yanked message between point and mark.
|
|
2232 Each hook function should return with point and mark around the yanked message.
|
|
2233
|
|
2234 See the documentation for vm-yank-message to see when VM will run
|
|
2235 these hooks.")
|
|
2236
|
|
2237 (defvar mail-citation-hook nil
|
|
2238 "*Hook for modifying a citation just inserted in the mail buffer.
|
|
2239 Each hook function can find the citation between (point) and (mark t).
|
|
2240 And each hook function should leave point and mark around the citation
|
|
2241 text as modified.
|
|
2242
|
|
2243 If this hook is entirely empty (nil), a default action is taken
|
|
2244 instead of no action.")
|
|
2245
|
|
2246 (defvar mail-default-headers nil
|
|
2247 "*A string containing header lines, to be inserted in outgoing messages.
|
|
2248 It is inserted before you edit the message,
|
|
2249 so you can edit or delete these lines.")
|
|
2250
|
|
2251 (defvar mail-signature nil
|
|
2252 "*Text inserted at end of mail buffer when a message is initialized.
|
|
2253 If t, it means to insert the contents of the file `~/.signature'.")
|
|
2254
|
|
2255 (defvar vm-rename-current-buffer-function nil
|
|
2256 "*Non-nil value should be a function to call to rename a buffer.
|
|
2257 Value should be something that can be passed to `funcall'. If
|
|
2258 this variable is non-nil, VM will use this function instead of
|
|
2259 its own buffer renaming code. The buffer to be renamed will be
|
|
2260 the current buffer when the function is called.")
|
|
2261
|
|
2262 (defvar mode-popup-menu nil
|
|
2263 "The mode-specific popup menu. Automatically buffer local.
|
|
2264 By default, when you press mouse-3 in VM, this menu is popped up.")
|
|
2265 (make-variable-buffer-local 'mode-popup-menu)
|
|
2266
|
|
2267 (defvar vm-movemail-program "movemail"
|
|
2268 "*Name of program to use to move mail from the system spool
|
|
2269 to another location. Normally this should be the movemail program
|
|
2270 distributed with Emacs.")
|
|
2271
|
|
2272 (defvar vm-netscape-program "netscape"
|
|
2273 "*Name of program to use to run Netscape.
|
|
2274 vm-mouse-send-url-to-netscape uses this.")
|
|
2275
|
|
2276 (defvar vm-mosaic-program "Mosaic"
|
|
2277 "*Name of program to use to run Mosaic.
|
|
2278 vm-mouse-send-url-to-mosaic uses this.")
|
|
2279
|
98
|
2280 (defvar vm-temp-file-directory "/tmp"
|
|
2281 "*Name of a directory where VM can put temporary files.
|
|
2282 This name must not end with a slash.")
|
|
2283
|
0
|
2284 (defvar vm-tale-is-an-idiot nil
|
|
2285 "*Non-nil value causes vm-mail-send to check multi-line recipient
|
|
2286 headers of outbound mail for lines that don't end with a
|
|
2287 comma. If such a line is found, an error is signaled and the
|
|
2288 mail is not sent.")
|
|
2289
|
|
2290 (defvar vm-maintainer-address "bug-vm@uunet.uu.net"
|
|
2291 "Where to send VM bug reports.")
|
|
2292
|
|
2293 (defvar vm-mode-map
|
|
2294 (let ((map (make-sparse-keymap)))
|
|
2295 ;; unneeded now that VM buffers all have buffer-read-only == t.
|
|
2296 ;; (suppress-keymap map)
|
|
2297 (define-key map "h" 'vm-summarize)
|
|
2298 (define-key map "\M-n" 'vm-next-unread-message)
|
|
2299 (define-key map "\M-p" 'vm-previous-unread-message)
|
|
2300 (define-key map "n" 'vm-next-message)
|
|
2301 (define-key map "p" 'vm-previous-message)
|
|
2302 (define-key map "N" 'vm-next-message-no-skip)
|
|
2303 (define-key map "P" 'vm-previous-message-no-skip)
|
|
2304 (define-key map "\C-\M-n" 'vm-move-message-forward)
|
|
2305 (define-key map "\C-\M-p" 'vm-move-message-backward)
|
|
2306 (define-key map "\t" 'vm-goto-message-last-seen)
|
|
2307 (define-key map "\r" 'vm-goto-message)
|
|
2308 (define-key map "^" 'vm-goto-parent-message)
|
|
2309 (define-key map "t" 'vm-expose-hidden-headers)
|
|
2310 (define-key map " " 'vm-scroll-forward)
|
|
2311 (define-key map "b" 'vm-scroll-backward)
|
70
|
2312 (define-key map "\C-?" 'vm-scroll-backward)
|
98
|
2313 (define-key map "D" 'vm-decode-mime-message)
|
0
|
2314 (define-key map "d" 'vm-delete-message)
|
|
2315 (define-key map "\C-d" 'vm-delete-message-backward)
|
|
2316 (define-key map "u" 'vm-undelete-message)
|
|
2317 (define-key map "U" 'vm-unread-message)
|
|
2318 (define-key map "e" 'vm-edit-message)
|
|
2319 (define-key map "a" 'vm-set-message-attributes)
|
|
2320 (define-key map "j" 'vm-discard-cached-data)
|
|
2321 (define-key map "k" 'vm-kill-subject)
|
|
2322 (define-key map "f" 'vm-followup)
|
|
2323 (define-key map "F" 'vm-followup-include-text)
|
|
2324 (define-key map "r" 'vm-reply)
|
|
2325 (define-key map "R" 'vm-reply-include-text)
|
|
2326 (define-key map "\M-r" 'vm-resend-bounced-message)
|
|
2327 (define-key map "B" 'vm-resend-message)
|
|
2328 (define-key map "z" 'vm-forward-message)
|
|
2329 (define-key map "c" 'vm-continue-composing-message)
|
|
2330 (define-key map "@" 'vm-send-digest)
|
|
2331 (define-key map "*" 'vm-burst-digest)
|
|
2332 (define-key map "m" 'vm-mail)
|
|
2333 (define-key map "g" 'vm-get-new-mail)
|
|
2334 (define-key map "G" 'vm-sort-messages)
|
|
2335 (define-key map "v" 'vm-visit-folder)
|
|
2336 (define-key map "s" 'vm-save-message)
|
|
2337 (define-key map "w" 'vm-save-message-sans-headers)
|
|
2338 (define-key map "A" 'vm-auto-archive-messages)
|
|
2339 (define-key map "S" 'vm-save-folder)
|
|
2340 (define-key map "|" 'vm-pipe-message-to-command)
|
|
2341 (define-key map "#" 'vm-expunge-folder)
|
|
2342 (define-key map "q" 'vm-quit)
|
|
2343 (define-key map "x" 'vm-quit-no-change)
|
|
2344 (define-key map "i" 'vm-iconify-frame)
|
|
2345 (define-key map "?" 'vm-help)
|
|
2346 (define-key map "\C-_" 'vm-undo)
|
|
2347 (define-key map "\C-xu" 'vm-undo)
|
|
2348 (define-key map "!" 'shell-command)
|
|
2349 (define-key map "<" 'vm-beginning-of-message)
|
|
2350 (define-key map ">" 'vm-end-of-message)
|
|
2351 (define-key map "\M-s" 'vm-isearch-forward)
|
|
2352 (define-key map "=" 'vm-summarize)
|
|
2353 (define-key map "L" 'vm-load-init-file)
|
|
2354 (define-key map "l" (make-sparse-keymap))
|
|
2355 (define-key map "la" 'vm-add-message-labels)
|
|
2356 (define-key map "ld" 'vm-delete-message-labels)
|
|
2357 (define-key map "V" (make-sparse-keymap))
|
|
2358 (define-key map "VV" 'vm-visit-virtual-folder)
|
|
2359 (define-key map "VC" 'vm-create-virtual-folder)
|
|
2360 (define-key map "VA" 'vm-apply-virtual-folder)
|
|
2361 (define-key map "VM" 'vm-toggle-virtual-mirror)
|
|
2362 (define-key map "V?" 'vm-virtual-help)
|
|
2363 (define-key map "M" (make-sparse-keymap))
|
|
2364 (define-key map "MN" 'vm-next-command-uses-marks)
|
|
2365 (define-key map "Mn" 'vm-next-command-uses-marks)
|
|
2366 (define-key map "MM" 'vm-mark-message)
|
|
2367 (define-key map "MU" 'vm-unmark-message)
|
|
2368 (define-key map "Mm" 'vm-mark-all-messages)
|
|
2369 (define-key map "Mu" 'vm-clear-all-marks)
|
|
2370 (define-key map "MC" 'vm-mark-matching-messages)
|
|
2371 (define-key map "Mc" 'vm-unmark-matching-messages)
|
|
2372 (define-key map "MT" 'vm-mark-thread-subtree)
|
|
2373 (define-key map "Mt" 'vm-unmark-thread-subtree)
|
|
2374 (define-key map "MS" 'vm-mark-messages-same-subject)
|
|
2375 (define-key map "Ms" 'vm-unmark-messages-same-subject)
|
|
2376 (define-key map "MA" 'vm-mark-messages-same-author)
|
|
2377 (define-key map "Ma" 'vm-unmark-messages-same-author)
|
98
|
2378 (define-key map "MR" 'vm-mark-summary-region)
|
|
2379 (define-key map "Mr" 'vm-unmark-summary-region)
|
0
|
2380 (define-key map "M?" 'vm-mark-help)
|
|
2381 (define-key map "W" (make-sparse-keymap))
|
|
2382 (define-key map "WW" 'vm-apply-window-configuration)
|
|
2383 (define-key map "WS" 'vm-save-window-configuration)
|
|
2384 (define-key map "WD" 'vm-delete-window-configuration)
|
|
2385 (define-key map "W?" 'vm-window-help)
|
|
2386 (define-key map "\C-t" 'vm-toggle-threads-display)
|
|
2387 (define-key map "\C-x\C-s" 'vm-save-buffer)
|
|
2388 (define-key map "\C-x\C-w" 'vm-write-file)
|
|
2389 (define-key map "\C-x\C-q" 'vm-toggle-read-only)
|
|
2390 (define-key map "%" 'vm-change-folder-type)
|
|
2391 (define-key map "\M-C" 'vm-show-copying-restrictions)
|
|
2392 (define-key map "\M-W" 'vm-show-no-warranty)
|
|
2393 ;; suppress-keymap provides these, but now that we don't use
|
|
2394 ;; suppress-keymap anymore...
|
|
2395 (define-key map "0" 'digit-argument)
|
|
2396 (define-key map "1" 'digit-argument)
|
|
2397 (define-key map "2" 'digit-argument)
|
|
2398 (define-key map "3" 'digit-argument)
|
|
2399 (define-key map "4" 'digit-argument)
|
|
2400 (define-key map "5" 'digit-argument)
|
|
2401 (define-key map "6" 'digit-argument)
|
|
2402 (define-key map "7" 'digit-argument)
|
|
2403 (define-key map "8" 'digit-argument)
|
|
2404 (define-key map "9" 'digit-argument)
|
|
2405 (define-key map "-" 'negative-argument)
|
|
2406 map )
|
|
2407 "Keymap for VM mode.")
|
|
2408
|
|
2409 (defvar vm-summary-mode-map vm-mode-map
|
|
2410 "Keymap for VM Summary mode")
|
|
2411
|
|
2412 (defvar vm-mail-mode-map
|
|
2413 (let ((map (make-sparse-keymap)))
|
|
2414 (define-key map "\C-c\C-v" vm-mode-map)
|
98
|
2415 (define-key map "\C-c\C-p" 'vm-mime-preview-composition)
|
|
2416 (define-key map "\C-c\C-e" 'vm-mime-encode-composition)
|
|
2417 (define-key map "\C-c\C-a" 'vm-mime-attach-file)
|
|
2418 (define-key map "\C-c\C-m" 'vm-mime-attach-mime-file)
|
0
|
2419 (define-key map "\C-c\C-y" 'vm-yank-message)
|
|
2420 (define-key map "\C-c\C-s" 'vm-mail-send)
|
|
2421 (define-key map "\C-c\C-c" 'vm-mail-send-and-exit)
|
|
2422 map )
|
70
|
2423 "Keymap for VM Mail mode buffers.")
|
0
|
2424
|
|
2425 (defvar vm-edit-message-map
|
|
2426 (let ((map (make-sparse-keymap)))
|
|
2427 (define-key map "\C-c\C-v" vm-mode-map)
|
|
2428 (define-key map "\C-c\e" 'vm-edit-message-end)
|
|
2429 (define-key map "\C-c\C-c" 'vm-edit-message-end)
|
|
2430 (define-key map "\C-c\C-]" 'vm-edit-message-abort)
|
|
2431 map )
|
|
2432 "Keymap for the buffers created by VM's vm-edit-message command.")
|
|
2433
|
|
2434 (defvar vm-folder-history nil
|
|
2435 "List of folders visited this Emacs session.")
|
|
2436
|
|
2437 ;; internal vars
|
|
2438 (defvar vm-folder-type nil)
|
|
2439 (make-variable-buffer-local 'vm-folder-type)
|
|
2440 (defvar vm-message-list nil)
|
|
2441 (make-variable-buffer-local 'vm-message-list)
|
|
2442 (defvar vm-virtual-folder-definition nil)
|
|
2443 (make-variable-buffer-local 'vm-virtual-folder-definition)
|
|
2444 (defvar vm-virtual-buffers nil)
|
|
2445 (make-variable-buffer-local 'vm-virtual-buffers)
|
|
2446 (defvar vm-real-buffers nil)
|
|
2447 (make-variable-buffer-local 'vm-real-buffers)
|
|
2448 (defvar vm-message-pointer nil)
|
|
2449 (make-variable-buffer-local 'vm-message-pointer)
|
|
2450 (defvar vm-message-order-changed nil)
|
|
2451 (make-variable-buffer-local 'vm-message-order-changed)
|
|
2452 (defvar vm-message-order-header-present nil)
|
|
2453 (make-variable-buffer-local 'vm-message-order-header-present)
|
|
2454 (defvar vm-last-message-pointer nil)
|
|
2455 (make-variable-buffer-local 'vm-last-message-pointer)
|
|
2456 (defvar vm-mail-buffer nil)
|
|
2457 (make-variable-buffer-local 'vm-mail-buffer)
|
98
|
2458 (defvar vm-presentation-buffer nil)
|
|
2459 (make-variable-buffer-local 'vm-presentation-buffer)
|
|
2460 (defvar vm-presentation-buffer-handle nil)
|
|
2461 (make-variable-buffer-local 'vm-presentation-buffer-handle)
|
|
2462 (defvar vm-mime-decoded nil)
|
|
2463 (make-variable-buffer-local 'vm-mime-decoded)
|
0
|
2464 (defvar vm-summary-buffer nil)
|
|
2465 (make-variable-buffer-local 'vm-summary-buffer)
|
|
2466 (defvar vm-summary-pointer nil)
|
|
2467 (make-variable-buffer-local 'vm-summary-pointer)
|
|
2468 (defvar vm-system-state nil)
|
|
2469 (make-variable-buffer-local 'vm-system-state)
|
|
2470 (defvar vm-undo-record-list nil)
|
|
2471 (make-variable-buffer-local 'vm-undo-record-list)
|
|
2472 (defvar vm-saved-undo-record-list nil)
|
|
2473 (make-variable-buffer-local 'vm-saved-undo-record-list)
|
|
2474 (defvar vm-undo-record-pointer nil)
|
|
2475 (make-variable-buffer-local 'vm-undo-record-pointer)
|
|
2476 (defvar vm-last-save-folder nil)
|
|
2477 (make-variable-buffer-local 'vm-last-save-folder)
|
|
2478 (defvar vm-last-written-file nil)
|
|
2479 (make-variable-buffer-local 'vm-last-written-file)
|
|
2480 (defvar vm-last-visit-folder nil)
|
|
2481 (defvar vm-last-pipe-command nil)
|
|
2482 (make-variable-buffer-local 'vm-last-pipe-command)
|
|
2483 (defvar vm-messages-not-on-disk 0)
|
|
2484 (make-variable-buffer-local 'vm-messages-not-on-disk)
|
|
2485 (defvar vm-totals nil)
|
|
2486 (make-variable-buffer-local 'vm-totals)
|
|
2487 (defvar vm-modification-counter 0)
|
|
2488 (make-variable-buffer-local 'vm-modification-counter)
|
|
2489 (defvar vm-flushed-modification-counter nil)
|
|
2490 (make-variable-buffer-local 'vm-flushed-modification-counter)
|
98
|
2491 (defvar vm-tempfile-counter 0)
|
0
|
2492 (defvar vm-messages-needing-summary-update nil)
|
|
2493 (defvar vm-buffers-needing-display-update nil)
|
|
2494 (defvar vm-numbering-redo-start-point nil)
|
|
2495 (make-variable-buffer-local 'vm-numbering-redo-start-point)
|
|
2496 (defvar vm-numbering-redo-end-point nil)
|
|
2497 (make-variable-buffer-local 'vm-numbering-redo-end-point)
|
|
2498 (defvar vm-summary-redo-start-point nil)
|
|
2499 (make-variable-buffer-local 'vm-summary-redo-start-point)
|
|
2500 (defvar vm-need-summary-pointer-update nil)
|
|
2501 (make-variable-buffer-local 'vm-need-summary-pointer-update)
|
|
2502 (defvar vm-thread-obarray nil)
|
|
2503 (make-variable-buffer-local 'vm-thread-obarray)
|
|
2504 (defvar vm-thread-subject-obarray nil)
|
|
2505 (make-variable-buffer-local 'vm-thread-subject-obarray)
|
|
2506 (defvar vm-label-obarray nil)
|
|
2507 (make-variable-buffer-local 'vm-label-obarray)
|
|
2508 (defvar vm-block-new-mail nil)
|
|
2509 (make-variable-buffer-local 'vm-block-new-mail)
|
|
2510 (defvar vm-saved-buffer-modified-p nil)
|
|
2511 (make-variable-buffer-local 'vm-saved-buffer-modified-p)
|
|
2512 (defvar vm-kept-mail-buffers nil)
|
|
2513 (defvar vm-inhibit-write-file-hook nil)
|
100
|
2514 ;; used to choose between the default and
|
|
2515 ;; mail-extract-address-components but I don't see the utility of
|
|
2516 ;; it anymore. It tries to be too smart.
|
|
2517 ;;(defvar vm-chop-full-name-function 'vm-choose-chop-full-name-function)
|
|
2518 (defvar vm-chop-full-name-function 'vm-default-chop-full-name)
|
0
|
2519 (defvar vm-session-beginning t)
|
|
2520 (defvar vm-init-file-loaded nil)
|
|
2521 (defvar vm-window-configurations nil)
|
|
2522 (defvar vm-window-configuration nil)
|
|
2523 (defvar vm-message-id-number 0)
|
|
2524 (defconst vm-spool-directory
|
|
2525 (or (and (boundp 'rmail-spool-directory) rmail-spool-directory)
|
|
2526 "/usr/spool/mail/"))
|
|
2527 (defconst vm-content-length-search-regexp "^Content-Length:.*\n\\|\\(\n\n\\)")
|
|
2528 (defconst vm-content-length-header "Content-Length:")
|
|
2529 (defconst vm-attributes-header-regexp
|
|
2530 "^X-VM-\\(Attributes\\|v5-Data\\):\\(.*\n\\([ \t].*\n\\)*\\)")
|
|
2531 (defconst vm-attributes-header "X-VM-v5-Data:")
|
|
2532 (defconst vm-message-order-header-regexp "^X-VM-Message-Order:")
|
|
2533 (defconst vm-message-order-header "X-VM-Message-Order:")
|
|
2534 (defconst vm-bookmark-header-regexp "^X-VM-Bookmark:")
|
|
2535 (defconst vm-bookmark-header "X-VM-Bookmark:")
|
|
2536 (defconst vm-summary-header-regexp "^X-VM-Summary-Format:")
|
|
2537 (defconst vm-summary-header "X-VM-Summary-Format:")
|
|
2538 (defconst vm-vheader-header-regexp "^X-VM-VHeader:")
|
|
2539 (defconst vm-vheader-header "X-VM-VHeader:")
|
|
2540 (defconst vm-labels-header-regexp "^X-VM-Labels:")
|
|
2541 (defconst vm-labels-header "X-VM-Labels:")
|
|
2542 (defconst vm-berkeley-mail-status-header "Status: ")
|
|
2543 (defconst vm-berkeley-mail-status-header-regexp "^Status: \\(..?\\)\n")
|
|
2544 (defvar vm-matched-header-vector (make-vector 6 nil))
|
|
2545 (defconst vm-supported-folder-types
|
|
2546 '("From_" "From_-with-Content-Length" "mmdf" "babyl"))
|
|
2547 (defconst vm-supported-window-configurations
|
98
|
2548 '(
|
|
2549 ("default")
|
0
|
2550 ("startup")
|
|
2551 ("quitting")
|
|
2552 ("composing-message")
|
|
2553 ("editing-message")
|
|
2554 ("marking-message")
|
|
2555 ("reading-message")
|
|
2556 ("searching-message")
|
98
|
2557 ("vm")
|
|
2558 ("vm-add-message-labels")
|
|
2559 ("vm-apply-virtual-folder")
|
|
2560 ("vm-auto-archive-messages")
|
|
2561 ("vm-beginning-of-message")
|
|
2562 ("vm-burst-digest")
|
|
2563 ("vm-burst-mime-digest")
|
|
2564 ("vm-burst-rfc1153-digest")
|
|
2565 ("vm-burst-rfc934-digest")
|
|
2566 ("vm-change-folder-type")
|
|
2567 ("vm-clear-all-marks")
|
|
2568 ("vm-continue-composing-message")
|
|
2569 ("vm-create-virtual-folder")
|
|
2570 ("vm-decode-mime-message")
|
0
|
2571 ("vm-delete-message")
|
|
2572 ("vm-delete-message-backward")
|
98
|
2573 ("vm-delete-message-labels")
|
|
2574 ("vm-discard-cached-data")
|
70
|
2575 ("vm-edit-message")
|
98
|
2576 ("vm-edit-message-abort")
|
70
|
2577 ("vm-edit-message-end")
|
98
|
2578 ("vm-edit-message-other-frame")
|
|
2579 ("vm-end-of-message")
|
|
2580 ("vm-expose-hidden-headers")
|
|
2581 ("vm-expunge-folder")
|
|
2582 ("vm-followup")
|
|
2583 ("vm-followup-include-text")
|
|
2584 ("vm-followup-include-text-other-frame")
|
|
2585 ("vm-followup-other-frame")
|
|
2586 ("vm-forward-message")
|
|
2587 ("vm-forward-message-all-headers")
|
|
2588 ("vm-forward-message-all-headers-other-frame")
|
|
2589 ("vm-forward-message-other-frame")
|
|
2590 ("vm-get-new-mail")
|
|
2591 ("vm-goto-message")
|
|
2592 ("vm-goto-message-last-seen")
|
|
2593 ("vm-goto-parent-message")
|
|
2594 ("vm-help")
|
|
2595 ("vm-isearch-forward")
|
|
2596 ("vm-kill-subject")
|
|
2597 ("vm-load-init-file")
|
|
2598 ("vm-mail")
|
|
2599 ("vm-mail-other-frame")
|
|
2600 ("vm-mail-other-window")
|
|
2601 ("vm-mail-send")
|
|
2602 ("vm-mail-send-and-exit")
|
|
2603 ("vm-mark-all-messages")
|
|
2604 ("vm-mark-help")
|
|
2605 ("vm-mark-matching-messages")
|
|
2606 ("vm-mark-message")
|
|
2607 ("vm-mark-messages-same-author")
|
|
2608 ("vm-mark-messages-same-subject")
|
|
2609 ("vm-mark-summary-region")
|
|
2610 ("vm-mark-thread-subtree")
|
|
2611 ("vm-mode")
|
|
2612 ("vm-move-message-backward")
|
|
2613 ("vm-move-message-backward-physically")
|
|
2614 ("vm-move-message-forward")
|
|
2615 ("vm-move-message-forward-physically")
|
|
2616 ("vm-next-command-uses-marks")
|
|
2617 ("vm-next-message")
|
|
2618 ("vm-next-message-no-skip")
|
|
2619 ("vm-next-message-no-skip")
|
|
2620 ("vm-next-message-same-subject")
|
|
2621 ("vm-next-unread-message")
|
|
2622 ("vm-other-frame")
|
|
2623 ("vm-other-window")
|
|
2624 ("vm-pipe-message-to-command")
|
|
2625 ("vm-previous-message")
|
|
2626 ("vm-previous-message-no-skip")
|
|
2627 ("vm-previous-message-no-skip")
|
|
2628 ("vm-previous-message-same-subject")
|
|
2629 ("vm-previous-unread-message")
|
70
|
2630 ("vm-quit")
|
98
|
2631 ("vm-quit-just-bury")
|
|
2632 ("vm-quit-just-iconify")
|
|
2633 ("vm-quit-no-change")
|
|
2634 ("vm-reply")
|
|
2635 ("vm-reply-include-text")
|
|
2636 ("vm-reply-include-text-other-frame")
|
|
2637 ("vm-reply-other-frame")
|
|
2638 ("vm-resend-bounced-message")
|
|
2639 ("vm-resend-bounced-message-other-frame")
|
|
2640 ("vm-resend-message")
|
|
2641 ("vm-resend-message-other-frame")
|
|
2642 ("vm-save-and-expunge-folder")
|
0
|
2643 ("vm-save-buffer")
|
|
2644 ("vm-save-folder")
|
98
|
2645 ("vm-save-message")
|
|
2646 ("vm-save-message-sans-headers")
|
|
2647 ("vm-scroll-backward")
|
|
2648 ("vm-scroll-forward")
|
|
2649 ("vm-send-digest")
|
|
2650 ("vm-send-digest-other-frame")
|
|
2651 ("vm-send-mime-digest")
|
|
2652 ("vm-send-mime-digest-other-frame")
|
|
2653 ("vm-send-rfc1153-digest")
|
|
2654 ("vm-send-rfc1153-digest-other-frame")
|
|
2655 ("vm-send-rfc934-digest")
|
|
2656 ("vm-send-rfc934-digest-other-frame")
|
|
2657 ("vm-set-message-attributes")
|
|
2658 ("vm-show-copying-restrictions")
|
|
2659 ("vm-show-no-warranty")
|
|
2660 ("vm-sort-messages")
|
|
2661 ("vm-submit-bug-report")
|
|
2662 ("vm-summarize")
|
|
2663 ("vm-summarize-other-frame")
|
|
2664 ("vm-toggle-read-only")
|
|
2665 ("vm-toggle-threads-display")
|
|
2666 ("vm-undelete-message")
|
|
2667 ("vm-undo")
|
|
2668 ("vm-unmark-matching-messages")
|
|
2669 ("vm-unmark-message")
|
|
2670 ("vm-unmark-messages-same-author")
|
|
2671 ("vm-unmark-messages-same-subject")
|
|
2672 ("vm-unmark-summary-region")
|
|
2673 ("vm-unmark-thread-subtree")
|
|
2674 ("vm-unread-message")
|
|
2675 ("vm-virtual-help")
|
0
|
2676 ("vm-visit-folder")
|
|
2677 ("vm-visit-folder-other-frame")
|
|
2678 ("vm-visit-folder-other-window")
|
|
2679 ("vm-visit-virtual-folder")
|
|
2680 ("vm-visit-virtual-folder-other-frame")
|
98
|
2681 ("vm-visit-virtual-folder-other-window")
|
|
2682 ("vm-write-file")
|
|
2683 ("vm-yank-message")
|
|
2684 ("vm-yank-message-other-folder")
|
|
2685 ))
|
0
|
2686 (defconst vm-supported-sort-keys
|
|
2687 '("date" "reversed-date"
|
|
2688 "author" "reversed-author"
|
|
2689 "subject" "reversed-subject"
|
|
2690 "recipients" "reversed-recipients"
|
|
2691 "line-count" "reversed-line-count"
|
|
2692 "byte-count" "reversed-byte-count"
|
|
2693 "physical-order" "reversed-physical-order"))
|
|
2694 (defconst vm-supported-interactive-virtual-selectors
|
|
2695 '(("any")
|
|
2696 ("header")
|
|
2697 ("label")
|
|
2698 ("text")
|
|
2699 ("recipient")
|
|
2700 ("author")
|
|
2701 ("subject")
|
|
2702 ("sent-before")
|
|
2703 ("sent-after")
|
|
2704 ("more-chars-than")
|
|
2705 ("less-chars-than")
|
|
2706 ("more-lines-than")
|
|
2707 ("less-lines-than")
|
|
2708 ("new")
|
|
2709 ("unread")
|
|
2710 ("read")
|
|
2711 ("deleted")
|
|
2712 ("replied")
|
|
2713 ("forwarded")
|
|
2714 ("filed")
|
|
2715 ("written")
|
|
2716 ("edited")
|
|
2717 ("marked")))
|
|
2718 (defconst vm-supported-attribute-names
|
|
2719 '("new"
|
|
2720 "unread"
|
|
2721 "read"
|
|
2722 "deleted"
|
|
2723 "replied"
|
|
2724 "forwarded"
|
|
2725 "redistributed"
|
|
2726 "filed"
|
|
2727 "written"
|
|
2728 "edited"
|
|
2729 "undeleted"
|
|
2730 "unreplied"
|
|
2731 "unforwarded"
|
|
2732 "unredistributed"
|
|
2733 "unfiled"
|
|
2734 "unwritten"
|
|
2735 "unedited"
|
|
2736 ;; for babyl cogniscenti
|
|
2737 "recent"
|
|
2738 "unseen"
|
|
2739 "answered"
|
|
2740 "unanswered"))
|
|
2741
|
|
2742 (defvar vm-key-functions nil)
|
98
|
2743 (defconst vm-digest-type-alist '(("rfc934") ("rfc1153") ("mime")))
|
0
|
2744 (defvar vm-completion-auto-correct t
|
|
2745 "Non-nil means that minibuffer-complete-file should aggressively erase
|
|
2746 the trailing part of a word that caused completion to fail, and retry
|
|
2747 the completion with the resulting word.")
|
|
2748 (defvar vm-minibuffer-completion-table nil
|
|
2749 "Completion table used by vm-minibuffer-complete-word.
|
|
2750 Should be just a list of strings, not an alist or an obarray.")
|
|
2751 (defvar vm-completion-auto-space t
|
|
2752 "Non-nil value means that vm-minibuffer-complete-word should automatically
|
|
2753 append a space to words that complete unambiguously.")
|
|
2754 (defconst vm-attributes-vector-length 9)
|
70
|
2755 (defconst vm-cache-vector-length 20)
|
98
|
2756 (defconst vm-softdata-vector-length 18)
|
0
|
2757 (defconst vm-location-data-vector-length 6)
|
|
2758 (defconst vm-mirror-data-vector-length 5)
|
|
2759 (defconst vm-startup-message-lines
|
|
2760 '("Please use \\[vm-submit-bug-report] to report bugs."
|
98
|
2761 "For discussion about the VM mail reader, see the gnu.emacs.vm.info newsgroup"
|
0
|
2762 "You may give out copies of VM. Type \\[vm-show-copying-restrictions] to see the conditions"
|
|
2763 "VM comes with ABSOLUTELY NO WARRANTY; type \\[vm-show-no-warranty] for full details"
|
|
2764 "In Stereo (where available)"))
|
|
2765 (defconst vm-startup-message-displayed nil)
|
|
2766 ;; for the mode line
|
|
2767 (defvar vm-mode-line-format
|
|
2768 '("" " %&%& "
|
98
|
2769 ("VM " vm-version ": "
|
0
|
2770 (vm-folder-read-only "read-only ")
|
|
2771 (vm-virtual-folder-definition (vm-virtual-mirror "mirrored "))
|
|
2772 "%b"
|
|
2773 (vm-mail-buffer (vm-ml-sort-keys ("" " by " vm-ml-sort-keys)))
|
|
2774 (vm-message-list
|
|
2775 (" " vm-ml-message-number
|
|
2776 " (of " vm-ml-highest-message-number ")")
|
|
2777 (vm-folder-type
|
|
2778 " (unrecognized folder type)"
|
|
2779 " (no messages)")))
|
100
|
2780 (vm-spooled-mail-waiting " Mail")
|
0
|
2781 (vm-message-list
|
|
2782 (" %[ " vm-ml-message-attributes-alist
|
|
2783 (vm-ml-labels ("; " vm-ml-labels)) " %] ")
|
|
2784 (" %[%] "))
|
|
2785 "%p" " " global-mode-string))
|
|
2786
|
|
2787 (defvar vm-ml-message-attributes-alist
|
|
2788 '((vm-ml-message-new
|
|
2789 "new"
|
|
2790 (vm-ml-message-unread
|
|
2791 "unread"
|
|
2792 (vm-ml-message-read "read")))
|
|
2793 (vm-ml-message-edited " edited")
|
|
2794 (vm-ml-message-filed " filed")
|
|
2795 (vm-ml-message-written " written")
|
|
2796 (vm-ml-message-replied " replied")
|
|
2797 (vm-ml-message-forwarded " forwarded")
|
|
2798 (vm-ml-message-redistributed " redistributed")
|
|
2799 (vm-ml-message-deleted " deleted")
|
|
2800 (vm-ml-message-marked " MARKED")))
|
|
2801 (defvar vm-ml-message-number nil)
|
|
2802 (make-variable-buffer-local 'vm-ml-message-number)
|
|
2803 (defvar vm-ml-highest-message-number nil)
|
|
2804 (make-variable-buffer-local 'vm-ml-highest-message-number)
|
|
2805 (defvar vm-ml-sort-keys nil)
|
|
2806 (make-variable-buffer-local 'vm-ml-sort-keys)
|
|
2807 (defvar vm-ml-labels nil)
|
|
2808 (make-variable-buffer-local 'vm-ml-labels)
|
|
2809 ; unused now
|
|
2810 ;(defvar vm-ml-attributes-string nil)
|
|
2811 ;(make-variable-buffer-local 'vm-ml-attributes-string)
|
|
2812 (defvar vm-ml-message-new nil)
|
|
2813 (make-variable-buffer-local 'vm-ml-message-new)
|
|
2814 (defvar vm-ml-message-unread nil)
|
|
2815 (make-variable-buffer-local 'vm-ml-message-unread)
|
|
2816 (defvar vm-ml-message-read nil)
|
|
2817 (make-variable-buffer-local 'vm-ml-message-read)
|
|
2818 (defvar vm-ml-message-edited nil)
|
|
2819 (make-variable-buffer-local 'vm-ml-message-edited)
|
|
2820 (defvar vm-ml-message-replied nil)
|
|
2821 (make-variable-buffer-local 'vm-ml-message-replied)
|
|
2822 (defvar vm-ml-message-forwarded nil)
|
|
2823 (make-variable-buffer-local 'vm-ml-message-forwarded)
|
|
2824 (defvar vm-ml-message-redistributed nil)
|
|
2825 (make-variable-buffer-local 'vm-ml-message-redistributed)
|
|
2826 (defvar vm-ml-message-deleted nil)
|
|
2827 (make-variable-buffer-local 'vm-ml-message-deleted)
|
|
2828 (defvar vm-ml-message-filed nil)
|
|
2829 (make-variable-buffer-local 'vm-ml-message-filed)
|
|
2830 (defvar vm-ml-message-written nil)
|
|
2831 (make-variable-buffer-local 'vm-ml-message-written)
|
|
2832 (defvar vm-ml-message-marked nil)
|
|
2833 (make-variable-buffer-local 'vm-ml-message-marked)
|
|
2834 ;; to make the tanjed compiler shut up
|
|
2835 (defvar vm-pop-read-point nil)
|
100
|
2836 (defvar vm-pop-ok-to-ask nil)
|
0
|
2837 (defvar vm-reply-list nil)
|
|
2838 (defvar vm-forward-list nil)
|
|
2839 (defvar vm-redistribute-list nil)
|
|
2840 (defvar current-itimer nil)
|
|
2841 (defvar current-menubar nil)
|
|
2842 (defvar scrollbar-height nil)
|
|
2843 (defvar top-toolbar nil)
|
|
2844 (defvar top-toolbar-height nil)
|
|
2845 (defvar bottom-toolbar nil)
|
|
2846 (defvar bottom-toolbar-height nil)
|
|
2847 (defvar right-toolbar nil)
|
|
2848 (defvar right-toolbar-width nil)
|
|
2849 (defvar left-toolbar nil)
|
|
2850 (defvar left-toolbar-width nil)
|
|
2851 ;; this defvar matches the XEmacs one so it doesn't matter if VM
|
|
2852 ;; is loaded before highlight-headers.el
|
|
2853 (defvar highlight-headers-regexp "Subject[ \t]*:")
|
|
2854 (defvar vm-url-regexp
|
98
|
2855 "<URL:\\([^>]+\\)>\\|\\(\\(file\\|ftp\\|gopher\\|http\\|https\\|news\\|wais\\|www\\)://[^ \t\n\f\r\"<>|()]*[^ \t\n\f\r\"<>|.!?(){}]\\)\\|\\(mailto:[^ \t\n\f\r\"<>|()]*[^ \t\n\f\r\"<>|.!?(){}]\\)"
|
|
2856 "Regular expression that matches an absolute URL.
|
|
2857 The URL itself must be matched by a \\(..\\) grouping.
|
|
2858 VM will extract the URL by copying the lowest number grouping
|
|
2859 that has a match.")
|
0
|
2860 (defconst vm-month-alist
|
|
2861 '(("jan" "January" "1")
|
|
2862 ("feb" "February" "2")
|
|
2863 ("mar" "March" "3")
|
|
2864 ("apr" "April" "4")
|
|
2865 ("may" "May" "5")
|
|
2866 ("jun" "June" "6")
|
|
2867 ("jul" "July" "7")
|
|
2868 ("aug" "August" "8")
|
|
2869 ("sep" "September" "9")
|
|
2870 ("oct" "October" "10")
|
|
2871 ("nov" "November" "11")
|
|
2872 ("dec" "December" "12")))
|
|
2873 (defvar vm-pop-passwords nil)
|
|
2874 (defvar pop-up-frames nil)
|
|
2875 (defvar vm-parse-date-workspace (make-vector 6 nil))
|
|
2876 ;; cache so we don't call timezone-make-date-sortable so much.
|
|
2877 ;; messages have their own cache; this is for the virtual folder
|
|
2878 ;; alist selectors.
|
|
2879 (defvar vm-sortable-date-alist nil)
|
|
2880 (defvar vm-summary-=> nil)
|
|
2881 (defvar vm-summary-no-=> nil)
|
|
2882 (defvar vm-summary-overlay nil)
|
|
2883 (make-variable-buffer-local 'vm-summary-overlay)
|
|
2884 (defvar vm-thread-loop-obarray (make-vector 29 0))
|
|
2885 (defvar vm-delete-duplicates-obarray (make-vector 29 0))
|
|
2886 (defvar vm-mail-mode-map-parented nil)
|
|
2887 (defvar vm-xface-cache (make-vector 29 0))
|
98
|
2888 (defconst vm-mime-base64-alphabet
|
|
2889 (concat
|
|
2890 [
|
|
2891 65 66 67 68 69 70 71 72 73 74 75 76 77
|
|
2892 78 79 80 81 82 83 84 85 86 87 88 89 90
|
|
2893 97 98 99 100 101 102 103 104 105 106 107 108 109
|
|
2894 110 111 112 113 114 115 116 117 118 119 120 121 122
|
|
2895 48 49 50 51 52 53 54 55 56 57 43 47
|
|
2896 ]
|
|
2897 ))
|
|
2898 (defconst vm-mime-base64-alphabet-decoding-vector
|
|
2899 [
|
|
2900 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
|
|
2901 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
|
|
2902 0 0 0 0 0 0 0 0 0 0 0 62 0 0 0 63
|
|
2903 52 53 54 55 56 57 58 59 60 61 0 0 0 0 0 0
|
|
2904 0 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
|
|
2905 15 16 17 18 19 20 21 22 23 24 25 0 0 0 0 0
|
|
2906 0 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
|
|
2907 41 42 43 44 45 46 47 48 49 50 51 0 0 0 0 0
|
|
2908 ])
|
|
2909
|
|
2910 ;;(defconst vm-mime-base64-alphabet-decoding-alist
|
|
2911 ;; '(
|
|
2912 ;; ( 65 . 00) ( 66 . 01) ( 67 . 02) ( 68 . 03) ( 69 . 04) ( 70 . 05)
|
|
2913 ;; ( 71 . 06) ( 72 . 07) ( 73 . 08) ( 74 . 09) ( 75 . 10) ( 76 . 11)
|
|
2914 ;; ( 77 . 12) ( 78 . 13) ( 79 . 14) ( 80 . 15) ( 81 . 16) ( 82 . 17)
|
|
2915 ;; ( 83 . 18) ( 84 . 19) ( 85 . 20) ( 86 . 21) ( 87 . 22) ( 88 . 23)
|
|
2916 ;; ( 89 . 24) ( 90 . 25) ( 97 . 26) ( 98 . 27) ( 99 . 28) (100 . 29)
|
|
2917 ;; (101 . 30) (102 . 31) (103 . 32) (104 . 33) (105 . 34) (106 . 35)
|
|
2918 ;; (107 . 36) (108 . 37) (109 . 38) (110 . 39) (111 . 40) (112 . 41)
|
|
2919 ;; (113 . 42) (114 . 43) (115 . 44) (116 . 45) (117 . 46) (118 . 47)
|
|
2920 ;; (119 . 48) (120 . 49) (121 . 50) (122 . 51) ( 48 . 52) ( 49 . 53)
|
|
2921 ;; ( 50 . 54) ( 51 . 55) ( 52 . 56) ( 53 . 57) ( 54 . 58) ( 55 . 59)
|
|
2922 ;; ( 56 . 60) ( 57 . 61) ( 43 . 62) ( 47 . 63)
|
|
2923 ;; ))
|
|
2924 ;;
|
|
2925 ;;(defvar vm-mime-base64-alphabet-decoding-vector
|
|
2926 ;; (let ((v (make-vector 123 nil))
|
|
2927 ;; (p vm-mime-base64-alphabet-decoding-alist))
|
|
2928 ;; (while p
|
|
2929 ;; (aset v (car (car p)) (cdr (car p)))
|
|
2930 ;; (setq p (cdr p)))
|
|
2931 ;; v ))
|
|
2932
|
|
2933 (defvar vm-message-garbage-alist nil)
|
|
2934 (make-variable-buffer-local 'vm-message-garbage-alist)
|
|
2935 (defvar vm-folder-garbage-alist nil)
|
|
2936 (make-variable-buffer-local 'vm-folder-garbage-alist)
|
|
2937 (defconst vm-mime-header-list '("MIME-Version:" "Content-"))
|
100
|
2938 (defconst vm-mime-mule-charset-to-coding-alist
|
98
|
2939 '(
|
|
2940 ("us-ascii" no-conversion)
|
|
2941 ("iso-8859-1" no-conversion)
|
|
2942 ("iso-8859-2" iso-8859-2)
|
|
2943 ("iso-8859-3" iso-8859-3)
|
|
2944 ("iso-8859-4" iso-8859-4)
|
|
2945 ("iso-8859-5" iso-8859-5)
|
|
2946 ("iso-8859-6" iso-8859-6)
|
|
2947 ("iso-8859-7" iso-8859-7)
|
|
2948 ("iso-8859-8" iso-8859-8)
|
|
2949 ("iso-8859-9" iso-8859-9)
|
|
2950 ("iso-2022-jp" iso-2022-jp)
|
|
2951 ;; probably not correct, but probably better than nothing.
|
|
2952 ("iso-2022-jp-2" iso-2022-jp)
|
|
2953 ("iso-2022-int-1" iso-2022-int-1)
|
|
2954 ("iso-2022-kr" iso-2022-kr)
|
|
2955 ("euc-kr" iso-2022-kr)
|
|
2956 ))
|
100
|
2957 (defvar vm-mime-mule-charset-to-charset-alist
|
|
2958 '(
|
|
2959 (latin-iso8859-1 "iso-8859-1")
|
|
2960 (latin-iso8859-2 "iso-8859-2")
|
|
2961 (latin-iso8859-3 "iso-8859-3")
|
|
2962 (latin-iso8859-4 "iso-8859-4")
|
|
2963 (cyrillic-iso8859-5 "iso-8859-5")
|
|
2964 (arabic-iso8859-6 "iso-8859-6")
|
|
2965 (greek-iso8859-7 "iso-8859-7")
|
|
2966 (hebrew-iso8859-8 "iso-8859-8")
|
|
2967 (latin-iso8859-9 "iso-8859-9")
|
|
2968 (japanese-jisx0208 "iso-2022-jp")
|
|
2969 (korean-ksc5601 "iso-2022-kr")
|
|
2970 (chinese-gb2312 "iso-2022-jp")
|
|
2971 (sisheng "iso-2022-jp")
|
|
2972 (thai-tis620 "iso-2022-jp")
|
|
2973 ))
|
|
2974 (defvar vm-mime-mule-coding-to-charset-alist
|
|
2975 '(
|
|
2976 (iso-2022-8 "iso-2022-jp")
|
|
2977 (iso-2022-7-unix "iso-2022-jp")
|
|
2978 (iso-2022-7-dos "iso-2022-jp")
|
|
2979 (iso-2022-7-mac "iso-2022-jp")
|
|
2980 ))
|
98
|
2981 (defconst vm-mime-charset-completion-alist
|
|
2982 '(
|
|
2983 ("us-ascii")
|
|
2984 ("iso-8859-1")
|
|
2985 ("iso-8859-2")
|
|
2986 ("iso-8859-3")
|
|
2987 ("iso-8859-4")
|
|
2988 ("iso-8859-5")
|
|
2989 ("iso-8859-6")
|
|
2990 ("iso-8859-7")
|
|
2991 ("iso-8859-8")
|
|
2992 ("iso-8859-9")
|
|
2993 ("iso-2022-jp")
|
|
2994 ("iso-2022-jp-2")
|
|
2995 ("iso-2022-int-1")
|
|
2996 ("iso-2022-kr")
|
|
2997 ))
|
|
2998 (defconst vm-mime-type-completion-alist
|
|
2999 '(
|
|
3000 ("text/plain")
|
|
3001 ("text/enriched")
|
|
3002 ("text/html")
|
|
3003 ("audio/basic")
|
|
3004 ("image/jpeg")
|
|
3005 ("image/png")
|
|
3006 ("image/gif")
|
|
3007 ("image/tiff")
|
|
3008 ("video/mpeg")
|
|
3009 ("application/postscript")
|
|
3010 ("application/octet-stream")
|
|
3011 ("message/rfc822")
|
|
3012 ))
|
|
3013 (defconst vm-mime-encoded-word-regexp
|
|
3014 "=\\?\\([^?]+\\)\\?\\([BQ]\\)\\?\\([^?]+\\)\\?=")
|
|
3015 ;; for MS-DOS and Windows NT
|
|
3016 ;; nil value means text file
|
|
3017 ;; t value means binary file
|
|
3018 ;; presumably it controls whether LF -> CRLF mapping is done
|
|
3019 ;; when writing to files.
|
|
3020 (defvar buffer-file-type)
|
|
3021 (defvar vm-frame-list nil)
|
|
3022 (if (not (boundp 'shell-command-switch))
|
|
3023 (defvar shell-command-switch "-c"))
|