* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
@ 2024-11-18 17:52 Ashton Wiersdorf
2024-11-21 10:53 ` Eli Zaretskii
2024-11-25 5:13 ` Jim Porter
0 siblings, 2 replies; 21+ messages in thread
From: Ashton Wiersdorf @ 2024-11-18 17:52 UTC (permalink / raw)
To: 74430
Reproducing the bug from emacs -Q
I had this as my `early-init.el`:
(setq package-enable-at-startup nil)
(setq frame-resize-pixelwise t)
and this as `init.el`:
(pixel-scroll-precision-mode)
Then, when Emacs started, I resized the window so it wasn't a
multiple
of a full character's height.
Next, I ran `M-x eshell` and went to an Elixir project where I ran
`mix
test`. This bit shouldn't be important, but it's the most reliable
way I
could find to trigger the bug, unfortunately. I'll report back if
I find
another easily reproducible command that trigger the behavior.
When the command finished, the Eshell prompt was almost entirely
obscured by the modeline.
The bug does not manifest when I turn off
`pixel-scroll-precision-mode`.
It returns when I turn `pixel-scroll-precision-mode` back on.
In GNU Emacs 30.0.92 (build 2, aarch64-apple-darwin24.1.0, NS
appkit-2575.20 Version 15.1 (Build 24B83)) of 2024-11-05 built on
vulcan.local
Windowing system distributor 'Apple', version 10.3.2575
System Description: macOS 15.1
Configured using:
'configure --disable-dependency-tracking --disable-silent-rules
--enable-locallisppath=/opt/homebrew/share/emacs/site-lisp
--infodir=/opt/homebrew/Cellar/emacs-plus@30/30.0.92/share/info/emacs
--prefix=/opt/homebrew/Cellar/emacs-plus@30/30.0.92 --with-xml2
--with-gnutls --with-native-compilation=aot
--without-compress-install
--with-dbus --with-imagemagick --with-modules --with-rsvg
--with-webp
--without-pop --with-xwidgets --with-ns
--disable-ns-self-contained
'CFLAGS=-O2 -DFD_SETSIZE=10000 -DDARWIN_UNLIMITED_SELECT
-I/opt/homebrew/opt/gcc/include
-I/opt/homebrew/opt/libgccjit/include'
'LDFLAGS=-L/opt/homebrew/lib/gcc/14
-I/opt/homebrew/opt/gcc/include
-I/opt/homebrew/opt/libgccjit/include''
Configured features:
ACL DBUS GIF GLIB GMP GNUTLS IMAGEMAGICK JPEG LCMS2 LIBXML2
MODULES
NATIVE_COMP NOTIFY KQUEUE NS PDUMPER PNG RSVG SQLITE3 THREADS TIFF
TOOLKIT_SCROLL_BARS TREE_SITTER WEBP XIM XWIDGETS ZLIB
Important settings:
value of $LANG: en_US.UTF-8
locale-coding-system: utf-8-unix
Major mode: Eshell
Minor modes in effect:
eshell-prompt-mode: t
eshell-pred-mode: t
eshell-hist-mode: t
eshell-cmpl-mode: t
eshell-proc-mode: t
eshell-arg-mode: t
pixel-scroll-precision-mode: t
tooltip-mode: t
global-eldoc-mode: t
show-paren-mode: t
electric-indent-mode: t
mouse-wheel-mode: t
tool-bar-mode: t
menu-bar-mode: t
file-name-shadow-mode: t
global-font-lock-mode: t
font-lock-mode: t
blink-cursor-mode: t
minibuffer-regexp-mode: t
line-number-mode: t
indent-tabs-mode: t
transient-mark-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
Load-path shadows:
None found.
Features:
(shadow sort mail-extr compile comp-run comp-common emacsbug
message
mailcap yank-media puny dired dired-loaddefs rfc822 mml mml-sec
password-cache epa derived epg rfc6068 epg-config gnus-util
time-date
mm-decode mm-bodies mm-encode mail-parse rfc2231 mailabbrev
gmm-utils
mailheader sendmail rfc2047 rfc2045 ietf-drums mm-util mail-prsvr
mail-utils cl-seq pcmpl-unix cl-extra help-mode rx em-unix em-term
term
disp-table shell ehelp em-script em-prompt text-property-search
em-pred
em-ls em-hist em-glob em-extpipe em-cmpl em-dirs em-basic
em-banner
em-alias esh-mode esh-var eshell esh-cmd generator cl-loaddefs
cl-lib
esh-ext esh-opt esh-proc esh-io byte-opt gv bytecomp byte-compile
esh-arg pcomplete comint ansi-osc ansi-color esh-module
esh-module-loaddefs esh-util files-x pixel-scroll cua-base ring
subr-x
rmc iso-transl tooltip cconv eldoc paren electric uniquify
ediff-hook
vc-hooks lisp-float-type elisp-mode mwheel term/ns-win ns-win
ucs-normalize mule-util term/common-win tool-bar dnd fontset image
regexp-opt fringe tabulated-list replace newcomment text-mode
lisp-mode
prog-mode register page tab-bar menu-bar rfn-eshadow isearch
easymenu
timer select scroll-bar mouse jit-lock font-lock syntax font-core
term/tty-colors frame minibuffer nadvice seq simple cl-generic
indonesian philippine cham georgian utf-8-lang misc-lang
vietnamese
tibetan thai tai-viet lao korean japanese eucjp-ms cp51932 hebrew
greek
romanian slovak czech european ethiopic indian cyrillic chinese
composite emoji-zwj charscript charprop case-table epa-hook
jka-cmpr-hook help abbrev obarray oclosure cl-preloaded button
loaddefs
theme-loaddefs faces cus-face macroexp files window
text-properties
overlay sha1 md5 base64 format env code-pages mule custom widget
keymap
hashtable-print-readable backquote threads xwidget-internal
dbusbind
kqueue cocoa ns lcms2 multi-tty make-network-process
native-compile
emacs)
Memory information:
((conses 16 107402 9344) (symbols 48 8995 0) (strings 32 25963
2526)
(string-bytes 1 865352) (vectors 16 16688)
(vector-slots 8 212549 7121) (floats 8 179 59) (intervals 56 579
0)
(buffers 992 14))
--
Ashton Wiersdorf
https://lambdaland.org/
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-11-18 17:52 bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands Ashton Wiersdorf
@ 2024-11-21 10:53 ` Eli Zaretskii
2024-11-21 18:37 ` Jim Porter
2024-11-25 5:13 ` Jim Porter
1 sibling, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-11-21 10:53 UTC (permalink / raw)
To: Ashton Wiersdorf, Po Lu, Jim Porter; +Cc: 74430
> From: Ashton Wiersdorf <ashton@wiersdorfmail.net>
> Date: Mon, 18 Nov 2024 10:52:27 -0700
>
>
> Reproducing the bug from emacs -Q
>
> I had this as my `early-init.el`:
>
> (setq package-enable-at-startup nil)
> (setq frame-resize-pixelwise t)
>
> and this as `init.el`:
>
> (pixel-scroll-precision-mode)
>
> Then, when Emacs started, I resized the window so it wasn't a
> multiple
> of a full character's height.
>
> Next, I ran `M-x eshell` and went to an Elixir project where I ran
> `mix
> test`. This bit shouldn't be important, but it's the most reliable
> way I
> could find to trigger the bug, unfortunately. I'll report back if
> I find
> another easily reproducible command that trigger the behavior.
>
> When the command finished, the Eshell prompt was almost entirely
> obscured by the modeline.
>
> The bug does not manifest when I turn off
> `pixel-scroll-precision-mode`.
> It returns when I turn `pixel-scroll-precision-mode` back on.
Po Lu and Jim, could you look into this, please?
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-11-21 10:53 ` Eli Zaretskii
@ 2024-11-21 18:37 ` Jim Porter
2024-11-21 23:59 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 1 reply; 21+ messages in thread
From: Jim Porter @ 2024-11-21 18:37 UTC (permalink / raw)
To: Eli Zaretskii, Ashton Wiersdorf, Po Lu; +Cc: 74430
On 11/21/2024 2:53 AM, Eli Zaretskii wrote:
>> From: Ashton Wiersdorf <ashton@wiersdorfmail.net>
>> Date: Mon, 18 Nov 2024 10:52:27 -0700
>>
>> When the command finished, the Eshell prompt was almost entirely
>> obscured by the modeline.
>>
>> The bug does not manifest when I turn off
>> `pixel-scroll-precision-mode`.
>> It returns when I turn `pixel-scroll-precision-mode` back on.
>
> Po Lu and Jim, could you look into this, please?
I'm only dimly aware of how 'pixel-scroll-precision-mode' works, but I
seem to recall that it sets the window's vscroll to allow scrolling past
*part* of a line. On the Eshell side, I believe the relevant function is
'eshell-postoutput-scroll-to-bottom', which calls 'recenter' to scroll
the window.
I'm guessing these interact badly, and what we actually want to do is to
reset the vscroll when Eshell calls 'recenter'. However, I'm not sure
what the best way to do this would be. Is there some better function
Eshell can call that would handle this case correctly?
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-11-21 18:37 ` Jim Porter
@ 2024-11-21 23:59 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-11-22 6:58 ` Eli Zaretskii
0 siblings, 1 reply; 21+ messages in thread
From: Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2024-11-21 23:59 UTC (permalink / raw)
To: Jim Porter; +Cc: Eli Zaretskii, Ashton Wiersdorf, 74430
Jim Porter <jporterbugs@gmail.com> writes:
> I'm only dimly aware of how 'pixel-scroll-precision-mode' works, but I
> seem to recall that it sets the window's vscroll to allow scrolling
> past *part* of a line. On the Eshell side, I believe the relevant
> function is 'eshell-postoutput-scroll-to-bottom', which calls
> 'recenter' to scroll the window.
>
> I'm guessing these interact badly, and what we actually want to do is
> to reset the vscroll when Eshell calls 'recenter'. However, I'm not
> sure what the best way to do this would be. Is there some better
> function Eshell can call that would handle this case correctly?
Since pixel-scroll-precision-mode never configures a vscroll taller than
one screen line, resetting vscroll in these scenarios is generally the
safest and simplest solutions to problems such as the OP is facing.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-11-21 23:59 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2024-11-22 6:58 ` Eli Zaretskii
2024-11-30 10:07 ` Eli Zaretskii
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-11-22 6:58 UTC (permalink / raw)
To: Po Lu; +Cc: jporterbugs, ashton, 74430
> From: Po Lu <luangruo@yahoo.com>
> Cc: Eli Zaretskii <eliz@gnu.org>, Ashton Wiersdorf
> <ashton@wiersdorfmail.net>, 74430@debbugs.gnu.org
> Date: Fri, 22 Nov 2024 07:59:50 +0800
>
> Jim Porter <jporterbugs@gmail.com> writes:
>
> > I'm only dimly aware of how 'pixel-scroll-precision-mode' works, but I
> > seem to recall that it sets the window's vscroll to allow scrolling
> > past *part* of a line. On the Eshell side, I believe the relevant
> > function is 'eshell-postoutput-scroll-to-bottom', which calls
> > 'recenter' to scroll the window.
> >
> > I'm guessing these interact badly, and what we actually want to do is
> > to reset the vscroll when Eshell calls 'recenter'. However, I'm not
> > sure what the best way to do this would be. Is there some better
> > function Eshell can call that would handle this case correctly?
>
> Since pixel-scroll-precision-mode never configures a vscroll taller than
> one screen line, resetting vscroll in these scenarios is generally the
> safest and simplest solutions to problems such as the OP is facing.
So you suggest that eshell-postoutput-scroll-to-bottom explicitly
resets the window's vscroll, and that should solve the OP's problem?
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-11-18 17:52 bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands Ashton Wiersdorf
2024-11-21 10:53 ` Eli Zaretskii
@ 2024-11-25 5:13 ` Jim Porter
2024-11-30 10:07 ` Eli Zaretskii
1 sibling, 1 reply; 21+ messages in thread
From: Jim Porter @ 2024-11-25 5:13 UTC (permalink / raw)
To: Ashton Wiersdorf, 74430
On 11/18/2024 9:52 AM, Ashton Wiersdorf wrote:
> Then, when Emacs started, I resized the window so it wasn't a multiple
> of a full character's height.
[snip]
> When the command finished, the Eshell prompt was almost entirely
> obscured by the modeline.
I'm not able to reproduce this. I tried running a bunch of commands,
including ones that output large amounts of text, but it all works as
expected: once Eshell starts scrolling the buffer (by way of calls to
'recenter'), the vscroll is reset to 0 and everything works as it should.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-11-25 5:13 ` Jim Porter
@ 2024-11-30 10:07 ` Eli Zaretskii
2024-12-14 9:38 ` Eli Zaretskii
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-11-30 10:07 UTC (permalink / raw)
To: ashton, Jim Porter; +Cc: 74430
> Date: Sun, 24 Nov 2024 21:13:33 -0800
> From: Jim Porter <jporterbugs@gmail.com>
>
> On 11/18/2024 9:52 AM, Ashton Wiersdorf wrote:
> > Then, when Emacs started, I resized the window so it wasn't a multiple
> > of a full character's height.
> [snip]
> > When the command finished, the Eshell prompt was almost entirely
> > obscured by the modeline.
>
> I'm not able to reproduce this. I tried running a bunch of commands,
> including ones that output large amounts of text, but it all works as
> expected: once Eshell starts scrolling the buffer (by way of calls to
> 'recenter'), the vscroll is reset to 0 and everything works as it should.
Ashton, could you please help Jim reproduce the problem?
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-11-22 6:58 ` Eli Zaretskii
@ 2024-11-30 10:07 ` Eli Zaretskii
2024-12-14 9:38 ` Eli Zaretskii
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-11-30 10:07 UTC (permalink / raw)
To: luangruo; +Cc: jporterbugs, ashton, 74430
Ping!
> Cc: jporterbugs@gmail.com, ashton@wiersdorfmail.net, 74430@debbugs.gnu.org
> Date: Fri, 22 Nov 2024 08:58:58 +0200
> From: Eli Zaretskii <eliz@gnu.org>
>
> > From: Po Lu <luangruo@yahoo.com>
> > Cc: Eli Zaretskii <eliz@gnu.org>, Ashton Wiersdorf
> > <ashton@wiersdorfmail.net>, 74430@debbugs.gnu.org
> > Date: Fri, 22 Nov 2024 07:59:50 +0800
> >
> > Jim Porter <jporterbugs@gmail.com> writes:
> >
> > > I'm only dimly aware of how 'pixel-scroll-precision-mode' works, but I
> > > seem to recall that it sets the window's vscroll to allow scrolling
> > > past *part* of a line. On the Eshell side, I believe the relevant
> > > function is 'eshell-postoutput-scroll-to-bottom', which calls
> > > 'recenter' to scroll the window.
> > >
> > > I'm guessing these interact badly, and what we actually want to do is
> > > to reset the vscroll when Eshell calls 'recenter'. However, I'm not
> > > sure what the best way to do this would be. Is there some better
> > > function Eshell can call that would handle this case correctly?
> >
> > Since pixel-scroll-precision-mode never configures a vscroll taller than
> > one screen line, resetting vscroll in these scenarios is generally the
> > safest and simplest solutions to problems such as the OP is facing.
>
> So you suggest that eshell-postoutput-scroll-to-bottom explicitly
> resets the window's vscroll, and that should solve the OP's problem?
>
>
>
>
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-11-30 10:07 ` Eli Zaretskii
@ 2024-12-14 9:38 ` Eli Zaretskii
2024-12-14 18:40 ` Ashton Wiersdorf
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-12-14 9:38 UTC (permalink / raw)
To: ashton; +Cc: jporterbugs, 74430
Ping! Ashton, please respond.
> Cc: 74430@debbugs.gnu.org
> Date: Sat, 30 Nov 2024 12:07:20 +0200
> From: Eli Zaretskii <eliz@gnu.org>
>
> > Date: Sun, 24 Nov 2024 21:13:33 -0800
> > From: Jim Porter <jporterbugs@gmail.com>
> >
> > On 11/18/2024 9:52 AM, Ashton Wiersdorf wrote:
> > > Then, when Emacs started, I resized the window so it wasn't a multiple
> > > of a full character's height.
> > [snip]
> > > When the command finished, the Eshell prompt was almost entirely
> > > obscured by the modeline.
> >
> > I'm not able to reproduce this. I tried running a bunch of commands,
> > including ones that output large amounts of text, but it all works as
> > expected: once Eshell starts scrolling the buffer (by way of calls to
> > 'recenter'), the vscroll is reset to 0 and everything works as it should.
>
> Ashton, could you please help Jim reproduce the problem?
>
>
>
>
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-11-30 10:07 ` Eli Zaretskii
@ 2024-12-14 9:38 ` Eli Zaretskii
2024-12-28 11:13 ` Eli Zaretskii
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-12-14 9:38 UTC (permalink / raw)
To: luangruo; +Cc: jporterbugs, ashton, 74430
Ping! Ping! Po Lu, can you please answer the question?
> Cc: jporterbugs@gmail.com, ashton@wiersdorfmail.net, 74430@debbugs.gnu.org
> Date: Sat, 30 Nov 2024 12:07:51 +0200
> From: Eli Zaretskii <eliz@gnu.org>
>
> Ping!
>
> > Cc: jporterbugs@gmail.com, ashton@wiersdorfmail.net, 74430@debbugs.gnu.org
> > Date: Fri, 22 Nov 2024 08:58:58 +0200
> > From: Eli Zaretskii <eliz@gnu.org>
> >
> > > From: Po Lu <luangruo@yahoo.com>
> > > Cc: Eli Zaretskii <eliz@gnu.org>, Ashton Wiersdorf
> > > <ashton@wiersdorfmail.net>, 74430@debbugs.gnu.org
> > > Date: Fri, 22 Nov 2024 07:59:50 +0800
> > >
> > > Jim Porter <jporterbugs@gmail.com> writes:
> > >
> > > > I'm only dimly aware of how 'pixel-scroll-precision-mode' works, but I
> > > > seem to recall that it sets the window's vscroll to allow scrolling
> > > > past *part* of a line. On the Eshell side, I believe the relevant
> > > > function is 'eshell-postoutput-scroll-to-bottom', which calls
> > > > 'recenter' to scroll the window.
> > > >
> > > > I'm guessing these interact badly, and what we actually want to do is
> > > > to reset the vscroll when Eshell calls 'recenter'. However, I'm not
> > > > sure what the best way to do this would be. Is there some better
> > > > function Eshell can call that would handle this case correctly?
> > >
> > > Since pixel-scroll-precision-mode never configures a vscroll taller than
> > > one screen line, resetting vscroll in these scenarios is generally the
> > > safest and simplest solutions to problems such as the OP is facing.
> >
> > So you suggest that eshell-postoutput-scroll-to-bottom explicitly
> > resets the window's vscroll, and that should solve the OP's problem?
> >
> >
> >
> >
>
>
>
>
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-12-14 9:38 ` Eli Zaretskii
@ 2024-12-14 18:40 ` Ashton Wiersdorf
2024-12-15 19:10 ` Jim Porter
0 siblings, 1 reply; 21+ messages in thread
From: Ashton Wiersdorf @ 2024-12-14 18:40 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: jporterbugs, 74430
Hey, sorry Eli. I haven't been able to get this to reproduce
consistently—it happens most often when I run a (broken) test
suite on an Elixir project I'm working on, and then only
sometimes. I think running a complex Elixir application would be a
suboptimal thing to run to try to reproduce the bug, no?
I might have a little time today to try reproducing it with
simpler commands; I'll let you know then. Sorry I haven't been
able to get a MWE yet.
--
Ashton Wiersdorf
https://lambdaland.org/
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-12-14 18:40 ` Ashton Wiersdorf
@ 2024-12-15 19:10 ` Jim Porter
2024-12-27 20:09 ` Ashton Wiersdorf
0 siblings, 1 reply; 21+ messages in thread
From: Jim Porter @ 2024-12-15 19:10 UTC (permalink / raw)
To: Ashton Wiersdorf, Eli Zaretskii; +Cc: 74430
On 12/14/2024 10:40 AM, Ashton Wiersdorf wrote:
> Hey, sorry Eli. I haven't been able to get this to reproduce
> consistently—it happens most often when I run a (broken) test suite on
> an Elixir project I'm working on, and then only sometimes. I think
> running a complex Elixir application would be a suboptimal thing to run
> to try to reproduce the bug, no?
>
> I might have a little time today to try reproducing it with simpler
> commands; I'll let you know then. Sorry I haven't been able to get a MWE
> yet.
If you can't find a minimal example, a screenshot could also help, so
long as you wouldn't be leaking any private information.
Also, are there any "unique" properties of the output that causes this
bug? For example, does it use "\r" carriage returns to overwrite the
last line, or does it use emojis, or anything like that? If there's
something different from the norm, that could help narrow things down.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-12-15 19:10 ` Jim Porter
@ 2024-12-27 20:09 ` Ashton Wiersdorf
0 siblings, 0 replies; 21+ messages in thread
From: Ashton Wiersdorf @ 2024-12-27 20:09 UTC (permalink / raw)
To: Jim Porter; +Cc: Eli Zaretskii, 74430
[-- Attachment #1: Type: text/plain, Size: 178 bytes --]
> If you can't find a minimal example, a screenshot could also
> help, so
> long as you wouldn't be leaking any private information.
Here's a screenshot of the bug in action:
[-- Attachment #2: Screenshot showing scroll bug in Emacs --]
[-- Type: image/png, Size: 282829 bytes --]
[-- Attachment #3: Type: text/plain, Size: 1008 bytes --]
> Also, are there any "unique" properties of the output that
> causes this
> bug? For example, does it use "\r" carriage returns to overwrite
> the
> last line, or does it use emojis, or anything like that? If
> there's
> something different from the norm, that could help narrow things
> down.
I've seen this most often after running Elixir scripts—that might
just be availability bias because that's what I'm doing for work
right now! There *is* some colored text in the output. AFAIK
Elixir doesn't send "\r" to do anything tricky with the last line.
I think I've seen this happen with other commands.
I've noticed that the easiest way to rid myself of this behavior
is to just it Ctrl-l when it arises. That resets something and it
will work again for a while.
Note: I just upgraded to 30.0.93, and I'll keep my eyes peeled to
see if it resurfaces.
Thanks for your help, attention, and patience. Happy holidays!
--
Ashton Wiersdorf
https://lambdaland.org/
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-12-14 9:38 ` Eli Zaretskii
@ 2024-12-28 11:13 ` Eli Zaretskii
2024-12-31 23:51 ` Ashton Wiersdorf
0 siblings, 1 reply; 21+ messages in thread
From: Eli Zaretskii @ 2024-12-28 11:13 UTC (permalink / raw)
To: luangruo; +Cc: jporterbugs, ashton, 74430
Ping! Ping! Ping! Po Lu, are you there?
> Cc: jporterbugs@gmail.com, ashton@wiersdorfmail.net, 74430@debbugs.gnu.org
> Date: Sat, 14 Dec 2024 11:38:38 +0200
> From: Eli Zaretskii <eliz@gnu.org>
>
> Ping! Ping! Po Lu, can you please answer the question?
>
> > Cc: jporterbugs@gmail.com, ashton@wiersdorfmail.net, 74430@debbugs.gnu.org
> > Date: Sat, 30 Nov 2024 12:07:51 +0200
> > From: Eli Zaretskii <eliz@gnu.org>
> >
> > Ping!
> >
> > > Cc: jporterbugs@gmail.com, ashton@wiersdorfmail.net, 74430@debbugs.gnu.org
> > > Date: Fri, 22 Nov 2024 08:58:58 +0200
> > > From: Eli Zaretskii <eliz@gnu.org>
> > >
> > > > From: Po Lu <luangruo@yahoo.com>
> > > > Cc: Eli Zaretskii <eliz@gnu.org>, Ashton Wiersdorf
> > > > <ashton@wiersdorfmail.net>, 74430@debbugs.gnu.org
> > > > Date: Fri, 22 Nov 2024 07:59:50 +0800
> > > >
> > > > Jim Porter <jporterbugs@gmail.com> writes:
> > > >
> > > > > I'm only dimly aware of how 'pixel-scroll-precision-mode' works, but I
> > > > > seem to recall that it sets the window's vscroll to allow scrolling
> > > > > past *part* of a line. On the Eshell side, I believe the relevant
> > > > > function is 'eshell-postoutput-scroll-to-bottom', which calls
> > > > > 'recenter' to scroll the window.
> > > > >
> > > > > I'm guessing these interact badly, and what we actually want to do is
> > > > > to reset the vscroll when Eshell calls 'recenter'. However, I'm not
> > > > > sure what the best way to do this would be. Is there some better
> > > > > function Eshell can call that would handle this case correctly?
> > > >
> > > > Since pixel-scroll-precision-mode never configures a vscroll taller than
> > > > one screen line, resetting vscroll in these scenarios is generally the
> > > > safest and simplest solutions to problems such as the OP is facing.
> > >
> > > So you suggest that eshell-postoutput-scroll-to-bottom explicitly
> > > resets the window's vscroll, and that should solve the OP's problem?
> > >
> > >
> > >
> > >
> >
> >
> >
> >
>
>
>
>
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-12-28 11:13 ` Eli Zaretskii
@ 2024-12-31 23:51 ` Ashton Wiersdorf
2025-01-01 3:10 ` Jim Porter
2025-01-01 9:02 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 2 replies; 21+ messages in thread
From: Ashton Wiersdorf @ 2024-12-31 23:51 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: luangruo, jporterbugs, 74430
[-- Attachment #1: Type: text/plain, Size: 681 bytes --]
Hey all, I've had some luck reproducing this just now!
Dump this into "eshell_scroll_bug.el":
(pixel-scroll-precision-mode)
(tool-bar-mode -1)
(setopt frame-resize-pixelwise t)
(set-frame-height (selected-frame) 486 nil t)
(eshell)
Then run `emacs -Q -l eshell_scroll_bug.el`, and then run `find
/etc/` from inside Eshell.
The prompt should appear covered by the mode-line.
Here's the `emacs-version` that this is occurring under:
GNU Emacs 30.0.93 (build 2, aarch64-apple-darwin24.2.0, NS
appkit-2575.30 Version 15.2 (Build 24C101)) of 2024-12-26
I've attached a screenshot of what it looks like on my machine
after running that. I hope this helps!
[-- Attachment #2: Screenshot 2024-12-31 at 16.46.54.png --]
[-- Type: image/png, Size: 519151 bytes --]
[-- Attachment #3: Type: text/plain, Size: 46 bytes --]
--
Ashton Wiersdorf
https://lambdaland.org/
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-12-31 23:51 ` Ashton Wiersdorf
@ 2025-01-01 3:10 ` Jim Porter
2025-01-01 9:02 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
1 sibling, 0 replies; 21+ messages in thread
From: Jim Porter @ 2025-01-01 3:10 UTC (permalink / raw)
To: Ashton Wiersdorf, Eli Zaretskii; +Cc: luangruo, 74430
On 12/31/2024 3:51 PM, Ashton Wiersdorf wrote:
> Hey all, I've had some luck reproducing this just now!
>
> Dump this into "eshell_scroll_bug.el":
>
> (pixel-scroll-precision-mode)
> (tool-bar-mode -1)
> (setopt frame-resize-pixelwise t)
> (set-frame-height (selected-frame) 486 nil t)
> (eshell)
>
> Then run `emacs -Q -l eshell_scroll_bug.el`, and then run `find /etc/`
> from inside Eshell.
>
> The prompt should appear covered by the mode-line.
Everything looks ok to me on GNU/Linux. Maybe this is a macOS-specific
issue?
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2024-12-31 23:51 ` Ashton Wiersdorf
2025-01-01 3:10 ` Jim Porter
@ 2025-01-01 9:02 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-01 10:31 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
1 sibling, 1 reply; 21+ messages in thread
From: martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2025-01-01 9:02 UTC (permalink / raw)
To: Ashton Wiersdorf, Eli Zaretskii; +Cc: luangruo, jporterbugs, 74430
> Dump this into "eshell_scroll_bug.el":
>
> (pixel-scroll-precision-mode)
> (tool-bar-mode -1)
> (setopt frame-resize-pixelwise t)
> (set-frame-height (selected-frame) 486 nil t)
> (eshell)
>
> Then run `emacs -Q -l eshell_scroll_bug.el`, and then run `find /etc/` from inside Eshell.
>
> The prompt should appear covered by the mode-line.
I can reproduce it here with (setopt frame-resize-pixelwise t) and
dragging the bottom border of the frame up so the eshell window doesn't
have an integral number of lines.
'pixel-scroll-precision-mode' sets 'make-cursor-line-fully-visible' to
nil so this is probably the intended bahavior. When I do
(setq-default make-cursor-line-fully-visible nil)
I can't see it any more.
martin
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2025-01-01 9:02 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2025-01-01 10:31 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-03 0:09 ` Ashton Wiersdorf
0 siblings, 1 reply; 21+ messages in thread
From: martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2025-01-01 10:31 UTC (permalink / raw)
To: Ashton Wiersdorf, Eli Zaretskii; +Cc: luangruo, jporterbugs, 74430
> When I do
>
> (setq-default make-cursor-line-fully-visible nil)
This should obviously become
(setq-default make-cursor-line-fully-visible t)
> I can't see it any more.
Sorry for the confusion, martin
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2025-01-01 10:31 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2025-01-03 0:09 ` Ashton Wiersdorf
2025-01-03 8:26 ` Eli Zaretskii
2025-01-03 8:55 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 2 replies; 21+ messages in thread
From: Ashton Wiersdorf @ 2025-01-03 0:09 UTC (permalink / raw)
To: martin rudalics; +Cc: luangruo, jporterbugs, Eli Zaretskii, 74430
> (setq-default make-cursor-line-fully-visible t)
I can confirm: this does solve the issue. Thank you so much!
I'm curious: does anyone know what the rationale is for
`pixel-scroll-precision-mode` setting this to `nil`? It doesn't
seem like something that you'd want… Did this behavior change in
Emacs 30?
--
Ashton Wiersdorf
https://lambdaland.org/
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2025-01-03 0:09 ` Ashton Wiersdorf
@ 2025-01-03 8:26 ` Eli Zaretskii
2025-01-03 8:55 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
1 sibling, 0 replies; 21+ messages in thread
From: Eli Zaretskii @ 2025-01-03 8:26 UTC (permalink / raw)
To: Ashton Wiersdorf; +Cc: luangruo, rudalics, 74430, jporterbugs
> From: Ashton Wiersdorf <ashton@wiersdorfmail.net>
> Cc: Eli Zaretskii <eliz@gnu.org>, luangruo@yahoo.com,
> jporterbugs@gmail.com, 74430@debbugs.gnu.org
> Date: Thu, 02 Jan 2025 17:09:13 -0700
>
> > (setq-default make-cursor-line-fully-visible t)
>
> I can confirm: this does solve the issue. Thank you so much!
>
> I'm curious: does anyone know what the rationale is for
> `pixel-scroll-precision-mode` setting this to `nil`? It doesn't
> seem like something that you'd want…
pixel-scroll-precision-mode sets that variable because otherwise you
couldn't have smooth scroll when the last line is tall, since Emacs
would then scroll by a larger amount to have the last line fully
visible.
> Did this behavior change in Emacs 30?
Yes, see bug#65214.
^ permalink raw reply [flat|nested] 21+ messages in thread
* bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands
2025-01-03 0:09 ` Ashton Wiersdorf
2025-01-03 8:26 ` Eli Zaretskii
@ 2025-01-03 8:55 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
1 sibling, 0 replies; 21+ messages in thread
From: martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2025-01-03 8:55 UTC (permalink / raw)
To: Ashton Wiersdorf; +Cc: luangruo, jporterbugs, Eli Zaretskii, 74430
> I'm curious: does anyone know what the rationale is for
> `pixel-scroll-precision-mode` setting this to `nil`? It doesn't seem
> like something that you'd want… Did this behavior change in Emacs 30?
Apparently. AFAICT the rationale was to fix Bug#65214. I think the two
ways to handle that bug and the present one are:
- Add two new values for 'make-cursor-line-fully-visible', say 'always'
and 'never', a mode would not be permitted to override.
- Add a second customizable variable say
'pixel-scroll-precision-mode-make-cursor-line-fully-visible'
that would control the behavior.
More experienced users could also try to set the buffer local value of
'make-cursor-line-fully-visible' in 'after-change-major-mode-hook'.
martin
^ permalink raw reply [flat|nested] 21+ messages in thread
end of thread, other threads:[~2025-01-03 8:55 UTC | newest]
Thread overview: 21+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-11-18 17:52 bug#74430: 30.0.92; pixel-scroll-precision-mode hiding Eshell prompt after some commands Ashton Wiersdorf
2024-11-21 10:53 ` Eli Zaretskii
2024-11-21 18:37 ` Jim Porter
2024-11-21 23:59 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-11-22 6:58 ` Eli Zaretskii
2024-11-30 10:07 ` Eli Zaretskii
2024-12-14 9:38 ` Eli Zaretskii
2024-12-28 11:13 ` Eli Zaretskii
2024-12-31 23:51 ` Ashton Wiersdorf
2025-01-01 3:10 ` Jim Porter
2025-01-01 9:02 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-01 10:31 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-03 0:09 ` Ashton Wiersdorf
2025-01-03 8:26 ` Eli Zaretskii
2025-01-03 8:55 ` martin rudalics via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-11-25 5:13 ` Jim Porter
2024-11-30 10:07 ` Eli Zaretskii
2024-12-14 9:38 ` Eli Zaretskii
2024-12-14 18:40 ` Ashton Wiersdorf
2024-12-15 19:10 ` Jim Porter
2024-12-27 20:09 ` Ashton Wiersdorf
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).