File: //usr/share/emacs/27.1/lisp/mail/mailalias.elc
;ELC   
;;; Compiled
;;; in Emacs version 27.1
;;; with all optimizations.
;;; This file uses dynamic docstrings, first added in Emacs 19.29.
;;; This file does not contain utf-8 non-ASCII characters,
;;; and so can be loaded in Emacs versions earlier than 23.
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(byte-code "\300\301!\210\302\303\304\305\306\307%\210\310\311\312\313\314DD\315\316\317\306\303&\210\310\320\312\313\321DD\322\316\323\306\303&\207" [require sendmail custom-declare-group mailalias nil "Expanding mail aliases." :group mail custom-declare-variable mail-passwd-files funcall function #[0 "\300\207" [("/etc/passwd")] 1] "List of files from which to determine valid user names." :type (repeat string) mail-passwd-command #[0 "\300\207" [nil] 1] "Shell command to retrieve text to add to `/etc/passwd', or nil." (choice string (const nil))] 8)
#@85 Alist of mail address directory entries.
When t this still needs to be initialized.
(defvar mail-directory-names t (#$ . 968))
(defvar mail-address-field-regexp "^\\(Resent-\\)?\\(To\\|From\\|Cc\\|Bcc\\|Reply-To\\):")
(byte-code "\300\301\302\303\304DD\305\306\307\310\311&\210\312\301\313\314#\210\300\315\302\303\316DD\317\306\320\310\311&\210\300\321\302\303\322DD\323\306\324\310\311&\210\325\321\326\327#\210\300\330\302\303\331DD\332\306\333\310\311&\210\300\334\302\303\335DD\336\306\337\310\311&\210\300\340\302\303\341DD\342\306\343\310\311&\210\312\340\313\314#\210\300\344\302\303\345DD\346\306\347\310\311&\210\312\344\313\314#\210\300\350\302\303\351DD\352\306\353\310\311&\210\312\350\313\314#\207" [custom-declare-variable mail-complete-alist funcall function #[0 "\300\207" [(("^\\(Resent-\\)?\\(To\\|From\\|Cc\\|Bcc\\|Reply-To\\):" mail-get-names pattern) ("Newsgroups:" if (boundp 'gnus-active-hashtb) gnus-active-hashtb (if (boundp news-group-article-assoc) news-group-article-assoc)) ("Followup-To:" mail-sentto-newsgroups))] 1] "Alist of header field and expression to return alist for completion.\nThe expression may reference the variable `pattern'\nwhich will hold the string being completed.\nIf not on matching header, `mail-complete-function' gets called instead." :type alist :group mailalias put risky-local-variable t mail-complete-style #[0 "\300\207" [angles] 1] "Specifies how \\[mail-complete] formats the full name when it completes.\nIf nil, they contain just the return address like:\n	king@grassland.com\nIf `parens', they look like:\n	king@grassland.com (Elvis Parsley)\nIf `angles', they look like:\n	Elvis Parsley <king@grassland.com>" (choice (const angles) (const parens) (const nil)) mail-complete-function #[0 "\300\207" [ispell-complete-word] 1] "Function to call when completing outside `mail-complete-alist'-header." (choice function (const nil)) make-obsolete-variable completion-at-point-functions "24.1" mail-directory-function #[0 "\300\207" [nil] 1] "Function to get completions from directory service or nil for none.\nSee `mail-directory-requery'." (choice function (const nil)) mail-directory-requery #[0 "\300\207" [nil] 1] "When non-nil call `mail-directory-function' for each completion.\nIn that case, one argument gets passed to the function, the partial string\nentered so far." boolean mail-directory-process #[0 "\300\207" [nil] 1] "Shell command to get the list of names from a mail directory.\nThis value is used when the value of `mail-directory-function'\nis `mail-directory-process'.  The value should be a list\nof the form (COMMAND ARG ...), where each of the list elements\nis evaluated.  COMMAND should evaluate to a string.  When\n`mail-directory-requery' is non-nil, during evaluation of these\nelements, the variable `pattern' contains the partial input being\ncompleted.  `pattern' is nil when `mail-directory-requery' is nil.\n\nThe value might look like this:\n\n  (remote-shell-program \"HOST\" \"-nl\" \"USER\" \"COMMAND\")\n\nor like this:\n\n  (remote-shell-program \"HOST\" \"-n\" \"COMMAND \\='^\" pattern \"\\='\")" sexp mail-directory-stream #[0 "\300\207" [nil] 1] "List of (HOST SERVICE) for stream connection to mail directory." (choice (const nil) (list (string :tag "Host name or ip address") (choice (integer :tag "Service port number") (string :tag "Service name")) (plist :inline t :tag "Additional open-network-stream parameters"))) mail-directory-parser #[0 "\300\207" [nil] 1] "How to interpret the output of `mail-directory-function'.\nThree types of values are possible:\n\n  - nil means to gather each line as one name\n  - regexp means first \\(grouping\\) in successive matches is name\n  - function called at beginning of buffer that returns an alist of names" (choice (const nil) regexp function)] 8)
#@246 Alist of local users, aliases and directory entries as available.
Elements have the form (MAILNAME) or (MAILNAME . FULLNAME).
If the value means t, it means the real value should be calculated
for the next use.  This is used in `mail-complete'.
(defvar mail-names t (#$ . 4789))
#@66 Alist of local users.
When t this still needs to be initialized.
(defvar mail-local-names t (#$ . 5074))
#@358 Expand all mail aliases in suitable header fields found between BEG and END.
If interactive, expand in header fields.
Suitable header fields are `To', `From', `Cc' and `Bcc', `Reply-To', and
their `Resent-' variants.
Optional second arg EXCLUDE may be a regular expression defining text to be
removed from alias expansions.
(fn BEG END &optional EXCLUDE)
(defalias 'expand-mail-aliases #[770 "\303 \210\304=\203 \305\306 \210\212b\210\307 \305\223\262\305\304\310\n\304#)\203\357 \311\305w\210`\305\211\211\211\211\310\312	\313#\210\314 \210\315\305x\210\316 \262b\210`W\203\346 `\262\211\203c @AZV\203c \211A\262\202N \310\317\304#\203x \320\224\262`Z\262\202\200 \321!\262\320\262\322\"\305\323\"\204\333 \323\"A\211\262\203\333 ZBB\262b\210\211c\210\203\313 \324	\325Q\316 b\210\310\304#\203\307 \326\327!\210\202\270 \211b\266``Z\\|\210b\210\202\341 b\210u\210\266\202E \305\211\223\266\202 \305\211\223*\207" [mail-aliases case-fold-search mail-address-field-regexp sendmail-sync-aliases t nil build-mail-aliases make-marker re-search-forward " 	" "^[^ 	]" move beginning-of-line " 	\n" point-marker "[ 	]*[\n,][ 	]*" 0 marker-position buffer-substring-no-properties assoc "\\b\\(" "\\)\\b" replace-match ""] 17 (#$ . 5186) (byte-code "\212eb\300 )D\207" [mail-header-end] 2)])
#@161 Read mail aliases from personal aliases file and set `mail-aliases'.
By default, this is the file specified by `mail-personal-alias-file'.
(fn &optional FILE)
(defalias 'build-mail-aliases #[256 "\302\206 !\262\303\304\305!r\211q\210\306\307\310\311\312!\313\"\314$\216\203\315 \315!\2038 r\315!q\210\316ed\")c\210\202[ \317!\203E \320!\210\202[ \317\302\321\"\211\262!\203X \320!\210\202[ \303\262eb\210\322\323\303\324#\203t `\314Z\303\210\211`|\266\202^ db\210h\325=\204\200 \326 \210eb\210m\204\244 \303\210h\327U\203\236 \330\331!\210\330\332!\210\333c\210\202\203 \332u\210\202\203 eb\210\334\335\303\324#\203\307 \334\336!\210\316\307\224\307\225\"\262\337 \210\323c\210\337 \210\202 \303\262\202 eb\210\334\340\303\324#\203\373 \341\314!\342\303w\210`\303\211\210\316`\"\262\211\343\232\204\366 \344\324#\210\266\202\320 	*\207" [mail-personal-alias-file mail-aliases expand-file-name nil generate-new-buffer " *temp*" make-byte-code 0 "\301\300!\205	 \302\300!\207" vconcat vector [buffer-name kill-buffer] 2 get-file-buffer buffer-substring-no-properties file-exists-p insert-file-contents "~/" search-forward "# " t 10 newline 92 delete-char -1 1 32 re-search-forward "^source[ 	]+" "\\S-+" beginning-of-line "^\\(a\\|alias\\|g\\|group\\)[ 	]+\\([^ 	\n]+\\)" match-string " 	" "" define-mail-alias] 9 (#$ . 6539) (byte-code "\301\302\303\"\304\305$C\207" [mail-personal-alias-file read-file-name format "Read mail alias file (default %s): " nil t] 5)])
#@408 Define NAME as a mail alias that translates to DEFINITION.
This means that sending a message to NAME will actually send to DEFINITION.
Normally, the addresses in DEFINITION must be separated by commas.
If FROM-MAILRC-FILE is non-nil, then addresses in DEFINITION
can be separated by spaces; an address can contain spaces
if it is quoted with double-quotes.
(fn NAME DEFINITION &optional FROM-MAILRC-FILE)
(defalias 'define-mail-alias #[770 "\211\204 \303 \210\304=\203 \305\306	!\203 \307 \210\310\311\"\203&