# HG changeset patch # User Stefan Monnier # Date 971196157 0 # Node ID 40d8b29df57e35d28a8d84a396fb3796c4b79f44 # Parent ccb29a0414b23d1958a805db7556c22e23caab3c (desktop-modes-not-to-save): New var. (desktop-save-buffer-p): Use it. Also, obey desktop-buffers-not-to-save even for non-file buffers. (desktop-buffer-file): Use pop-to-buffer if switch-to-buffer fails. diff -r ccb29a0414b2 -r 40d8b29df57e lisp/desktop.el --- a/lisp/desktop.el Tue Oct 10 13:04:09 2000 +0000 +++ b/lisp/desktop.el Tue Oct 10 16:42:37 2000 +0000 @@ -182,6 +182,11 @@ :type 'regexp :group 'desktop) +(defcustom desktop-modes-not-to-save nil + "List of major modes whose buffers should not be saved." + :type '(repeat symbol) + :group 'desktop) + (defcustom desktop-buffer-major-mode nil "When desktop creates a buffer, this holds the desired Major mode." :type 'symbol @@ -427,16 +432,17 @@ FILENAME is the visited file name, BUFNAME is the buffer name, and MODE is the major mode." (let ((case-fold-search nil)) - (or (and filename - (not (string-match desktop-buffers-not-to-save bufname)) - (not (string-match desktop-files-not-to-save filename))) - (and (eq mode 'dired-mode) - (save-excursion - (set-buffer (get-buffer bufname)) - (not (string-match desktop-files-not-to-save - default-directory)))) - (and (null filename) - (memq mode '(Info-mode rmail-mode)))))) + (and (not (string-match desktop-buffers-not-to-save bufname)) + (not (memq mode desktop-modes-not-to-save)) + (or (and filename + (not (string-match desktop-files-not-to-save filename))) + (and (eq mode 'dired-mode) + (save-excursion + (set-buffer (get-buffer bufname)) + (not (string-match desktop-files-not-to-save + default-directory)))) + (and (null filename) + (memq mode '(Info-mode rmail-mode))))))) ;; ---------------------------------------------------------------------------- (defun desktop-save (dirname) "Save the Desktop file. Parameter DIRNAME specifies where to save desktop." @@ -616,7 +622,10 @@ (y-or-n-p (format "File \"%s\" no longer exists. Re-create? " desktop-buffer-file-name)))) - (progn (find-file desktop-buffer-file-name) (current-buffer)) + (let ((buf (find-file-noselect desktop-buffer-file-name))) + (condition-case nil + (switch-to-buffer buf) + (error (pop-to-buffer buf)))) 'ignored))) ;; ---------------------------------------------------------------------------- ;; Create a buffer, load its file, set is mode, ...; called from Desktop file @@ -687,4 +696,4 @@ (provide 'desktop) -;; desktop.el ends here. +;;; desktop.el ends here