aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard M. Stallman1997-05-31 00:31:40 +0000
committerRichard M. Stallman1997-05-31 00:31:40 +0000
commitfb873cfcb6000d30bd90b5c40dc1118f4d00c3ba (patch)
treedb8ad6da8644aba9a9a0d40544c581d9de5d1133
parent7b30f6cfdf7d9205012abd9c95f7314a68e505ad (diff)
downloademacs-fb873cfcb6000d30bd90b5c40dc1118f4d00c3ba.tar.gz
emacs-fb873cfcb6000d30bd90b5c40dc1118f4d00c3ba.zip
(server-kill-buffer): Prevent infinite recursion.
(server-kill-buffer-running): New variable.
-rw-r--r--lisp/server.el11
1 files changed, 9 insertions, 2 deletions
diff --git a/lisp/server.el b/lisp/server.el
index 3fb4b039e8f..49fd8172c40 100644
--- a/lisp/server.el
+++ b/lisp/server.el
@@ -385,11 +385,18 @@ or nil. KILLED is t if we killed the BUFFER (because it was a temp file)."
385 385
386(add-hook 'kill-emacs-query-functions 'server-kill-emacs-query-function) 386(add-hook 'kill-emacs-query-functions 'server-kill-emacs-query-function)
387 387
388(defvar server-kill-buffer-running nil
389 "Non-nil while `server-kill-buffer' is running.")
390
388;; When a buffer is killed, inform the clients. 391;; When a buffer is killed, inform the clients.
389(add-hook 'kill-buffer-hook 'server-kill-buffer) 392(add-hook 'kill-buffer-hook 'server-kill-buffer)
390(defun server-kill-buffer () 393(defun server-kill-buffer ()
391 (when server-process 394 ;; Prevent infinite recursion if user has made server-done-hook
392 (server-buffer-done (current-buffer) t))) 395 ;; call kill-buffer.
396 (or server-kill-buffer-running
397 (let ((server-kill-buffer-running t))
398 (when server-process
399 (server-buffer-done (current-buffer) t)))))
393 400
394(defun server-edit (&optional arg) 401(defun server-edit (&optional arg)
395 "Switch to next server editing buffer; say \"Done\" for current buffer. 402 "Switch to next server editing buffer; say \"Done\" for current buffer.