Fix typo.
[elisp/wanderlust.git] / elmo / elmo-vars.el
index 450b6a7..bc9900e 100644 (file)
@@ -1,6 +1,6 @@
 ;;; elmo-vars.el -- User variables for ELMO.
 
-;; Copyright 1998,1999,2000 Yuuichi Teranishi <teranisi@gohome.org>
+;; Copyright (C) 1998,1999,2000 Yuuichi Teranishi <teranisi@gohome.org>
 
 ;; Author: Yuuichi Teranishi <teranisi@gohome.org>
 ;; Keywords: mail, net news
   (defun-maybe dynamic-link (a))
   (defun-maybe dynamic-call (a b)))
 
-;; Version info.
-(defconst elmo-version "1.1.2")
-(defconst elmo-appname "ELMO")
-
-(defun elmo-version ()
-  (format "%s/%s" elmo-appname elmo-version))
-
 ;; IMAP4
 (defvar elmo-default-imap4-mailbox "inbox"
   "*Default IMAP4 mailbox.")
 (defvar elmo-default-imap4-server "localhost"
   "*Default IMAP4 server.")
-(defvar elmo-default-imap4-authenticate-type "auth"
-  "*Default Authentication type for IMAP4.") ; "auth" or "login"
-(defvar elmo-default-imap4-user (or (getenv "USER") 
-                                   (getenv "LOGNAME") 
+(defvar elmo-default-imap4-authenticate-type 'login
+  "*Default Authentication type for IMAP4.")
+(defvar elmo-default-imap4-user (or (getenv "USER")
+                                   (getenv "LOGNAME")
                                    (user-login-name))
-  "*Default username for IMAP4")
-(defvar elmo-default-imap4-port 143 
+  "*Default username for IMAP4.")
+(defvar elmo-default-imap4-port 143
   "*Default Port number of IMAP.")
-(defvar elmo-default-imap4-ssl nil
-  "*Non-nil forces using SSL by default.")
+(defvar elmo-default-imap4-stream-type nil
+  "*Default stream type for IMAP4.
+Any symbol value of `elmo-network-stream-type-alist'.")
+(defvar elmo-imap4-stream-type-alist nil
+  "*Stream bindings for IMAP4.
+This is taken precedence over `elmo-network-stream-type-alist'.")
 
 ;; POP3
-(defvar elmo-default-pop3-user (or (getenv "USER") 
-                                  (getenv "LOGNAME") 
+(defvar elmo-default-pop3-user (or (getenv "USER")
+                                  (getenv "LOGNAME")
                                   (user-login-name))
-  "*Default username for POP3")
+  "*Default username for POP3.")
 (defvar elmo-default-pop3-server  "localhost"
   "*Default POP3 server.")
-(defvar elmo-default-pop3-authenticate-type "user"
-  "*Default Authentication type for POP3") ; "apop" or "user"
+(defvar elmo-default-pop3-authenticate-type 'user
+  "*Default Authentication type for POP3.")
 (defvar elmo-default-pop3-port 110
   "*Default POP3 port.")
-(defvar elmo-default-pop3-ssl nil
-  "*Non-nil forces using SSL by default.")
+(defvar elmo-default-pop3-stream-type nil
+  "*Default stream type for POP3.
+Any symbol value of `elmo-network-stream-type-alist'.")
+(defvar elmo-pop3-stream-type-alist nil
+  "*Stream bindings for POP3.
+This is taken precedence over `elmo-network-stream-type-alist'.")
+(defvar elmo-pop3-use-uidl t
+  "*If non-nil, use UIDL.")
 
 ;; NNTP
 (defvar elmo-default-nntp-server  "localhost"
   "*Default NNTP server.")
 (defvar elmo-default-nntp-user nil
-  "*Default User of NNTP. nil means no user authentication.")
-(defvar elmo-default-nntp-port 119 
-  "*Default Port number of NNTP")
-(defvar elmo-default-nntp-ssl nil
-  "*Non-nil forces using SSL by default.")
-
+  "*Default User of NNTP.  nil means no user authentication.")
+(defvar elmo-default-nntp-port 119
+  "*Default Port number of NNTP.")
+(defvar elmo-default-nntp-stream-type nil
+  "*Default stream type for NNTP.
+Any symbol value of `elmo-network-stream-type-alist'.")
+(defvar elmo-nntp-stream-type-alist nil
+  "*Stream bindings for NNTP.
+This is taken precedence over `elmo-network-stream-type-alist'.")
+
+;; Local
 (defvar elmo-localdir-folder-path "~/Mail"
   "*Local mail folder path.")
 (defvar elmo-localnews-folder-path "~/News"
 (defvar elmo-maildir-list '("\\+~/Maildir")
   "*All Folders that match this list will be treated as Maildir.
 Each elements are regexp of folder name (This is obsolete).")
+
 (defvar elmo-msgdb-dir "~/.elmo"
   "*ELMO Message Database path.")
 (defvar elmo-passwd-alist-file-name "passwd"
   "*ELMO Password filename.")
+(defvar elmo-passwd-life-time nil
+  "*Duration of ELMO Password in seconds.  nil means infinity.")
 (defvar elmo-warning-threshold 30000
   "*Display warning when the bytes of message exceeds this value.")
 (defvar elmo-msg-appended-hook nil
   "A hook called when message is appended to database.")
 (defvar elmo-msg-deleted-hook nil
-  "A hook called when message is deleted from database")
+  "A hook called when message is deleted from database.")
 (defvar elmo-nntp-post-pre-hook nil
   "A hook called just before the nntp posting.")
 (defvar elmo-lang "ja"
   "Language for displayed messages.")
 
 (defvar elmo-mime-charset 'iso-2022-jp)
-(defvar elmo-search-mime-charset 'iso-2022-jp)
 
 (defvar elmo-msgdb-mark-filename "mark"
   "Mark database.")
@@ -126,15 +136,15 @@ Each elements are regexp of folder name (This is obsolete).")
 (defvar elmo-msgdb-finfo-filename "finfo"
   "Folder information cache...list of '(filename . '(new unread all)).")
 (defvar elmo-msgdb-append-list-filename "append"
-  "Appended messages...Structure is same as number-alist. 
+  "Appended messages...Structure is same as number-alist.
 For disconnected operations.")
 (defvar elmo-msgdb-resume-list-filename "resume"
-  "Resumed messages. For disconnected operations.")
+  "Resumed messages.  For disconnected operations.")
 (defvar elmo-msgdb-lock-list-filename "lock"
-  "Locked messages...list of message-id. 
+  "Locked messages...list of message-id.
 For disconnected operations.")
 (defvar elmo-msgdb-global-mark-filename "global-mark"
-  "Alist of global mark .")
+  "Alist of global mark.")
 (defvar elmo-lost+found-folder "+lost+found"
   "Lost and found.")
 (defvar elmo-crosspost-alist-filename "crosspost-alist"
@@ -144,8 +154,8 @@ For disconnected operations.")
   "Non-nil forces to get unread message information on server.")
 
 (defvar elmo-imap4-disuse-server-flag-mailbox-regexp "^#mh" ; UW imapd
-  "If mailbox name matches this value, flags on server are not used except
- \Delete flag.")
+  "Regexp to match IMAP4 mailbox names whose message flags on server should be ignored.
+(Except `\\Deleted' flag).")
 
 (defvar elmo-msgdb-extra-fields nil
   "Extra fields for msgdb.")
@@ -158,7 +168,7 @@ For disconnected operations.")
 (defvar elmo-imap4-overview-fetch-chop-length 200
   "*Number of overviews to fetch in one request in imap4.")
 (defvar elmo-nntp-overview-fetch-chop-length 200
- "*Number of overviews to fetch in one request in nntp.") 
+ "*Number of overviews to fetch in one request in nntp.")
 (defvar elmo-localdir-header-chop-length 2048
   "*Number of bytes to get header in one reading from file.")
 (defvar elmo-imap4-force-login nil
@@ -166,17 +176,15 @@ For disconnected operations.")
 (defvar elmo-imap4-use-select-to-update-status nil
   "*Some imapd have to send select command to update status.
 (ex. UW imapd 4.5-BETA?).  For these imapd, you must set this variable t.")
-
 (defvar elmo-imap4-use-modified-utf7 nil
   "*Use mofidied UTF-7 (rfc2060) encoding for IMAP4 folder name.")
 
 (defvar elmo-auto-change-plugged 600
-  "*Time to expire change plugged state automatically,
-as the number of seconds. Don't change plugged state automatically if nil.")
-
+  "*Time to expire change plugged state automatically, as the number of seconds.
+Don't change plugged state automatically if nil.")
 (defvar elmo-plugged-condition 'one
   "*The condition for `elmo-plugged' becomes on.
-If `all', when all port is on. If `one', when even one port is on.
+If `all', when all ports are on.  If `one', when even one port is on.
 If `independent', independent port plugged.
 If function, return value of function.")
 
@@ -207,7 +215,7 @@ If function, return value of function.")
 
 ;;; User variables for elmo-archive.
 (defvar elmo-archive-default-type 'zip
-  "*Default archiver type. The value must be a symbol.")
+  "*Default archiver type.  The value must be a symbol.")
 
 ;; database dynamic linking
 (defvar elmo-database-dl-module
@@ -233,7 +241,7 @@ If function, return value of function.")
                              (fboundp 'open-database)))
 
 (defvar elmo-date-match (not (boundp 'nemacs-version))
-  "Date match is available or not")
+  "Date match is available or not.")
 
 (defconst elmo-spec-alist
   '((?%  . imap4)
@@ -248,6 +256,18 @@ If function, return value of function.")
     (?|  . pipe)
     (?.  . maildir)))
 
+(defvar elmo-network-stream-type-alist
+  '(("!"      ssl       ssl      open-ssl-stream)
+    ("!!"     starttls  starttls starttls-open-stream)
+    ("!socks" socks     socks    socks-open-network-stream))
+  "An alist of (SPEC-STRING SYMBOL FEATURE OPEN-STREAM-FUNCTION).
+SPEC-STRING is a string for stream-type spec (it must start with '!').
+SYMBOL is a symbol which indicates the name of the stream type.
+SYMBOL should be identical in this alist.
+FEATURE is a symbol of the feature for OPEN-STREAM-FUNCTION.
+OPEN-STREAM-FUNCTION is a function to open network stream.
+Arguments for this function are NAME, BUFFER, HOST and SERVICE.")
+
 (defvar elmo-debug nil)
 (defconst mmelmo-entity-buffer-name "*MMELMO-BUFFER*")
 
@@ -261,7 +281,7 @@ If function, return value of function.")
   "Default expiration method.")
 
 (defvar elmo-cache-expire-default-size 30000
-  "Cache expiration disk size (Kilo bytes). This must be float value.")
+  "Cache expiration disk size (Kilo bytes).  This must be float value.")
 
 (defvar elmo-cache-expire-default-age 50
   "Cache expiration age (days).")
@@ -316,14 +336,40 @@ If function, return value of function.")
 (defvar elmo-localdir-lockfile-list nil)
 
 (defvar elmo-nntp-max-number-precedes-list-active nil
-  "If non-nil, max number of the msgdb is set as the max number of 
-'list active' (needed for inn 2.3 or later?). ")
+  "Non-nil means max number of msgdb is set as the max number of `list active'.
+(Needed for inn 2.3 or later?).")
+
+(defvar elmo-use-killed-list t
+  "If non-nil, deleted messages are saved as `killed'
+and do not appear again.")
 
 (defvar elmo-pop3-send-command-synchronously nil
   "If non-nil, commands are send synchronously.
-If server doesn't accept asynchronous commands, this variable should be 
+If server doesn't accept asynchronous commands, this variable should be
 set as non-nil.")
 
-(provide 'elmo-vars)
+(defvar elmo-hash-maximum-size 4096
+  "Maximum size of hash table.")
+
+(defvar elmo-use-decoded-cache (featurep 'xemacs)
+  "Use cache of decoded mime charset string.")
+
+(defvar elmo-use-overview-hashtb t
+  "Use hash table of overview.")
+
+(defvar elmo-display-progress-threshold 20
+  "*Displaying progress gauge if number of messages are more than this value.")
+
+(defvar elmo-inhibit-read-cache nil
+  "*Global switch to inhibit reading cache.")
+
+(defvar elmo-inhibit-display-retrieval-progress nil
+  "Global switch to inhibit display progress of each message's retrieval.")
+
+(defvar elmo-display-retrieval-progress-threshold 30000
+  "*Don't display progress if the message size is smaller than this value.")
+
+(require 'product)
+(product-provide (provide 'elmo-vars) (require 'elmo-version))
 
 ;;; elmo-vars.el ends here