changeset 98315:5053145089c9

(with-output-to-string): Make sure that the temporary buffer gets killed.
author Romain Francoise <romain@orebokech.com>
date Tue, 23 Sep 2008 17:26:40 +0000
parents 7fafc74e823f
children 8ecc08b621cb
files lisp/ChangeLog lisp/subr.el
diffstat 2 files changed, 14 insertions(+), 8 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/ChangeLog	Tue Sep 23 11:32:25 2008 +0000
+++ b/lisp/ChangeLog	Tue Sep 23 17:26:40 2008 +0000
@@ -1,3 +1,8 @@
+2008-09-23  Romain Francoise  <romain@orebokech.com>
+
+	* subr.el (with-output-to-string): Make sure that the temporary
+	buffer gets killed.
+
 2008-09-23  Markus Sauermann <markus@sauermann-consulting.de>  (tiny change)
 
 	* emacs-lisp/emacslisp-mode.el (calculate-lisp-indent): Fix
@@ -34,7 +39,7 @@
 
 2008-09-20  David De La Harpe Golden  <david@harpegolden.net>
 
-        * files.el (move-file-to-trash): Avoid recursive trashing if
+	* files.el (move-file-to-trash): Avoid recursive trashing if
 	rename-file calls delete-file.
 
 2008-09-20  Glenn Morris  <rgm@gnu.org>
@@ -111,7 +116,7 @@
 
 2008-09-17  Jay Belanger  <jay.p.belanger@gmail.com>
 
-	* calc/calc-units.el (calc-convert-temperature):  Use default
+	* calc/calc-units.el (calc-convert-temperature): Use default
 	units when appropriate.
 
 2008-09-16  Markus Triska  <markus.triska@gmx.at>
--- a/lisp/subr.el	Tue Sep 23 11:32:25 2008 +0000
+++ b/lisp/subr.el	Tue Sep 23 17:26:40 2008 +0000
@@ -2586,12 +2586,13 @@
   (declare (indent 0) (debug t))
   `(let ((standard-output
 	  (get-buffer-create (generate-new-buffer-name " *string-output*"))))
-     (let ((standard-output standard-output))
-       ,@body)
-     (with-current-buffer standard-output
-       (prog1
-	   (buffer-string)
-	 (kill-buffer nil)))))
+     (unwind-protect
+	 (progn
+	   (let ((standard-output standard-output))
+	     ,@body)
+	   (with-current-buffer standard-output
+	     (buffer-string)))
+       (kill-buffer standard-output))))
 
 (defmacro with-local-quit (&rest body)
   "Execute BODY, allowing quits to terminate BODY but not escape further.