aboutsummaryrefslogtreecommitdiffstats
path: root/lisp
diff options
context:
space:
mode:
Diffstat (limited to 'lisp')
-rw-r--r--lisp/server.el16
1 files changed, 16 insertions, 0 deletions
diff --git a/lisp/server.el b/lisp/server.el
index 0a3eb446761..d57739fbef4 100644
--- a/lisp/server.el
+++ b/lisp/server.el
@@ -106,6 +106,13 @@ Each element is (CLIENTID BUFFERS...) where CLIENTID is a string
106that can be given to the server process to identify a client. 106that can be given to the server process to identify a client.
107When a buffer is marked as \"done\", it is removed from this list.") 107When a buffer is marked as \"done\", it is removed from this list.")
108 108
109(defvar server-frames nil
110 "List of current server frames.
111Each element is (CLIENTID FRAME) where CLIENTID is a string
112that can be given to the server process to identify a client.
113When all the buffers of the client are marked as \"done\",
114the frame is deleted.")
115
109(defvar server-buffer-clients nil 116(defvar server-buffer-clients nil
110 "List of client ids for clients requesting editing of current buffer.") 117 "List of client ids for clients requesting editing of current buffer.")
111(make-variable-buffer-local 'server-buffer-clients) 118(make-variable-buffer-local 'server-buffer-clients)
@@ -178,6 +185,7 @@ are done with it in the server.")
178 ;; Remove PROC from the list of clients. 185 ;; Remove PROC from the list of clients.
179 (when client 186 (when client
180 (setq server-clients (delq client server-clients)) 187 (setq server-clients (delq client server-clients))
188 (setq server-frames (delq client server-frames))
181 (dolist (buf (cdr client)) 189 (dolist (buf (cdr client))
182 (with-current-buffer buf 190 (with-current-buffer buf
183 ;; Remove PROC from the clients of each buffer. 191 ;; Remove PROC from the clients of each buffer.
@@ -326,6 +334,8 @@ PROC is the server process. Format of STRING is \"PATH PATH PATH... \\n\"."
326 (setq request (substring request (match-end 0))) 334 (setq request (substring request (match-end 0)))
327 (condition-case err 335 (condition-case err
328 (let ((frame (make-terminal-frame `((tty . ,pty) (tty-type . ,type))))) 336 (let ((frame (make-terminal-frame `((tty . ,pty) (tty-type . ,type)))))
337 (setq server-frames (cons (list (car client) frame) server-frames))
338 (sit-for 0)
329 (process-send-string proc (concat (number-to-string (emacs-pid)) "\n")) 339 (process-send-string proc (concat (number-to-string (emacs-pid)) "\n"))
330 (select-frame frame)) 340 (select-frame frame))
331 (error (process-send-string proc (nth 1 err)) 341 (error (process-send-string proc (nth 1 err))
@@ -368,6 +378,9 @@ PROC is the server process. Format of STRING is \"PATH PATH PATH... \\n\"."
368 (if (null (cdr client)) 378 (if (null (cdr client))
369 ;; This client is empty; get rid of it immediately. 379 ;; This client is empty; get rid of it immediately.
370 (progn 380 (progn
381 (let ((frame (cadr (assq (car client) server-frames))))
382 ;; Close the client's frame.
383 (when frame (delete-frame frame)))
371 (delete-process proc) 384 (delete-process proc)
372 (server-log "Close empty client" proc)) 385 (server-log "Close empty client" proc))
373 ;; We visited some buffer for this client. 386 ;; We visited some buffer for this client.
@@ -454,6 +467,9 @@ FOR-KILLING if non-nil indicates that we are called from `kill-buffer'."
454 ;; If client now has no pending buffers, 467 ;; If client now has no pending buffers,
455 ;; tell it that it is done, and forget it entirely. 468 ;; tell it that it is done, and forget it entirely.
456 (unless (cdr client) 469 (unless (cdr client)
470 (let ((frame (cadr (assq (car client) server-frames))))
471 ;; Close the client's frame.
472 (when frame (delete-frame frame)))
457 (delete-process (car client)) 473 (delete-process (car client))
458 (server-log "Close" (car client)) 474 (server-log "Close" (car client))
459 (setq server-clients (delq client server-clients)))) 475 (setq server-clients (delq client server-clients))))