From mboxrd@z Thu Jan 1 00:00:00 1970 Path: main.gmane.org!not-for-mail From: Jan Nieuwenhuizen Newsgroups: gmane.emacs.devel Subject: Bugfix and feature for server.el Date: Sat, 10 Aug 2002 17:46:22 +0200 Organization: Jan at Peder Sender: emacs-devel-admin@gnu.org Message-ID: <87u1m2iunl.fsf@peder.flower> NNTP-Posting-Host: localhost.gmane.org Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii X-Trace: main.gmane.org 1028994384 22766 127.0.0.1 (10 Aug 2002 15:46:24 GMT) X-Complaints-To: usenet@main.gmane.org NNTP-Posting-Date: Sat, 10 Aug 2002 15:46:24 +0000 (UTC) Cc: Han-Wen Return-path: Original-Received: from quimby.gnus.org ([80.91.224.244]) by main.gmane.org with esmtp (Exim 3.35 #1 (Debian)) id 17dYRb-0005v3-00 for ; Sat, 10 Aug 2002 17:46:23 +0200 Original-Received: from monty-python.gnu.org ([199.232.76.173]) by quimby.gnus.org with esmtp (Exim 3.12 #1 (Debian)) id 17dYoi-0000Gn-00 for ; Sat, 10 Aug 2002 18:10:16 +0200 Original-Received: from localhost ([127.0.0.1] helo=monty-python.gnu.org) by monty-python.gnu.org with esmtp (Exim 4.10) id 17dYSL-00065V-00; Sat, 10 Aug 2002 11:47:09 -0400 Original-Received: from list by monty-python.gnu.org with tmda-scanned (Exim 4.10) id 17dYRh-00064y-00 for emacs-devel@gnu.org; Sat, 10 Aug 2002 11:46:29 -0400 Original-Received: from mail by monty-python.gnu.org with spam-scanned (Exim 4.10) id 17dYRf-00064m-00 for emacs-devel@gnu.org; Sat, 10 Aug 2002 11:46:28 -0400 Original-Received: from node-d-3053.a2000.nl ([62.195.48.83] helo=peder.flower) by monty-python.gnu.org with esmtp (Exim 4.10) id 17dYRe-00064g-00 for emacs-devel@gnu.org; Sat, 10 Aug 2002 11:46:26 -0400 Original-Received: from localhost.localdomain ([127.0.0.1] helo=peder.flower) by peder.flower with esmtp (Exim 3.35 #1 (Debian)) id 17dYRc-0000uq-00; Sat, 10 Aug 2002 17:46:24 +0200 Original-To: emacs-devel@gnu.org Original-Lines: 156 Errors-To: emacs-devel-admin@gnu.org X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.0.11 Precedence: bulk List-Help: List-Post: List-Subscribe: , List-Id: Emacs development discussions. List-Unsubscribe: , List-Archive: Xref: main.gmane.org gmane.emacs.devel:6420 X-Report-Spam: http://spam.gmane.org/gmane.emacs.devel:6420 Find the following fix attached. We had a problem with our application that uses `emacslient --no-wait' to edit input files. Emacs-21.2 (unlike previous versions), when invoked through `emacsclient --no-wait', wants to revert buffers whenever they have been edited, and does allow any editing, which is annoying. When invoking with --no-wait, we are typically `moving around' and editing the same file all the time; and do not want to revert. When it does revert the buffer, it does not use the column argument of emacsclient; this is now fixed. Greetings, Han-Wen and Jan. Btw: this message was sent to bug-gnu-emacs about three weeks ago, but that list seems to be slightly foobarred? We both have current disclaimers with GNU. ChangeLog: 2002-07-21 Jan Nieuwenhuizen * server.el (server-process-filter): Cleanup stray if. Add 'no-revert to file list entry when emacsclient was invoked with '--no-wait'. (server-visit-files): New function goto-line-column. Accept 'no-revert option. Bugfix: also goto column when reverting buffer. --- server.el.~1.78.~ 2001-12-18 17:42:38.000000000 +0100 +++ server.el 2002-08-10 17:32:10.000000000 +0200 @@ -251,40 +251,43 @@ Prefix arg means just kill any existing (substring request (match-beginning 0) (1- (match-end 0)))) (pos 0)) (setq request (substring request (match-end 0))) - (if (string-match "\\`-nowait" arg) - (setq nowait t) - (cond - ;; ARG is a line number option. - ((string-match "\\`\\+[0-9]+\\'" arg) + (cond + ((string-match "\\`-nowait" arg) + (setq nowait t)) + ;; ARG is a line number option. + ((string-match "\\`\\+[0-9]+\\'" arg) (setq lineno (string-to-int (substring arg 1)))) - ;; ARG is line number:column option. - ((string-match "\\`+\\([0-9]+\\):\\([0-9]+\\)\\'" arg) - (setq lineno (string-to-int (match-string 1 arg)) - columnno (string-to-int (match-string 2 arg)))) - (t - ;; ARG is a file name. - ;; Collapse multiple slashes to single slashes. - (setq arg (command-line-normalize-file-name arg)) - ;; Undo the quoting that emacsclient does - ;; for certain special characters. - (while (string-match "&." arg pos) - (setq pos (1+ (match-beginning 0))) - (let ((nextchar (aref arg pos))) - (cond ((= nextchar ?&) - (setq arg (replace-match "&" t t arg))) - ((= nextchar ?-) - (setq arg (replace-match "-" t t arg))) - (t - (setq arg (replace-match " " t t arg)))))) - ;; Now decode the file name if necessary. - (if coding-system - (setq arg (decode-coding-string arg coding-system))) - (setq files - (cons (list arg lineno columnno) - files)) - (setq lineno 1) - (setq columnno 0)))))) - (run-hooks 'pre-command-hook) + ;; ARG is line number:column option. + ((string-match "\\`+\\([0-9]+\\):\\([0-9]+\\)\\'" arg) + (setq lineno (string-to-int (match-string 1 arg)) + columnno (string-to-int (match-string 2 arg)))) + (t + ;; ARG is a file name. + ;; Collapse multiple slashes to single slashes. + (setq arg (command-line-normalize-file-name arg)) + ;; Undo the quoting that emacsclient does + ;; for certain special characters. + (while (string-match "&." arg pos) + (setq pos (1+ (match-beginning 0))) + (let ((nextchar (aref arg pos))) + (cond ((= nextchar ?&) + (setq arg (replace-match "&" t t arg))) + ((= nextchar ?-) + (setq arg (replace-match "-" t t arg))) + (t + (setq arg (replace-match " " t t arg)))))) + ;; Now decode the file name if necessary. + (if coding-system + (setq arg (decode-coding-string arg coding-system))) + (setq files + ;; When invoking emacsclient with --no-wait, we are + ;; typically `moving around' and editing the same file; + ;; and do not want to revert. Should make --no-revert + ;; option for emacsclient? + (cons (list arg lineno columnno (if nowait 'no-revert nil)) + files)) + (setq lineno 1) + (setq columnno 0))))) (server-visit-files files client nowait) (run-hooks 'post-command-hook) ;; CLIENT is now a list (CLIENTNUM BUFFERS...) @@ -309,6 +312,13 @@ Prefix arg means just kill any existing FILES is an alist whose elements are (FILENAME LINENUMBER COLUMNNUMBER). NOWAIT non-nil means this client is not waiting for the results, so don't mark these buffers specially, just visit them normally." + + (defun goto-line-column (file-line-col) + (goto-line (nth 1 file-line-col)) + (let ((column-number (nth 2 file-line-col))) + (if (> column-number 0) + (move-to-column (1- column-number))))) + ;; Bind last-nonmenu-event to force use of keyboard, not mouse, for queries. (let (client-record (last-nonmenu-event t) (obuf (current-buffer))) ;; Restore the current buffer afterward, but not using save-excursion, @@ -322,7 +332,8 @@ so don't mark these buffers specially, j (let* ((filen (car (car files))) (obuf (get-file-buffer filen))) (push filen file-name-history) - (if (and obuf (set-buffer obuf)) + (if (and obuf (set-buffer obuf) + (not (memq 'no-revert (car files)))) (progn (cond ((file-exists-p filen) (if (or (not (verify-visited-file-modtime obuf)) @@ -335,12 +346,9 @@ so don't mark these buffers specially, j ", write buffer to file? ")) (write-file filen)))) (setq server-existing-buffer t) - (goto-line (nth 1 (car files)))) + (goto-line-column (car files))) (set-buffer (find-file-noselect filen)) - (goto-line (nth 1 (car files))) - (let ((column-number (nth 2 (car files)))) - (when (> column-number 0) - (move-to-column (1- column-number)))) + (goto-line-column (car files)) (run-hooks 'server-visit-hook))) (if (not nowait) (setq server-buffer-clients -- Jan Nieuwenhuizen | GNU LilyPond - The music typesetter http://www.xs4all.nl/~jantien | http://www.lilypond.org