;;; 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
-;; Time-stamp: <00/05/10 10:28:00 teranisi>
;; This file is part of ELMO (Elisp Library for Message Orchestration).
(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.")
(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"
"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.")
(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
(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.")
;;; 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
(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)
(?| . 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*")
"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).")
(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