all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
* bug#8476: 23.2; One-line scrolling & jit-lock (or font-lock)
@ 2011-04-11 13:59 Eli Barzilay
  2011-04-11 14:24 ` Juanma Barranquero
  2011-04-11 14:29 ` Eli Zaretskii
  0 siblings, 2 replies; 5+ messages in thread
From: Eli Barzilay @ 2011-04-11 13:59 UTC (permalink / raw
  To: 8476

Like many others, I've been trying to get Emacs to scroll the display
by one line when the cursor goes out of the displayed area.  In my
settings I have

  scroll-step 1
  scroll-conservatively 10000
  scroll-margin 0

I know that in theory only the second is needed, but I still got the
recentering behavior.  However, this is not consistent -- sometimes it
does work, but a buffer that presents the bad behavior usually
persists in doing so.

I just tried disabling `jit-lock-mode', and to my surprise that made
the problem go away, but it also disabled highlighting new text.  But
if I go through the whole buffer (so it gets the highlights) and then
disable it, scrolling works fine.  There are some guesses around that
its bold font that makes thing too slow, but that doesn't look like
the problem given what I see.


In GNU Emacs 23.2.1 (x86_64-redhat-linux-gnu, GTK+ Version 2.21.4)
 of 2010-07-08 on x86-10.phx2.fedoraproject.org
Windowing system distributor `Fedora Project', version 11.0.10904000
configured using `configure  '--build=x86_64-redhat-linux-gnu' '--host=x86_64-redhat-linux-gnu' '--program-prefix=' '--disable-dependency-tracking' '--prefix=/usr' '--exec-prefix=/usr' '--bindir=/usr/bin' '--sbindir=/usr/sbin' '--sysconfdir=/etc' '--datadir=/usr/share' '--includedir=/usr/include' '--libdir=/usr/lib64' '--libexecdir=/usr/libexec' '--localstatedir=/var' '--sharedstatedir=/var/lib' '--mandir=/usr/share/man' '--infodir=/usr/share/info' '--with-dbus' '--with-gif' '--with-jpeg' '--with-png' '--with-rsvg' '--with-tiff' '--with-xft' '--with-xpm' '--with-x-toolkit=gtk' 'build_alias=x86_64-redhat-linux-gnu' 'host_alias=x86_64-redhat-linux-gnu' 'CFLAGS=-DMAIL_USE_LOCKF -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=gene
 ric -fno-optimize-sibling-calls''

Important settings:
  value of $LC_ALL: nil
  value of $LC_COLLATE: POSIX
  value of $LC_CTYPE: nil
  value of $LC_MESSAGES: nil
  value of $LC_MONETARY: nil
  value of $LC_NUMERIC: nil
  value of $LC_TIME: nil
  value of $LANG: en_US
  value of $XMODIFIERS: @im=none
  locale-coding-system: iso-latin-1-unix
  default enable-multibyte-characters: t

Major mode: Emacs-Lisp

Minor modes in effect:
  whitespace-mode: t
  desktop-save-mode: t
  cua-mode: t
  display-time-mode: t
  minibuffer-electric-default-mode: t
  tooltip-mode: t
  mouse-wheel-mode: t
  global-font-lock-mode: t
  font-lock-mode: t
  auto-encryption-mode: t
  auto-compression-mode: t
  temp-buffer-resize-mode: t
  size-indication-mode: t
  column-number-mode: t
  line-number-mode: t
  transient-mark-mode: t

Features:
(shadow mailalias vm-reply vm-rfaddons vm-menu vm-window vm-toolbar
vm-folder vm-mime vm-undo vm-virtual vm-summary-faces vm-summary
vm-mouse vm-page vm-motion vm-minibuf vm-message vm-misc vm-macro
vm-autoloads vm-version vm-vars vm emacsbug debug apropos find-func
jka-compr w32-vars cal-menu calendar cal-loaddefs gnus-score
score-mode gnus-async nntp gnus-sum nnoo gnus-group gnus-undo nnmail
mail-source format-spec gnus-start gnus-spec gnus-int gnus-range
message idna byte-opt sendmail ecomplete rfc822 mml mml-sec
password-cache mm-decode mm-bodies mm-encode mailcap mail-parse
rfc2231 rfc2047 rfc2045 qp ietf-drums mailabbrev gmm-utils mailheader
canlock sha1 sha1-el hex-util hashcash gnus-win gnus gnus-ems nnheader
gnus-util netrc time-date mail-utils mm-util mail-prsvr completion
complete cus-edit cus-start cus-load wid-edit longlines
mode-compile-kill mode-compile cl cl-19 bytecomp byte-compile compile
comint ring pp help-mode easymenu view multi-isearch vc-git whitespace
regexp-opt desktop filladapt scroll-in-place cua-base time
minibuf-eldef paren mic-paren uniquify advice help-fns advice-preload
disp-table tooltip ediff-hook vc-hooks lisp-float-type mwheel x-win
x-dnd font-setting tool-bar dnd fontset image fringe lisp-mode
register page menu-bar rfn-eshadow timer select scroll-bar mldrag
mouse jit-lock font-lock syntax facemenu font-core frame cham georgian
utf-8-lang misc-lang vietnamese tibetan thai tai-viet lao korean
japanese hebrew greek romanian slovak czech european ethiopic indian
cyrillic chinese case-table epa-hook jka-cmpr-hook help simple abbrev
loaddefs button minibuffer faces cus-face files text-properties
overlay md5 base64 format env code-pages mule custom widget
hashtable-print-readable backquote make-network-process dbusbind
system-font-setting font-render-setting gtk x-toolkit x multi-tty
emacs)

-- 
          ((lambda (x) (x x)) (lambda (x) (x x)))          Eli Barzilay:
                    http://barzilay.org/                   Maze is Life!





^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#8476: 23.2; One-line scrolling & jit-lock (or font-lock)
  2011-04-11 13:59 bug#8476: 23.2; One-line scrolling & jit-lock (or font-lock) Eli Barzilay
@ 2011-04-11 14:24 ` Juanma Barranquero
  2011-04-11 14:28   ` Eli Barzilay
  2011-04-11 14:29 ` Eli Zaretskii
  1 sibling, 1 reply; 5+ messages in thread
From: Juanma Barranquero @ 2011-04-11 14:24 UTC (permalink / raw
  To: Eli Barzilay; +Cc: 8476

On Mon, Apr 11, 2011 at 15:59, Eli Barzilay <eli@barzilay.org> wrote:

> Like many others, I've been trying to get Emacs to scroll the display
> by one line when the cursor goes out of the displayed area.

We are legion.

> In my
> settings I have
>
>  scroll-step 1
>  scroll-conservatively 10000
>  scroll-margin 0
>
> I know that in theory only the second is needed, but I still got the
> recentering behavior.

Have you tried setting `redisplay-dont-pause' to t? That could help.

    Juanma





^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#8476: 23.2; One-line scrolling & jit-lock (or font-lock)
  2011-04-11 14:24 ` Juanma Barranquero
@ 2011-04-11 14:28   ` Eli Barzilay
  0 siblings, 0 replies; 5+ messages in thread
From: Eli Barzilay @ 2011-04-11 14:28 UTC (permalink / raw
  To: Juanma Barranquero; +Cc: 8476

Three minutes ago, Juanma Barranquero wrote:
> On Mon, Apr 11, 2011 at 15:59, Eli Barzilay <eli@barzilay.org> wrote:
> 
> > Like many others, I've been trying to get Emacs to scroll the
> > display by one line when the cursor goes out of the displayed
> > area.
> 
> We are legion.

(Which is why I'm surprised that this one-line scrolling is still
failing...)


> > In my
> > settings I have
> >
> >  scroll-step 1
> >  scroll-conservatively 10000
> >  scroll-margin 0
> >
> > I know that in theory only the second is needed, but I still got the
> > recentering behavior.
> 
> Have you tried setting `redisplay-dont-pause' to t? That could help.

Yeah, I have that too.

-- 
          ((lambda (x) (x x)) (lambda (x) (x x)))          Eli Barzilay:
                    http://barzilay.org/                   Maze is Life!





^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#8476: 23.2; One-line scrolling & jit-lock (or font-lock)
  2011-04-11 13:59 bug#8476: 23.2; One-line scrolling & jit-lock (or font-lock) Eli Barzilay
  2011-04-11 14:24 ` Juanma Barranquero
@ 2011-04-11 14:29 ` Eli Zaretskii
  2011-04-11 15:37   ` Juanma Barranquero
  1 sibling, 1 reply; 5+ messages in thread
From: Eli Zaretskii @ 2011-04-11 14:29 UTC (permalink / raw
  To: Eli Barzilay; +Cc: 8476-done

> From: Eli Barzilay <eli@barzilay.org>
> Date: Mon, 11 Apr 2011 09:59:43 -0400
> Cc: 
> 
> Like many others, I've been trying to get Emacs to scroll the display
> by one line when the cursor goes out of the displayed area.  In my
> settings I have
> 
>   scroll-step 1
>   scroll-conservatively 10000
>   scroll-margin 0
> 
> I know that in theory only the second is needed, but I still got the
> recentering behavior.

This has been resolved, I hope for good, in the current development
sources.  See bug #6671.

The problem was that Emacs would always recenter whenever it exhausted
all its wits to get to the new position of point from the old one by
line-wise movement.  However, such recentering is not necessary even
in that case, because even if we jump to an entirely new location in
the buffer, we can still position point at the last or first screen
line.  Code to do that was added a couple of weeks ago (on Mar 31, to
be exact).

If you can upgrade to the development version or to some recent enough
snapshot, you should see that problem gone.

> I just tried disabling `jit-lock-mode', and to my surprise that made
> the problem go away, but it also disabled highlighting new text.

JIT Lock is one of the reasons that trigger recentering (because JIT
Lock slows down scrolling and makes more probable the situation where
redisplay cannot keep up and eventually becomes confused and
recenters), but it's not the only one.  Displaying complex scripts or
fonts will also have that effect (try "C-h H", for example), as will
simply leaning on the down arrow on a keyboard with high auto-repeat
rate.  The root cause was elsewhere, as explained above.

I'm closing this bug report.  If you do upgrade to Emacs 24 and see
recentering, feel free to re-open it.

In any case, thank you for your report.





^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#8476: 23.2; One-line scrolling & jit-lock (or font-lock)
  2011-04-11 14:29 ` Eli Zaretskii
@ 2011-04-11 15:37   ` Juanma Barranquero
  0 siblings, 0 replies; 5+ messages in thread
From: Juanma Barranquero @ 2011-04-11 15:37 UTC (permalink / raw
  To: Eli Zaretskii, 8476; +Cc: Eli Barzilay, 8476-done

On Mon, Apr 11, 2011 at 16:29, Eli Zaretskii <eliz@gnu.org> wrote:

> This has been resolved, I hope for good, in the current development
> sources.  See bug #6671.

Oops, sorry, I should've looked at the version number.

    Juanma





^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2011-04-11 15:37 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-04-11 13:59 bug#8476: 23.2; One-line scrolling & jit-lock (or font-lock) Eli Barzilay
2011-04-11 14:24 ` Juanma Barranquero
2011-04-11 14:28   ` Eli Barzilay
2011-04-11 14:29 ` Eli Zaretskii
2011-04-11 15:37   ` Juanma Barranquero

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.