annotate lisp/mail/rmailout.el @ 15097:32c26cb9e078

(Fexpand_file_name, Ffile_name_absolute_p): Doc fixes. (Ffile_exists_p, Ffile_executable_p, Ffile_readable_p) (Ffile_writable_p, Ffile_directory_p, Ffile_regular_p) (Ffile_modes, Fset_file_modes, Ffile_newer_than_file_p) (expand_and_dir_to_file): Rename abspath to absname. (CORRECT_DIR_SEPS) [DOS_NT]: New macro. (IS_DRIVE) [DOS_NT]: Added separate definitions for DOS and NT. (Ffile_name_directory) [DOS_NT]: Simplify code to match change in getdefdir in msdos.c. Ignore embedded colons. Correct dir seps. (Ffile_name_nondirectory) [DOS_NT]: Ignore embedded colons. Correct IS_ANY_SEP to IS_DIRECTORY_SEP. (file_name_as_directory) [DOS_NT]: Correct dir seps. Correct IS_ANY_SEP to IS_DIRECTORY_SEP. (directory_file_name) [DOS_NT]: Correct dir seps. (Fmake_temp_name) [DOS_NT: Correct dir seps. (Fexpand_file_name) [mostly DOS_NT]: Remove relpath, tmp and defdir variables; init drive to 0. Correctly detect when default_directory is absolute. Be strict when looking for MSDOS drive specifier; defer calling getdefdir. Ignore drive specifier if name now has UNC prefix. Correctly recognise if name is not absolute when trying simple method to expand; return original string if possible. Skip dir sep after ~ or ~user. Use getpwnam instead of HOME for ~user on NT. Handle error return from getdefdir. Correctly detect if newdir is absolute before using default_directory. Handle case where newdir is not absolute - expand relative to current working dir if necessary (instead of calling getdisk later). Only keep UNC prefix if nm starts with dir sep. Replace kludgy handling of drive spec in newdir. Correct dir seps. (Fexpand_file_name) [!DOS_NT]: Fix incorrect expansion of "/foo/../bar" -> "//bar". (Fsubstitute_in_file_name) [DOS_NT]: Correct dir seps for NT as well. Merge equivalent #ifdef APOLLO and WINDOWSNT cases. Ignore embedded colons and be strict about drive specs. (Fcopy_file) [DOS_NT]: Do dev/inode check on NT. (Ffile_name_absolute_p) [DOS_NT]: Be strict about drive specs. (check_executable) [DOS_NT]: Test st_mode on NT. (Ffile_readable_p) [DOS_NT]: Use access instead of open on NT. (Ffile_modes) [DOS_NT]: Don't embelish st_mode value on NT. (Fread_file_name) [DOS_NT]: Correct dir seps in HOME. (syms_of_fileio): Add Vdirectory_sep_char.
author Richard M. Stallman <rms@gnu.org>
date Sat, 27 Apr 1996 01:14:17 +0000
parents 83f275dcd93a
children 5bc27ae3cd14
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
658
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 202
diff changeset
1 ;;; rmailout.el --- "RMAIL" mail reader for Emacs: output message to a file.
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 202
diff changeset
2
7298
4fd40bd394fe Update copyright.
Karl Heuer <kwzh@gnu.org>
parents: 6884
diff changeset
3 ;; Copyright (C) 1985, 1987, 1993, 1994 Free Software Foundation, Inc.
845
213978acbc1e entered into RCS
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 814
diff changeset
4
788
c8d4eb38ebfc *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 713
diff changeset
5 ;; Maintainer: FSF
814
38b2499cb3e9 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 807
diff changeset
6 ;; Keywords: mail
788
c8d4eb38ebfc *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 713
diff changeset
7
63
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
8 ;; This file is part of GNU Emacs.
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
9
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
10 ;; GNU Emacs is free software; you can redistribute it and/or modify
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
11 ;; it under the terms of the GNU General Public License as published by
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 788
diff changeset
12 ;; the Free Software Foundation; either version 2, or (at your option)
63
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
13 ;; any later version.
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
14
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
15 ;; GNU Emacs is distributed in the hope that it will be useful,
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
18 ;; GNU General Public License for more details.
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
19
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
20 ;; You should have received a copy of the GNU General Public License
14169
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13054
diff changeset
21 ;; along with GNU Emacs; see the file COPYING. If not, write to the
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13054
diff changeset
22 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 13054
diff changeset
23 ;; Boston, MA 02111-1307, USA.
63
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
24
788
c8d4eb38ebfc *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 713
diff changeset
25 ;;; Code:
63
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
26
5859
84ad3a2c5373 Add (require 'rmail) so the macro will be byte-compiled properly.
Karl Heuer <kwzh@gnu.org>
parents: 5802
diff changeset
27 (require 'rmail)
84ad3a2c5373 Add (require 'rmail) so the macro will be byte-compiled properly.
Karl Heuer <kwzh@gnu.org>
parents: 5802
diff changeset
28
63
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
29 ;; Temporary until Emacs always has this variable.
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
30 (defvar rmail-delete-after-output nil
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
31 "*Non-nil means automatically delete a message that is copied to a file.")
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
32
145
1a0f15a66c06 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 63
diff changeset
33 (defvar rmail-output-file-alist nil
1a0f15a66c06 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 63
diff changeset
34 "*Alist matching regexps to suggested output Rmail files.
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
35 This is a list of elements of the form (REGEXP . NAME-EXP).
4851
b70799eabd57 (rmail-output-file-alist): Doc fix.
Roland McGrath <roland@gnu.org>
parents: 4836
diff changeset
36 The suggestion is taken if REGEXP matches anywhere in the message buffer.
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
37 NAME-EXP may be a string constant giving the file name to use,
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
38 or more generally it may be any kind of expression that returns
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
39 a file name as a string.")
145
1a0f15a66c06 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 63
diff changeset
40
1866
a712cff3b6e7 * rmailout.el (rmail-output, rmail-output-to-mail-file): Reverse
Jim Blandy <jimb@redhat.com>
parents: 1460
diff changeset
41 ;;; There are functions elsewhere in Emacs that use this function; check
a712cff3b6e7 * rmailout.el (rmail-output, rmail-output-to-mail-file): Reverse
Jim Blandy <jimb@redhat.com>
parents: 1460
diff changeset
42 ;;; them out before you change the calling method.
a712cff3b6e7 * rmailout.el (rmail-output, rmail-output-to-mail-file): Reverse
Jim Blandy <jimb@redhat.com>
parents: 1460
diff changeset
43 (defun rmail-output-to-rmail-file (file-name &optional count)
63
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
44 "Append the current message to an Rmail file named FILE-NAME.
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
45 If the file does not exist, ask if it should be created.
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
46 If file is being visited, the message is appended to the Emacs
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
47 buffer visiting that file.
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
48 If the file exists and is not an Rmail file,
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
49 the message is appended in inbox format.
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
50
7332
e30a34bfc536 (rmail-output-menu): Set rmail-default-rmail-file.
Richard M. Stallman <rms@gnu.org>
parents: 7320
diff changeset
51 The default file name comes from `rmail-default-rmail-file',
5592
ee1ed3d9e517 Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 5590
diff changeset
52 which is updated to the name you use in this command.
ee1ed3d9e517 Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 5590
diff changeset
53
63
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
54 A prefix argument N says to output N consecutive messages
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
55 starting with the current one. Deleted messages are skipped and don't count."
3657
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
56 (interactive
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
57 (let ((default-file
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
58 (let (answer tail)
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
59 (setq tail rmail-output-file-alist)
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
60 ;; Suggest a file based on a pattern match.
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
61 (while (and tail (not answer))
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
62 (save-excursion
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
63 (goto-char (point-min))
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
64 (if (re-search-forward (car (car tail)) nil t)
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
65 (setq answer (eval (cdr (car tail)))))
3657
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
66 (setq tail (cdr tail))))
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
67 ;; If not suggestions, use same file as last time.
5590
1d9fabec8bec Use new names rmail-default-file and rmail-default-rmail-file.
Richard M. Stallman <rms@gnu.org>
parents: 5399
diff changeset
68 (or answer rmail-default-rmail-file))))
1d9fabec8bec Use new names rmail-default-file and rmail-default-rmail-file.
Richard M. Stallman <rms@gnu.org>
parents: 5399
diff changeset
69 (list (setq rmail-default-rmail-file
5399
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
70 (let ((read-file
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
71 (read-file-name
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
72 (concat "Output message to Rmail file: (default "
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
73 (file-name-nondirectory default-file)
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
74 ") ")
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
75 (file-name-directory default-file)
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
76 default-file)))
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
77 (if (file-directory-p read-file)
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
78 (expand-file-name (file-name-nondirectory default-file)
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
79 read-file)
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
80 (expand-file-name
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
81 (or read-file default-file)
67aa88583b90 (rmail-output-to-rmail-file): If just a dir is specified,
Richard M. Stallman <rms@gnu.org>
parents: 5331
diff changeset
82 (file-name-directory default-file)))))
3657
7503a402c721 (rmail-output-to-rmail-file): Use the smart default in the prompt.
Richard M. Stallman <rms@gnu.org>
parents: 2717
diff changeset
83 (prefix-numeric-value current-prefix-arg))))
1866
a712cff3b6e7 * rmailout.el (rmail-output, rmail-output-to-mail-file): Reverse
Jim Blandy <jimb@redhat.com>
parents: 1460
diff changeset
84 (or count (setq count 1))
202
ae5ace097df2 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 145
diff changeset
85 (setq file-name
ae5ace097df2 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 145
diff changeset
86 (expand-file-name file-name
5590
1d9fabec8bec Use new names rmail-default-file and rmail-default-rmail-file.
Richard M. Stallman <rms@gnu.org>
parents: 5399
diff changeset
87 (file-name-directory rmail-default-rmail-file)))
13054
b2df0396fae2 (rmail-file-p): Function moved to mail-utils.el
Richard M. Stallman <rms@gnu.org>
parents: 10101
diff changeset
88 (if (and (file-readable-p file-name) (not (mail-file-babyl-p file-name)))
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
89 (rmail-output file-name count)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
90 (rmail-maybe-set-message-counters)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
91 (setq file-name (abbreviate-file-name file-name))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
92 (or (get-file-buffer file-name)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
93 (file-exists-p file-name)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
94 (if (yes-or-no-p
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
95 (concat "\"" file-name "\" does not exist, create it? "))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
96 (let ((file-buffer (create-file-buffer file-name)))
63
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
97 (save-excursion
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
98 (set-buffer file-buffer)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
99 (rmail-insert-rmail-file-header)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
100 (let ((require-final-newline nil))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
101 (write-region (point-min) (point-max) file-name t 1)))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
102 (kill-buffer file-buffer))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
103 (error "Output file does not exist")))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
104 (while (> count 0)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
105 (let (redelete)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
106 (unwind-protect
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
107 (progn
5278
92268e08c166 (rmail-output-to-rmail-file): Call rmail-update-summary.
Richard M. Stallman <rms@gnu.org>
parents: 5051
diff changeset
108 ;; Temporarily turn off Deleted attribute.
92268e08c166 (rmail-output-to-rmail-file): Call rmail-update-summary.
Richard M. Stallman <rms@gnu.org>
parents: 5051
diff changeset
109 ;; Do this outside the save-restriction, since it would
92268e08c166 (rmail-output-to-rmail-file): Call rmail-update-summary.
Richard M. Stallman <rms@gnu.org>
parents: 5051
diff changeset
110 ;; shift the place in the buffer where the visible text starts.
92268e08c166 (rmail-output-to-rmail-file): Call rmail-update-summary.
Richard M. Stallman <rms@gnu.org>
parents: 5051
diff changeset
111 (if (rmail-message-deleted-p rmail-current-message)
92268e08c166 (rmail-output-to-rmail-file): Call rmail-update-summary.
Richard M. Stallman <rms@gnu.org>
parents: 5051
diff changeset
112 (progn (setq redelete t)
92268e08c166 (rmail-output-to-rmail-file): Call rmail-update-summary.
Richard M. Stallman <rms@gnu.org>
parents: 5051
diff changeset
113 (rmail-set-attribute "deleted" nil)))
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
114 (save-restriction
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
115 (widen)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
116 ;; Decide whether to append to a file or to an Emacs buffer.
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
117 (save-excursion
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
118 (let ((buf (get-file-buffer file-name))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
119 (cur (current-buffer))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
120 (beg (1+ (rmail-msgbeg rmail-current-message)))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
121 (end (1+ (rmail-msgend rmail-current-message))))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
122 (if (not buf)
9993
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
123 ;; Output to a file.
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
124 (if rmail-fields-not-to-output
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
125 ;; Delete some fields while we output.
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
126 (let ((obuf (current-buffer)))
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
127 (set-buffer (get-buffer-create " rmail-out-temp"))
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
128 (insert-buffer-substring obuf beg end)
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
129 (rmail-delete-unwanted-fields)
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
130 (append-to-file (point-min) (point-max) file-name)
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
131 (set-buffer obuf)
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
132 (kill-buffer (get-buffer " rmail-out-temp")))
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
133 (append-to-file beg end file-name))
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
134 (if (eq buf (current-buffer))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
135 (error "Can't output message to same file it's already in"))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
136 ;; File has been visited, in buffer BUF.
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
137 (set-buffer buf)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
138 (let ((buffer-read-only nil)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
139 (msg (and (boundp 'rmail-current-message)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
140 rmail-current-message)))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
141 ;; If MSG is non-nil, buffer is in RMAIL mode.
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
142 (if msg
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
143 (progn
5331
a74ffe260236 (rmail-output-to-rmail-file): When copying to a buffer,
Richard M. Stallman <rms@gnu.org>
parents: 5278
diff changeset
144 ;; Turn on auto save mode, if it's off in this
a74ffe260236 (rmail-output-to-rmail-file): When copying to a buffer,
Richard M. Stallman <rms@gnu.org>
parents: 5278
diff changeset
145 ;; buffer but enabled by default.
a74ffe260236 (rmail-output-to-rmail-file): When copying to a buffer,
Richard M. Stallman <rms@gnu.org>
parents: 5278
diff changeset
146 (and (not buffer-auto-save-file-name)
a74ffe260236 (rmail-output-to-rmail-file): When copying to a buffer,
Richard M. Stallman <rms@gnu.org>
parents: 5278
diff changeset
147 auto-save-default
a74ffe260236 (rmail-output-to-rmail-file): When copying to a buffer,
Richard M. Stallman <rms@gnu.org>
parents: 5278
diff changeset
148 (auto-save-mode t))
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
149 (rmail-maybe-set-message-counters)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
150 (widen)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
151 (narrow-to-region (point-max) (point-max))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
152 (insert-buffer-substring cur beg end)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
153 (goto-char (point-min))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
154 (widen)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
155 (search-backward "\n\^_")
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
156 (narrow-to-region (point) (point-max))
9993
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
157 (rmail-delete-unwanted-fields)
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
158 (rmail-count-new-messages t)
5278
92268e08c166 (rmail-output-to-rmail-file): Call rmail-update-summary.
Richard M. Stallman <rms@gnu.org>
parents: 5051
diff changeset
159 (if (rmail-summary-exists)
92268e08c166 (rmail-output-to-rmail-file): Call rmail-update-summary.
Richard M. Stallman <rms@gnu.org>
parents: 5051
diff changeset
160 (rmail-select-summary
92268e08c166 (rmail-output-to-rmail-file): Call rmail-update-summary.
Richard M. Stallman <rms@gnu.org>
parents: 5051
diff changeset
161 (rmail-update-summary)))
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
162 (rmail-show-message msg))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
163 ;; Output file not in rmail mode => just insert at the end.
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
164 (narrow-to-region (point-min) (1+ (buffer-size)))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
165 (goto-char (point-max))
9993
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
166 (insert-buffer-substring cur beg end)
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
167 (rmail-delete-unwanted-fields)))))))
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
168 (rmail-set-attribute "filed" t))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
169 (if redelete (rmail-set-attribute "deleted" t))))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
170 (setq count (1- count))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
171 (if rmail-delete-after-output
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
172 (rmail-delete-forward)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
173 (if (> count 0)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
174 (rmail-next-undeleted-message 1))))))
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
175
9993
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
176 (defvar rmail-fields-not-to-output nil
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
177 "*Regexp describing fields to exclude when outputting a message to a file.")
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
178
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
179 ;; Delete from the buffer header fields we don't want output.
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
180 ;; NOT-RMAIL if t means this buffer does not have the full header
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
181 ;; and *** EOOH *** that a message in an Rmail file has.
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
182 (defun rmail-delete-unwanted-fields (&optional not-rmail)
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
183 (if rmail-fields-not-to-output
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
184 (save-excursion
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
185 (goto-char (point-min))
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
186 ;; Find the end of the header.
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
187 (if (and (or not-rmail (search-forward "\n*** EOOH ***\n" nil t))
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
188 (search-forward "\n\n" nil t))
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
189 (let ((end (point-marker)))
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
190 (goto-char (point-min))
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
191 (while (re-search-forward rmail-fields-not-to-output end t)
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
192 (beginning-of-line)
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
193 (delete-region (point)
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
194 (progn (forward-line 1) (point)))))))))
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
195
1866
a712cff3b6e7 * rmailout.el (rmail-output, rmail-output-to-mail-file): Reverse
Jim Blandy <jimb@redhat.com>
parents: 1460
diff changeset
196 ;;; There are functions elsewhere in Emacs that use this function; check
a712cff3b6e7 * rmailout.el (rmail-output, rmail-output-to-mail-file): Reverse
Jim Blandy <jimb@redhat.com>
parents: 1460
diff changeset
197 ;;; them out before you change the calling method.
5011
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
198 (defun rmail-output (file-name &optional count noattribute from-gnus)
6651
714341c56a9a Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 6407
diff changeset
199 "Append this message to system-inbox-format mail file named FILE-NAME.
63
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
200 A prefix argument N says to output N consecutive messages
1866
a712cff3b6e7 * rmailout.el (rmail-output, rmail-output-to-mail-file): Reverse
Jim Blandy <jimb@redhat.com>
parents: 1460
diff changeset
201 starting with the current one. Deleted messages are skipped and don't count.
4265
2812d8619305 (rmail-output): New arg NOATTRIBUTE.
Richard M. Stallman <rms@gnu.org>
parents: 4264
diff changeset
202 When called from lisp code, N may be omitted.
2812d8619305 (rmail-output): New arg NOATTRIBUTE.
Richard M. Stallman <rms@gnu.org>
parents: 4264
diff changeset
203
4836
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
204 If the pruned message header is shown on the current message, then
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
205 messages will be appended with pruned headers; otherwise, messages
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
206 will be appended with their original headers.
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
207
7561
22a4985ddad3 (rmail-output): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 7332
diff changeset
208 The default file name comes from `rmail-default-file',
5592
ee1ed3d9e517 Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 5590
diff changeset
209 which is updated to the name you use in this command.
ee1ed3d9e517 Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 5590
diff changeset
210
4265
2812d8619305 (rmail-output): New arg NOATTRIBUTE.
Richard M. Stallman <rms@gnu.org>
parents: 4264
diff changeset
211 The optional third argument NOATTRIBUTE, if non-nil, says not
5011
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
212 to set the `filed' attribute, and not to display a message.
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
213
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
214 The optional fourth argument FROM-GNUS is set when called from GNUS."
63
714e88ef93c8 Initial revision
root <root>
parents:
diff changeset
215 (interactive
5802
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
216 (let ((default-file
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
217 (let (answer tail)
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
218 (setq tail rmail-output-file-alist)
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
219 ;; Suggest a file based on a pattern match.
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
220 (while (and tail (not answer))
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
221 (save-excursion
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
222 (goto-char (point-min))
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
223 (if (re-search-forward (car (car tail)) nil t)
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
224 (setq answer (eval (cdr (car tail)))))
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
225 (setq tail (cdr tail))))
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
226 ;; If not suggestions, use same file as last time.
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
227 (or answer rmail-default-file))))
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
228 (list (setq rmail-default-file
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
229 (let ((read-file
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
230 (read-file-name
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
231 (concat "Output message to Unix mail file: (default "
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
232 (file-name-nondirectory default-file)
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
233 ") ")
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
234 (file-name-directory default-file)
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
235 default-file)))
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
236 (if (file-directory-p read-file)
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
237 (expand-file-name (file-name-nondirectory default-file)
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
238 read-file)
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
239 (expand-file-name
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
240 (or read-file default-file)
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
241 (file-name-directory default-file)))))
3db75b13c7f5 (rmail-output): Handle rmail-output-file-alist.
Richard M. Stallman <rms@gnu.org>
parents: 5592
diff changeset
242 (prefix-numeric-value current-prefix-arg))))
1866
a712cff3b6e7 * rmailout.el (rmail-output, rmail-output-to-mail-file): Reverse
Jim Blandy <jimb@redhat.com>
parents: 1460
diff changeset
243 (or count (setq count 1))
202
ae5ace097df2 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 145
diff changeset
244 (setq file-name
ae5ace097df2 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 145
diff changeset
245 (expand-file-name file-name
5590
1d9fabec8bec Use new names rmail-default-file and rmail-default-rmail-file.
Richard M. Stallman <rms@gnu.org>
parents: 5399
diff changeset
246 (and rmail-default-file
1d9fabec8bec Use new names rmail-default-file and rmail-default-rmail-file.
Richard M. Stallman <rms@gnu.org>
parents: 5399
diff changeset
247 (file-name-directory rmail-default-file))))
13054
b2df0396fae2 (rmail-file-p): Function moved to mail-utils.el
Richard M. Stallman <rms@gnu.org>
parents: 10101
diff changeset
248 (if (and (file-readable-p file-name) (mail-file-babyl-p file-name))
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
249 (rmail-output-to-rmail-file file-name count)
4836
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
250 (let ((orig-count count)
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
251 (rmailbuf (current-buffer))
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
252 (case-fold-search t)
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
253 (tembuf (get-buffer-create " rmail-output"))
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
254 (original-headers-p
5011
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
255 (and (not from-gnus)
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
256 (save-excursion
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
257 (save-restriction
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
258 (narrow-to-region (rmail-msgbeg rmail-current-message) (point-max))
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
259 (goto-char (point-min))
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
260 (forward-line 1)
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
261 (= (following-char) ?0)))))
4836
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
262 header-beginning
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
263 mail-from)
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
264 (while (> count 0)
5011
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
265 (or from-gnus
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
266 (setq mail-from
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
267 (save-excursion
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
268 (save-restriction
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
269 (widen)
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
270 (goto-char (rmail-msgbeg rmail-current-message))
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
271 (setq header-beginning (point))
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
272 (search-forward "\n*** EOOH ***\n")
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
273 (narrow-to-region header-beginning (point))
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
274 (mail-fetch-field "Mail-From")))))
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
275 (save-excursion
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
276 (set-buffer tembuf)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
277 (erase-buffer)
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
278 (insert-buffer-substring rmailbuf)
9993
26f63d276d89 (rmail-fields-not-to-output): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8910
diff changeset
279 (rmail-delete-unwanted-fields t)
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
280 (insert "\n")
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
281 (goto-char (point-min))
4836
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
282 (if mail-from
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
283 (insert mail-from "\n")
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
284 (insert "From "
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
285 (mail-strip-quoted-names (or (mail-fetch-field "from")
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
286 (mail-fetch-field "really-from")
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
287 (mail-fetch-field "sender")
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
288 "unknown"))
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
289 " " (current-time-string) "\n"))
4056
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
290 ;; ``Quote'' "\nFrom " as "\n>From "
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
291 ;; (note that this isn't really quoting, as there is no requirement
419e92a78e6f (rmail-output): If file is an Rmail file,
Richard M. Stallman <rms@gnu.org>
parents: 3832
diff changeset
292 ;; that "\n[>]+From " be quoted in the same transparent way.)
10101
c0afdaf34c6f (rmail-output): Don't quote "From " lines unless the capitalization is exact.
Karl Heuer <kwzh@gnu.org>
parents: 9993
diff changeset
293 (let ((case-fold-search nil))
c0afdaf34c6f (rmail-output): Don't quote "From " lines unless the capitalization is exact.
Karl Heuer <kwzh@gnu.org>
parents: 9993
diff changeset
294 (while (search-forward "\nFrom " nil t)
c0afdaf34c6f (rmail-output): Don't quote "From " lines unless the capitalization is exact.
Karl Heuer <kwzh@gnu.org>
parents: 9993
diff changeset
295 (forward-char -5)
c0afdaf34c6f (rmail-output): Don't quote "From " lines unless the capitalization is exact.
Karl Heuer <kwzh@gnu.org>
parents: 9993
diff changeset
296 (insert ?>)))
4265
2812d8619305 (rmail-output): New arg NOATTRIBUTE.
Richard M. Stallman <rms@gnu.org>
parents: 4264
diff changeset
297 (write-region (point-min) (point-max) file-name t
2812d8619305 (rmail-output): New arg NOATTRIBUTE.
Richard M. Stallman <rms@gnu.org>
parents: 4264
diff changeset
298 (if noattribute 'nomsg)))
4836
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
299 (or noattribute
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
300 (if (equal major-mode 'rmail-mode)
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
301 (rmail-set-attribute "filed" t)))
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
302 (setq count (1- count))
5011
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
303 (or from-gnus
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
304 (let ((next-message-p
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
305 (if rmail-delete-after-output
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
306 (rmail-delete-forward)
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
307 (if (> count 0)
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
308 (rmail-next-undeleted-message 1))))
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
309 (num-appended (- orig-count count)))
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
310 (if (and next-message-p original-headers-p)
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
311 (rmail-toggle-header))
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
312 (if (and (> count 0) (not next-message-p))
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
313 (progn
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
314 (error
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
315 (save-excursion
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
316 (set-buffer rmailbuf)
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
317 (format "Only %d message%s appended" num-appended
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
318 (if (= num-appended 1) "" "s"))))
22c7b341d536 (rmail-output): New argument FROM-GNUS.
Richard M. Stallman <rms@gnu.org>
parents: 4851
diff changeset
319 (setq count 0))))))
4836
38a0f0209707 (rmail-output): If message was shown with full headers,
Richard M. Stallman <rms@gnu.org>
parents: 4265
diff changeset
320 (kill-buffer tembuf))))
658
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 202
diff changeset
321
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 202
diff changeset
322 ;;; rmailout.el ends here