]> git.eshelyaron.com Git - emacs.git/commitdiff
(rmail-edit-current-message, rmail-cease-edit):
authorRichard M. Stallman <rms@gnu.org>
Mon, 13 Jul 1998 22:04:35 +0000 (22:04 +0000)
committerRichard M. Stallman <rms@gnu.org>
Mon, 13 Jul 1998 22:04:35 +0000 (22:04 +0000)
Save and restore save-buffer-coding-system in another local variable.

lisp/mail/rmailedit.el

index 4fee4f848a247d3a1a1b2fbab7220febc32f2564..76994d4fb611d3571e1abb241bd9e455f8271fa8 100644 (file)
@@ -64,14 +64,23 @@ to return to regular RMAIL:
 (defvar rmail-old-pruned nil)
 (put 'rmail-old-pruned 'permanent-local t)
 
+(defvar rmail-edit-saved-coding-system nil)
+(put 'rmail-edit-saved-coding-system 'permanent-local t)
+
 ;;;###autoload
 (defun rmail-edit-current-message ()
   "Edit the contents of this message."
   (interactive)
   (make-local-variable 'rmail-old-pruned)
   (setq rmail-old-pruned (rmail-msg-is-pruned))
+  (make-local-variable 'rmail-edit-saved-coding-system)
+  (setq rmail-edit-saved-coding-system save-buffer-coding-system)
   (rmail-toggle-header 0)
   (rmail-edit-mode)
+  ;; As the local value of save-buffer-coding-system is deleted by
+  ;; rmail-edit-mode, we restore the original value.
+  (make-local-variable 'save-buffer-coding-system)
+  (setq save-buffer-coding-system rmail-edit-saved-coding-system)
   (make-local-variable 'rmail-old-text)
   (setq rmail-old-text (buffer-substring (point-min) (point-max)))
   (setq buffer-read-only nil)
@@ -102,6 +111,9 @@ to return to regular RMAIL:
     (kill-all-local-variables)
     (rmail-mode-1)
     (rmail-variables)
+    ;; As the local value of save-buffer-coding-system is changed by
+    ;; rmail-variables, we restore the original value.
+    (setq save-buffer-coding-system rmail-edit-saved-coding-system)
     (if (and (= (length old) (- (point-max) (point-min)))
             (string= old (buffer-substring (point-min) (point-max))))
        ()