all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: "Mark H. Weaver" <mhw@netris.org>
Subject: Problem with comint-postoutput-scroll-to-bottom
Date: Sat, 16 Apr 2005 13:59:38 -0400	[thread overview]
Message-ID: <E1DMrZy-0003D9-MP@strings> (raw)

I've discovered a problem in comint.el, which results in at least two
user-visible bugs.  Although I have some experience working in Scheme,
I'm very new to hacking elisp, so please excuse me if the terminology
below is incorrect.

The problem is that comint-postoutput-scroll-to-bottom (normally
included in comint-output-filter-functions) makes decisions based on
the location of point, and in some cases moves point.  This logic
assumes that point is where the user thinks point is, i.e. where the
cursor is visible on the screen.

Unfortunately, none of that logic works, because at the time the
comint-output-filter-functions are called from comint-output-filter,
point has been temporarily moved to the process mark.

Furthermore, after the comint-output-filter-functions are called,
comint-output-filter moves point back to the process mark, thus
discarding any movement done by comint-postoutput-scroll-to-bottom.


So far, I've found two user-visible bugs caused by this problem:

* comint-move-point-for-output does not work.  For example, when this
  variable is set to t or 'all, the point should be moved to the end
  when new output arrives.  This doesn't work at all, because it is
  comint-postoutput-scroll-to-bottom which moves point, but
  coming-output-filter immediately discards that change by moving
  point back to the process mark.

* Consider the case when comint-move-point-for-output is nil,
  comint-scroll-show-maximum-output is t, and point is somewhere in
  the middle of the buffer.  In this case, whenever new output
  arrives, (recenter -1) is called, which is most annoying.
  comint-postoutput-scroll-to-bottom tries to prevent this, by
  recentering only if point is at the end of the buffer, but since
  point has been temporarily moved by coming-output-filter, this logic
  doesn't work.


Below is one possible way to fix the user-visible problems, but it may
not be the best fix, and may even break established conventions for
comint-output-filter-functions.  My Emacs knowledge is not sufficient
to confidently propose a proper fix.

     Mark


*** comint.el	15 Apr 2005 21:41:13 -0400	1.315
--- comint.el	16 Apr 2005 13:16:43 -0400	
***************
*** 1701,1708 ****
  	      ;; Interpret any carriage motion characters (newline, backspace)
  	      (comint-carriage-motion comint-last-output-start (point)))
  
  	    (run-hook-with-args 'comint-output-filter-functions string)
! 
  	    (goto-char (process-mark process)) ; in case a filter moved it
  
  	    (unless comint-use-prompt-regexp-instead-of-fields
--- 1701,1709 ----
  	      ;; Interpret any carriage motion characters (newline, backspace)
  	      (comint-carriage-motion comint-last-output-start (point)))
  
+ 	    (goto-char saved-point)
  	    (run-hook-with-args 'comint-output-filter-functions string)
! 	    (set-marker saved-point (point-marker))
  	    (goto-char (process-mark process)) ; in case a filter moved it
  
  	    (unless comint-use-prompt-regexp-instead-of-fields

                 reply	other threads:[~2005-04-16 17:59 UTC|newest]

Thread overview: [no followups] expand[flat|nested]  mbox.gz  Atom feed

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=E1DMrZy-0003D9-MP@strings \
    --to=mhw@netris.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this external index

	https://git.savannah.gnu.org/cgit/emacs.git
	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.