]> git.eshelyaron.com Git - emacs.git/commitdiff
(last-buffer): Don't set major mode of *scratch* if
authorMartin Rudalics <rudalics@gmx.at>
Wed, 31 Dec 2008 15:44:25 +0000 (15:44 +0000)
committerMartin Rudalics <rudalics@gmx.at>
Wed, 31 Dec 2008 15:44:25 +0000 (15:44 +0000)
that buffer exists already.  Rewrite doc-string.

lisp/ChangeLog
lisp/simple.el

index afd073f121679d3197ad2d58d1a4cacfad539b1c..fa46fdcf7d343e3092875ee92dcf24e20bf06bca 100644 (file)
@@ -1,3 +1,8 @@
+2008-12-31  Martin Rudalics  <rudalics@gmx.at>
+
+       * simple.el (last-buffer): Don't set major mode of *scratch* if
+       that buffer exists already.  Rewrite doc-string.
+
 2008-12-31  Andreas Schwab  <schwab@suse.de>
 
        * tar-mode.el (tar-mode): Set write-contents-functions instead of
index 386de7738490054b5099ab444a9a7424cffea78b..c5d036b1d9a1060a3eba2874dc45f5f0031aab04 100644 (file)
@@ -78,19 +78,22 @@ If BUFFER is non-nil, ignore occurrences of that buffer in LIST."
     (car list)))
 
 (defun last-buffer (&optional buffer visible-ok frame)
-  "Return the last non-hidden displayable buffer in the buffer list.
-If BUFFER is non-nil, last-buffer will ignore that buffer.
+  "Return the last buffer in FRAME's buffer list.
+If BUFFER is the last buffer, return the preceding buffer instead.
 Buffers not visible in windows are preferred to visible buffers,
 unless optional argument VISIBLE-OK is non-nil.
-If the optional third argument FRAME is non-nil, use that frame's
-buffer list instead of the selected frame's buffer list.
-If no other buffer exists, the buffer `*scratch*' is returned."
+Optional third argument FRAME nil or omitted means use the
+selected frame's buffer list.
+If no such buffer exists, return the buffer `*scratch*', creating
+it if necessary."
   (setq frame (or frame (selected-frame)))
   (or (get-next-valid-buffer (nreverse (buffer-list frame))
                             buffer visible-ok frame)
-      (progn
-       (set-buffer-major-mode (get-buffer-create "*scratch*"))
-       (get-buffer "*scratch*"))))
+      (get-buffer "*scratch*")
+      (let ((scratch (get-buffer-create "*scratch*")))
+       (set-buffer-major-mode scratch)
+       scratch)))
+
 (defun next-buffer ()
   "Switch to the next buffer in cyclic order."
   (interactive)