randy@umn-cs.CS.UMN.EDU (Randy Orrison) (01/18/89)
I'm using GNU emacs in server mode under X windows. The problem that I've found is that when I use emacsclient, and change the mode of the buffer (say, from Fundamental to Text for editing mail), emacs forgets that that buffer was a server buffer, and so C-x # does nothing, and the only way I've found to let the client continue on is to exit emacs. Shouldn't the server attribute (is it a minor mode?) be kept when the major mode of a buffer changes? Relevant stats: Emacs version 18.51 under X11R2 on SunOS 3.5 on Sun 3 machines (varied). (Is this fixed in 18.52?) -randy -- Randy Orrison, Chemical Computer Thinking Battery -- randy@cctb.mn.org (aka randy@{ux.acss.umn.edu, umn-cs.uucp, umnacca.bitnet, garnet.uucp}) Tonight's the night: Sleep in a eucalyptus tree.
nate@hobbes.intel.com (Nate Hess) (01/19/89)
In article <10864@umn-cs.CS.UMN.EDU>, randy@umn-cs (Randy Orrison) writes: >the only way I've found to let the client continue on is to exit emacs. You can always go back to the "Waiting for Emacs..." message and type 'C-c' to kill the emacsclient process -- you don't have to do anything to the Emacs process. --woodstock -- "What I like is when you're looking and thinking and looking and thinking...and suddenly you wake up." - Hobbes woodstock@hobbes.intel.com ...!{decwrl|hplabs!oliveb|amd}!intelca!mipos3!nate
nelson@ishmael (01/19/89)
> The problem that > I've found is that when I use emacsclient, and change the mode of the > buffer (say, from Fundamental to Text for editing mail), emacs forgets > that that buffer was a server buffer, and so C-x # does nothing, and > the only way I've found to let the client continue on is to exit > emacs. Hey, thanks for figuring this out. I used to wonder why it would sporadically "hang" on me, and I never made the correlation to mode change. Inspired by your discovery, I played around with some server commands and found that the command M-x server-start will have the (side?) effect of returning control to the caller with all of your buffer intact. (Same effect as C-x #). (At least it worked the one time I tried it). Not a pretty solution, but it appears to work. I agree that the server mode shouldn't be lost in the first place. - Nelson Nelson Lerner uunet!inmet!nelson nelson@inmet.inmet.com
jbw@bucsb.UUCP (Joe Wells) (01/19/89)
In article <10864@umn-cs.CS.UMN.EDU> randy@umn-cs (Randy Orrison) writes: >I'm using GNU emacs in server mode under X windows. The problem that >I've found is that when I use emacsclient, and change the mode of the >buffer (say, from Fundamental to Text for editing mail), emacs forgets >that that buffer was a server buffer, and so C-x # does nothing, and >the only way I've found to let the client continue on is to exit >emacs. Shouldn't the server attribute (is it a minor mode?) be kept >when the major mode of a buffer changes? > >(Is this fixed in 18.52?) No, this isn't fixed in any version. This is a consequence of the fact that almost every major mode calls the function kill-all-local-variables to clear out mode specific settings. This also destroys any other local variables. Here is a fix: (require 'kill-fix) ; this file follows (put 'server-buffer-clients 'preserved t) The file kill-fix.el is at the end of this message. -- Joe Wells INTERNET: jbw%bucsf.bu.edu@bu-it.bu.edu UUCP: ...!harvard!bu-cs!bucsf!jbw IP: [128.197.2.9] ---------------------------------------------------------------------- ;; Enhancement to kill-all-local-variables ;; Copyright (C) 1988 Free Software Foundation, Inc. ;; This file is not officially part of GNU Emacs, but is being donated ;; to the Free Software Foundation. ;; GNU Emacs is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY. No author or distributor ;; accepts responsibility to anyone for the consequences of using it ;; or for whether it serves any particular purpose or works at all, ;; unless he says so in writing. Refer to the GNU Emacs General Public ;; License for full details. ;; Everyone is granted permission to copy, modify and redistribute ;; GNU Emacs, but only under the conditions described in the ;; GNU Emacs General Public License. A copy of this license is ;; supposed to have been given to you along with GNU Emacs so you ;; can know your rights and responsibilities. It should be in a ;; file named COPYING. Among other things, the copyright notice ;; and this notice must be preserved on all copies. ;; Author: Joe Wells ;; jbw%bucsf.bu.edu@bu-it.bu.edu (school year) ;; joew%uswest@boulder.colorado.edu (summer) ;; save the original subr function definition of kill-all-local-variables (or (fboundp 'original-kill-all-local-variables) (fset 'original-kill-all-local-variables (symbol-function 'kill-all-local-variables))) (defun kill-all-local-variables () "Eliminate all the buffer-local variable values of the current buffer. This buffer will then see the default values of all variables. NOTE: This function has been modified to ignore buffer-local variables whose preserved property is non-nil." (let ((oldvars (buffer-local-variables))) (original-kill-all-local-variables) (while oldvars (let ((var (car (car oldvars)))) (cond ((get var 'preserved) (make-local-variable var) (set var (cdr (car oldvars)))))) (setq oldvars (cdr oldvars))))) (provide 'kill-fix)
derek@AU-BON-PAIN.LCS.MIT.EDU (Derek Chiou) (04/28/91)
Hello, I just got an error message from Emacs. That message is: Wrong type argument: listp, #<EMACS BUG: ILLEGAL DATATYPE (#o 60) Save your buffers immediately and please report this bug> I just killed a large region of data, and Emacs was garbage collecting (I think.) Derek