annotate lisp/mail/vms-pmail.el @ 2009:755588575884

(h8300hds): Change hds to hms.
author Steve Chamberlain <sac@transmeta.com>
date Thu, 04 Mar 1993 18:10:15 +0000
parents 747b98b6d825
children 4f9d60f7de9d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1190
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1 ;;; vms-pmail.el -- use Emacs as the editor within VMS mail.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2 ;; Copyright (C) 1992 Free Software Foundation, Inc.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
3
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
4 ;; Author: Roland B Roberts <roberts@nsrl31.nsrl.rochester.edu>
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
5
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
6 ;; This file is part of GNU Emacs.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
7
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
8 ;; GNU Emacs is free software; you can redistribute it and/or modify
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
9 ;; it under the terms of the GNU General Public License as published by
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
10 ;; the Free Software Foundation; either version 2, or (at your option)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
11 ;; any later version.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
12
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
13 ;; GNU Emacs is distributed in the hope that it will be useful,
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
14 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
15 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
16 ;; GNU General Public License for more details.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
17
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
18 ;; You should have received a copy of the GNU General Public License
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
19 ;; along with GNU Emacs; see the file COPYING. If not, write to
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
20 ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
21
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
22 ;;; Code:
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
23
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
24 ;;;
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
25 ;;; Quick hack to use emacs as mail editor. There are a *bunch* of
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
26 ;;; changes scattered throughout emacs to make this work, namely:
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
27 ;;; (1) mod to sysdep.c to allow emacs to attach to a process other
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
28 ;;; than the one that originally spawned it.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
29 ;;; (2) mod to kepteditor.com to define the logical emacs_parent_pid
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
30 ;;; which is what sysdep.c looks for, and define the logical
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
31 ;;; emacs_command_args which contains the command line
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
32 ;;; (3) mod to re-parse command line arguments from emacs_command_args
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
33 ;;; then execute them as though emacs were just starting up.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
34 ;;;
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
35 (defun vms-pmail-save-and-exit ()
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
36 "Save current buffer and exit emacs.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
37 If this emacs cannot be suspended, you will be prompted about modified
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
38 buffers other than the mail buffer. BEWARE --- suspending emacs without
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
39 saving your mail buffer causes mail to abort the send (potentially useful
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
40 since the mail buffer is still here)."
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
41 (interactive)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
42 (basic-save-buffer)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
43 (if (vms-system-info "LOGICAL" "DONT_SUSPEND_EMACS")
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
44 (progn
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
45 (save-some-buffers)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
46 (kill-emacs 1))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
47 (kill-buffer (current-buffer))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
48 (suspend-emacs)))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
49
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
50 (defun vms-pmail-abort ()
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
51 "Mark buffer as unmodified and exit emacs.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
52 When the editor is exited without saving its buffer, VMS mail does not
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
53 send a message. If you have other modified buffers you will be
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
54 prompted for what to do with them."
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
55 (interactive)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
56 (if (not (yes-or-no-p "Really abort mail? "))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
57 (ding)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
58 (not-modified)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
59 (if (vms-system-info "LOGICAL" "DONT_SUSPEND_EMACS")
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
60 (progn
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
61 (save-some-buffers)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
62 (kill-emacs 1))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
63 (kill-buffer (current-buffer))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
64 (suspend-emacs))))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
65
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
66 (defun vms-pmail-setup ()
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
67 "Set up file assuming use by VMS MAIL utility.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
68 The buffer is put into text-mode, auto-save is turned off and the
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
69 following bindings are established.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
70
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
71 \\[vms-pmail-save-and-exit] vms-pmail-save-and-exit
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
72 \\[vms-pmail-abort] vms-pmail-abort
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
73
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
74 All other emacs commands are still available."
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
75 (interactive)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
76 (auto-save-mode -1)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
77 (text-mode)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
78 (let ((default (vms-system-info "LOGICAL" "SYS$SCRATCH"))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
79 (directory (file-name-directory (buffer-file-name)))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
80 (filename (file-name-nondirectory (buffer-file-name))))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
81 (if (string= directory "SYS$SCRATCH:")
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
82 (progn
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
83 (cd default)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
84 (setq buffer-file-name (concat default filename))))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
85 (use-local-map (copy-keymap (current-local-map)))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
86 (local-set-key "\C-c\C-c" 'vms-pmail-save-and-exit)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
87 (local-set-key "\C-c\C-g" 'vms-pmail-abort)))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
88
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
89 (defun indicate-mail-reply-text ()
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
90 "Prepares received mail for re-sending by placing >'s on each line."
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
91 (interactive)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
92 (goto-char (point-min))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
93 (while (not (eobp))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
94 (insert ">")
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
95 (beginning-of-line)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
96 (forward-line 1))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
97 (set-buffer-modified-p nil)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
98 (goto-char (point-min)))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
99
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
100 (defun insert-signature ()
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
101 "Moves to the end of the buffer and inserts a \"signature\" file.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
102 First try the file indicated by environment variable MAIL$TRAILER.
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
103 If that fails, try the file \"~/.signature\".
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
104 If neither file exists, fails quietly."
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
105 (interactive)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
106 (end-of-buffer)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
107 (newline)
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
108 (if (vms-system-info "LOGICAL" "MAIL$TRAILER")
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
109 (if (file-attributes (vms-system-info "LOGICAL" "MAIL$TRAILER"))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
110 (insert-file-contents (vms-system-info "LOGICAL" "MAIL$TRAILER"))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
111 (if (file-attributes "~/.signature")
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
112 (insert-file-contents "~/.signature")))))
747b98b6d825 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
113